欧美性猛交xxxx免费看_牛牛在线视频国产免费_天堂草原电视剧在线观看免费_国产粉嫩高清在线观看_国产欧美日本亚洲精品一5区

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

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

Verilog中的基本數(shù)據(jù)類型

CHANBAEK ? 來(lái)源:FPGA入門到精通 ? 作者:未可知摩爾 ? 2023-05-12 17:43 ? 次閱讀

本文將討論 verilog 中常用的數(shù)據(jù)類型,包括對(duì)數(shù)據(jù)表示、線網(wǎng)類型、變量類型和數(shù)組,分享一下使用方法和注意事項(xiàng)。

一、Verilog 中的數(shù)值表示

編寫(xiě) verilog代碼 時(shí),經(jīng)常需要在代碼中表示數(shù)據(jù)值,可以將這些數(shù)據(jù)表示為2進(jìn)制、8進(jìn)制、10進(jìn)制或16進(jìn)制值。

特別是verilog中需要定義數(shù)據(jù)的位寬,因?yàn)関erilog 本質(zhì)上是在描述硬件電路。

語(yǔ)法:


說(shuō)明:

  • bits:位寬,可省略,則默認(rèn)是32bit
  • representation:進(jìn)制, b或B表示2進(jìn)制,o或O表示8進(jìn)制,d或D表示10進(jìn)制,h或H表示16進(jìn)制,可省略,則默認(rèn)是十進(jìn)制?
  • value :具體數(shù)值

示例:

8'b1000_1000;    //2進(jìn)制表示
4'o10;      //8進(jìn)制表示
4'd8;       //10進(jìn)制表示
4'h8;       //十六進(jìn)制表示

每一個(gè)bit位不同值表示:

二、Verilog 中的基本數(shù)據(jù)類型

verilog 中的基本數(shù)據(jù)類型可以分為兩大類:線網(wǎng)類型(net)和變量類型(variable )

net類型用來(lái)對(duì)數(shù)字電路中的連接關(guān)系建模,無(wú)法存儲(chǔ)數(shù)值,表示數(shù)據(jù)驅(qū)動(dòng)路線。

variable類型用來(lái)對(duì)寄存器或觸發(fā)器建模,可以存儲(chǔ)數(shù)據(jù)。

1、Verilog 中的net類型

用來(lái)描述設(shè)計(jì)中不同組件之間的物理連接,net類型本身不能用于存儲(chǔ)數(shù)據(jù)或驅(qū)動(dòng)數(shù)據(jù)。

通常使用連續(xù)賦值(continuous assignment)語(yǔ)句來(lái)將數(shù)據(jù)驅(qū)動(dòng)到線型(wire)上,如assign 語(yǔ)句。

verilog 中最常用的net類型就是wire類型。 使用wire類型來(lái)聲明設(shè)計(jì)中基本的點(diǎn)對(duì)點(diǎn)連接信號(hào),顧名思義,它們大致相當(dāng)于傳統(tǒng)電路中的電線(wire英文原意)。

wire a;          //聲明一個(gè)1位寬wire類型信號(hào)a
 
assign a = c;    //使用assign關(guān)鍵字來(lái)賦值
assign b = d;    //使用assign關(guān)鍵字來(lái)賦值

2、Verilog 中的變量類型

verilog 中使用變量類型來(lái)存儲(chǔ)數(shù)據(jù),可以一直保持這個(gè)值直到被再次賦值。

verilog中最常用的變量類型是reg類型,用于always語(yǔ)句塊內(nèi),如下面的代碼片段所示,實(shí)現(xiàn)了一個(gè)D觸發(fā)器。

reg q;
//D觸發(fā)器
always @(posedge clock)
  q <= d;
end

雖然reg 類型常被用來(lái)建模觸發(fā)器,但在某些情況下,reg 類型也可用于在 verilog 中對(duì)組合邏輯進(jìn)行建模。

reg q;
always @(*)
  q = d;
end

verilog 中最常用的數(shù)值數(shù)據(jù)類型是integer類型。 但是,integer類型通常用于模塊中的內(nèi)部信號(hào)而不是端口。

注意:integer默認(rèn)是32bit的有符號(hào)數(shù)。

integer a = 255;    //聲明一個(gè)值為255的integer類型變量a

3、Verilog 中的有符號(hào)(Signed)和無(wú)符號(hào)數(shù)據(jù)(Unsigned)

Verilog-2001 標(biāo)準(zhǔn)引入了signed 和 unsigned關(guān)鍵字,在Verilog-2001標(biāo)準(zhǔn)發(fā)布之前,所有net類型和variable類型都只能用于存儲(chǔ)無(wú)符號(hào)(Unsigned)數(shù)據(jù)類型。

默認(rèn)情況下,integer類型是有符號(hào)的,而 reg 和 wire 類型都是無(wú)符號(hào)的。 如果希望修改此默認(rèn)行為,則需要使用這些關(guān)鍵字(signed 和 unsigned),在 verilog 代碼中將變量類型聲明為signed時(shí),會(huì)是補(bǔ)碼。

示例:

//聲明無(wú)符號(hào)reg變量a、有符號(hào)reg變量b
reg [31:0] a;
reg signed [31:0] b;
 
//聲明無(wú)符號(hào)wire變量a、有符號(hào)wire變量b
wire [31:0] a;
wire signed [31:0] b;
 
//聲明無(wú)符號(hào)integer變量a、有符號(hào)integer變量b
integer unsigned a;
integer b;

4、Verilog 中的數(shù)組(Arrays )

在 verilog 中可以創(chuàng)建和使用Arrays(數(shù)組)類型,在FPGA中實(shí)際是使用LUT或BRAM來(lái)實(shí)現(xiàn)的。

(1)一維數(shù)組

語(yǔ)法:


說(shuō)明:

  • type表示數(shù)組元素的類型
  • size表示數(shù)據(jù)元素的位寬大小
  • variable_name表示數(shù)組名稱
  • elements是表示數(shù)組的大小

示例:

//定義一個(gè)共有8個(gè)元素的數(shù)組example,每個(gè)元素的位寬為3位
wire [2:0] example [7:0];

可以使用帶有數(shù)組下標(biāo)的方括號(hào)來(lái)訪問(wèn)數(shù)組中的單個(gè)元素,如:

//將5賦值給數(shù)組example中的最后一個(gè)元素
assign example[7] = 3'h5;

(2)多維數(shù)組

在Verilog-1995標(biāo)準(zhǔn)中,只能創(chuàng)建一維數(shù)組。 verilog 2001 標(biāo)準(zhǔn)則可以創(chuàng)建多于一維的數(shù)組。 為此,只需添加另一個(gè)字段來(lái)定義需要的元素?cái)?shù)量。

語(yǔ)法:


說(shuō)明:

  • type表示數(shù)組元素的類型
  • size表示數(shù)據(jù)元素的位寬大小
  • variable_name表示數(shù)組名稱
  • elements0是表示數(shù)組第一層的大小
  • elements1表示數(shù)組第二層的大小

示例:

wire [3:0] example2d [7:0][1:0];
//賦值操作
assign example2d [7][1] = 4'ha;
assign example2d [7][0] = 4'ha;

verilog數(shù)組還是挺好用的,可以用于簡(jiǎn)化寫(xiě)代碼的邏輯,適用于循環(huán)復(fù)制的模塊或代碼。

genvar i;
wire [1:0] data_in [0:4];
wire [1:0] data_out [0:4];

generate
for(i = 0; i < 5; i = i + 1) begin: module_test
     mod_test u_mod_test(
        .clk(clk),
        .reset(reset),
        .data_in(data_in[i]),
        .data_out(data_out[i])
     );
end
endgenerate

integer j;
reg  [2:0] shift_add_index [0:8];

always@(posedge clk) begin
     shift_add_index[0] <= 'd2;
end

always@(posedge clk) begin
     for(j = 1; j < 9; j = j+1) begin
         shift_add_index[j] <= shift_add_index[j-1] + j;
     end
end
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5368

    瀏覽量

    121241
  • Verilog
    +關(guān)注

    關(guān)注

    28

    文章

    1352

    瀏覽量

    110434
  • 數(shù)值
    +關(guān)注

    關(guān)注

    0

    文章

    80

    瀏覽量

    14411
  • 觸發(fā)器
    +關(guān)注

    關(guān)注

    14

    文章

    2017

    瀏覽量

    61372
  • 數(shù)據(jù)類型
    +關(guān)注

    關(guān)注

    0

    文章

    236

    瀏覽量

    13667
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    C語(yǔ)言中的基本數(shù)據(jù)類型

    C語(yǔ)言是非常重要的一門程序設(shè)計(jì)語(yǔ)言,學(xué)好C語(yǔ)言再去學(xué)習(xí)其他編程語(yǔ)言將變得很輕松,因?yàn)榇蟛糠终Z(yǔ)言的都有相同的共性存在。本節(jié)我們來(lái)講解一下C語(yǔ)言中的基本數(shù)據(jù)類型,掌握如何使用變量以及變量在編程的作用及重要性,學(xué)會(huì)區(qū)分變量的存儲(chǔ)類型
    發(fā)表于 04-26 17:33 ?2109次閱讀
    C語(yǔ)言中的基<b class='flag-5'>本數(shù)據(jù)類型</b>

    C語(yǔ)言中基本數(shù)據(jù)類型、變量和常量的使用

    C語(yǔ)言中基本數(shù)據(jù)類型、變量和常量的使用
    發(fā)表于 08-18 16:42 ?2927次閱讀
    C語(yǔ)言中基<b class='flag-5'>本數(shù)據(jù)類型</b>、變量和常量的使用

    技術(shù)干貨驛站 ▏深入理解C語(yǔ)言:基本數(shù)據(jù)類型和變量

    在C語(yǔ)言中,數(shù)據(jù)類型和變量是編程的基礎(chǔ),也是理解更復(fù)雜概念的關(guān)鍵。數(shù)據(jù)類型決定了變量的內(nèi)存分配、存儲(chǔ)范圍和操作方式,而變量則是存儲(chǔ)數(shù)據(jù)的容器。本篇文章將從基本數(shù)據(jù)類型和變量?jī)蓚€(gè)方面,帶
    的頭像 發(fā)表于 07-26 17:53 ?2273次閱讀
    技術(shù)干貨驛站 ▏深入理解C語(yǔ)言:基<b class='flag-5'>本數(shù)據(jù)類型</b>和變量

    Java基本數(shù)據(jù)類型之間的運(yùn)算規(guī)則是什么?

    Java基本數(shù)據(jù)類型Java變量的使用說(shuō)明Java基本數(shù)據(jù)類型之間的運(yùn)算規(guī)則
    發(fā)表于 11-04 09:59

    C語(yǔ)言的基本數(shù)據(jù)類型包括哪幾種

    C語(yǔ)言的基本數(shù)據(jù)類型包括哪幾種?分別是什么?
    發(fā)表于 10-14 12:27

    淺析C51的基本數(shù)據(jù)類型和擴(kuò)充數(shù)據(jù)類型

    本數(shù)據(jù)類型:擴(kuò)充數(shù)據(jù)類型
    發(fā)表于 11-22 06:05

    C預(yù)處理與C語(yǔ)言基本數(shù)據(jù)類型

    指令表:注意:宏名的書(shū)寫(xiě)由標(biāo)識(shí)符與兩邊各兩條下劃線構(gòu)成。C語(yǔ)言基本數(shù)據(jù)類型不同操作系統(tǒng)數(shù)據(jù)類型所占字節(jié)數(shù)圖解數(shù)據(jù)類型的其他分類:變量常量(字面量和const常量)void(特殊
    發(fā)表于 12-21 08:29

    Java的基本數(shù)據(jù)類型與條件結(jié)構(gòu)

    《Java基礎(chǔ)入門》第二篇1 基本數(shù)據(jù)類型,運(yùn)算符與表達(dá)式,條件結(jié)構(gòu),循環(huán)結(jié)構(gòu)...
    發(fā)表于 12-23 08:02

    單片機(jī)C語(yǔ)言中常用的基本數(shù)據(jù)類型分為哪幾類

    不管在什么語(yǔ)言中,定義一個(gè)變量時(shí)必然要在內(nèi)存開(kāi)辟一個(gè)相應(yīng)大小的空間來(lái)存儲(chǔ)該變量。不同的數(shù)據(jù)類型在內(nèi)存所占的空間大小不同,其所能表示的數(shù)據(jù)范圍也不相同。在單片機(jī)C語(yǔ)言中,常用的基本數(shù)據(jù)類型
    發(fā)表于 02-28 06:46

    51單片機(jī)學(xué)習(xí)筆記(9)——C51的基本數(shù)據(jù)類型和擴(kuò)充數(shù)據(jù)類型

    本數(shù)據(jù)類型:擴(kuò)充數(shù)據(jù)類型
    發(fā)表于 11-14 13:36 ?1次下載
    51單片機(jī)學(xué)習(xí)筆記(9)——C51的基<b class='flag-5'>本數(shù)據(jù)類型</b>和擴(kuò)充<b class='flag-5'>數(shù)據(jù)類型</b>

    Struct結(jié)構(gòu)數(shù)據(jù)類型

    Struct類型是一種由多個(gè)不同數(shù)據(jù)類型元素組成的數(shù)據(jù)結(jié)構(gòu),其元素可以是基本數(shù)據(jù)類型,也可以是Struct、數(shù)組等復(fù)雜數(shù)據(jù)類型以及PLC
    的頭像 發(fā)表于 07-25 17:02 ?3095次閱讀

    C語(yǔ)言-基本數(shù)據(jù)類型與位運(yùn)算

    這篇文章作為基礎(chǔ)知識(shí)點(diǎn),總結(jié)C語(yǔ)言的基本數(shù)據(jù)類型有哪些,浮點(diǎn)數(shù)的精度,整數(shù)變量的空間范圍,變量定義語(yǔ)法,變量命名規(guī)則,浮點(diǎn)數(shù)打印格式,基本數(shù)據(jù)類型printf對(duì)應(yīng)的打印、位運(yùn)算的知識(shí)點(diǎn)。
    的頭像 發(fā)表于 08-14 09:56 ?1641次閱讀

    Verilog最常用的2種數(shù)據(jù)類型

    Verilog 最常用的 2 種數(shù)據(jù)類型就是線網(wǎng)(wire)與寄存器(reg),其余類型可以理解為這兩種數(shù)據(jù)類型的擴(kuò)展或輔助。
    的頭像 發(fā)表于 05-29 16:27 ?2471次閱讀
    <b class='flag-5'>Verilog</b>最常用的2種<b class='flag-5'>數(shù)據(jù)類型</b>

    本數(shù)據(jù)類型分享

    本數(shù)據(jù)類型本數(shù)據(jù)類型:包括位、位序列、整數(shù)、浮點(diǎn)數(shù)、日期時(shí)間。此外字符也屬于基本數(shù)據(jù)類型,請(qǐng)參見(jiàn)文檔String與WString。 1.位和位序列 2.整數(shù)數(shù)據(jù)類型 3.浮點(diǎn)型實(shí)
    的頭像 發(fā)表于 06-13 14:14 ?1w次閱讀
    基<b class='flag-5'>本數(shù)據(jù)類型</b>分享

    javascript的基本數(shù)據(jù)類型有哪些

    JavaScript 是一種動(dòng)態(tài)的、面向?qū)ο蟮木幊陶Z(yǔ)言,廣泛應(yīng)用于 Web 開(kāi)發(fā)。在 JavaScript ,有七種基本數(shù)據(jù)類型(Primitive Types),它們分別是 Undefined
    的頭像 發(fā)表于 12-03 11:17 ?837次閱讀