国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

FPGA仿真方法介紹及其仿真程序設(shè)計

發(fā)布時間:2012-3-16 21:38    發(fā)布者:1770309616
關(guān)鍵詞: FPGA , 仿真 , 仿真程序
一、概述

FPGA仿真方法:

(1)交互式仿真方法:利用EDA工具的仿真器進行仿真,使用方便,但輸入輸出不便于記錄規(guī)檔,當輸入量較多時不便于觀察和比較。

(2)測試平臺法:為設(shè)計模塊專門設(shè)計的仿真程序,可以實現(xiàn)對被測模塊自動輸入測試矢量,并通過波形輸出文件記錄輸出,便于將仿真結(jié)果記錄歸檔和比較。

二、仿真程序的設(shè)計方法

1 仿真的三個階段

(1)行為仿真:目的是驗證系統(tǒng)的數(shù)學模型和行為是否正確,對系統(tǒng)的描述的抽象程度較高。在行為仿真時,VHDL的語法語句都可以執(zhí)行。

(2)RTL仿真:目的是使被仿真模塊符合邏輯綜合工具的要求,使其能生成門級邏輯電路。在RTL仿真時,不能使用VHDL中一些不可綜合和難以綜合的語句和數(shù)據(jù)類型。該級仿真不考慮慣性延時,但要仿真?zhèn)鬏斞訒r。

(3)門級仿真:門級電路的仿真主要是驗證系統(tǒng)的工作速度,慣性延時僅僅是仿真的時候有用在綜合的時候?qū)⒈缓雎浴?br />
2 仿真程序的內(nèi)容

(1)被測實體的引入。
(2)被測實體仿真信號的輸入。
(3)被測實體工作狀態(tài)的激活。
(4)被測實體信號的輸出
(5)被測實體功能仿真的結(jié)果比較,并給出辨別信息
(6)被測實體的仿真波形比較處理

3 仿真要注意的地方

(1)仿真信號可以由程序直接產(chǎn)生,也可以用TEXTIO文件產(chǎn)生后讀入。

(2)仿真程序中可以簡化實體描述,省略有關(guān)端口的描述。仿真程序?qū)嶓w描述的簡化形式為:
ENTITY 測試平臺名 IS
END 測試平臺名;
(3)對于功能仿真結(jié)果的判斷,可以用斷言語句(ASSORT)描述。

(4)為了比較和分析電子系統(tǒng)的功能,尋求實現(xiàn)指標的最佳結(jié)構(gòu),往往利用一個測試平臺對實體的不同結(jié)構(gòu)進行仿真,一般是應用配置語句為同一被測實體選用多個結(jié)構(gòu)體。

CONFIGURATION 測試平臺名 OF 被測實體名 IS
FOR 被測實體的A的結(jié)構(gòu)體名
END FOR;
END 測試平臺名;
同樣,若選用結(jié)構(gòu)體B,則配置語句可寫為:
CONFIGURATION 測試平臺名 OF 被測實體名 IS
FOR 被測實體的B的結(jié)構(gòu)體名
END FOR;
END 測試平臺名;

4 VHDL仿真程序結(jié)構(gòu)

測試平臺僅僅是用于仿真,因此可以利用所有的行為描述語言進行描述,下表表示了一個測試平臺所包含的部分,典型的測試平臺將包括測試結(jié)果和錯誤報告結(jié)果。

(1)產(chǎn)生時鐘信號

-- Declare a clock period constant.
Constant ClockPeriod : TIME := 10 ns;
-- Clock Generation method 1:
Clock <= not Clock after ClockPeriod / 2;
-- Clock Generation method 2:
GENERATE CLOCK: process
begin
wait for (ClockPeriod / 2)
Clock <= ’1’;
wait for (ClockPeriod / 2)
Clock <= ’0’;
end process;

(2)提供仿真信號

提供仿真信號可以有兩種方法:絕對時間仿真和相對時間仿真。在絕對時間仿真方法中,仿真時間只是相對于零時刻的仿真時間。在相對時間仿真方法中,仿真的時間首先提供一個初值,在后繼的時間設(shè)置中相對于該初始時間進行事件動作。

絕對時間仿真:

MainStimulus: process begin
Reset <= ’1’;
Load <= ’0’;
Count_UpDn <= ’0’;
wait for 100 ns;
Reset <= ’0’;
wait for 20 ns;
Load <= ’1’;
wait for 20 ns;
Count_UpDn <= ’1’;
end process;
相對時間仿真:
Process (Clock)
Begin
If rising_edge(Clock) then
TB_Count <= TB_Count + 1;
end if;
end process;
SecondStimulus: process begin
if (TB_Count <= 5) then
Reset <= ’1’;
Load <= ’0’;
Count_UpDn <= ’0’;
Else
Reset <= ’0’;
Load <= ‘1’;
Count_UpDn <= ‘1’;
end process;
FinalStimulus: process begin
if (Count = "1100") then
Count_UpDn <= '0';
report "Terminal Count
Reached, now counting down."
end if;
end process;

(3)顯示結(jié)果

VHDL提供標準的std_textio函數(shù)包把輸入輸出結(jié)果顯示在終端上。

5 簡單的仿真程序

library IEEE;
use IEEE.std_logic_1164.all;
entity testbench is
end entity testbench;
architecture test_reg of testbench
component shift_reg is
port (clock : in std_logic;
reset : in std_logic;
load : in std_logic;
sel : in std_logic_vector(1 downto 0);
data : in std_logic_vector(4 downto 0);
shiftreg : out std_logic_vector(4 downto 0));
end component;
signal clock, reset, load: std_logic;
signal shiftreg, data: std_logic_vector(4 downto 0);
signal sel: std_logic_vector(1 downto 0);
constant ClockPeriod : TIME := 50 ns;
begin
UUT : shift_reg port map (clock => clock, reset => reset,
load => load, data => data,
shiftreg => shiftreg);
process begin
clock <= not clock after (ClockPeriod / 2);
end process;
process begin
reset <= ’1’;
data <= "00000";
load <= ’0’;
set <= "00";
wait for 200 ns;
reset <= ’0’;
load <= ’1’;
wait for 200 ns;
data <= "00001";
wait for 100 ns;
sel <= "01";
load <= ’0’;
wait for 200 ns;
sel <= "10";
wait for 1000 ns;
end process;
end architecture test_reg;

6 TEXTIO建立測試程序

在由仿真程序直接產(chǎn)生輸入信號的方法中,測試矢量是仿真程序的一個部分,如果系統(tǒng)比較復雜,測試矢量的數(shù)目非常大,修改測試矢量時就必須修改程序,重新編譯和仿真。工作量大。因此,在測試矢量非常大的時候可以用TEXTIO的方法來進行仿真。

TEXTIO仿真方法:測試矢量從仿真程序中分離出來,單獨存于一個文件中(即TEXTIO文件),在仿真時,根據(jù)定時要求按行讀出,并賦予相應的輸入信號。這種方法允許采用同一個測試平臺,通過不同的測試矢量文件進行不同的仿真。值得注意的是,測試矢量文件的讀取,需要利用TEXTIO程序包的功能。在TEXTIO程序包中,包含有對文本文件進行讀寫的過程和函數(shù)。

LIBRARY IEEE;
USE IEEE.std_logic_1164.all;
LIBRARY ieee;
USE IEEE.STD_LOGIC_TEXTIO.ALL;
USE STD.TEXTIO.ALL;
ENTITY testbench IS
END testbench;
ARCHITECTURE testbench_arch OF testbench IS
COMPONENT stopwatch

來源:網(wǎng)絡(luò)
本文地址:http://www.qingdxww.cn/thread-87417-1-1.html     【打印本頁】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點和對其真實性負責;文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問題,我們將根據(jù)著作權(quán)人的要求,第一時間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 深度體驗Microchip自動輔助駕駛應用方案——2025巡展開啟報名!
  • 更佳設(shè)計的解決方案——Microchip模擬開發(fā)生態(tài)系統(tǒng)
  • 我們是Microchip
  • 利用模擬開發(fā)工具生態(tài)系統(tǒng)進行安全電路設(shè)計
  • 貿(mào)澤電子(Mouser)專區(qū)

相關(guān)視頻

關(guān)于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 一级毛片aaaaaa视频免费看 | 日韩在线综合 | 免费看黄网页 | 99re在线 | 欧美视频在线观看 | 中文字幕亚洲欧美一区 | 国产精品亚洲精品日韩已方 | 影院欧美在线看免费 | 狠狠色狠狠色综合久久一 | 色综合久久综合欧美综合图片 | 啦啦啦在线观看免费观看4 啦啦啦手机在线播放视频 啦啦啦视频在线视频免费4 | 欧美在线专区 | 欧美影院在线观看 | 欧美很黄视频在线观看 | 四虎视屏 | 麻豆传煤适当放松一下自己 | 日本免费黄网 | 青青操网址| 黄工厂精品视频在线观看 | 精品91在线 | 好大好硬使劲脔我奶水吃 | 男啪女| 国产日韩欧美视频在线观看 | 国产最新视频 | 国产综合精品一区二区 | 天堂网2021| 欧美成人精品三级网站 | 91精品在线国产 | 欧美日韩中文国产一区二区三区 | 免费一级片在线 | 九九精品成人免费国产片 | 国内精品区一区二区三 | 亚洲黄在线观看 | 国产亚洲一区二区三区在线 | 99久久精品国产高清一区二区 | 欧美亚洲视频在线观看 | 亚洲婷婷第一狠人综合精品 | 男女羞羞视频网站 | 亚洲成人18 | aaaaaaaaa在线观看 | 久久精品在这里 |