99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

3天內不再提示

verilog的signed類型有哪些?

汽車玩家 ? 來源:博客園 ? 作者:lianjiehere ? 2020-01-30 09:52 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

有符號數(shù)通常以2的補碼形式來表示。圖1列出了4位二進制表示法所對應正負數(shù)。進一步觀察,我們發(fā)現(xiàn)兩種類型數(shù)的加減法是一樣的,做加法和減法就是 在數(shù)輪上按正時鐘轉轉或按反時鐘轉。比方說,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;

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

verilog的signed類型有哪些

圖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ù)類型被轉移成有符號數(shù),而reg和wire數(shù)據(jù)類型則被轉移成無符號數(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有相同的位寬,因此無論是轉譯成有符號數(shù)還是無符號數(shù),它都將引用相同的加法器電路。

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

在第三條語句中,我們給c手動前置4個0,以實現(xià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)中,我們通??梢赃x用有符號數(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(),用以將括號內的表達式轉換為signed和unsigned數(shù)據(jù)類型。比方說,我們可以轉換c的數(shù)據(jù)類型,

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

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

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

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

    關注

    29

    文章

    1367

    瀏覽量

    112286
  • 數(shù)字電路

    關注

    193

    文章

    1639

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    聲音芯片哪些類型和型號

    。下面小編就按照不同類型來給大家介紹各種類型語音芯片和型號。 ? 一、OTP語音芯片 OTP語音芯片是一次性編程語音芯片,主要應用于一些純播放類的需求和設備,播放時長6s/20s/40s/80s/170s等,以WTN6系列的O
    的頭像 發(fā)表于 07-03 17:09 ?206次閱讀
    聲音芯片<b class='flag-5'>有</b>哪些<b class='flag-5'>類型</b>和型號

    尋找verilog高手,報酬

    我采集了一塊電路板正常工作時的數(shù)據(jù),基于這些數(shù)據(jù)我想用EPM7128slc84-15(sys_clk:50Mhz)測試電路板,尋求一位verilog高手,有償
    發(fā)表于 03-08 16:31

    驅動器哪些類型

    類型之一。它適用于高速、高精度加工,如銑削、雕刻、線切割等應用場合。伺服電機驅動器多種類型,如模擬式伺服驅動器、數(shù)字式伺服驅動器等,其中數(shù)字式伺服驅動器具有更高的控制精度和穩(wěn)定性?12。 ?步進電機驅動器?:步
    的頭像 發(fā)表于 02-23 15:50 ?1051次閱讀

    分布式存儲哪幾種類型?

    分布式存儲哪幾種類型?分布式存儲系統(tǒng)是一種將數(shù)據(jù)分散存儲在多臺獨立節(jié)點上的技術,根據(jù)數(shù)據(jù)模型可分為鍵值存儲、列式存儲、文檔存儲和圖形存儲等類型;按數(shù)據(jù)存儲單位可分為基于文件、塊和對象的存儲;按
    的頭像 發(fā)表于 02-20 11:00 ?584次閱讀

    Verilogsigned和$signed()的用法

    1、在verilog中有時會用signed修飾符來修飾定義的數(shù)據(jù),運算的時候也會用$signed()任務來強制轉換數(shù)據(jù),那么signed的修飾是為什么呢,是為了區(qū)分
    的頭像 發(fā)表于 02-17 17:47 ?657次閱讀
    <b class='flag-5'>Verilog</b>中<b class='flag-5'>signed</b>和$<b class='flag-5'>signed</b>()的用法

    Verilog 與 ASIC 設計的關系 Verilog 代碼優(yōu)化技巧

    Verilog與ASIC設計的關系 Verilog作為一種硬件描述語言(HDL),在ASIC設計中扮演著至關重要的角色。ASIC(Application Specific Integrated
    的頭像 發(fā)表于 12-17 09:52 ?1042次閱讀

    Verilog 測試平臺設計方法 Verilog FPGA開發(fā)指南

    Verilog測試平臺設計方法是Verilog FPGA開發(fā)中的重要環(huán)節(jié),它用于驗證Verilog設計的正確性和性能。以下是一個詳細的Verilog測試平臺設計方法及
    的頭像 發(fā)表于 12-17 09:50 ?1146次閱讀

    Verilog與VHDL的比較 Verilog HDL編程技巧

    Verilog 與 VHDL 比較 1. 語法和風格 VerilogVerilog 的語法更接近于 C 語言,對于 C 語言背景的工程師來說,學習曲線較平緩。它支持結構化編程,代
    的頭像 發(fā)表于 12-17 09:44 ?1705次閱讀

    如何自動生成verilog代碼

    介紹幾種自動生成verilog代碼的方法。
    的頭像 發(fā)表于 11-05 11:45 ?1033次閱讀
    如何自動生成<b class='flag-5'>verilog</b>代碼

    Verilog硬件描述語言參考手冊

    一. 關于 IEEE 1364 標準二. Verilog簡介三. 語法總結四. 編寫Verilog HDL源代碼的標準五. 設計流程
    發(fā)表于 11-04 10:12 ?4次下載

    system verilog語言簡介

    ICer需要System Verilog語言得加成,這是ICer深度的表現(xiàn)。
    發(fā)表于 11-01 10:44 ?0次下載

    Verilog HDL的基礎知識

    本文繼續(xù)介紹Verilog HDL基礎知識,重點介紹賦值語句、阻塞與非阻塞、循環(huán)語句、同步與異步、函數(shù)與任務語法知識。
    的頭像 發(fā)表于 10-24 15:00 ?1199次閱讀
    <b class='flag-5'>Verilog</b> HDL的基礎知識

    如何利用Verilog-A開發(fā)器件模型

    Verilog-A對緊湊型模型的支持逐步完善,在模型的實現(xiàn)上扮演越來越重要的角色,已經成為緊湊模型開發(fā)的新標準。而且Verilog-A能夠在抽象級別和應用領域中擴展SPICE建模和仿真功能,因此學會
    的頭像 發(fā)表于 10-18 14:16 ?1354次閱讀
    如何利用<b class='flag-5'>Verilog</b>-A開發(fā)器件模型

    FPGA Verilog HDL什么奇技巧?

    今天給大俠帶來在FPAG技術交流群里平時討論的問題答疑合集(九),以后還會多推出本系列,話不多說,上貨。 交流問題(一) Q:Verilog 什么奇技淫巧? A:在 Verilog 中,以下這些
    發(fā)表于 09-12 19:10

    總線異步通信幾種聯(lián)絡類型

    的靈活性和擴展性。 在總線異步通信中,多種聯(lián)絡類型,每種類型都有其特定的應用場景和特點。以下是對這些聯(lián)絡類型的介紹: 單工通信 單工通信是一種最基本的通信方式,它只允許數(shù)據(jù)在一個方向
    的頭像 發(fā)表于 07-23 09:21 ?956次閱讀