安靜
(廣東松山職業(yè)技術學院電氣工程系,廣東韶關512126)
隨著控制技術向網(wǎng)絡化、智能化和開放式發(fā)展,傳統(tǒng)PLC逐漸暴露出其許多不足。主要表現(xiàn)為技術封閉,造成了各生產(chǎn)廠商的PLC產(chǎn)品互不兼容,且編程開發(fā)方法差別很大,技術專門性很強,用戶必須經(jīng)過長期培訓才能掌握其中一種產(chǎn)品的開發(fā)方法,這些問題制約了傳統(tǒng)PLC的快速發(fā)展[1]。隨著計算機科學的發(fā)展和工業(yè)控制的IEC61131國際標準的制定,出現(xiàn)了用軟件方式實現(xiàn)傳統(tǒng)PLC控制功能的軟PLC技術。
軟PLC具有符合現(xiàn)代工業(yè)控制技術的優(yōu)點,體系結構開放,支持多種硬件環(huán)境,解決了傳統(tǒng)硬PLC互不兼容的問題。軟PLC把控制運算的功能封裝在軟件中,具有傳統(tǒng)PLC的功能,可在計算機操作系統(tǒng)中實現(xiàn)程序的編輯、運算、編譯、存儲等功能,具有編程語言標準化、控制功能模塊化、硬件配置靈活等特點[2]。
本文介紹的嵌入式軟PLC編程系統(tǒng)軟件在Windows環(huán)境下引入VC++開發(fā)工具,利用VC++強大的軟件功能,使人機交互界面更友好,由于VC++固有的面向對象機制,可方便地設計梯形圖數(shù)據(jù)結構,并結合相應的算法,完成軟PLC編程系統(tǒng)設計。本文主要給出編輯、編譯和仿真模塊。
圖1 嵌入式軟PLC系統(tǒng)總體框圖
嵌入式軟PLC主要由編程系統(tǒng)和運行系統(tǒng)組成。編程系統(tǒng)進行梯形圖的編輯、指令的解析以及生產(chǎn)目標代碼;運行系統(tǒng)執(zhí)行目標代碼,實現(xiàn)控制目的[3]。其總體架構如圖1所示。
軟PLC編程系統(tǒng)的編程語言基于國際電工委員會發(fā)布的IEC61131-3國際標準,是一個通用的開發(fā)環(huán)境,主要是由編輯、編譯、仿真和通信四大模塊組成[4]。其中編輯模塊提供用戶程序開發(fā)環(huán)境;編譯模塊實現(xiàn)對用戶程序的掃描和編譯;仿真模塊用以離線模擬、調試用戶程序;通信模塊負責把編譯后的用戶程序目標代碼下載到運行系統(tǒng)。
IEC61131-3國際標準(International Electro technical Commission)定義了5種PLC編程語言的規(guī)范:梯形圖(LD)、順序功能圖(SFC)、功能模塊(FBD)、結構化文本(ST)和指令表(IL)[3]。由于梯形圖簡單、直觀,所以本編程系統(tǒng)主要采用梯形圖作為用戶程序的開發(fā)語言。
本軟件采用VC++開發(fā)工具,并基于多文檔的Document/View結構設計,以支持梯形圖和指令表對應的格式—*.lad和*.txt。其界面由梯形圖編輯區(qū)、指令表區(qū)和信息輸出區(qū)三部分組成,如圖2所示。
圖2 軟PLC編程系統(tǒng)主界面
1)梯形圖編輯區(qū)用于梯形圖駐留和相關參數(shù)的設置;
2)指令表區(qū)用于顯示梯形圖對應的邏輯指令;
3)信息輸出區(qū)顯示梯形圖可能的語法錯誤信息以及正確執(zhí)行后的輸出信息。
梯形圖元件包括常開觸點、常閉觸點和輸出線圈等簡單元件和定時器、計數(shù)器、數(shù)據(jù)運算(包括加減運算、比較運算等)等復雜元件。由面向對象的繼承特性,可以抽象出一個類作為梯形圖元件的總體接口,再以這個類為基礎,派生出具體的元件子類。梯形圖元件的抽象類定義如下:
由此抽象類派生出簡單元件類和復雜元件類,并擴充相應的屬性和方法操作;再由這兩類派生出具體元件類,如常開觸點或定時器等。如圖3所示為各元件類型的繼承樹示意圖。
圖3 梯形圖元件類型的繼承關系
整個存儲梯形圖的容器選擇用雙向鏈表結構表示。其原因基于以下兩點:①對梯形圖的添加、修改、刪除等操作,能夠方便地運用鏈表的存儲結構完成;②梯形圖的編輯過程是動態(tài)的,梯形圖的行數(shù)、列數(shù)和元件類型都是未知的,這種動態(tài)存儲過程,用鏈表結構比其它的數(shù)據(jù)結構表達得更為清楚、有效。
存儲梯形圖的雙向鏈表在文檔類中定義為:CObList m_LADList,存儲梯形圖的容器。由此,添加梯形圖元件,實質就是在內(nèi)存中建立相應的對象,并調用鏈表的AddHead或AddTail函數(shù)加入該對象的指針;而刪除梯形圖元件,實質就是調用鏈表的RemoteHead或RemoveTail函數(shù)移除鏈表中對應對象的指針。下列代碼表示生成一個常開元件對象,并把該對象的指針加入到鏈表中:
//通過簡單工廠生成常開元件對象
pLADEle=CPLCFactory::GetInstance(TYPE_POSITIVE);
pLADEle->SetIsSelected(FALSE);
//將常開元件對象的指針加到鏈表中
//這里,plcList是指向 m_LADList的指針plcList->AddHead(pLADEle);
用戶通過與編程界面的交互,達到對梯形圖元件的控制。為了縮小顯示、控制和梯形圖元件三者間的耦合性,可引入MVC(Model-View-Control)模式解決。其中,由VC++中的CView類充當顯示部分,并設計CPLCEleController類用以控制梯形圖元件。CPLCEleController類依賴于工廠類CPLCEleFactory類,通過簡單工廠模擬以創(chuàng)建梯形圖元件實體,并且針對編輯、編譯和仿真的操作封裝了相應方法。其定義如下:
梯形圖的編輯部分封裝于視圖類,能實現(xiàn)存儲與顯示分離,以有效降低代碼的耦合性。
梯形圖的編輯大體可分為以下步驟:①選擇所要加載的梯形圖元件類型;②用戶在編輯區(qū)單擊鼠標,掃描程序獲取單擊對應位置的笛卡兒坐標值;③添加該梯形圖元件到存儲鏈表中;④在窗口中顯示該梯形圖;⑤設置梯形圖元件的其它參數(shù)。
矢量圖是計算機通過數(shù)學表達式解析的圖形,具有內(nèi)存消耗小,操作靈活的特點。因此,本軟件按矢量繪制梯形圖。
在VC++中,MFC類庫中的CDC類封裝了矢量圖的相關操作,由此,對梯形圖的繪制可以通過遍歷鏈表,并調用CDC類對象指針的函數(shù)來完成。并基于面向對象的多態(tài)性調用各元件實際的繪制操作:
梯形圖被繪制后,其類型、行號、列號信息均被確定。而其它的參數(shù),如元件編號、定時器的時基,由用戶輸入確定,具體可以通過添加消息映射函數(shù),掃描鼠標操作實現(xiàn)。當用戶雙擊某梯形圖元件時,彈出參數(shù)設置對話框,輸入數(shù)據(jù)后,相關的參數(shù)就被綁定在該元件對象中。下面的代碼片段表示對定時器設置參數(shù)。
要實現(xiàn)梯形圖的多次編輯,就要對梯形圖實現(xiàn)序列化,將其保存為文件;而當再次調用時,需要把程序加載到內(nèi)存。
對于Document/View結構,數(shù)據(jù)都存放于CDocument類里,將其中的變量寫入文件,即實現(xiàn)了梯形圖的序列化;打開文件時,通過動態(tài)創(chuàng)建機制,把其中變量導入內(nèi)存,即實現(xiàn)了梯形圖的反序列化。
由于梯形圖元件類繼承了CObject類,因此,運行時其自身具有類型識別和動態(tài)創(chuàng)建的功能,在CArchive類中調用重載的讀寫運算符">>"和"<<",就能執(zhí)行相應文件緩沖區(qū)建立和數(shù)據(jù)讀寫。
梯形圖的編譯是編程系統(tǒng)的關鍵部分,因為編譯的實質是把用戶編輯的梯形圖程序,經(jīng)過語法分析和邏輯分析,循環(huán)掃描,最終生成運行系統(tǒng)可識別的目標程序。
按照梯形圖編程語言規(guī)范,編譯程序掃描梯形圖,經(jīng)過語法分析和邏輯分析后,若發(fā)現(xiàn)梯形圖有錯誤,便生產(chǎn)相應的錯誤提示信息,并復制到用戶界面。
梯形圖掃描和編譯以梯級為單位,且梯級是由相互影響的行組成的最小單元,圖4所示為一個梯級。對梯形圖的掃描采用深度掃描算法,即以豎線元素作為邏輯區(qū)分,對梯形圖網(wǎng)絡自左向右,從上到下,逐個元素進行。
圖4 梯形圖掃描過程圖
以圖4為例,一個梯形圖梯級的深度掃描過程為:①首先讀取串聯(lián)關系的元件X1和X2;②遇到并聯(lián)接點A,從而轉至下一行掃描,讀取元件X4;③遇到并聯(lián)接點B,轉至下一行,讀取元件X6;④回到并聯(lián)接點B,讀取元件X5;⑤回到并聯(lián)接點A,讀取元件X3;⑥讀取輸出元件Y1,則完成該梯級的掃描和編譯。
實踐證明,該掃描算法容易實現(xiàn),能深入解析梯形圖邏輯關系,占用存儲空間較少,掃描效率較高。
為了提高移植性,降低運行系統(tǒng)程序與VC++程序的耦合度,本軟件引入了生成相應配置文件技術,以記錄梯形圖的數(shù)據(jù)信息,供仿真模塊或運行系統(tǒng)讀取。
梯形圖被掃描過程,程序自動生成梯形圖相關的邏輯關系數(shù)據(jù)對應的配置文件,用四組數(shù)字分別代表梯形圖的類型、連接關系,包括復雜元件中定時器的時基等數(shù)據(jù)信息,以備在運行系統(tǒng)加載。其梯形圖數(shù)據(jù)信息存儲結構示例如表1所示。
表1存儲了一個梯形圖的梯級信息,一個梯形圖元件對應表中的一格,表中"X-X-X-X"的格式為簡單的元件信息,分別表示“元件類型-連接關系-存儲類型-對應存儲類型數(shù)組的偏移量”。如表中第1行第1列的"1-0-0-25"數(shù)據(jù),代表梯級中位于第1行第1列,無并聯(lián)關系的常開觸點,它在簡單元件類型輸入數(shù)組中的存儲偏移量為25。
表1 梯形圖數(shù)據(jù)信息存儲結構示例
為了判定被編譯程序執(zhí)行的正確性,本編程系統(tǒng)設計了仿真模塊,以模擬現(xiàn)場梯圖程序運行。仿真需要將梯形圖程序轉化為C程序,以實現(xiàn)邏輯控制。
仿真模塊主要分為邏輯運算模塊、算術運算模塊和梯形圖更新顯示模塊。其中,邏輯運算模塊是仿真模塊的核心,負責對梯形圖數(shù)據(jù)信息的識別,以及邏輯狀態(tài)的轉移。
仿真程序通過讀取存儲梯形圖邏輯信息的配置文件,并還原對應每個梯形圖元件及相應的邏輯關系。以下的代碼片段通過運行是類型識別,反映了當前讀取的元件是常開/常閉觸點或輸出線圈時的邏輯運算:
//常閉觸點,右連接:=左連接取反
//常開觸點,右連接:=左連接,不需改動
//輸出能流為左連接狀態(tài)和本元件狀態(tài)相與
動態(tài)仿真過程在梯形圖編輯區(qū)實時顯示方便用戶進行錯誤定位、追蹤。具體表現(xiàn)為梯形圖元件能流導通時的變色反顯,可通過重繪觸發(fā)的方式實現(xiàn)。
本嵌入式軟PLC編程系統(tǒng)實現(xiàn)了梯形圖的編輯、編譯和仿真功能。并基于VC++開發(fā)平臺面向對象的封裝、繼承和多態(tài)性,通過編輯過程引入存儲梯形圖信息的配置文件,實現(xiàn)了編譯與仿真的橋接,有效地降低了與VC++開發(fā)環(huán)境的耦合度,移植性強。
[1] 高金剛,陳建春,劉雄偉.數(shù)控系統(tǒng)的軟PLC系統(tǒng)開發(fā)[J] .計算機測量與控制,2004,12(3):254-256.
[2] 肖世廣,李 彥,吉 華.Linux環(huán)境下基于Qt庫的軟件PLC 編程系統(tǒng)[J] .計算機工程與設計,2007(4):1663-1666.
[3] 黃延延,林 躍,于海彬.軟PLC技術研究及實現(xiàn)[J] .計算機工程,2004,30(1):165-167.
[4] 江連海.嵌入式控制系統(tǒng)開發(fā)平臺上軟PLC的實現(xiàn)[D] .華中科技學,2005:14-17.