verilog实现格雷码与二进制的转化:

7 篇文章 1 订阅

verilog实现格雷码与二进制的转化:

    1)自然二进制码转换为格雷码的方法

        自然二进制码转换成二进制格雷码,其法则是保留自然二进制码的最高位作为格雷码的最高位,而次高位格雷码为二进制码的高位与次高    位相异或,而格雷码其余各位与次高位的求法相类似。     

    原理: 若二进制码表示为: B[N-1]B[N-2]...B[2]B[1]B[0];

         相应地, 则二进制格雷码表示为: G[N-1]G[N-2]...G[2]G[1]G[0].

         其中最高位保留: G[N-1] = B[N-1];

         其他各位: G[i] = B[i+1] xor B[i]. (i = 0, 1, 2, ..., n-2)

    图示如下:

       

 

            bin[3]    bin[2]     bin[1]      bin[0]          ---二进制值 : 二进制

         +     0     bin[3]     bin[2]      bin[1]          ---右移值(二进制)

          gray[3]  gray[2]    gray[1]    gray[0]      ---对应的格雷码值

总结:格雷码的值只需要在原来的二进制的基础上右移一位再异或原来的二进制值即可得到。

module  binary2grey #(
        parameter   N       =       4
)(
        input         [N-1: 0]   binary                 ,
        output  wire  [N-1: 0]   grey
);
//=====================================================================\
// ********** Define Parameter and Internal Signals *************
//=====================================================================/
 
 
//======================================================================
// ***************      Main    Code    ****************
//======================================================================
assign  grey    =       {1'b0,binary[N-1:1]}^binary;
endmodule


 2)格雷码转换为二进制码的实现方法

         二进制格雷码转换成自然二进制码,其法则是保留格雷码的最高位作为自然二进制码的最高位,而次高位自然二进制码为高位自然二进制       码与次高位格雷码相异或,而自然二进制码的其余各位与次高位自然二进制码的求法相类似。      

    原理: 若二进制格雷码表示为: G[N-1]G[N-2]...G[2]G[1]G[0];

         相应地, 则二进制码表示为: B[N-1]B[N-2]...B[2]B[1]B[0].

         其中最高位保留: B[N-1] = G[N-1];

         其他各位: B[i-1] = G[i-1] xor B[i]. (i = 1, 2, ..., n-1)

    图示如下:

  

module  grey2binary #(
        parameter   N       =       4
)(
        input         [N-1: 0]   grey                   ,
        output  wire  [N-1: 0]   binary
);
//=====================================================================\
// ********** Define Parameter and Internal Signals *************
//=====================================================================/
 
 
 
//======================================================================
// ***************      Main    Code    ****************
//======================================================================
assign  binary[N-1]     =       grey[N-1];
 
generate
genvar  i;
    for(i=0;i<N-1;i=i+1) begin:b2g
        assign  binary[i]     =       grey[i]^binary[i+1];
    end
endgenerate
 
 
endmodule


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值