天天看點

16位計數器之元件例化的學習

16位全加器

         通過該實驗,學習元件例化。

1個16位全加器由4個4位全加器構成;

1個4位全加器由4個1位全加器構成;

1位全加器由兩個半加器加上一個或門構成;

一個半加器由門級電路構成。

如下圖:

16位計數器之元件例化的學習
16位計數器之元件例化的學習
16位計數器之元件例化的學習

頂層檔案:

16位計數器之元件例化的學習

第二層:1個16位全加器由4個4位全加器構成;

16位計數器之元件例化的學習

第三層:1個4位全加器由4個1位全加器構成;

16位計數器之元件例化的學習

第四層:1位全加器由兩個半加器加上一個或門構成;

16位計數器之元件例化的學習

第五層:一個半加器由門級電路構成

a

b

sum

c_out

1

門級電路如下:

16位計數器之元件例化的學習

代碼部分:

//16為全加器

//頂層檔案為16為全加器

module add_full_16(a,b,c_in,sum,c_out);

    input

[15:0]a,b;

    input c_in;

    output

[15:0]sum;

    output c_out;

    wire m0_c_out,m1_c_out,m2_c_out;

    add_full_4 m0(.a(a[3:0]),.b(b[3:0]),.c_in(c_in),.sum(sum[3:0]),.c_out(m0_c_out));

    add_full_4 m1(.a(a[7:4]),.b(b[7:4]),.c_in(m0_c_out),.sum(sum[7:4]),.c_out(m1_c_out));

    add_full_4 m2(.a(a[11:8]),.b(b[11:8]),.c_in(m1_c_out),.sum(sum[11:8]),.c_out(m2_c_out));

    add_full_4 m3(.a(a[15:12]),.b(b[15:12]),.c_in(m2_c_out),.sum(sum[15:12]),.c_out(c_out));

endmodule

第二層:

//4位全加器,4個4為全加器構成一個16位的全加器

module add_full_4(a,b,c_in,sum,c_out);

[3:0]a,b;

[3:0]sum;

    wire b0_c_out,b1_c_out,b2_c_out;

    add_full b0(.a(a[0]),.b(b[0]),.c_in(c_in),.sum(sum[0]),.c_out(b0_c_out));

    add_full b1(.a(a[1]),.b(b[1]),.c_in(b0_c_out),.sum(sum[1]),.c_out(b1_c_out));

    add_full b2(.a(a[2]),.b(b[2]),.c_in(b1_c_out),.sum(sum[2]),.c_out(b2_c_out));

    add_full b3(.a(a[3]),.b(b[3]),.c_in(b2_c_out),.sum(sum[3]),.c_out(c_out));

第三層:

//1位全加器

//4個1位全加器構成一個4位全加器

module add_full(a,b,c_in,sum,c_out);

    input a,b;

    input c_in;

    output sum;

    wire h0_sum,h0_c_out,h1_c_out;

    add_half h0(.a(a),.b(b),.sum(h0_sum),.c_out(h0_c_out));

    add_half h1(.a(c_in),.b(h0_sum),.sum(sum),.c_out(h1_c_out));

    assign c_out

= h0_c_out | h1_c_out;

第四層:

//半加器

//兩個半加器加上一個或門構成1位全加器

module add_half(a,b,sum,c_out);

    and u0(c_out

,a ,b);

    xor u1(sum

前仿真代碼:

`timescale

1ns/1ns

module add_full_16_tb;

    reg

    reg c_in;

    wire

    wire c_out;

    add_full_16 add_full_16(.a(a),.b(b),.sum(sum),.c_in(c_in),.c_out(c_out));

    integer i;

    initial

begin

        a =

0;b =0;c_in

=0;

        forever

            for(i=0;i<65536;i=i+1)begin

                #10 a

= i;b

= i;c_in

= 0;

= 1;

            end

        end

    end

仿真圖:

16位計數器之元件例化的學習

繼續閱讀