首页 > 其他 > 详细

长训练序列---verilog代码

时间:2020-05-15 23:37:43      阅读:77      评论:0      收藏:0      [点我收藏+]

长训练序列---verilog代码

module long_generator(

    input      wire          FFT_CLK,
    input      wire          RESET,
    input      wire          LONG_ACK,
    output     reg   [7:0]   LONG_RE,
    output     reg   [7:0]   LONG_IM,
    output     reg   [7:0]   LONG_INDEX,
    output     reg           LONG_DV
    );


reg [1:0] i;
reg [5:0] j;
reg [7:0] longrom_re [63:0];
reg [7:0] longrom_im [63:0];


always @ (negedge RESET or posedge FFT_CLK)
begin
    if(!RESET)
    begin
        i=0;
        j=0;
        LONG_RE=0;
        LONG_IM=0;
        LONG_INDEX=0;
        LONG_DV=0;

        longrom_re[0]=8b00101000;
        longrom_re[1]=8b11111111;
        longrom_re[2]=8b00001010;
        longrom_re[3]=8b00011001;
        longrom_re[4]=8b00000101;
        longrom_re[5]=8b00001111;
        longrom_re[6]=8b11100011;
        longrom_re[7]=8b11110110;
        longrom_re[8]=8b00011001;
        longrom_re[9]=8b00001110;
        longrom_re[10]=8b00000000;
        longrom_re[11]=8b11011101;
        longrom_re[12]=8b00000110;
        longrom_re[13]=8b00001111;
        longrom_re[14]=8b11111010;
        longrom_re[15]=8b00011111;
        longrom_re[16]=8b00010000;
        longrom_re[17]=8b00001001;
        longrom_re[18]=8b11110001;
        longrom_re[19]=8b11011110;
        longrom_re[20]=8b00010101;
        longrom_re[21]=8b00010010;
        longrom_re[22]=8b11110001;
        longrom_re[23]=8b11110010;
        longrom_re[24]=8b11110111;
        longrom_re[25]=8b11100001;
        longrom_re[26]=8b11011111;
        longrom_re[27]=8b00010011;
        longrom_re[28]=8b11111111;
        longrom_re[29]=8b11101000;
        longrom_re[30]=8b00010111;
        longrom_re[31]=8b00000011;
        longrom_re[32]=8b11011000;
        longrom_re[33]=8b00000011;
        longrom_re[34]=8b00010111;
        longrom_re[35]=8b11101000;
        longrom_re[36]=8b11111111;
        longrom_re[37]=8b00010011;
        longrom_re[38]=8b11011111;
        longrom_re[39]=8b11100001;
        longrom_re[40]=8b11110111;
        longrom_re[41]=8b11110010;
        longrom_re[42]=8b11110001;
        longrom_re[43]=8b00010010;
        longrom_re[44]=8b00010101;
        longrom_re[45]=8b11011110;
        longrom_re[46]=8b11110001;
        longrom_re[47]=8b00001001;
        longrom_re[48]=8b00010000;
        longrom_re[49]=8b00011111;
        longrom_re[50]=8b11111010;
        longrom_re[51]=8b00001111;
        longrom_re[52]=8b00000110;
        longrom_re[53]=8b11011101;
        longrom_re[54]=8b00000000;
        longrom_re[55]=8b00001110;
        longrom_re[56]=8b00011001;
        longrom_re[57]=8b11110110;
        longrom_re[58]=8b11100011;
        longrom_re[59]=8b00001111;
        longrom_re[60]=8b00000101;
        longrom_re[61]=8b00011001;
        longrom_re[62]=8b00001010;
        longrom_re[63]=8b11111111;

        longrom_im[0]=8b00000000;
        longrom_im[1]=8b11100001;
        longrom_im[2]=8b11100100;
        longrom_im[3]=8b00010101;
        longrom_im[4]=8b00000111;
        longrom_im[5]=8b11101010;
        longrom_im[6]=8b11110010;
        longrom_im[7]=8b11100101;
        longrom_im[8]=8b11111001;
        longrom_im[9]=8b00000001;
        longrom_im[10]=8b11100011;
        longrom_im[11]=8b11110100;
        longrom_im[12]=8b11110001;
        longrom_im[13]=8b11111100;
        longrom_im[14]=8b00101001;
        longrom_im[15]=8b11111111;
        longrom_im[16]=8b11110000;
        longrom_im[17]=8b00011001;
        longrom_im[18]=8b00001010;
        longrom_im[19]=8b00010001;
        longrom_im[20]=8b00011000;
        longrom_im[21]=8b00000100;
        longrom_im[22]=8b00010101;
        longrom_im[23]=8b11111010;
        longrom_im[24]=8b11011001;
        longrom_im[25]=8b11111100;
        longrom_im[26]=8b11111011;
        longrom_im[27]=8b11101101;
        longrom_im[28]=8b00001110;
        longrom_im[29]=8b00011101;
        longrom_im[30]=8b00011011;
        longrom_im[31]=8b00011001;
        longrom_im[32]=8b00000000;
        longrom_im[33]=8b11100111;
        longrom_im[34]=8b11100101;
        longrom_im[35]=8b11100011;
        longrom_im[36]=8b11110010;
        longrom_im[37]=8b00010011;
        longrom_im[38]=8b00000101;
        longrom_im[39]=8b00000100;
        longrom_im[40]=8b00100111;
        longrom_im[41]=8b00000110;
        longrom_im[42]=8b11101011;
        longrom_im[43]=8b11111100;
        longrom_im[44]=8b11101000;
        longrom_im[45]=8b11101111;
        longrom_im[46]=8b11110110;
        longrom_im[47]=8b11100111;
        longrom_im[48]=8b00010000;
        longrom_im[49]=8b00000001;
        longrom_im[50]=8b11010111;
        longrom_im[51]=8b00000100;
        longrom_im[52]=8b00001111;
        longrom_im[53]=8b00001100;
        longrom_im[54]=8b00011101;
        longrom_im[55]=8b11111111;
        longrom_im[56]=8b00000111;
        longrom_im[57]=8b00011011;
        longrom_im[58]=8b00001110;
        longrom_im[59]=8b00010110;
        longrom_im[60]=8b11111001;
        longrom_im[61]=8b11101011;
        longrom_im[62]=8b00011100;
        longrom_im[63]=8b00011111;
    end
    else 
    begin
        if(LONG_ACK)
        begin
            LONG_INDEX=LONG_INDEX+1;
            if(i==0)
            begin
                if(j<31)
                begin
                   LONG_RE=longrom_re[j+32];
                      LONG_IM=longrom_im[j+32];
                   LONG_DV=1;
                   if(i==0&j==0)
                   begin
                           LONG_RE=8b11101100;
                   end
                   j=j+1;
                end
                else 
                begin
                    LONG_RE=longrom_re[j+32];
                       LONG_IM=longrom_im[j+32];
                       LONG_DV=1;
                       j=0;
                       i=i+1;
                end
            end 
            else if(i>0&i<=2)
            begin
                if(j<63)
                begin
                   LONG_RE=longrom_re[j];
                      LONG_IM=longrom_im[j];
                   LONG_DV=1;
                   j=j+1;
                end
                else 
                begin
                   LONG_RE=longrom_re[j];
                   LONG_IM=longrom_im[j];
                   LONG_DV=1;
                   j=0;
                   i=i+1;
                end
            end
            else 
            begin
                i=0;
                LONG_RE=longrom_re[j]>>1;
                LONG_IM=longrom_im[j]>>1;
            end
        end
        else 
        begin
            i=0;
            j=0;
            LONG_RE=0;
            LONG_IM=0;
            LONG_INDEX=0;
            LONG_DV=0;
        end
    end
end


endmodule



/*


add_force {/long_generator/FFT_CLK} -radix hex {1 0ns} {0 50000ps} -repeat_every 100000ps
add_force {/long_generator/RESET} -radix hex {1 0ns} {0 200ns} {1 300ns}
add_force {/long_generator/LONG_ACK} -radix hex {0 0ns} {1 700ns}



*/

 

长训练序列---verilog代码

原文:https://www.cnblogs.com/chensimin1990/p/12897699.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!