verilog中异或(^)理解与应用(格雷码,奇偶判断,奇分频)

异或运算:

首先异或表示当两个数的二进制表示,进行异或运算时,当前位的两个二进制表示不同则为1相同则为0.该方法被广泛推广用来统计一个数的1的位数!

参与运算的两个值,如果两个相应bit位相同,则结果为0,否则为1。
即:
  0^0 = 0, 
  1^0 = 1, 
  0^1 = 1, 
  1^1 = 0
按位异或的3个特点:
(1) 0^0=0,0^1=1  0异或任何数=任何数
(2) 1^0=1,1^1=0  1异或任何数-任何数取反
(3) 任何数异或自己=把自己置0

一、异或^的运用:

(1)使某些特定的位翻转
    例如对数10100001的第2位和第3位翻转,则可以将该数与00000110进行按位异或运算。
       10100001^00000110 = 10100111

(2)奇偶判断

       ^a操作就是将a中的每一位按位逐一进行异或,例如a=4'b1010,则b=1^0^1^0=0,由此可以判断a中为1的位数是奇数还是偶数,是一个便捷的操作。

(3)交换两个整数的值而不必用第三个参数
a = 9;b = 11;

a=a^b; 1001^1011=0010
b=b^a; 1011^0010=1001
a=a^b;  0010^1001=1011

a = 11;b = 9;

(4)格雷码(Gray code)

          格雷码(Gray code)是由贝尔实验室的Frank Gray在1940年提出,用于在PCM(Pusle Code Modulation)方法传送讯号时防止出错,并1953年三月十七日取得美国专利。格雷码是一个数列集合,相邻两数间只有一个位元改变,为无权数码,且格雷码的顺序不是唯一的。直接排列以二进制为0值的格雷码为第零项,第一项改变最右边的位元,第二项改变右起第一个为1的位元的左边位元,第三、四项方法同第一、二项,如此反覆,即可排列出n个位元的格雷码。

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



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

二进制数转格雷码
(假设以二进制为0的值做为格雷码的0)
格雷码第n位 = 二进制码第(n+1)位+二进制码第n位。不必理会进制。

     Verilog 代码:gray=(binary>>1)^binary;


     格雷码转二进制数
二进制码第n位 = 二进制码第(n+1)位+格雷码第n位。因为二进制码和格雷码皆有相同位数,所以二进制码可从最高位的左边位元取0,以进行计算。

      verilog 代码://------假设 reg [n-1] gray,binary;

             integer i;

             for(i=0;i<=n-1;i=i+1)

              binary[i]= ^(gray>>i)//gray移位后,自身按位异或

放一段代码这,用于参考:


//example_1
module GrayToBinary2ex (binarycode, graycode);
  parameter n = 4;      // this module is parameterizable
  output reg [n-1:0] binarycode;
  input  [n-1:0] graycode;
  integer i;
  always @ (graycode)
     begin
          binarycode[n-1]=graycode[n-1];
          // for(i=1;i<=n-1;i=i+1)
          // binarycode[i-1]=graycode[i-1] ^ binarycode[i];//比较节省空间
          for(i=n-1;i>0;i=i-1)
          binarycode[i-1]=graycode[i-1] ^ binarycode[i];//比较节省空间
     end
endmodule

// example_2
module gray2bin (bin, gray);
  parameter SIZE = 4;      // this module is parameterizable
  output [SIZE-1:0] bin;
  input  [SIZE-1:0] gray;

  genvar i;
  generate
    for (i=0; i<SIZE; i=i+1) begin:bit
      assign bin[i] = ^gray[SIZE-1:i];
            // i refers to the implicitly defined localparam whose
            // value in each instance of the generate block is
            // the value of the genvar when it was elaborated.
    end
  endgenerate
endmodule

//example_3
//http://www.cnblogs.com/adamite/archive/2008/10/20/1314949.html
//example1
module GrayToBinary1 (binarycode, graycode);
  parameter n = 4;      // this module is parameterizable
  output reg [n-1:0] binarycode;
  input  [n-1:0] graycode;
  integer i;
  always @ (graycode)
     begin
          for(i=0;i<=n-1;i=i+1)
          binarycode[i]=^(graycode>>i);//比较浪费空间
     end
endmodule

//测试代码
`timescale 1ns/1ns
module tb_GrayToBinary1;

reg [3:0] gray;
wire [3:0] bin;

GrayToBinary1 dut (bin,gray);

initial begin
  gray = 4'h0;
  #10;
  gray = 4'h1;
  #10;
  gray = 4'h2;
  #10;
  gray = 4'h3;
  #10;
  gray = 4'he;
  #10;
  gray = 4'h7;
  #10;
  gray = 4'hf;
end
endmodule

(4)奇数分频

奇数分频电路:

  奇数分频电路常用的是错位“异或”法的原理。如进行三分频,通过待分频时钟的上升沿触发计数器进行模三技术,当计数器计数到邻近值进行两次翻转。比如计数器在计数到1时,输出时钟进行翻转,计数到2时再进行翻转,即在邻近的1和2时刻进行两次翻转。这样实现的三分频占空比为1/3或2/3.如果要实现占空比为50%的三分频时钟,可通过待分频的时钟上升沿触发计数器和下降沿触发计数器进行三分频,然后将上升沿和下降沿产生的三分频时钟进行相或预算,即可得到占空比为50%的三分频时钟。

      错位“异或”法推广:

  对于实现占空比为50%的N倍奇数分频,首先进行上升沿触发的模N计数,计数到某一选定值时,进行输出时钟翻转,然后进过(N-1)/2再次进行翻转得到一个占空比非50%的技术分频时钟。再者同时进行下降沿触发的模N计数,到和上升沿触发输出时钟翻转选定值相同时,进行输出时钟翻转,同样经过(n-1)/2时,输出时钟再次翻转生成占空比非50%的奇数N分频时钟。两个占空比非50%的时钟相或运算,得到占空比为50%的奇数N分频时钟。

  • 9
    点赞
  • 75
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值