久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5718|回復: 0
打印 上一主題 下一主題
收起左側

FPGA學習-3-8譯碼器設計驗證

[復制鏈接]
跳轉到指定樓層
樓主
ID:108531 發表于 2016-3-12 22:46 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式

[組合邏輯]

源程序:可以認為 led_test 就是一個芯片

module led_test(a, b, c, out);

 

    input a;                    // 輸入信號

    input b;                    // 輸入信號

    input c;                    // 輸入信號

   

    //output [7:0]out;    // 由于要用到 always 程序塊中,需要聲明為 reg 類型

    // 如果不是 reg 類型則會報錯

    // Error (10137): Verilog HDL Procedural Assignment error at led_test.v(12):

    //    object "out" on left-hand side of assignment must have a variable data type

    output reg [7:0]out;    // 輸出信號

 

    always@(a, b, c)begin

        case({a, b, c})

            3'b000 : out = 8'b0000_0001;

            3'b001 : out = 8'b0000_0010;

            3'b010 : out = 8'b0000_0100;

            3'b011 : out = 8'b0000_1000;

            3'b100 : out = 8'b0001_0000;

            3'b101 : out = 8'b0010_0000;

            3'b110 : out = 8'b0100_0000;

            3'b111 : out = 8'b1000_0000;

        endcase

    end

 

endmodule

 

 

仿真程序:

`timescale 1ns/1ns                // 延時時間單位/仿真精度

module led_test_tb;

   

    reg a, b, c;

    wire[7:0] out;

   

    led_test u1(.a(a), .b(b), .c(c), .out(out));    // 將端口(IO口)連接到 led_test 芯片中

       

    initial begin   

   

        a = 0; b = 0; c = 0;    // 設置端口(IO口)的電平狀態

        #200;

        a = 0; b = 0; c = 1;

        #200;

        a = 0; b = 1; c = 0;

        #200;

        a = 0; b = 1; c = 1;

        #200;

        a = 1; b = 0; c = 0;

        #200;

        a = 1; b = 0; c = 1;

        #200;

        a = 1; b = 1; c = 0;

        #200;

        a = 1; b = 1; c = 1;

        #200;

        $stop;                // 停止執行

   

    end

   

endmodule

 

 

知識點總結:

1、always 里面的變量必須是 reg 類型,否則會報如下錯誤


2、
從仿真的角度來看,out 輸出的電平并不是理想的。
 


放大其中
,從 00000001 跳變到 00000010 中間還有一個 00000000


從 00000001 變化到 0000010 有兩個bit會發生變化,由于電路結構關系,它們有可能不會同時變化,有可能bit1最開始變化,也有可能bit0最開始變化。

還有另外一種情況:

 

3、如果已經運行了仿真程序,則會報如下錯誤

 

作業:實現一個4-16 譯碼器

源程序:

/* 4-16 譯碼器 */

module led_test(a, b, c, d, out);

 

    input a, b, c, d;

    output reg[15:0] out;

   

    always@(a, b, c, d)begin

   

        case({a, b, c, d})

            4'b0000 : out = 16'b0000_0000_0000_0001;

            4'b0001 : out = 16'b0000_0000_0000_0010;

            4'b0010 : out = 16'b0000_0000_0000_0100;

            4'b0011 : out = 16'b0000_0000_0000_1000;

            4'b0100 : out = 16'b0000_0000_0001_0000;

            4'b0101 : out = 16'b0000_0000_0010_0000;

            4'b0110 : out = 16'b0000_0000_0100_0000;

            4'b0111 : out = 16'b0000_0000_1000_0000;

            4'b1000 : out = 16'b0000_0001_0000_0000;

            4'b1001 : out = 16'b0000_0010_0000_0000;

            4'b1010 : out = 16'b0000_0100_0000_0000;

            4'b1011 : out = 16'b0000_1000_0000_0000;

            4'b1100 : out = 16'b0001_0000_0000_0000;

            4'b1101 : out = 16'b0010_0000_0000_0000;

            4'b1110 : out = 16'b0100_0000_0000_0000;

            4'b1111 : out = 16'b1000_0000_0000_0000;

        endcase

   

    end

 

endmodule

 

 

仿真程序:

`timescale 1ns/1ns

module led_test_tb;

 

    reg a, b, c, d;

    wire[15:0] out;

   

    led_test u1(.a(a), .b(b), .c(c), .d(d), .out(out));

 

    initial begin   

        a = 0; b = 0; c = 0; d = 0; #200;

        a = 0; b = 0; c = 0; d = 1; #200;

        a = 0; b = 0; c = 1; d = 0; #200;

        a = 0; b = 0; c = 1; d = 1; #200;

        a = 0; b = 1; c = 0; d = 0; #200;

        a = 0; b = 1; c = 0; d = 1; #200;

        a = 0; b = 1; c = 1; d = 0; #200;

        a = 0; b = 1; c = 1; d = 1; #200;

        a = 1; b = 0; c = 0; d = 0; #200;

        a = 1; b = 0; c = 0; d = 1; #200;

        a = 1; b = 0; c = 1; d = 0; #200;

        a = 1; b = 0; c = 1; d = 1; #200;

        a = 1; b = 1; c = 0; d = 0; #200;

        a = 1; b = 1; c = 0; d = 1; #200;

        a = 1; b = 1; c = 1; d = 0; #200;

        a = 1; b = 1; c = 1; d = 1; #200;

        $stop;

    end

endmodule

 

 

仿真波形:

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产日韩欧美 | 成人欧美一区二区三区黑人孕妇 | 中文字幕在线观看日韩 | 亚洲国产成人精品女人久久久 | 中文字幕亚洲视频 | 在线午夜电影 | 亚洲国产精品一区二区久久 | 国产精品一二三区 | 91精品国产一区二区三区香蕉 | 天堂一区 | 欧美久久一区二区 | 给我免费的视频在线观看 | 国产精品123区 | 国产91精品久久久久久久网曝门 | 在线观看视频一区二区三区 | 91精品久久久久久综合五月天 | 一区二区视频在线 | 日韩高清国产一区在线 | 国产精品福利在线观看 | 一区二区免费在线视频 | 综合久久av | 国产成人精品一区二 | 亚洲欧美在线一区 | 欧美一区二区三区视频 | 国产精品久久久久久久久久妇女 | 国产精品久久久久久久模特 | av黄色在线| 欧美爱爱视频 | av在线一区二区三区 | 欧美极品少妇xxxxⅹ免费视频 | 羞羞视频网页 | 国产亚洲精品久久久久动 | 精品国产乱码久久久久久图片 | 国产精品99一区二区 | 一区二区三区视频在线观看 | 国产精品久久久久久久久久久免费看 | 国产91一区 | 七七婷婷婷婷精品国产 | 国产成人免费网站 | 日韩在线视频观看 | 日韩久久在线 |