EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
本帖最后由 Taio 于 2019-4-10 11:05 编辑
' \& d4 y5 K9 T* Y7 y7 t7 e2 f: L! j8 z2 `& P; p/ ^& Z
转——Verilog中状态机编码方式的选择:二进制编码、格雷码编码、独热码编码 . C3 d6 v$ ]/ A x$ l
一般的,在Verilog中最常用的编码方式有二进制编码(Binary)、格雷码(Gray-code)编码、独热码(One-hot)编码。& C$ k" M4 e) H7 Z- ?9 R
1 v2 I7 q/ o) D/ j0 A! z二进制码和格雷码是压缩状态编码。 若使用格雷编码,则相邻状态转换时只有一个状态位发生翻转,这样不仅能消除状态转换时由多条状态信号线的传输延迟所造成的毛刺,又可以降低功耗。
9 o n; O; r" m' J3 C2 E2 I1 E4 W Y- {& [# W
二进制编码也可称连续编码,也就是码元值的大小是连续变化的。如S0=3'd0,S1=3'd1,S2=3'd2,S3=3'd3....
% x) f9 x5 h O3 E9 ]" H& x, w: y
+ ~+ x; N# n# C
格雷码的相邻码元值间只有一位是不同的,如S0=3'b000,S1=3'b001,S2=3'b011,S3=3'b010....
! W& F# o+ j( B" }0 p- o2 R% r" U6 T2 l- u
独热编码即 One-Hot 编码,又称一位有效编码,其方法是使用N位状态寄存器来对N个状态进行编码,每个状态都由他独立的寄存器位,并且在任意时候,其中只有一位有效。虽然使用较多的触发器,但由于状态译码简单,可减少组合逻辑且速度较快, 这种编码方式还易于修改,增加状态或改变状态转换条件都可以在不影响状态机的其它部分的情况下很方便地实现。另外,它的速度独立于状态数量。与之相比,压缩状态编码在状态增加时速度会明显下降。
* T$ {* Q ~8 D- _" T) ]. o: Q" _) J& u6 j% j: Z4 s; [' |) X: ^/ v
独热码值每个码元值只有一位是'1',其他位都是'0',如S0=3'b001,S1=3'b010,S2=3'b100# u/ s/ H0 d% y3 e" T
8 B: d# X3 Q: m. A. j* H; K; i2 r
/ U/ F/ T9 m" w i+ i$ {: e | 二进制编码、格雷码编码使用最少的触发器,消耗较多的组合逻辑,而独热码编码反之。独热码编码的最大优势在于状态比较时仅仅需要比较一个位,从而一定程度上简化了译码逻辑。虽然在需要表示同样的状态数时,独热编码占用较多的位,也就是消耗较多的触发器,但这些额外触发器占用的面积可与译码电路省下来的面积相抵消。9 _/ q& x2 Y' \! v
6 H6 A' e! f5 O5 Q; X3 O7 X( v7 A为了进一步提高独热编码的速度,可以使用并行 CASE语句"即在case(1‘b1) 后添加综合器可以辨认的并行CASE注释语句。注意:并行CASE 只推荐在独热编码时使用,在二进制编码和格雷编码时使用有时反而会增大面积降低速度。2 I a, @& B. ~9 v! z) M
q, F, B( q! s/ G- J+ A+ x, u& l5 |
在cpld中,由于器件拥有较多的地提供组合逻辑资源,所以CPLD多使用二进制编码或格雷码,而FPGA更多地提供触发器资源,所以在FPGA中多使用独热码编码。当然,这并不是说在FPGA中就非得用独热编码,在CPLD中不能用独热编码,一般的,对于小型设计(状态数小于4)使用二进制编码,当状态数处于4-24之间时,宜采用独热码编码,而大型状态机(状态数大于24)使用格雷码更高效。5 o, Q6 t$ y$ r% _0 p
|