- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 CUDD C++ 接口(interface) ( https://github.com/ivmai/cudd ),但几乎没有关于这个库的信息。我想知道如何根据它的值删除一个变量。
例如,我现在将下一个表存储在 bdd
中:
|-----|-----|-----|
| x1 | x2 | y |
|-----|-----|-----|
| 0 | 0 | 1 |
|-----|-----|-----|
| 0 | 1 | 1 |
|-----|-----|-----|
| 1 | 0 | 1 |
|-----|-----|-----|
| 1 | 1 | 0 |
|-----|-----|-----|
我想根据 x2 的值将前一个表拆分为两个单独的 bdd
,然后删除该节点:
如果x2 = 0
:
|-----|-----|
| x1 | y |
|-----|-----|
| 0 | 1 |
|-----|-----|
| 1 | 1 |
|-----|-----|
如果 x2 = 1
:
|-----|-----|
| x1 | y |
|-----|-----|
| 0 | 1 |
|-----|-----|
| 1 | 0 |
|-----|-----|
这可能吗?
最佳答案
CUDD 库的 C++ 接口(interface)几乎没有文档的原因是它只是 C 函数的包装器,有大量文档。
C++ 包装器主要用于摆脱使用 C 接口(interface)的代码需要执行的所有 Cudd_Ref(...) 和 Cudd_RecursiveDeref(...) 调用。请注意,如果需要,您也可以在 C++ 代码中使用 C 接口(interface)。
要完成您想做的事情,您必须组合 CUDD 提供的 bool 运算符,从而获得具有所需属性的新 bool 函数。
第一步是将 s
限制为 x=0 和 x=1 的情况:
BDD s0 = s & !x;
BDD s1 = s & x;
正如您所注意到的,新的 BDD(还)没有忘记 x 变量的值。您希望它们“不关心”w.r.t 到 x 的值。由于您已经知道 x 被限制为 s0 和 s1 中的一个特定值,您可以使用存在抽象运算符:
s0 = s0.ExistAbstract(x);
s1 = s1.ExistAbstract(x);
请注意,x
在这里用作所谓的立方体(见下文)。
这些现在是您想要的 BDD。
立方体解释:如果同时从多个变量中抽象出来,则应该先从所有要抽象出的变量中计算出这样一个立方体。立方体主要用于表示一组变量。从数理逻辑可知,如果你存在性地或普遍地抽象出多个变量,那么抽象出这些变量的顺序无关紧要。由于 CUDD 中的递归 BDD 操作是在 BDD 对(或三元组)上实现的,因此 CUDD 在内部也将一组变量表示为立方体,因此存在抽象操作只能在(1)BDD 上工作将执行存在抽象,以及 (2) BDD 表示要从中抽象的变量集。多维数据集作为 BDD 的内部表示不应该与仅使用 CUDD(而不是扩展 CUDD)的开发人员相关,除了表示变量的 BDDD 也可以用作多维数据集。
关于binary - CUDD:BDD 的操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55246590/
对于编译我使用: 1) ./configure --enable-dddmp --enable-obj --enable-shared --enable-static; make 2)
我正在尝试将 CUDD 的变量排序启发式方法用于另一个程序。我创建了一个 BDD,尝试了一些变量排序以查看哪个最小化了大小,现在我想提取变量排序。我该怎么做? 根据 this answer ,dd p
我正在使用 CUDD C++ 接口(interface) ( https://github.com/ivmai/cudd ),但几乎没有关于这个库的信息。我想知道如何根据它的值删除一个变量。 例如,我
我正在使用 CUDD C++ 接口(interface) ( https://github.com/ivmai/cudd ),但几乎没有关于这个库的信息。我想知道如何根据它的值删除一个变量。 例如,我
我正在研究二元决策图的变量排序。到目前为止,我们一直使用不可逆电路。但并不是我们需要使用可逆基准来实现某些方法。但我没有任何方法使用 C 语言中的 CUDD 库来读取基准文件(例如 blif、kiss
我正在使用 CUDD (https://github.com/ivmai/cudd) 使用 bdd 和 zdd 功能进行模型检查,我想知道如何量化 zdds。 对于 bdd,有 bddExistAbs
我正在使用 CUDD C++ 接口(interface)。 我找不到太多关于这个库的信息。 如何获得 BDD 的两个 child ? 例如: Cudd mgr; BDD x = mgr.bddVar(
我正在尝试运行一个简单的程序来学习如何使用 CUDD 包版本 3.0.0。我下载并安装了软件包:( 1- ./configure 2- make 3- make check)。 我创建了以下简单程序:
我正在使用 C 上的 CUDD 库制作二元决策图。我想知道是否有某种方法可以将以字符串形式给出的 bool 表达式转换为二元决策图。 谢谢! 最佳答案 有几个项目已经包含将字符串解析为 BDD 的功能
是否有可能获得 (x0 ∧ x1 ) ∨ (x0 ∧!x1 ) ∨ (!x0 ∧ x1 ) ∨ (!x 0 ∧!x 1 ) 的 bdd 仍然具有表示变量 x0 和 x1 的节点, 使用 CUDD?我知
我正在尝试将 BLIF 文件导入 CUDD 包,从中创建 BDD,然后执行一些操作。我已经设法使用 ntr 包导入 BLIF 文件。但是,我无法弄清楚我应该如何访问生成的 BDD 中的任何变量或节点。
我正在与 ( https://github.com/ivmai/cudd) 合作,目标是执行以下重复过程: (1)输入:(相干,非递减) bool 函数表达式顶部 = a_1a_2a_3...+ x_
我是一名优秀的程序员,十分优秀!