verilog中符號位的擴充問題

來源:互聯網
上載者:User

標籤:

以下內容轉自艾米電子 - 使用有符號數,Verilog(http://www.cnblogs.com/yuphone/archive/2010/12/12/1903647.html) Verilog-1995中的有符號數

在Verilog-1995中,只有integer資料類型被轉移成有符號數,而reg和wire資料類型則被轉移成無符號數。由於integer類型有固定的32位寬,因此它不太靈活。我們通常使用手動加上擴充位來實現有符號數運算。下面的程式碼片段將描述有符號數和無符號數的運算:

 1 reg [7:0] a, b; 2 reg [3:0] c, 3 reg [7:0] sum1, sum2, sum3, sum4; 4 . . . 5 // same width. can be applied to signed and unsigned 6 sum1 = a + b; 7 // automatica 0 extension 8 sum2 = a + c; 9 // manual 0 extension10 sum3 = a + {{4{1‘b0}}, c};11 // manual sign extension12 sum4 = a + {{4{c[3]}}, c};

在第一條語句中,a、b和sum1有相同的位寬,因此無論是轉譯成有符號數還是無符號數,它都將引用相同的加法器電路。

在第二條語句中,c的位寬僅為4,在加法運算中,它的位寬會被調整。因為reg類型被作為無符號數看待,所以c的前面會被自動置入0擴充位。

在第三條語句中,我們給c手動前置4個0,以實現和第二個運算式一樣的效果。

在第四條語句中,我們需要把變數轉譯成有符號數。為了實現所需的行為,c必須擴充符號位到8位。沒有其他的辦法,只好手動擴充。在代碼中,我們重複復制c的最高位4次(4{c[3]})來建立具有擴充符號位的8位元。

3 Verilog-2001中的有符號數

在Verilog-2001中,有符號形式也被擴充到reg和wire資料類型中。哈哈,新加一個關鍵字,signed,可以按照下面的方式定義:

reg signed [7:0] a, b

使用有符號資料類型, 第2節所述代碼可以被改寫為:

reg signed [7:0] a, b;reg signed [3:0] c;reg signed [7:0] sum1, sum4;. . .// same width. can be applied to signed and unsignedsum1 = a + b;// automatic sign extensionsum4 = a + c;

第一條語句將引用一個常規的加法器,因為a、b和sum1具有相同的位寬。

第二條語句,所有的右手邊變數都具有signed資料類型,c被自動擴充符號位到8位。因此,無需再手動添加符號位。

 

在小型的數字系統中,我們通常可以選用有符號數或者無符號數。然而,在一些大型的系統中,會包括不同形式的子系統。Verilog是一種弱類型語言,無符合變數和有符號變數可以在同一運算式中混用。根據Verilof的標準,只有當所有右手邊的變數具有signed資料類型屬性的時候,擴充符號位才被執行。否則,所有的變數都只擴充0。考慮下面的程式碼片段:

1 reg signed [7:0] a, sum;2 reg signed [3:0] b;3 reg [3:0] c;4 . . .5 sum = a + b + c;

由於c不具有signed資料類型屬性,因此右手邊的變數b和c的擴充位為0。

Verilog有兩個系統函數,$signed和$unsigned(),用以將括弧內的運算式轉換為signed和unsigned資料類型。比方說,我們可以轉換c的資料類型,

sum = a + b + $signed(c);

現在,右手邊的所有變數都具有signed資料類型屬性,因此b和c將擴充符號位。

在複雜的運算式中,混用signed和unsigned資料類型將引入一些微妙的錯誤,因此應當避免混用。如果真的很有必要,那麼運算式需要保持簡單,同時通用轉換函式,以確保資料類型的一致性。

verilog中符號位的擴充問題

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.