10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码

 always的block之间,采用并行执行

always之内,采用非阻塞赋值,为顺序执行

一些代码分析

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第1张图片10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第2张图片

这个把使能信号和W信号组合在一起,进行case语句,即只有合并信号最高位为1时,才进行操作

always后面要写@,assign不用

存储元件代码

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第3张图片

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第4张图片

这没有期望的边沿,就是只要发生变化就会触发

加上posedge,negedge就可以标记期望的边沿10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第5张图片

按位操作与逻辑操作

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第6张图片

一个操作符就是按位操作,两个就是逻辑操作

香浓展开与选择器实现电路 

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第7张图片

对四变量提取w1,做出香浓展开,则w1为选择信号,其他w2,w3,w4组合成被选择的信号

提取出n个量,就有n个选择信号,就需要传进2^n的被选择信号

例一

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第8张图片

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第9张图片

香浓展开的提取项,就是选择器的选择信号

对两个量进行展开,考虑出所有情况

对于各子项里没有出现的提取项,可以放到任意一个里去,但必须有对应的提取项,最后的目标是各种情况能凑齐子项

移位器

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第10张图片

就是移位信号为1时,y3选为0,y2为w3,y1为w2,y0为w1,即整体左移一位

代码

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第11张图片由于采用了always,所以输出信号在模块内要定义成reg

always@(W,Shift)就是说,只要这里面有一个变化,就进行触发

如果用assign就是时刻都在触发,而always是标定信号发生变化时才触发

另一种实现

桶形移位器

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第12张图片

就是一个可以指定移动位数的移位器,并且循环

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第13张图片

y3,y2,y1,y0是实际输出的每位,每位都是一个四选一选择器,被选择信号就是循环出现的四个信号,然后s1s0组合在一起构成移位信号对每个选择器进行选择。

代码

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第14张图片

多位宽信号在运算时,是整成实际大小意义进行的

二进制转格雷码函数

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第15张图片

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第16张图片

就是从低位与高位两两异或,最高位独自保留

异或实现

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第17张图片

 选择器的上是0,下是1的情况,即异或式中,认为一个信号是选择信号,剩下的所有信号的异或运算结果和它的非为被选择信号,选择信号为0时,不做改变,直接消掉,即输出剩下所有的运算结果,即选择上部直接出;为1时,对前面的所有信号的异或运算结果取反,输出取反后的结果;

10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码_第18张图片

三个项异或电路

n个项就是往后不断递归加二选一选择器,延长电路长度

这个原理也可说明异或函数能检验一串二进制数的1的个数

如果个数为奇数,则输出结果为1;

如果个数为偶数,则输出结果为0;

你可能感兴趣的:(数电,javascript,开发语言,ecmascript,1024程序员节,单片机,嵌入式硬件)