《電子技術應用》
您所在的位置:首頁 > 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亚洲国产精品_日韩亚洲一区二区
欧美成人午夜剧场免费观看| 国产精品天美传媒入口| 亚洲伊人一本大道中文字幕| 亚洲高清在线| 久久狠狠亚洲综合| 欧美在线三级| 欧美亚洲专区| 午夜综合激情| 欧美一区二区高清| 欧美一区二区黄| 欧美一区二区三区的| 欧美一区二区视频网站| 亚洲欧美国产制服动漫| 亚洲一区二区免费在线| 在线综合亚洲| 亚洲天堂久久| 亚洲一区二区在线| 亚洲尤物影院| 欧美一区激情视频在线观看| 先锋影音国产精品| 久久国产加勒比精品无码| 久久国产精品第一页| 亚洲高清av| 日韩视频一区二区在线观看| 99视频在线观看一区三区| 在线一区二区三区做爰视频网站| 99精品欧美一区| 亚洲特黄一级片| 午夜精品久久久久久久蜜桃app| 香蕉久久一区二区不卡无毒影院 | 欧美大片一区二区| 欧美激情一区二区三区在线视频| 欧美日韩国产成人在线91| 国产精品福利在线观看| 国产嫩草一区二区三区在线观看| 国产亚洲综合性久久久影院| 狠狠综合久久av一区二区小说| 精品福利免费观看| 影音先锋久久| 日韩一级黄色av| 亚洲一区欧美一区| 欧美一站二站| 亚洲精品永久免费| 亚洲一区激情| 久久久欧美精品| 欧美黄色免费| 国产精品久久久久久久第一福利 | 国产日韩欧美在线播放| 在线成人激情视频| 99视频一区二区| 午夜日韩激情| 亚洲三级免费| 亚洲永久在线| 久久人91精品久久久久久不卡| 欧美激情麻豆| 国产精品美女久久久| 精品av久久707| 99re亚洲国产精品| 香蕉免费一区二区三区在线观看| 亚洲欧洲在线视频| 欧美一区二区精品| 欧美成人精品一区二区| 国产精品v欧美精品v日韩精品| 国产最新精品精品你懂的| 亚洲三级电影全部在线观看高清| 亚洲欧美99| 亚洲狼人综合| 久久精品99国产精品日本| 欧美激情在线狂野欧美精品| 国产乱码精品一区二区三区五月婷 | 国产精品久久午夜| 一区二区亚洲欧洲国产日韩| 99国产一区| 久久成人综合视频| 亚洲综合色在线| 欧美国产极速在线| 国产日韩精品一区二区浪潮av| 亚洲国产精品电影在线观看| 午夜久久福利| 一区二区三区欧美| 久久久噜噜噜久久中文字免| 欧美天堂亚洲电影院在线观看| 精品51国产黑色丝袜高跟鞋| 亚洲一二三区在线| 亚洲美女在线看| 久久久久.com| 国产精品入口福利| 日韩视频永久免费观看| 亚洲第一在线视频| 欧美亚洲在线播放| 欧美三级在线视频| 亚洲国产片色| 亚洲国产精品传媒在线观看| 性xx色xx综合久久久xx| 欧美日韩在线一区二区三区| 亚洲国产精品99久久久久久久久| 销魂美女一区二区三区视频在线| 亚洲小说区图片区| 欧美精品三级在线观看| 激情丁香综合| 欧美一区成人| 欧美一区二区三区喷汁尤物| 欧美图区在线视频| 亚洲精品免费一区二区三区| 亚洲黄一区二区| 久久九九热re6这里有精品| 欧美性大战久久久久久久| 亚洲精品国产精品国自产在线 | 在线成人av网站| 久久aⅴ国产紧身牛仔裤| 性欧美1819sex性高清| 欧美午夜视频一区二区| 亚洲精品一二三| 日韩午夜黄色| 欧美精品一区二区三区久久久竹菊| 在线视频成人| 亚洲激情图片小说视频| 免费亚洲电影在线| 一区二区三区在线免费观看| 欧美一区二区私人影院日本 | 欧美永久精品| 久久av红桃一区二区小说| 国产精品二区二区三区| 99国产精品国产精品久久| 一区二区不卡在线视频 午夜欧美不卡在| 欧美aa国产视频| 亚洲高清在线观看| 亚洲人午夜精品| 欧美另类综合| 夜夜嗨av一区二区三区中文字幕 | 国产日韩精品一区二区| 性欧美办公室18xxxxhd| 欧美一区激情| 国产一区高清视频| 久久aⅴ国产紧身牛仔裤| 久久婷婷麻豆| 亚洲电影在线观看| 日韩视频免费观看| 欧美日韩精品欧美日韩精品一| 亚洲精品一区二| 亚洲欧美电影院| 国产免费成人| 亚洲电影在线看| 农村妇女精品| 亚洲精品久久| 亚洲欧美日韩精品久久久久| 国产日韩1区| 亚洲电影免费观看高清完整版在线观看 | 影音先锋中文字幕一区| 亚洲国产精品国自产拍av秋霞| 一区二区三区四区国产精品| 亚洲午夜在线| 国产精品一区二区视频| 欧美在线视频免费观看| 免费亚洲网站| 一本色道久久88综合亚洲精品ⅰ| 亚洲欧美美女| 国产欧美一区二区色老头| 久久精品亚洲热| 欧美精品v日韩精品v韩国精品v| 9色精品在线| 久久国产精品久久久| 在线日韩中文字幕| 亚洲午夜免费视频| 国产色综合网| 亚洲精品欧洲| 国产精品区一区| 亚洲第一级黄色片| 欧美理论在线| 亚洲欧美日韩一区在线观看| 久久亚洲一区二区| 亚洲麻豆国产自偷在线| 新狼窝色av性久久久久久| 精品9999| 亚洲欧美精品在线| 国产在线麻豆精品观看| 一区二区欧美激情| 国产偷国产偷精品高清尤物| 亚洲美女视频在线观看| 国产精品一区=区| 91久久精品www人人做人人爽| 欧美三级在线播放| 亚洲高清成人| 国产精品久久波多野结衣| 亚洲成在线观看| 欧美体内she精视频| 亚洲国产清纯| 国产精品美女午夜av| 亚洲精华国产欧美| 国产乱人伦精品一区二区 | 亚洲国产精品高清久久久| 午夜欧美精品| 亚洲欧洲精品一区二区精品久久久 | 欧美高清hd18日本| 亚洲欧美日本伦理| 欧美久久久久久蜜桃| 久久成人精品无人区| 国产精品成人一区二区艾草| 最新日韩精品| 国产日本精品|