v3學院教你學習-task和function的異同

v3學院教你學習-task和function的異同

task(任務)與function(函數)的不同
任務與函數主要有以下四點不同:
l 函數只能與主模塊共用一個仿真時間單位,而任務定義自己的仿真時間單位。
l 函數不能啟動任務,任務可以啟動其他任務和函數。
l 函數至少要有一個輸入變量,而任務可以沒有或有多任何類型的變量。
l 函數返回一個值,而任務不返回值。

  1. task語句說明
    l 任務的定義
    定義任務的語法如下:
    task<任務名>
    <端口及數據類型聲明語句>
    <語句1>
    <語句2>
    …………
    <語句n>
    endtask
    l 任務的調用及變量的傳遞
    任務的調用:
    <任務名>(端口1,端口2,…..,端口n);
    下面舉例子說明怎么定義任務與調用任務:
    任務定義:
    task my_task;
    input a,b;
    output c;
    <語句>
    ….
    endtask
    任務調用:my_task(v,w,x);
    任務調用變量(v,w,x)和任務定義的I/O變量(a,b,c)之間是一一對應的,當任務啟動時,由v和w傳入的變量賦給了a和b,而當任務完成之后的輸出又通過c賦給x,下面舉一個具體程序來介紹:
    代碼如下:
    165861-20170302091601907-1139394826.jpg
    165861-20170302091621376-1717043377.jpg
    165861-20170302091629126-1044190025.jpg

測試代碼如下:
165861-20170302091647923-1242725676.jpg
165861-20170302091655907-1900165231.jpg

仿真波形圖如下:
165861-20170302091710548-1617045231.jpg
165861-20170302091722188-180428428.jpg
當start信號變成高電平的時候,即當state狀態由0跳變到1時,
調用load任務,把data_in的值寄存在save_data的同時狀態機狀態跳轉到2,當狀態跳轉到2的時候,調用shift任務,把save_data的值往左移一位的同時狀態機狀態跳轉到3,當狀態跳轉到3的時候,調用out任務,把save_data的值往data_out賦值的同時狀態機狀態跳轉到0,仿真的波形跟設計的完全一樣。

  1. function說明語句
    l 定義函數的語法:
    function<返回值的類型或范圍>(函數名);
    <端口說明語句>
    <變量類型說明語句>
    begin
    <語句>
    ………
    end
    endfunction
    注意:<返回值的類型或范圍>這一項是可選項,如缺省則返回值位一位寄存器類型數據
    l 舉例說明
    下面舉一個實際程序的例子,來說明一下function函數的實際定
    義與如何調用。
    程序代碼如下:
    165861-20170302091750610-1689258038.jpg
    165861-20170302091803141-654306004.jpg
    165861-20170302091813204-1014760627.jpg
    165861-20170302091820516-1036395612.jpg

測試代碼如下:
165861-20170302091843891-1879579891.jpg
165861-20170302091855626-976596728.jpg

仿真波形圖如下:
165861-20170302091919095-665972912.jpg
165861-20170302091932110-604181736.jpg
165861-20170302091940641-460959647.jpg

當start信號變成高電平的時候,即當state狀態有0跳變到1時,調用load_data(data_in)函數,把data_in的值寄存在save_data的同時狀態機狀態跳轉到2,當狀態跳轉到2的時候,調用shift(save_data)函數,把save_data的值往左移一位的同時狀態機狀態跳轉到3,當狀態跳轉到3的時候,調用load_data(save_data)函數,把save_data的值往data_out賦值的同時狀態機狀態跳轉到0,仿真的波形跟設計的完全一樣。
此文章為原創出自 V3學院 www.v3edu.org

posted on 2017-03-02 09:20 老凱 閱讀(...) 評論(...) 編輯 收藏

轉載于:https://www.cnblogs.com/laokai/p/6488866.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/371447.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/371447.shtml
英文地址,請注明出處:http://en.pswp.cn/news/371447.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Spring事件的觀察者模式

介紹 觀察者模式的本質是“定義對象之間的一對多依賴關系&#xff0c;以便當一個對象改變狀態時&#xff0c;其所有依賴關系都會得到通知并自動更新。” GoF。 觀察者模式是發布/訂閱模式的子集&#xff0c;它允許許多觀察者對象查看事件。 可以在不同的情況下使用此模式&#…

jQuery選擇什么版本 1.x? 2.x? 3.x?

目前jQuery有三個大版本&#xff1a; 1.x&#xff1a;兼容ie678,使用最為廣泛的&#xff0c;官方只做BUG維護&#xff0c;功能不再新增。因此一般項目來說&#xff0c;使用1.x版本就可以了&#xff0c;最終版本&#xff1a;1.12.4 (2016年5月20日)2.x&#xff1a;不兼容ie678&a…

Delta DVP 系列 PLC 各裝置 Modbus 地址

此Modbus地址表以 1 為基礎地址 Device Range Type DVP address (Hex) Modbus address (Dec) Effective ES/EX/SS SA/SX/SC EH S 000~255 bit 0000~00FF 000001~000256 0~127 0~1024 0~1024 S 256~511 bit 0100~01FF 000247~000512 S 512~767 bit 020…

Reporting Service 2008 “報表服務器數據庫內出錯。此錯誤可能是因連接失敗、超時或數據庫中磁盤空間不足而導致的”...

今天遇到了兩個關于Reporting Service的問題&#xff0c; 出現問題的環境為Microsoft SQL Server 2008 R2 (SP2) - 10.50.4000.0 (X64) 。具體情況請見下面描述。 1&#xff1a;在修改報表的訂閱后&#xff0c;保存時出現下面錯誤&#xff1a; 提示&#xff1a;報表服務器數據庫…

Java 7:HashMap與ConcurrentHashMap

從我過去有關性能的文章和HashMap案例研究中可能已經看到&#xff0c;Java線程安全性問題可以很輕松地使Java EE應用程序和Java EE容器崩潰。 在對Java EE性能問題進行故障排除時&#xff0c;我觀察到的最常見問題之一是由非線程安全的HashMap get&#xff08;&#xff09;和pu…

計算機網絡按信息傳輸介質的性能來劃分,大學計算機基礎練習題網絡技術.doc...

網絡技術一、單選&#xff1a;1. 在計算機網絡中&#xff0c;表征數據傳輸可靠性的指標是( )。A?誤碼率 B?頻帶利用率C?信道容量 D?傳輸速率參考答案&#xff1a;A2. 和通信網絡相比&#xff0c;計算機網絡最本質的功能是( )。A?數據通信 B?資源共享C?提高計算機的可靠性…

【2017-03-02】集合、結構體、枚舉

集合和數組的差別&#xff1a; 數組&#xff1a;同一類型&#xff0c;固定長度集合&#xff1a;不同類型&#xff0c;不固定長度 一、普通集合&#xff08;弱類型&#xff09; 1、ArryList 使用集合首先要引用命名空間。 或者在ArryList上右鍵找“解析”。 2、集合的定義&#…

Hibernate懶/急加載示例

這篇文章將重點討論為什么以及如何在應用程序中使用稱為LAZY和EAGER加載的概念&#xff0c;以及如何使用Spring的休眠模板以EAGER方式加載LAZY實體。 當然&#xff0c;正如標題本身所暗示的那樣&#xff0c;我們將通過一個示例來說明這一點。 場景就是這樣&#xff1b; 您是一…

讀者使用計算機終端是指,全國2010年10月自學考試管理系統中計算機應用真題及答案...

A.上級模塊向下級模塊傳遞控制信號B.下級模塊對上級模塊傳遞控制信號C.同級模塊之間傳遞數據或控制信號D.上級模塊向下級模塊傳遞數據信號18.“客戶”數據表結構為&#xff1a;客戶編號、手機號、購物金額&#xff0c;合理的字段類型為( )A.字符型&#xff0c;字符型&#xff0…

軟件測試HW02-------fault error failure

程序一 問題一&#xff1a;i應該>0&#xff1b; 問題二&#xff1a; x為空 問題三&#xff1a;test x[2, 3, 5]; y 3;問題四:test: x[2]; y 3&#xff1b;程序二問題一&#xff1a;循環應該反過來;問題二&#xff1a;無;問題三&#xff1a;test:x[1];問題四:test: x[1,2,3…

Mathematica圖片局部變色

這篇博客來源于Stack-Exchange上的一個帖子&#xff0c;問題描述如下&#xff1a;如何將圖中的紅球變為藍球&#xff1f; 這個問題下面有很多答案&#xff0c;我選了最好的一個答案&#xff0c;代碼如下 img Import["C:/Users/1/Desktop/red.jpg"]; getReds[x_Image…

在WebLogic 12c上運行RichFaces

我最初以為我可以在幾個月前寫這篇文章。 但是我最終被不一樣的事情所淹沒。 其中之一是&#xff0c;它無法像我在4.0版本中那樣簡單地啟動RichFaces展示柜。 有了所有的JMS magic和不同的提供者檢查&#xff0c;這已經成為簡單構建和部署它的挑戰。 無論如何&#xff0c;我愿意…

Spring Boot系列教程一:Eclipse安裝spring-tool-suite插件

一.前言 一直使用eclipse&#xff0c;個人習慣選用Eclipsespring-tool-suite進行開發&#xff0c;特別注意Eclipse要選用對應的spring-tool-suite進行安裝&#xff0c;這點筆者浪費了好長時間&#xff0c;以下為對應的版本。eclipse-kepler.4.3.1–>springsource-tool-suite…

湖南工程學院計算機網絡考試,湖南工程學院 計算機網絡期末試卷試題

湖南工程學院 計算機網絡期末試卷試題湖南工程學院 計算機網絡 期末試題(計算機10級&#xff0c;90%的題目)1 從邏輯功能上看,計算機網絡可分為哪兩個子網?答&#xff1a;通信子網和資源子網 2 數據鏈路層的最基本功能答&#xff1a;數據鏈路層的最基本的功能是向該層用戶提供…

C#設計模式(11)——外觀模式(Facade Pattern)

一、引言 在軟件開發過程中&#xff0c;客戶端程序經常會與復雜系統的內部子系統進行耦合&#xff0c;從而導致客戶端程序隨著子系統的變化而變化&#xff0c;然而為了將復雜系統的內部子系統與客戶端之間的依賴解耦&#xff0c;從而就有了外觀模式&#xff0c;也稱作 ”門面“…

OS X Mountain Lion上的多個Java版本

在Mountain Lion之前&#xff0c;Java被捆綁在OS X中。似乎在升級期間&#xff0c;我在計算機上安裝的Java 6版本被刪除了。 顯然&#xff0c;在升級過程中卸載Java的原因是Java運行時存在的安全問題。通過這種方式&#xff0c;您不得不安裝可解決此安全問題的最新版本。 所以我…

Oracle鎖機制的總結【轉】

最近在研究Oracle鎖機制的時候發現網上的資料魚龍混雜將&#xff0c;很多將問題復雜化&#xff0c;讓人感覺沒有條理性。經過查詢原始理論資料&#xff0c;總結如下&#xff1a; 在數據庫理論中&#xff0c;我們知道。我們在執行并發訪問數據庫表時&#xff0c;如果沒有任何一致…

2020暨陽學院園林計算機考研考場,【圖片】2020考研,老學長教你如何規劃!【計算機考研吧】_百度貼吧...

該樓層疑似違規已被系統折疊 隱藏此樓查看此樓二、關鍵一步——院校選擇我把各位同學的院校選擇階段分為以上幾個階段&#xff0c;因為考研這一年中&#xff0c;很多人的目標院校并不是固定不變的&#xff0c;而是隨著不同階段而改變的。學長我在大三下學期這一時間段內也多次更…

List Box 控件

1 //定義變量&#xff0c;并關聯控件與變量。IDC_RecvData為控件ID&#xff0c;recvData為控件對應的變量名 2 CListBox recvData; 3 4 DDX_Control(pDX, IDC_RecvData, recvData); 5 6 //向List Box控件IDC_RecvData中添加一行數據 7 CString str&#xff1b; 8 recvData.Ad…

JavaOne 2012:向上,向上和向外:使用Akka擴展軟件

在最后的社區主題演講后&#xff0c;我前往希爾頓金門大橋3/4/5觀看了維克多巴生 &#xff08; Viktor Klang &#xff09;的&#xff08; Typesafe &#xff09;“上&#xff0c;下&#xff0c;外&#xff1a;Akka”演講。 巴生&#xff08;Klang&#xff09;是Akka的技術主管…