《電子技術應用》
您所在的位置:首頁 > EDA與制造 > 設計應用 > VHDL設計中信號與變量的區別及賦予初始值的技巧
VHDL設計中信號與變量的區別及賦予初始值的技巧
摘要: 在VHDL程序設計中,可以充分利用信號或變量的系統默認值,來靈活實現設計目標。本文從應用的角度舉例說明了VHDL設計中信號與變量的區別,以及正確的使用方法,并介紹了為信號或變量賦予初始值的技巧。
Abstract:
Key words :

     在VHDL程序設計中,可以充分利用信號變量的系統默認值,來靈活實現設計目標。本文從應用的角度舉例說明了VHDL設計中信號與變量的區別,以及正確的使用方法,并介紹了為信號或變量賦予初始值的技巧。

  概述
  隨著集成電路技術的發展,用傳統的方法進行芯片或系統設計已不能滿足要求,迫切需要提高設計效率,因此能大大降低設計難度的VHDL設計方法被越來越廣泛地采用。用VHDL語言設計系統的主要方法是:設計者根據VHDL的語法規則,對系統目標的邏輯行為進行描述,然后通過綜合工具進行電路結構的綜合、編譯、優化,通過仿真工具進行邏輯功能仿真和系統時延的仿真,最后把設計的程序下載到芯片中,成功地實現系統功能。
  在VHDL設計中,最常用的數據對象主要有三種:信號(signal)、變量(variable)和常數(constant)。信號是電子電路內部硬件連接的抽象。它除了沒有數據流動方向說明以外,其他性質幾乎和“端口”一樣;信號是一個全局量,它可以用來進行進程之間的通信。變量只能在進程語句、函數語句和過程語句結構中使用,是一個局部量。
  在VHDL語言中,對信號賦值是按仿真時間進行的,到了規定的仿真時間才進行賦值,而變量的賦值是立即發生的。下面的例子是從賦初值的角度說明信號與變量的這種區別的。
 
  例如用VHDL語言實現初值為A的十六進制的16個數的循環顯示。
 
  對于如此的設計要求,如果用變量實現,則VHDL程序如下。
 
  library ieee;
 
  use ieee.std_logic_1164.all;
 
  use ieee.std_logic_unsigned.all;
 
  entity sevenauto is
 
  port(clk:in std_logic;
 
  y:out std_logic_vector(6 downto 0));
 
  end sevenauto;
 
  architecture behave of sevenauto is
 
  begin
 
  process(clk)
 
  variable count:std_logic_vector(3 downto 0);
 
  variable init:std_logic;
 
  begin
 
  if (clk''event) and (clk=''1'') then
 
  if (init = ''0'') then
 
  count:= "1001";
 
  init:=''1'
 
  end if;
 
  count:=count+1;
 
  case count is
 
  when "0000"=>y<="1111110";
 
  when "0001"=>y<="0110000";
 
  when X"2"=>y<="1101101";
 
  when X"3"=>y<="1111001";
 
  when X"4"=>y<="0110011";
 
  when X"5"=>y<="1011011";
 
  when X"6"=>y<="1011111";
 
  when X"7"=>y<="1110000";
 
  when X"8"=>y<="1111111";
 
  when X"9"=>y<="1111011";
 
  when X"A"=>y<="1110111";
 
  when X"B"=>y<="0011111";
 
  when X"C"=>y<="1001110";
 
  when "1101"=>y<="0111101";
 
  when "1110"=>y<="1001111";
 
  when "1111"=>y<="1000111";
 
  when thers=>y<="XXXXXXX";
 
  end case;
 
  end if;
 
  end process;
 
  end behave;
 
  在程序中,定義了變量count,希望初始值為“1010”。通過實驗發現,在定義變量或信號時直接賦予初始值不能生效(如variable count:std_logic_vector(3 downto 0) :=“1010”),它的初始值仍然是系統默認值(如count為“0000”)。正是利用這一點,通過init(初始值為''0'')來給count賦初值 A即“1010”,具體方法見程序中斜體部分。這樣,在第一個脈沖來時執行斜體部分if語句,而第二個脈沖來時由于init不為''0''而是 ''1'',因此不執行該部分語句,從而實現為count賦初值的功能,這樣程序從A開始進行數字的循環顯示。 
 
     如果把count類型改為signal,則結果將大不一樣。
 
  signal count: std_logic_vector(3 downto 0);
 
  process(clk)
 
  variable init :std_logic;
 
  begin
 
  if (clk''event) and (clk=''1'') then
 
  if (init = ''0'') then
 
  count<= "1001"; --(1)
 
  init := ''1'
 
  end if;
 
  count<=count+1; --(2)
 
  由于信號的賦值不是立即發生的,在語句(1)后面還存在對信號count的賦值操作(2),因此,語句(1)在此不起作用,count的最后值是語句 (2)的值。因此如果將count設為signal的話,程序實現的是從0開始的16個十六進制數的循環。在這里,對信號賦初值的語句是不可行的。
 
  仿真結果
 
  將設計好的VHDL程序在Altera公司提供的軟件maxplusⅡ10.1環境下進行編譯仿真,得到的仿真結果如圖1、圖2所示,其中圖1是 count為變量的結果,圖2是count為信號的結果,其中輸出y[6...0]分別與七段數碼管的abcdefg七段相連。
 
  從圖1可以看出,在第一個時鐘脈沖上升沿,結果是“1110111”,數碼管顯示即為A,然后依次為b,C,d, E,F,0,1...9,A...循環下去,此處用小寫的b和d,主要是與數字8進行區別。
 
  從圖中可以看出,在第一個時鐘脈沖上升沿,結果是“1111110”,數碼管顯示即為0,然后依次示1...9,A, b,C,d,E,F,0,...循環下去。
 
此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲茄子视频| 亚洲午夜激情| 99国产精品久久久久久久久久 | 亚洲欧洲日本一区二区三区| 国语自产偷拍精品视频偷 | 亚洲欧美日韩在线观看a三区 | 久久在线视频| 久久精品国产亚洲一区二区| 欧美亚洲三区| 羞羞答答国产精品www一本| 亚洲欧美国产高清va在线播| 亚洲主播在线观看| 亚洲欧美激情视频| 先锋亚洲精品| 欧美亚洲一区| 欧美一区二区视频观看视频| 午夜久久资源| 久久国产欧美| 可以免费看不卡的av网站| 久久成人在线| 久久看片网站| 免费成人激情视频| 欧美国产高清| 欧美日韩午夜剧场| 欧美性jizz18性欧美| 国产精品久久久久毛片软件| 国产精品一区二区三区四区| 久久久久**毛片大全| 久久综合九色综合久99| 欧美成年人在线观看| 欧美精品少妇一区二区三区| 欧美日韩综合在线免费观看| 国产精品盗摄久久久| 国产精品每日更新在线播放网址| 国产精品美女一区二区| 国产欧美精品va在线观看| 国产一区美女| 亚洲高清激情| 一区二区激情| 亚洲欧美福利一区二区| 久久精品国产清高在天天线| 亚洲人午夜精品免费| 一区二区欧美亚洲| 午夜精品福利视频| 久久久亚洲午夜电影| 欧美大片专区| 国产精品免费aⅴ片在线观看| 国产丝袜一区二区三区| 亚洲成人在线| 一区二区三区精品| 欧美淫片网站| 日韩视频中午一区| 午夜精品区一区二区三| 葵司免费一区二区三区四区五区| 欧美激情亚洲国产| 国产精品一区二区在线| 亚洲国产99精品国自产| 亚洲视频在线一区| 亚洲国产成人高清精品| 亚洲一区二区视频在线| 久久精品国产免费看久久精品| 欧美第一黄色网| 国产精品区一区| 亚洲国产精品久久久久婷婷884 | 亚洲精品乱码久久久久久黑人| 亚洲一级片在线看| 久久久免费av| 欧美午夜视频在线| 激情成人亚洲| 亚洲一区二区三区四区中文| 亚洲国产你懂的| 亚洲欧美美女| 欧美黄色一区| 国产一区二区三区四区| 亚洲精品视频二区| 久久精品国产第一区二区三区最新章节 | 亚洲欧美日韩人成在线播放| 麻豆免费精品视频| 国产精品二区影院| 亚洲高清不卡在线观看| 性18欧美另类| 亚洲欧美日韩国产中文在线| 欧美国产日韩一区| 国产一区二区精品久久| 中日韩高清电影网| 亚洲精品中文字幕女同| 久久精品视频在线看| 国产精品成人午夜| 亚洲人体影院| 亚洲人www| 久久久噜久噜久久综合| 国产精品久久久久久影视| 亚洲欧洲综合| 亚洲国产欧美在线人成| 久久精品电影| 国产欧美日韩一区二区三区在线| 日韩一区二区精品在线观看| 亚洲国内精品在线| 久久久久一区二区三区| 国产农村妇女精品一区二区| 亚洲视频二区| 亚洲先锋成人| 欧美另类一区| 伊人久久亚洲影院| 久久国产精品毛片| 久久福利视频导航| 国产精品入口尤物| 亚洲午夜精品久久久久久app| 洋洋av久久久久久久一区| 欧美成人精品福利| 尤物在线精品| 亚洲国产精品久久91精品| 久久久久久一区二区| 国产自产女人91一区在线观看| 性xx色xx综合久久久xx| 欧美在线免费视屏| 国产精品五月天| 亚洲淫性视频| 欧美一区二区三区免费视| 国产精品日韩精品欧美精品| 国产精品99久久久久久白浆小说 | 激情亚洲网站| 久久精品一区四区| 国产日韩欧美精品| 亚洲国产高清一区二区三区| 亚洲电影免费观看高清完整版在线观看 | 日韩午夜精品视频| 一区二区欧美亚洲| 欧美色图首页| 亚洲午夜影视影院在线观看| 亚洲自拍另类| 国产精品一区二区在线观看| 久久视频在线看| 欧美在线三区| 国产精品乱码妇女bbbb| 一本久道久久久| 亚洲欧洲一区二区天堂久久| 另类天堂av| 亚洲国产99| 99国产精品久久久久久久成人热| 美女国产精品| 亚洲欧洲一二三| 一区二区三区四区蜜桃| 欧美午夜精品久久久久久孕妇 | 久久中文字幕一区| 在线观看欧美精品| 亚洲毛片视频| 欧美日韩一区二区三区四区五区| 99一区二区| 先锋影音久久久| 国内精品久久久久影院色| 亚洲国产精品女人久久久| 欧美大色视频| 在线性视频日韩欧美| 欧美在线不卡| 在线免费不卡视频| 亚洲图片欧洲图片av| 国产区精品在线观看| 亚洲欧洲精品一区二区三区| 欧美日韩一区在线播放| 亚洲欧美激情四射在线日 | 久久婷婷丁香| 亚洲经典视频在线观看| 亚洲宅男天堂在线观看无病毒| 国产亚洲精品7777| 亚洲精品久久久久久久久| 欧美午夜无遮挡| 久久精品成人一区二区三区| 欧美日韩123| 先锋影音久久| 欧美成人免费全部观看天天性色| 一本一本大道香蕉久在线精品| 欧美在线观看一二区| 亚洲国产精品国自产拍av秋霞| 亚洲免费在线电影| 亚洲承认在线| 午夜精品免费视频| 91久久久亚洲精品| 久久九九热re6这里有精品| 亚洲精品欧美一区二区三区| 欧美主播一区二区三区美女 久久精品人 | 日韩视频中文| 欧美涩涩网站| 午夜精品成人在线视频| 欧美夫妇交换俱乐部在线观看| 亚洲天堂第二页| 久久午夜精品一区二区| 中日韩高清电影网| 欧美高清视频一区| 午夜久久久久久久久久一区二区| 欧美成在线观看| 亚洲淫性视频| 欧美日韩国产在线观看| 欧美在线观看视频在线| 欧美日韩一区精品| 亚洲激情av| 国产一区二区三区黄视频| 亚洲在线日韩| 亚洲美女视频| 欧美a级片网|