计算机应用 | 古代文学 | 市场营销 | 生命科学 | 交通物流 | 财务管理 | 历史学 | 毕业 | 哲学 | 政治 | 财税 | 经济 | 金融 | 审计 | 法学 | 护理学 | 国际经济与贸易
计算机软件 | 新闻传播 | 电子商务 | 土木工程 | 临床医学 | 旅游管理 | 建筑学 | 文学 | 化学 | 数学 | 物理 | 地理 | 理工 | 生命 | 文化 | 企业管理 | 电子信息工程
计算机网络 | 语言文学 | 信息安全 | 工程力学 | 工商管理 | 经济管理 | 计算机 | 机电 | 材料 | 医学 | 药学 | 会计 | 硕士 | 法律 | MBA
现当代文学 | 英美文学 | 通讯工程 | 网络工程 | 行政管理 | 公共管理 | 自动化 | 艺术 | 音乐 | 舞蹈 | 美术 | 本科 | 教育 | 英语 |

ABC对输入MV文件的解决方案网络毕业论文(4)

2013-09-17 01:00
导读:/* 计算因子 */ if (topf = topg) { index = F-index; fv = cuddT(F); fnv = cuddE(F); if (Cudd_IsComplement(f)) { fv = Cudd_Not(fv); fnv = Cudd_Not(fnv); } } else { index = G-index; fv = fnv = f; } if

    /* 计算因子 */

    if (topf <= topg) {

       index = F->index;

       fv = cuddT(F);

       fnv = cuddE(F);

       if (Cudd_IsComplement(f)) {

           fv = Cudd_Not(fv);

           fnv = Cudd_Not(fnv);

       }

    } else {

       index = G->index;

       fv = fnv = f;

    }

    if (topg <= topf) {

       gv = cuddT(G);

       gnv = cuddE(G);

       if (Cudd_IsComplement(g)) {              //判断g结点是否取过反

           gv = Cudd_Not(gv);             //对gv结点取反

           gnv = Cudd_Not(gnv);

       }

    } else {

       gv = gnv = g;

    }

    t = cuddBddAndRecur(manager, fv, gv);

    e = cuddBddAndRecur(manager, fnv, gnv);

    if (t == e) {

       r = t;

    } else {

       if (Cudd_IsComplement(t)) {

//如果已经存在以Cudd_Not(t),Cudd_Not(e)为孩子的结点,则返回,如没有,则重//新创建一个,并且把index赋值于它。

           r = cuddUniqueInter(manager,(int)index,Cudd_Not(t),Cudd_Not(e));

           r = Cudd_Not(r);           //对r结点取反

       } else {

           r = cuddUniqueInter(manager,(int)index,t,e);

       }

    }

    if (F->ref != 1 || G->ref != 1)

       cuddCacheInsert2(manager, Cudd_bddAnd, f, g, r);    //加入缓存机制

    return(r);

} /* end of cuddBddAndRecur */

  这里根据算法,我们举例说明结点功能为AIG,表达式为a*b的情况,其转换成BDD功能,如下所示:

上一篇:网络交际中语言的失范与思考网络毕业论 下一篇:没有了