關 閉

新聞中心

EEPW首頁 > 工控自動化 > 設計應用 > 基于Petri網(wǎng)的并行控制器的VHDL實現(xiàn)

基于Petri網(wǎng)的并行控制器的VHDL實現(xiàn)

作者: 時間:2012-11-21 來源:網(wǎng)絡 收藏

網(wǎng)是異步并發(fā)系統(tǒng)建模與分析的一種重要工具,1962年由德國科學家C.A.博士創(chuàng)立。40多年來,網(wǎng)理論得到了很大的豐富和發(fā)展,其應用領域也在不斷擴大,越來越受到國際同行的重視,已成為計算機、自動化和通信領域的熱門研究課題。Petri網(wǎng)既有直觀的圖形表示,又有深厚的數(shù)學基礎;既是層次化的結構模型,又能反映系統(tǒng)的動態(tài)性能[1][2]。用硬件描述語言進行電路和系統(tǒng)設計是當前EDA技術的重要特征,它使得設計者能在較抽象的層次上進行系統(tǒng)結構和內(nèi)部特征的設計。作為一種高速的硬件描述語言適于描述設計異步并發(fā)的系統(tǒng),因而可與Petri網(wǎng)模型建立聯(lián)系。用對模型進行程序設計,為模型的硬件奠定了基礎。隨著大規(guī)模、高密度的可編程邏輯器件FPGA和CPLD的問世與應用方面的迅速推廣,并且有各種EDA軟件工具的支持,使得人們可以根據(jù)Petri網(wǎng)的拓撲結構用硬件加以,以使Petri網(wǎng)的硬件成為可能。因此,Petri網(wǎng)的智能化的的設計與硬件實現(xiàn)的課題引起了人們的強烈興趣。利用Petri網(wǎng)技術,不僅可以用來進行設計、分析和驗證,還能夠進行優(yōu)化控制。

本文引用地址:http://butianyuan.cn/article/159670.htm

  微電子技術發(fā)展到今天,已提供了幾千至幾千萬個標準門的芯片。特別是在系統(tǒng)可編程技術,可有條件地在一個芯片上設計制作一個數(shù)字系統(tǒng),即系統(tǒng)芯片(System on Chip,SoC)。國內(nèi)市場上常見的Altera公司、Xilinx公司、Lattice公司的FPGA和CPLD芯片,一般都能滿足設計SoC的需要,并且都提供了EDA軟件開發(fā)工具。而且在現(xiàn)有的軟件開發(fā)工具中,有電路圖、狀態(tài)圖、真值表和硬件描述語言等輸入方式。但設計片上,難以用電路圖或邏輯方程輸入方式實現(xiàn);如果用狀態(tài)圖或真值表輸入方式,隨著問題復雜程度的增加,系統(tǒng)的狀態(tài)將發(fā)生組合爆炸,這是十分棘手的問題。而且有限狀態(tài)機(FSM)雖已被廣泛運用到數(shù)字邏輯控制系統(tǒng),也只是因為它給出了系統(tǒng)化的硬件實現(xiàn)方法和具體的實現(xiàn)模型(如Moore自動機和Mealy自動機),用FSM實現(xiàn)也十分困難。因為FSM必須于設計前劃分控制器,所以常常會導致非最優(yōu)的門級實現(xiàn),且使設計中并發(fā)的數(shù)量受到使用FSM數(shù)量的限制,同時FSM間相互依賴,使得設計難于驗證且易產(chǎn)生并行同步錯誤(如死鎖、丟失數(shù)據(jù)的完整性)。上述這些缺點只有設計遍歷整個狀態(tài)空間時才能驗證,因而可能被漏檢[3]。若用硬件描述語言輸入,遇到的困難是模型和驗證。

  針對傳統(tǒng)的設計方法不太適合并行控制器設計的問題,本文介紹一種使用硬件描述語言來實現(xiàn)Petri網(wǎng)的并行控制器的方法。首先使用Petri網(wǎng)對問題進行建模,并對模型進行分析和控制,獲得控制器的Petri網(wǎng)模型;然后用VHDL對Petri網(wǎng)控制模型加以描述,得到源文件;最后通過EDA軟件開發(fā)工具Max+PlusⅡ進行編譯、模擬、適配,并下載到可編程邏輯器件中。

  1 Petri網(wǎng)簡介[2]

  定義:四元組Ε=(B,E;F,C)能構成條件/事件系統(tǒng)(condition/event system,C/E系統(tǒng))的要求是:

公式

  2 實現(xiàn)的基本方法

  Petri網(wǎng)本身就是一種硬件描述語言,是一種高度抽象的、結構化的并發(fā)語言。Petri網(wǎng)非常適合于復雜離散系統(tǒng)的建模和形式化分析,而VHDL則是一種標準的硬件描述語言,可以解決數(shù)字系統(tǒng)描述中并發(fā)性問題,允許其仿真和綜合。Petri網(wǎng)和VHDL可以相互補充,并且也可以提供一個驗證子系統(tǒng)接收所有設計任務相同的用戶接口描述[4]。并行控制器的VHDL文本Petri網(wǎng)描述在一個實際設計中可獲得50%的面積減少及40%的速度改善(相對于最好的FSM綜合)[4]。

  用大規(guī)??删幊踢壿嬈骷韺崿F(xiàn)由Petri網(wǎng)描述的并行控制器,其實現(xiàn)的基本步驟如下:

  (1)對實際系統(tǒng)建立Petri網(wǎng)系統(tǒng)模型。

  (2)采用Petri網(wǎng)軟件工具對所建立的Petri網(wǎng)系統(tǒng)模型進行分析并加以控制,建立監(jiān)控器的Petri網(wǎng)系統(tǒng)模型。

  (3)確定輸入輸出變量并選擇相應的FPGA或CPLD器件。

  (4)根據(jù)網(wǎng)的拓撲結構確定條件與事件間的邏輯關系,用硬件描述語言如VHDL對Petri網(wǎng)模型進行描述。

  (5)以VHDL描述作為設計輸入,通過EDA軟件開發(fā)工具,如ispDesign EXPERT或Max+PlusⅡ等,進行編譯、模擬、適配,然后下載到器件中。

  整個硬件實現(xiàn)的流程圖如圖1所示。

整個硬件實現(xiàn)的流程圖

  3 Petri網(wǎng)的并行控制器設計舉例

  3.1 系統(tǒng)描述

  從文獻[5]中選擇了一個如圖2所示的并行控制器設計例子,這是一個用于說明離散事件系統(tǒng)控制器設計的典型示例。它有3個盛放液體的罐子:V1、V2、V3,其中V1、V2是用來盛放不同種液體F1、F2的,M是攪拌系統(tǒng)的驅(qū)動電機。系統(tǒng)停止時,指示燈Y0亮。當起動按鈕按下時(X0=1),閥Y1、Y2打開,2種不同的液體F1、F2分別注入V1、V2。當V1中的液體到達X1位置時,Y1關閉;當V2中液體到達X3時,閥Y2關閉。當V1、V2中的液體分別都到達X1、X3時,Y3、Y4同時打開;當V1、V2中液體分別都低于X2、X4時,Y3、Y4關閉,同時Y6打開。當V3中液體高于X5時,Y5閉合,電動機M開始攪拌;當V3中液體流出低于X6時,Y6關閉,指示燈亮,重新回到原來狀態(tài)。

離散事件系統(tǒng)控制器設計

伺服電機相關文章:伺服電機工作原理


電子血壓計相關文章:電子血壓計原理



上一頁 1 2 下一頁

評論


相關推薦

技術專區(qū)

關閉
×

报名截止时间 12月22日
Let's do--DIY 液体流量检测仪让喝水更有乐趣,快来报名吧!