介绍Simplify如何简化解码逻辑。
 
 
1. 使用
 
Simplify在DecodeLogic中使用,如下:
 
简化从t和dc项中查找的逻辑。
 
其方法签名如下:
其中:
a. minTerms: 卡诺图中的最小项;
b. dcTerms:卡诺图中的无关项;
c. bits:最小项中变量的个数;
 
2. 主要过程
 
Simplify定义如下:
 
主要步骤如下:
1) 从minTerms和dcTerms中获取质项,即在卡诺图中画圈,把最小项和无关项划入圈中,以合并最小项;
2) 从质项中查找必要质项,做出如下区分:
a. 把质项分为必要质项和非必要质项;
b. 把最小项(minTerms)分为必要质项覆盖的最小项和未覆盖的最小项;
c. 从非必要质项中提取出代价最小的能够覆盖未覆盖最小项的质项,并与必要质项合并为cover;
3) cover就是能够覆盖minTerms的最简项的集合;
 
 
3. 获取质项:getPrimeImplicants
 
调用方式如下:
 
把最小项和无关项合在一起进行化简,如卡诺图中把无关项合在一起进行画圈。
 
getPrimeImplicants的实现如下:
 
1) 合并之前,所有的最小项都是质项。即初始情况下,所有的最小项都是质项,互相不包含(cover);
 
 
2) 把所有项分布到一个bits x bits的表中;
 
若bits=4,表格如下:
 
a. 先根据mask中比特位值为1的位的个数,把所有的蕴含项划分为5列;
b. 然后根据value中比特位值为1的位的个数,把所有列划分为5行;
 
由mask的意义可知:
a. 如果mask中1的个数为0,则value中最多可以有4个1;
b. 如果mask中1的个数为1,则value中最多可以有3个1;
所以每一列中,有一些单元格为空,没有蕴含项分布。
 
 
3) 把单元格(i, j)和(i, j+1)中的蕴含项合并之后存入单元格(i+1, j)
 
单元格(i, j+1)中的项与单元格(i, j)中的项相比,mask中1的位数相同,value中1的位数多了一个,即符合Term.similar的初步特征;
 
如果判断出有similar的项,则可以将二者merge。合并生成的新项相较于(i, j+1),value中1的位数减少一个,mask中1的位数增加一个,即应当存入单元格(i+1, j)。
 
 
4) 搜集未被合并的质项
 
 
5) 把所有质项进行排序
 
 
举例如下:
 
也就是说primes中primes(0)“最小”。
primes(0)相较于primes(1),具有这样的倾向:value中的1更少,或者mask中的1更少。
只是倾向,而非绝对。
 
6) 所有最小项都被质项覆盖
 
 
4. 获取必要质项
 
调用方式如下:
从质项中查找必要质项,即含有不被其他任何项包含的子项的质项。
 
getEssentialPrimeImplicants实现如下:
 
1) 获取每一个质项覆盖的最小项
 
 
可以使用如下表格演示:
 
2) 移除可以省略的质项
 
把(p0, p0CoverdMinTerms)与(p1, p1CoveredMinTerms)进行对比,如果p0覆盖的最小项多,并且p0覆盖p1覆盖的所有最小项,则p1不是必要质项。
 
再把(p0, p0CoverdMinTerms)逐个与(p2, p2CoveredMinTerms),(p3, p3CoverdMinTerms)等进行对比。
 
然后是把p1与p2,p3等进行对比。
 
因为比对的方法是:
不存在else处理,所以这里存在一个假设:p0覆盖的最小项比p1的多。
 
这样就依赖于primes.sortWith(_ < _)这个动作,而这个排序动作无法保证这个假设。
所以这里无法保证primeTerms是最简的。
 
3) 获取必要质项覆盖的最小项
 
 
只被一个质项覆盖的最小项,所对应的质项一定是必要质项。但这不是必要质项的全部。
 
4) 把质项分为必要质项和非必要质项两部分
 
 
5) 获取未被必要质项覆盖到的最小项
 
 
6) 判断是否找到全部必要质项
 
a. 如果所有最小项已经全部被覆盖(uncovered.isEmpty),则已经找全;
b. 如果没有找到必要质项,则所有质项都是非必要质项,无需再找;
 
7) 如果只是找到一部分必要质项,而尚有一部分最小项没被覆盖。则在非必要质项中继续查找针对uncovered的必要质项。
 
 
直至6)中的条件为真。
 
可以看到getEssentialPrimeImplicants终止有两种情况:
a. 找到全部必要质项,uncovered为空;
b. 没找到全部必要质项,uncovered不为空。而余下的非必要质项每一个都覆盖2个以上的最小项;
 
 
5. 获取cover
 
如果没有找到全部必要质项,uncovered不为空。则需要从剩余的非必要质项中,选出能够以最小的代价覆盖uncovered的质项。
 
 
getCover实现如下:
 
这里看minTerms也就是uncovered不为空的情况。
 
1) 获取每个最小项对应的蕴含项
 
如下表:
 
每个蕴含项至少覆盖2个最小项;
 
2) 获取能覆盖全部最小项的蕴含项组合
 
执行示例:
 
a. 把最小项t0对应的蕴含项分别放入集合中:cover.head.map(Set(_))
 
之所以用Set,是为了去重。
 
b. 把t1对应的蕴含项分别加入到t0生成的集合中:c0.flatMap(a => c1.map(a + _))
 
c1.map(...)每次都生成一个新的集合,这样生成的集合的数量成指数级增长。最终获取到能覆盖全部最小项的所有蕴含项组合。
 
3) 比较所有蕴含项组合,选择最cheaper的组合使用
 
 
4) cheaper
 
 
简单来说,就是组合中使用的变量最少。
 
6. 确保所有最小项都得以覆盖
 
 
 
 

Rocket - decode - Simplify的更多相关文章

  1. Rocket - decode - 几个问题

    https://mp.weixin.qq.com/s/pMsK_E4mQrm3QXdnp7nDPQ   讨论指令解码部分遗留的几个问题.     1. 最小项与蕴含项之间的关系   参考链接: htt ...

  2. Rocket - decode - SimplifyDC

    https://mp.weixin.qq.com/s/4uWqBRrMVG6FlnBKmw8U-w   介绍SimplifyDC如何简化解码逻辑.     1. 使用   ​​   简化从mint和m ...

  3. Rocket - decode - 最小项与最大项

    https://mp.weixin.qq.com/s/XrBh9Kapj01HdvBi5MkbgA   介绍布尔代数最小项与最大项相关概念,以及Term类的实现.     参考链接: https:// ...

  4. Rocket - decode - Term

    https://mp.weixin.qq.com/s/CbBWdTlc_DESlUzd8KFcSg   介绍Term类各方法的实现.     ​​   1. prime   表示一个项是否是质项,即这 ...

  5. Rocket - decode - 解码单个信号

    https://mp.weixin.qq.com/s/0D_NaeBEZX5LBQRdCz2seQ     介绍解码单个信号逻辑的实现.    1. 单个信号   每个指令对应了一组信号,每个信号对应 ...

  6. Rocket - decode - Inst Decode

    https://mp.weixin.qq.com/s/WvepB3yAzjMbQalO3Z82pQ   介绍RocketChip Instruction解码逻辑的实现.   1. RISC-V   R ...

  7. 64位开源处理器Rocket该人士介绍

    最近大概读一点UCB发布时间Rocket处理器的源代码,的每个文件的源代码的功能有一定的一般理解,Mark一点点. Rocket是一家64bit标量处理器,5第一阶段管道,用途risc-v指令集.综合 ...

  8. (转)64位开源处理器Rocket的源代码简单介绍

    转载地址: http://blog.csdn.net/leishangwen/article/details/46604819 最近大概阅读了一下UCB发布的Rocket处理器的源码,对源代码各个文件 ...

  9. flask+sqlite3+echarts2+ajax数据可视化报错:UnicodeDecodeError: 'utf8' codec can't decode byte解决方法

    flask+sqlite3+echarts2+ajax数据可视化报错: UnicodeDecodeError: 'utf8' codec can't decode byte 解决方法: 将 py文件和 ...

随机推荐

  1. Oracle触发器之替代触发器

    替代触发器 替代视图增删改操作.视图可以认为成逻辑上的一张表,类似于把一个sql语句的执行结果永久的像表存储到数据 库中,视图一般用来做查询. 创建视图的语法: create view 视图名称 as ...

  2. hadoop中如何动态更新集群队列和容量

    1.集群默认是FIFO容量调度器,有的时候不同的业务部门都需要使用hadoop集群,那么这时候就需要来设置容量调度器了,如何平衡各个部门的容量.合理利用资源? 首先配置调度器需要在修改两个配置文件,分 ...

  3. [hdu1028]整数拆分,生成函数

    题意:给一个正整数n,求n的拆分方法数(不考虑顺序) 思路:不妨考虑用1~n来构成n.用多项式表示单个数所有能构成的数,用多项式表示,就相当于卷积运算了. 1 2 3 4 5 6 7 8 9 10 1 ...

  4. python 数据类型: 字符串String / 列表List / 元组Tuple / 集合Set / 字典Dictionary

    #python中标准数据类型 字符串String 列表List 元组Tuple 集合Set 字典Dictionary 铭记:变量无类型,对象有类型 #单个变量赋值 countn00 = '; #整数 ...

  5. js 获取URL后面传的参数

    function GetRequest() { var url = location.search; //获取url中"?"符后的字串 var theRequest = new O ...

  6. 【SMB源码解析系列】——003.SMB游戏基本框架

    前面有了解到RESET中断相关代码,结尾处通过一句jmp进入了无限循环,之后CPU将会在每一帧PUU进入VBlank状态时,接收NMI中断信号, 跳转至NMI代码处继续执行,直到遇见RTI指令时又返回 ...

  7. python之文件操作模块(os和shutil)

      1.os.name #操作系统类型 如果是posix,说明系统是liunx.Unix或Mac OS X,如果是nt,就是windows2.os.enviro #操作系统中定义的环境变量3.os.e ...

  8. Excel 数据导入至Sqlserver 数据库中 ltrim() 、rtrim() 、replace() 函数 依次空格无效问题

    今天导一些数据从Excel中至Sqlserver 数据库中,在做数据合并去重的时候发现,有两条数据一模一样,竟然没有进行合并: 最后发现有一条后面有个“空格”,正是因为这个“空格”让我抓狂许久,因为它 ...

  9. 最香远程开发解决方案!手把手教你配置VS Code远程开发工具,工作效率提升N倍

    文章每周持续更新,原创不易,「三连」让更多人看到是对我最大的肯定.可以微信搜索公众号「 后端技术学堂 」第一时间阅读(一般比博客早更新一到两篇) 今天和大家分享远程开发工具,分享一下我平常是如何用 V ...

  10. ajax提交可以上传文件的form表单

    var formData = new FormData($( "#fm")[0]);       $.ajax({            url: 'webnavigationcw ...