版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第3章數(shù)據(jù)類型和表達式3.1數(shù)據(jù)類型3.2操作符和表達式
3.1數(shù)據(jù)類型
3.1.1常量
在程序運行過程中,其值不能被改變的量稱為常量。VerilogHDL中有三類常量:整型、實數(shù)型和字符串型。
在整型或?qū)崝?shù)型常量的任何位置可以隨意插入下劃線符號“_”(但不能作為首字符),它們就數(shù)的本身來說沒有意義,但當(dāng)數(shù)很長時,使用下劃線更易讀。
1.整型常量
整型常量就是整型數(shù),它可以按如下兩種方式書寫:
(1)簡單的十進制數(shù)格式,表示為有符號數(shù),如20、-10。
(2)基數(shù)格式,通常是無符號數(shù),這種形式的格式為
<位寬>'<進制><數(shù)字>
2.實數(shù)型常量
在VerilogHDL中,實常數(shù)的定義可以用十進制表示也可以用科學(xué)浮點數(shù)表示。
(1)十進制表示:由數(shù)字和小數(shù)點組成(必須有小數(shù)點)例如3.2、1158.29、25.8。
(2)指數(shù)格式:由數(shù)字和字符e(E)組成,e(E)的前面必須有數(shù)字而且后面必須為整數(shù)。例如:
3.字符串型常量
字符串常量用于表示需要顯示的信息,是由一對雙引號括起來的字符序列。顯示在雙引號內(nèi)的任何字符(包括空格和下劃線)都作為字符串的一部分。字符串不能分成多行書寫。例如:3.1.2變量
變量即在程序運行過程中其值可以改變的量,在VerilogHDL中變量的數(shù)據(jù)類型有很多種,其中最基本的是線網(wǎng)型(NetType)和寄存器型(RegisterType)兩種,且每種類型都有其在電路中的實際意義。這兩種數(shù)據(jù)類型中最常用的是wire型、reg型和integer型。
1.線網(wǎng)型變量
線網(wǎng)表示器件之間的物理連接,稱為線網(wǎng)類型信號,其特點是輸出的值緊跟輸入值的變化而變化。對線網(wǎng)型變量有兩種驅(qū)動方式,一種是在結(jié)構(gòu)描述中將其連接到邏輯門或模塊的輸出端;另一種方式是用持續(xù)賦值語句assign對其進行賦值。該類變量不能存儲數(shù)據(jù)。
VerilogHDL提供了多種線網(wǎng)型變量,見表3.1。在為不同工藝的基本元件建立庫模型的時候,常常需要用不同的連接類型來與之對應(yīng),使其行為與實際器件一致。線網(wǎng)型變量的語法格式為:
net_kind[msb:lsb]net1,net2,…,netN;
其中,net_kind是線網(wǎng)類型;[msb:lsb]定義線網(wǎng)寬度的最高位和最低位,此項可選,如果沒有定義寬度,則默認線網(wǎng)寬度是1位;net1,net2,…,netN是線網(wǎng)變量的名稱。可在同一個定義中聲明多個變量,例如:
wire和tri是最常用的線網(wǎng)類型,它們具有相同的語法格式和功能。wire型變量通常用來表示單個門驅(qū)動或連續(xù)賦值語句驅(qū)動的網(wǎng)絡(luò)型數(shù)據(jù),tri型變量則用來表示多驅(qū)動器驅(qū)動的網(wǎng)絡(luò)型數(shù)據(jù)。如果wire型或tri型變量沒有定義邏輯強度(logicstrength),在多個驅(qū)動源的情況下,邏輯值會發(fā)生沖突從而產(chǎn)生不確定值。如果多個驅(qū)動源驅(qū)動同一個連線(或三態(tài)線網(wǎng)),則這個線網(wǎng)的有效值可由表3.2來決定。
wire型數(shù)據(jù)常用來表示以assign關(guān)鍵字指定的組合邏輯信號。VerilogHDL程序模塊中的輸入輸出信號類型缺省時自動定義為wire型。wire型變量可以用作任何方程式的輸入,也可以用作assign語句或?qū)嵗妮敵觥?/p>
wire型變量的語法格式如下:
wire[n-1:0]數(shù)據(jù)名1,數(shù)據(jù)名2,…,數(shù)據(jù)名i;
或
wire[n:1]數(shù)據(jù)名1,數(shù)據(jù)名2,…,數(shù)據(jù)名i;其中,wire是wire型數(shù)據(jù)的確認符;[n-1:0]和[n:1]代表該數(shù)據(jù)的位寬,即該數(shù)據(jù)有幾位;數(shù)據(jù)名是變量的名字。如果一次定義多個變量,則變量名之間用逗號隔開。聲明語句的最后要用分號表示語句結(jié)束。例如:
2.寄存器型變量
寄存器是數(shù)據(jù)存儲單元的抽象,通過賦值語句可以改變寄存器內(nèi)存儲的值,其作用與改變觸發(fā)器存儲的值相當(dāng)。在設(shè)計中必須將寄存器變量放在過程語句(如initial、always)中,通過過程賦值語句賦值。在未被賦值時,寄存器的缺省值為x。
寄存器型信號或變量共有五種數(shù)據(jù)類型,見表3.3。
1)?reg型變量
reg型是最常用的寄存器類型。reg類型數(shù)據(jù)的缺省初始值為不定值x。它只能存儲無符號數(shù)。
reg型變量的語法格式如下:
reg[n-1:0]數(shù)據(jù)名1,數(shù)據(jù)名2,…,數(shù)據(jù)名i;
或
reg[n:1]數(shù)據(jù)名1,數(shù)據(jù)名2,…,數(shù)據(jù)名i;其中,reg是reg型數(shù)據(jù)的確認標識符;[n-1:0]和[n:1]代表該數(shù)據(jù)的位寬,即該數(shù)據(jù)有幾位(bit)。數(shù)據(jù)名是變量的名字,如果一次定義多個變量,變量名之間用逗號隔開。聲明語句的最后要用分號表示語句結(jié)束。例如:
2)?integer寄存器型變量
integer型是整數(shù)寄存器,也是VerilogHDL中常用的變量類型。這種寄存器用于存儲整數(shù)值,并且可以存儲帶符號數(shù)。integer型的定義形式如下:
integerinteger1,integer2,…integerN[msb:lsb];
其中,integer1,integer2,…integerN是整數(shù)寄存器名;msb和lsb是定義整數(shù)數(shù)組界限的常量,數(shù)組界限的定義是可選的。例如:
3)?time型變量
time類型的寄存器用于存儲和處理時間。time型變量的語法格式如下:
time
time_id1,time_id2,…,time_idN[msb:1sb];
例如:
time
Events[31:0]; //時間值數(shù)組
time
CurrTime; //CurrTime存儲一個時間值
4)?real和realtime型變量
real是實數(shù)寄存器型變量;realtime是實數(shù)型時間寄存器,一般用于在測試模塊中存儲仿真時間。它們的語法格式如下:
realreal_reg1,real_reg2,…,real_regN;
realtime
realtime_reg1,realtime_reg2,…,realtime_regN;
例如:
real
Swing,Top; //實數(shù)變量
3.2操作符和表達式
3.2.1操作符
VerilogHDL提供了豐富的操作符,按功能可分為算術(shù)操作符、位操作符、歸約操作符、邏輯操作符、關(guān)系操作符、相等與全等操作符、移位操作符、連接與復(fù)制操作符和條件操作符等9類;如果按操作符所帶操作數(shù)的個數(shù)來區(qū)分,操作符可分為3類,即單目操作符(可帶一個操作數(shù))、雙目操作符(可帶兩個操作數(shù))和三目操作符(可帶三個操作數(shù))。例如:
1.算術(shù)操作符
常用的算術(shù)操作符主要有5種:+?(加法操作符),如c+d,+4;-?(減法操作符),如a-b,-a;*?(乘法操作符),如a*5;/?(除法操作符),如c/d;%?(取模操作符),如8%3的值是2。
例如:
1)算術(shù)操作結(jié)果的長度
算術(shù)表達式結(jié)果的長度由最長的操作數(shù)決定。在賦值語句下,算術(shù)操作結(jié)果的長度由操作符左端的賦值目標的長度決定。例如:在第一個語句賦值中,加法操作的溢出部分被丟棄;在第二個賦值語句中,任何溢出的位存儲在結(jié)果位Frx[1]中。在較長的表達式中,中間結(jié)果的長度如何確定?在VerilogHDL中定義了如下規(guī)則:表達式中的所有中間結(jié)果的長度應(yīng)取最大操作數(shù)的長度(賦值時,此規(guī)則也包括左端目標)。例如:
2)無符號數(shù)和有符號數(shù)
執(zhí)行算術(shù)操作和賦值時,區(qū)分無符號數(shù)和有符號數(shù)是非常重要的。無符號數(shù)存儲在線網(wǎng)、一般寄存器和基數(shù)形式表示的整數(shù)中。有符號數(shù)存儲在整數(shù)寄存器和十進制形式表示的整數(shù)中。例如:例如:算術(shù)操作符應(yīng)用舉例。
2.位操作符
位操作符是對操作數(shù)按位進行與、或、非等邏輯操作,分別如下:
~(一元非)——單目操作符,相當(dāng)于非門操作;
&(二元與)——雙目操作符,相當(dāng)于與門操作;
|(二元或)——雙目操作符,相當(dāng)于或門操作;
^(二元異或)——雙目操作符,相當(dāng)于異或門操作;
~^,^~?(二元異或非)——雙目操作符,相當(dāng)于同或門操作。
這些操作符在兩個操作數(shù)的對應(yīng)位上按位進行邏輯操作,并產(chǎn)生結(jié)果。
1)?~(取反)操作符
~?是一個單目操作符,用來對一個操作數(shù)進行按位取反運算,其運算規(guī)則見表3.6。
2)
&(按位與)操作符
按位與操作就是將兩個操作數(shù)的相應(yīng)位進行與運算,其運算規(guī)則見表3.7。
3)?|(按位或)操作符
按位或操作就是將兩個操作數(shù)的相應(yīng)位進行或運算,其運算規(guī)則見表3.8。
4)^(按位異或)操作符
按位異或操作就是將兩個操作數(shù)的相應(yīng)位進行異或運算,其運算規(guī)則見表3.9。
5)?^~(按位異或非)操作符
按位異或非操作就是將兩個操作數(shù)的相應(yīng)位先進行異或運算再進行非運算,其運算規(guī)則見表3.10。
3.歸約操作符
歸約操作符是單目操作符,對操作數(shù)逐位進行運算,運算的結(jié)果是一位邏輯值。歸約操作符有6種:
&(歸約與)——如果存在位值為0,那么結(jié)果為0;如果存在位值為x或z,則結(jié)果為x;否則結(jié)果為1。
~&(歸約與非)——與歸約操作符&相反。
|(歸約或)——如果存在位值為1,那么結(jié)果為1;如果存在位值為x或z,則結(jié)果為x;否則結(jié)果為0。
~|(歸約或非)——與歸約操作符?|?相反。
^(歸約異或)——如果存在位值為x或z,那么結(jié)果為x;如果操作數(shù)中有偶數(shù)個1,則結(jié)果為0;否則結(jié)果為1。
~^(歸約異或非)——與歸約操作符?^?相反。
4.邏輯操作符
邏輯操作符是對操作數(shù)做與、或、非操作,這些操作符在邏輯值0或1上操作。操作結(jié)果為0或1,邏輯操作符有3種:&&(邏輯與)、||?(邏輯或)、!?(邏輯非)。
5.關(guān)系操作符
關(guān)系操作符是對兩個操作數(shù)進行比較,比較結(jié)果為真,則結(jié)果為1;比較結(jié)果為假,則結(jié)果為0。關(guān)系操作符有4種:>(大于)、<(小于)、>=(不小于)和<=(不大于)。
6.相等與全等操作符
相等與全等操作符和關(guān)系操作符類似,也是對兩個操作數(shù)進行比較,如果比較結(jié)果為假,則結(jié)果為0,否則結(jié)果為1。這類操作符有4種:==(邏輯相等)、!=(邏輯不等)、===(全等)和!==(非全等)。其中,“===”和“!==”嚴格按位進行比較,把不定態(tài)(x)和高阻態(tài)(z)看做邏輯狀態(tài)進行比較,比較結(jié)果不存在不定態(tài),一定是1或0。而“==”和“!=”是把兩個操作數(shù)的邏輯值做比較,值x和z具有通常的意義,如果兩個操作數(shù)之一包含x或z,則結(jié)果為未知的值(x)。
7.移位操作符
移位操作符是把操作數(shù)向左或向右移若干位。移位操作符有兩種:<<(左移)、>>(右移)。
移位操作符有兩個操作數(shù),右側(cè)操作數(shù)表示的是左側(cè)操作數(shù)所移動的位數(shù)。它是一個邏輯移位,空閑位添0補位。如果右側(cè)操作數(shù)的值為x或z,則移位操作的結(jié)果為x。
8.連接和復(fù)制操作符
連接操作是將多組信號用大括號括起來,拼接成一組新信號。其表示形式如下:
{expr1,expr2,…,exprN}
其中,expr1,expr2,…,exprN是若干個小表達式。
9.條件操作符
條件操作符是VerilogHDL中唯一的三目操作符,它根據(jù)條件表達式的值選擇表達式,其表示形式如下:
cond_expr?expr1:expr2
其中,如果cond_expr為真(即值為1),則選擇expr1;如果cond_expr為假(值為0),則選擇expr2。如果cond_expr為x或z,則結(jié)果是將兩個待選擇的表達式進行計算,然后把兩個計算結(jié)果按位進行運算得到最終結(jié)果,按位運算的原則是,如果兩個表達式的某一位都為1,則這一位的最終結(jié)果是1;如果都是0,則這一位的結(jié)果是0;否則結(jié)果為x。3.2.2操作數(shù)
1.常數(shù)
前面已講述了常量的書寫方式,下面舉例說明。表達式中的整數(shù)值可解釋為有符號數(shù)或無符號數(shù)。如果表達式中是十進制整數(shù),那么該整數(shù)就是有符號數(shù),例如,12被解釋為有符號數(shù)。如果整數(shù)是基數(shù)型整數(shù)(定長或非定長),那么該整數(shù)作為無符號數(shù)對待。例如:
2.參數(shù)
前一章中已對參數(shù)作了介紹。參數(shù)類似于常量,表達式中出現(xiàn)的參數(shù)都作為常數(shù)對待。參數(shù)就是用某標識符代表某個數(shù)或字符串的,使用參數(shù)聲明進行說明,在定義時給它賦值,程序中出現(xiàn)這個參數(shù)時將被替換為它所代表的常數(shù)值。例如:
3.線網(wǎng)
可在表達式中使用標量線網(wǎng)(1位)和向量線網(wǎng)(多位)。例如:
wire[0:3]Prt; //Prt為4位向量線網(wǎng)
wireBdq; //Bbq是標量線網(wǎng)
線網(wǎng)中的值被解釋為無符號數(shù)。在連續(xù)賦值語句中,如果賦給線網(wǎng)負值,則通常會被系統(tǒng)當(dāng)作正值對待。例如:
assignPrt=-3; //Prt被賦予位向量1101(-3的補碼),為十進制的13
assignPrt=4'HA; //Prt被賦予位向量1010,即十進制的10
4.寄存器
寄存器是在表達式中出現(xiàn)最多的操作數(shù),許多程序語句都是通過對寄存器中存儲的值進行轉(zhuǎn)換和傳輸來實現(xiàn)其設(shè)計目的的。
一位寄存器為標量,多位寄存器為向量;標量和向量寄存器都可在表達式中使用。整型寄存器中的值被解釋為有符號的二進制補碼,而reg型寄存器和時間寄存器中的值被解釋為無符號數(shù)。實數(shù)和實數(shù)時間類型寄存器中的值被解釋為有符號浮點數(shù)。例如:
5.位選擇
位選擇從向量中抽取特定的位,即表達式的操作數(shù)可以是線網(wǎng)或寄存器的某個位。其表示形式如下:
net_or_reg_vector[bit_select_expr]
其中,net_or_reg_vector是向量線網(wǎng)或寄存器名,bit_select_expr是要選擇位的編號。例如:
State[1]&&State[4] //寄存器位選擇,State[1]和State[4]進行邏輯與操作
Prt[0]|Bbq //線網(wǎng)位選
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024門禁工程合同
- 2024閘門采購合同模板大全
- 2024榨菜種植與農(nóng)業(yè)電商人才培訓(xùn)合作合同3篇
- 2025年度文化旅游代理股權(quán)轉(zhuǎn)讓及項目運營合同4篇
- 2025年度智能社區(qū)視頻監(jiān)控系統(tǒng)工程承包協(xié)議4篇
- 2025年度應(yīng)急物流承運商合作協(xié)議范本4篇
- 2024音樂制作合同:錄音工作室合同范本版B版
- 2025年度桉樹苗木線上線下融合發(fā)展合同3篇
- 2025年度知識產(chǎn)權(quán)運營丨合伙人共同運營專利技術(shù)的合同4篇
- 2024舞臺建設(shè)施工合同協(xié)議書
- 2024版智慧電力解決方案(智能電網(wǎng)解決方案)
- 公司SWOT分析表模板
- 小學(xué)預(yù)防流行性感冒應(yīng)急預(yù)案
- 肺癌術(shù)后出血的觀察及護理
- 聲紋識別簡介
- 生物醫(yī)藥大數(shù)據(jù)分析平臺建設(shè)-第1篇
- 基于Android的天氣預(yù)報系統(tǒng)的設(shè)計與實現(xiàn)
- 沖鋒舟駕駛培訓(xùn)課件
- 美術(shù)家協(xié)會會員申請表
- 聚合收款服務(wù)流程
- 中石化浙江石油分公司中石化溫州靈昆油庫及配套工程項目環(huán)境影響報告書
評論
0/150
提交評論