在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

關于verilog中的無符號數(shù)和有符號數(shù)

454398 ? 來源:博客園 ? 作者:lianjiehere ? 2020-11-18 17:46 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

數(shù)字電路中,出于應用的需要,我們可以使用無符號數(shù),即包括0及整數(shù)的集合;也可以使用有符號數(shù),即包括0和正負數(shù)的集合。在更加復雜的系統(tǒng)中,也許這兩種類型的數(shù),我們都會用到。

有符號數(shù)通常以2的補碼形式來表示。圖1列出了4位二進制表示法所對應正負數(shù)。進一步觀察,我們發(fā)現(xiàn)兩種類型數(shù)的加減法是一樣的,做加法和減法就是 在數(shù)輪上按正時鐘轉(zhuǎn)轉(zhuǎn)或按反時鐘轉(zhuǎn)。比方說,1001+0100,意味著從1001按照順時鐘方向移動4個位置,其結果為1101。在無符號數(shù)類型中,它 代表(+9)+(+4)=+13;而在有符號數(shù)類型中,它則代表(-7)+(+4)=-3。從數(shù)輪上看,若是加法所得的結果溢出了,那么也就是穿越了數(shù)輪 的臨界點。注意這個臨界點對于無符號數(shù)和有符號數(shù)來說,是不一樣的:無符號數(shù),是介于1111和0000之間;有符號數(shù),則是介于0111和1000之 間。

物理加減法的行為正好和數(shù)輪的移動類似。只要所有的運算子和結果具有相同的位寬,那么有符號數(shù)或無符號數(shù)的形式就可用于相同的電路。比方說,設a、b和sum都是8位信號,表達式

sum = a+ b;

無論這些信號被轉(zhuǎn)譯成有符號數(shù)或無符號數(shù),它都會引用相同的硬件且使用相同的二進制表示法。這種現(xiàn)象在其他算術運算中也是正確的(但是它不可用于非算術運算中,比方說有理數(shù)運算或溢出標志位的生成)。

圖1 4位二進制數(shù)輪

此外,當運算子或其結果的位寬不同時,我們需要區(qū)分它究竟使用哪一種符號類型。因為不同的符號類型需要不同的擴展位。對于無符號數(shù),前置一個0,即 所謂的零擴展位;對于有符號數(shù)來說,需要前置n個所謂的符號擴展位。比方說4位二進制表示的-5為1011;當其擴展成8位時,應該變?yōu)?1111_1011,而不是0000_1011。

舉個例子,設a和sum為8位信號,b為4位信號即b3b2b1b0。

表達式:sum = a + b

需要將b擴展為8位。如果是無符號數(shù)形式,那么b擴展為0000_b3b2b1b0;如果是有符號數(shù)形式,那么b擴展為 b3b3b3b3_b3b2b1b0。上述表達式所引用的硬件包括位寬擴展電路和加法器。因為對于有符號數(shù)和無符號數(shù)來說,擴展電路是不同的;所以上面那 個表達式,對應有符號數(shù)和無符號數(shù)形式,要使用不同的硬件實現(xiàn)。

Verilog-1995中的有符號數(shù)

在Verilog-1995中,只有integer數(shù)據(jù)類型被轉(zhuǎn)移成有符號數(shù),而reg和wire數(shù)據(jù)類型則被轉(zhuǎn)移成無符號數(shù)。由于integer 類型有固定的32位寬,因此它不太靈活。我們通常使用手動加上擴展位來實現(xiàn)有符號數(shù)運算。

下面的代碼片段將描述有符號數(shù)和無符號數(shù)的運算:

01 reg [7:0] a, b;
02 reg [3:0] c,
03 reg [7:0] sum1, sum2, sum3, sum4;
04 . . .
05 // same width. can be applied to signed and unsigned
06 sum1 = a + b;
07 // automatica 0 extension
08 sum2 = a + c;
09 // manual 0 extension
10 sum3 = a + {4{ 1'b0 }, c};
11 // manual sign extension
12 sum4 = a + {4{c[3]}, c};

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

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

在第三條語句中,我們給c手動前置4個0,以實現(xiàn)和第二個表達式一樣的效果。

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

Verilog-2001中的有符號數(shù)

在Verilog-2001中,有符號形式也被擴展到reg和wire數(shù)據(jù)類型中。哈哈,新加一個關鍵字,signed,可以按照下面的方式定義:

reg signed [7:0] a, b;

使用有符號數(shù)據(jù)類型, 第2節(jié)所述代碼可以被改寫為:

1 reg signed [7:0] a, b;
2 reg signed [3:0] c;
3 reg signed [7:0] sum1, sum4;
4 . . .
5 // same width. can be applied to signed and unsigned
6 sum1 = a + b;
7 // automatic sign extension
8 sum4 = a + c;

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

第二條語句,所有的右手邊變量都具有signed數(shù)據(jù)類型,c被自動擴展符號位到8位。因此,無需再手動添加符號位。

在小型的數(shù)字系統(tǒng)中,我們通常可以選用有符號數(shù)或者無符號數(shù)。然而,在一些大型的系統(tǒng)中,會包括不同形式的子系統(tǒng)。Verilog是一種弱類型語 言,無符合變量和有符號變量可以在同一表達式中混用。根據(jù)Verilof的標準,只有當所有右手邊的變量具有signed數(shù)據(jù)類型屬性的時候,擴展符號位 才被執(zhí)行。否則,所有的變量都只擴展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數(shù)據(jù)類型屬性,因此右手邊的變量b和c的擴展位為0。

Verilog有兩個系統(tǒng)函數(shù),$signed和$unsigned(),用以將括號內(nèi)的表達式轉(zhuǎn)換為signed和unsigned數(shù)據(jù)類型。比方說,我們可以轉(zhuǎn)換c的數(shù)據(jù)類型,

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

現(xiàn)在,右手邊的所有變量都具有signed數(shù)據(jù)類型屬性,因此b和c將擴展符號位。

在復雜的表達式中,混用signed和unsigned數(shù)據(jù)類型將引入一些微妙的錯誤,因此應當避免混用。如果真的很有必要,那么表達式需要保持簡單,同時通用轉(zhuǎn)換函數(shù),以確保數(shù)據(jù)類型的一致性。

編輯:hfy

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Verilog
    +關注

    關注

    29

    文章

    1366

    瀏覽量

    112144
  • 數(shù)字電路

    關注

    193

    文章

    1639

    瀏覽量

    81813
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    verilog中有符號數(shù)符號數(shù)的本質(zhì)探究

    不知道有沒有人像我一樣,長久以來將verilog符號數(shù)視為不敢觸碰的禁區(qū)。
    的頭像 發(fā)表于 12-04 16:13 ?1723次閱讀
    <b class='flag-5'>verilog</b>中有<b class='flag-5'>符號數(shù)</b>和<b class='flag-5'>無</b><b class='flag-5'>符號數(shù)</b>的本質(zhì)探究

    請問AFE5801 AD轉(zhuǎn)換后數(shù)字信號是用符號數(shù)還是符號數(shù)表示的?

    請問AFE5801 AD轉(zhuǎn)換后數(shù)字信號是用符號數(shù)還是符號數(shù)表示的啊?
    發(fā)表于 02-11 07:18

    采集的數(shù)據(jù)轉(zhuǎn)換成符號數(shù)的問題

    的時候怎么都不正確,具體原因如下,字符串轉(zhuǎn)數(shù)值的時候只發(fā)現(xiàn)可以轉(zhuǎn)換成符號數(shù),而采集下來的數(shù)據(jù)是符號數(shù),轉(zhuǎn)換成
    發(fā)表于 05-02 11:55

    原碼、補碼、反碼、符號數(shù)符號數(shù)概念.pdf

    原碼、補碼、反碼、符號數(shù)符號數(shù)概念.pdf
    發(fā)表于 11-15 08:44

    符號數(shù)符號數(shù),浮點數(shù)探討

    本帖最后由 hq1987 于 2015-4-29 11:52 編輯 對于符號數(shù)大家都基本理解,我主要說說符號數(shù),浮點數(shù)在機器世界里到底是怎么表示的。1、
    發(fā)表于 04-29 10:15

    關于符號數(shù)符號數(shù)的困惑

    ,存儲符號數(shù))Tab = -4'd12;//整數(shù)Tab的十進制數(shù)為-12,位形式為110100.(因為Tab是整數(shù)寄存器變量,存儲符號數(shù))我的困惑是,-12的二進制補碼應該是101
    發(fā)表于 11-02 14:13

    請問AFE5801 AD轉(zhuǎn)換后數(shù)字信號是用符號數(shù)還是符號數(shù)表示?

    請問AFE5801 AD轉(zhuǎn)換后數(shù)字信號是用符號數(shù)還是符號數(shù)表示的啊?
    發(fā)表于 05-24 08:04

    雙狀態(tài)符號/符號數(shù)據(jù)類型

    雙狀態(tài)符號數(shù)據(jù)類型雙狀態(tài)符號數(shù)據(jù)類型四狀態(tài)數(shù)據(jù)類型
    發(fā)表于 01-18 06:03

    fpga 符號數(shù)符號數(shù)

    ?在設計,所有的算數(shù)運算符都是按照符號數(shù)進行的。如果要完成符號數(shù)計算,對于加、減操作通過補碼處理即可用
    的頭像 發(fā)表于 10-09 15:22 ?6353次閱讀
    fpga <b class='flag-5'>有</b><b class='flag-5'>符號數(shù)</b>、<b class='flag-5'>無</b><b class='flag-5'>符號數(shù)</b>

    FPGA符號數(shù)乘法操作指南

    FPGA乘法器是很稀缺的資源,但也是我們做算法必不可少的資源。7系列及之前的FPGA都是25x18的DSP,UltraScale是27x18,我們可以通過調(diào)IP Core的方式或者原語的方式來進行乘法操作。在里面可以設置
    的頭像 發(fā)表于 03-08 17:14 ?7021次閱讀
    FPGA<b class='flag-5'>有</b><b class='flag-5'>符號數(shù)</b>乘法操作指南

    詳細分析Verilog編寫程序測試符號數(shù)符號數(shù)的乘法

    符號數(shù)的計算在 Verilog 是一個很重要的問題(也很容易會被忽視),在使用 Verilog 語言編寫 FIR 濾波器時,需要涉及到
    的頭像 發(fā)表于 05-02 10:48 ?8017次閱讀
    詳細分析<b class='flag-5'>Verilog</b>編寫程序測試<b class='flag-5'>無</b><b class='flag-5'>符號數(shù)</b>和<b class='flag-5'>有</b><b class='flag-5'>符號數(shù)</b>的乘法

    C語言中符號數(shù)符號數(shù)的左移和右移

    。那么對于符號數(shù)符號數(shù),對于左移和右移的操作分別是如何呢?下面通過實驗來進行驗證:對于符號數(shù)
    發(fā)表于 01-13 13:17 ?2次下載
    C語言中<b class='flag-5'>無</b><b class='flag-5'>符號數(shù)</b>和<b class='flag-5'>有</b><b class='flag-5'>符號數(shù)</b>的左移和右移

    FPGA符號數(shù)乘法說明

    FPGA乘法器是很稀缺的資源,但也是我們做算法必不可少的資源。7系列及之前的FPGA都是25x18的DSP,UltraScale是27x18,我們可以通過調(diào)IP Core的方式或者原語的方式來進行乘法操作。在里面可以設置
    的頭像 發(fā)表于 02-16 16:21 ?5408次閱讀
    FPGA<b class='flag-5'>中</b>的<b class='flag-5'>有</b><b class='flag-5'>符號數(shù)</b>乘法說明

    關于符號數(shù)據(jù)類型的示例

    我們學習一下Systemverilog符號數(shù)據(jù)類型的賦值。
    的頭像 發(fā)表于 10-17 14:40 ?1305次閱讀

    verilog數(shù)據(jù)的符號屬性(符號數(shù)符號數(shù))探究根源

    為了省流,還是先甩結論。符號數(shù)符號數(shù)的最本質(zhì)區(qū)別就是:符號位的識別和高位拓展。除此之外,另一個區(qū)別就是從人的角度如何如何讀這個數(shù),或者
    的頭像 發(fā)表于 12-10 10:50 ?2437次閱讀
    <b class='flag-5'>verilog</b><b class='flag-5'>中</b>數(shù)據(jù)的<b class='flag-5'>符號</b>屬性(<b class='flag-5'>有</b><b class='flag-5'>符號數(shù)</b>和<b class='flag-5'>無</b><b class='flag-5'>符號數(shù)</b>)探究根源
    主站蜘蛛池模板: 夜夜操天天操 | 免费人成网址在线观看国内 | 久久这里只有精品免费播放 | 午夜毛片免费看 | 天天操夜夜操免费视频 | 亚洲人成电影院 | 亚洲 欧美 另类 综合 日韩 | 欧美一级别 | 美女露出尿囗 | 国模啪啪一区二区三区 | 午夜在线观看视频 | 国产亚洲精品aa在线观看 | 99久久免费中文字幕精品 | jiuse在线| 亚洲一区小说区中文字幕 | 久久怡红院国产精品 | 中文天堂最新版在线精品 | 亚洲区免费 | 成人狠狠色综合 | 一区二区三区四区视频在线 | 黄色美女网站免费 | 国产精品www视频免费看 | 四虎午夜剧场 | 成人精品第一区二区三区 | 女bbwxxxx非洲黑人 | 国产午夜毛片v一区二区三区 | 亚洲精品视频区 | 亚洲人成www在线播放 | 午夜国产大片免费观看 | 欧美日韩国产另类一区二区三区 | 国语一级毛片私人影院 | 日本不卡视频免费 | 六月丁香深爱六月综合激情 | bt天堂在线www种子搜索 | 国产巨大bbbb天美 | 特黄特色网站 | 亚洲韩国在线一卡二卡 | 天堂社区在线观看 | 欧美xxxxxxxxx | 日本免费网站 | 91天天干 |