[发明专利]一种基于贪婪算法的同或/或电路的分解方法有效

专利信息
申请号: 201210389864.8 申请日: 2012-10-15
公开(公告)号: CN102915392A 公开(公告)日: 2013-02-06
发明(设计)人: 张会红;汪鹏君 申请(专利权)人: 宁波大学
主分类号: G06F17/50 分类号: G06F17/50
代理公司: 宁波奥圣专利代理事务所(普通合伙) 33226 代理人: 程晓明
地址: 315211 浙*** 国省代码: 浙江;33
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 基于 贪婪 算法 电路 分解 方法
【说明书】:

技术领域

发明涉及一种逻辑门电路的低功耗分解技术,尤其是涉及一种基于贪婪算法的同或/或电路的分解方法。

背景技术

随着集成电路的发展,功耗已成为集成电路设计中的关键性限制因素。以低功耗为目标的里德穆勒(RM)电路极性优化已引起了广泛关注。其中,多输入门分解是影响RM电路功耗的关键性环节之一,不同的分解方法将使电路具有不同的功耗。因此,研究RM电路的低功耗分解具有现实意义。

目前,对于同或/或电路,其多输入或门由于输出信号的概率随着输入信号的概率而增大,一般采用霍夫曼算法进行分解;而同或/或电路中的多输入同或门目前主要采用随机顺序分解方法或者分类分解方法(分类分解方法见P.Wang,J.Lu,J.Xu,et al.Power optimization algorithm based on XNOR/OR logic[J]..2009,26(1):138-144.[汪鹏君,陆金刚,徐建.基于XNOR/OR逻辑的功耗优化算法.电子科学学刊(英文版).2009,26(1):138-144])。随机顺序分解方法按照随机顺序将待分解的多输入同或门分解为一系列二输入同或门,没有进行优化组合,其低功耗分解效果较差;而分类分解方法中将待分解的多输入同或门分为三种情况:待分解的多输入同或门的所有输入信号的概率均大于0.5、待分解的多输入同或门的所有输入信号的概率均小于0.5和待分解的多输入同或门同时包含概率大于0.5、等于0.5和小于0.5的输入信号,通过将输入信号分为三类,不同的类别采取不同的分解算法,其相对于随机顺序分解方法低功耗效果较好。但是由于分类分解方法中对于一个或多个输入信号的概率为0.5的多输入同或门往往留待最后考虑,因此无法保证低功耗分解的最优性。

发明内容

本发明所要解决的技术问题是提供一种可以通用于同或门和或门的低功耗分解,低功耗分解效果好的基于贪婪算法的同或/或电路的分解方法,

本发明解决上述技术问题所采用的技术方案为:一种基于贪婪算法的同或/或电路的分解方法,首先导入或读入同或/或电路表达式,将多输入同或/或门的分解问题转换为最小二叉树搜索问题,然后采用贪婪算法分解同或/或电路中的多输入或门,再在多输入或门分解的基础上采用贪婪算法分解同或/或电路中的多输入同或门,具体包括以下步骤:

①读入同或/或电路表达式n为函数f(x1,x2,…,xi…,xn)的变量数,(x1,x2,…,xi…,xn)为函数f(x1,x2,…,xi…,xn)的n个输入变量,i为正整数,且1≤i≤n,Sk项代表同或/或电路中的某个或门,且dk为或项系数,且dk∈{0,1},当dk=0时,表示Sk项在同或/或电路表达式中出现,当dk=1时,表示Sk项不在同或/或电路表达式中出现,⊙∏表示同或操作,k为Sk项序号,k用二进制形式表示为k1k2…kj…kn,j为正整数,且1≤j≤n,当kj=0时,当kj=1时,Sk项代表的或门的输入变量xi的数量为m,m=Σj=1n(1-kj);]]>

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于宁波大学,未经宁波大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201210389864.8/2.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top