https://mp.weixin.qq.com/s/Jsy8P3m9W2EYKwneGVekiw

 
独热码相关的电路生成器。
 
参考链接:
 
 
1. PriorityEncoderOH
 
1) Seq.tabulate(n)(f)
 
相当于把0到n-1逐个带入函数f,把每一次计算得出的结果f(n)连接成为一个序列返回。
 
2) encode
 
a. Seq[Bool]中的每一个选择位,生成一个独热码:
 
val outs = Seq.tabulate(in.size)(i => (BigInt(1) << i).asUInt(in.size.W))
 
b. 委托PriorityMux生成一个低序高优先的级联选择器:PriorityMux(in :+ true.B, outs :+ 0.U(in.size.W))
 
:+ true.B,:+ 0.U(in.size.W) 提供了一个默认值;
 
c. 返回的是一个UInt
 
3) 第二个apply:def apply(in: Bits): UInt = encode((0 until in.getWidth).map(i => in(i)))
 
把输入的Bits转换成一串Bool,然后直接把encode返回的UInt返回;
 
4)第一个apply:def apply(in: Seq[Bool]): Seq[Bool]
 
把encode返回的UInt拆成一串Bool返回;
 
2. UIntToOH
 
把UInt转换成为独热码,即把UInt的值对应的位置位。
 
1) 第一个apply不限制位数,所以比较简单:def apply(in: UInt): UInt = 1.U << in
2) 第二个apply限制最终生成的独热码的位数
 
假设UInt的值为6,生成的独热码为8位,则需要把第7位补0.
 
a. 隐含条件:width >= UInt的值
 
所以width所占的位数大于等于UInt的位宽,所以需要把in进行补位(pad);
 
b. in补位之后截取[shiftAmountWidth - 1, 0]
 
这些位中已经包含in的全部有效位,shiftAmount即是in的值;
 
c. 移位shiftAmount得到对应的独热码:(1.U << shiftAmount)
 
d. 截取[width - 1, 0],隐含类型推断和补位
 
可以看到8.U虽然只有4位,但对其截取[7, 0]之后返回的类型有8位。
 
3. PriorityEncoder
 
返回一个低序高优先级的级联选择器,输出为第一个为真的值的序号。
 
4. OHToUInt
 
与UIntToOH互逆,返回独热码中第几位为1。
 
使用分治策略,逐半递归求值。
 
5. 附录

Chisel3 - util - OneHot的更多相关文章

  1. Chisel3 - util - MixedVec

    https://mp.weixin.qq.com/s/mO648yx4_ZRedXSWX4Gj2g   可以容纳不同类型的变量的向量.   参考链接: https://github.com/freec ...

  2. Chisel3 - util - Mux

    https://mp.weixin.qq.com/s/TK1mHqvDpG9fbLJyNxJp-Q   Mux相关电路生成器.   参考链接: https://github.com/freechips ...

  3. Chisel3 - util - Lookup

    https://mp.weixin.qq.com/s/g85Si6n37D9PYfR5hEoRQQ     实现一个查找逻辑.   参考链接: https://github.com/freechips ...

  4. Chisel3 - util - Valid

    https://mp.weixin.qq.com/s/L5eAwv--WzZdr-CfW2-XNA   Chisel提供的Valid接口.如果valid为置1,则表明输出的bits有效:反之,则输出无 ...

  5. Chisel3 - util - Math vs. CircuitMath

    https://mp.weixin.qq.com/s/8lC8vQnBdKW9C39H0QFFkA     对数相关的辅助方法,Math通过软件方法实现,CircuitMath通过硬件方法实现.   ...

  6. Chisel3 - util - LFSR16

    https://mp.weixin.qq.com/s/DSdb4tmRwDTOki7mbyuu9A     实现16位线性反馈移位寄存器.可用于生成简单的伪随机数.     ​​     ​​   参 ...

  7. Chisel3 - util - Bitwise

    https://mp.weixin.qq.com/s/MQzX1Ned35ztz0vusPdkdQ   比特相关的操作.   参考链接: https://github.com/freechipspro ...

  8. Chisel3 - util - BitPat

    https://mp.weixin.qq.com/s/80Q8j-OSMtgh5a92pI-MZA   使用value和mask来描述一个比特模式,即:value = bits & mask. ...

  9. Chisel3 - util - LockingArbiter

    https://mp.weixin.qq.com/s/5oAwH3scumARzPidRBfG2w     带锁多入单出仲裁器,输出会被锁定指定的时钟周期.   参考链接: https://githu ...

随机推荐

  1. 【mybatis】IF判断的坑

    http://cheng-xinwei.iteye.com/blog/2008200 最近在项目使用mybatis中碰到个问题 <if test="type=='y'"> ...

  2. 06_CSS入门和高级技巧(4)

    复习 CSS : 负责样式层,层叠式样式表cascading style sheet.CSS2.1,最新版本CSS3. CSS选择器: 选择哪些元素加样式.基本选择3种:标签p.id选择器#id.cl ...

  3. 【Hadoop离线基础总结】MapReduce案例之自定义groupingComparator

    MapReduce案例之自定义groupingComparator 求取Top 1的数据 需求 求出每一个订单中成交金额最大的一笔交易 订单id 商品id 成交金额 Order_0000005 Pdt ...

  4. linux gdb快速入门教程

    文章目录 前言 常用指令概览 开始使用gdb 一个完整流程一般所需步骤 1 加载程序 2 查看 2.1 查看函数 3 设置断点 3.1 根据函数名设置断点 3.2 根据程序位置(第几行) 4 运行程序 ...

  5. Python基础语法day_04——操作列表

    day_04 遍历整个列表 我们创建列表时,需要输出整个列表,但是通常列表会很长,包含很多元素,当列表长度发生变化是,都必须修改代码.通过for循环,我们可以很轻易地输出整个列表. #遍历整个列表 创 ...

  6. 1、Fiddler基础

    1.抓取https请求 前言 fiddler是一个很好的抓包工具,默认是抓http请求的,对于pc上的https请求,会提示网页不安全,这时候需要在浏览器上安装证书. 一.网页不安全 1.用fiddl ...

  7. PAT 1007 Maximum Subsequence Sum (25分)

    题目 Given a sequence of K integers { N​1​​ , N​2​​ , ..., N​K​​ }. A continuous subsequence is define ...

  8. ORACLE 统计文件后缀SQL

    ORACLE 统计文件后缀SQL查询语句 select lower(substr(file_name,instr(file_name, '.', -1),length(file_name))),cou ...

  9. 浅谈产品模型(Profile)在程序设计中的作用

    引言:物联网平台的一个重要功能就是资产管理,产品或者设备都可以看成是资产中组成部分,所以有时候说物联网平台可以进行产品管理和设备管理.通常应用物联网平台开发一套具有产品或者设备管理功能的系统的时候,必 ...

  10. 使用react的一点提醒17/10/26

    1.不直接操作dom 今天在和同学讨论的时候,发现了一些以前没注意的问题. 这段时间自己学习时一直都是用原生js写代码,但是以前在公司经常使用jq,也不知不觉间让我习惯了操作dom的倾向. 使用vue ...