基于LabVIEW的數(shù)控機(jī)床網(wǎng)絡(luò)測(cè)控系統(tǒng)--基于B/S模式的軟件設(shè)計(jì) 1
②生成SQL命令,執(zhí)行命令。在前面板table控件中輸入表名,Current和Error控件中輸入字段值。在程序框圖中使用Format Into String生成SQL命令,將它連接到ADO Connection Execute.vi即可執(zhí)行,同時(shí)可在前面板Command Text控件顯示此命令。
③斷開(kāi)與數(shù)據(jù)庫(kù)之間的連接。利用ADO Connection Close.vi關(guān)閉Connection對(duì)象,并使用ADO Connection Destroy.vi刪除Connection對(duì)象。
(4)歷史數(shù)據(jù)回放界面,可以根據(jù)用戶需要,按照測(cè)試的日期時(shí)間打開(kāi)所需要回放查詢的文件。數(shù)據(jù)回放界面繪制出的相應(yīng)歷史曲線如圖5.4所示。
在實(shí)時(shí)與歷史曲線顯示部分,趨勢(shì)曲線能夠形象清楚地描繪出現(xiàn)場(chǎng)數(shù)據(jù)在一段時(shí)間內(nèi)的分布趨勢(shì),通過(guò)趨勢(shì)圖,操作員可以根據(jù)各個(gè)現(xiàn)場(chǎng)數(shù)據(jù)采集點(diǎn)的數(shù)據(jù)的變化趨勢(shì)看出各個(gè)量的變化情況,且能查看任何歷史時(shí)刻的數(shù)據(jù),供現(xiàn)場(chǎng)操作人員作出適當(dāng)?shù)奶幚怼?br />
5.1.3數(shù)據(jù)記錄監(jiān)控模塊DSC的應(yīng)用
(1)測(cè)控系統(tǒng)在上述功能的實(shí)現(xiàn)過(guò)程中,遇到了三個(gè)實(shí)際工程問(wèn)題:
①監(jiān)控界面中現(xiàn)場(chǎng)數(shù)據(jù)顯示的速度慢,最慢達(dá)到5秒的延遲,很顯然這不符合工業(yè)現(xiàn)場(chǎng)過(guò)程控制實(shí)時(shí)性的要求。
②由于LabVIEW軟件本身不像FIX工控軟件一樣,帶有實(shí)時(shí)數(shù)據(jù)庫(kù)。當(dāng)系統(tǒng)比較小時(shí),即在控制點(diǎn)數(shù)少的情況下,實(shí)現(xiàn)監(jiān)控功能可以利用全局變量的概念,將監(jiān)視或控制的現(xiàn)場(chǎng)測(cè)量點(diǎn)都看作是全局變量,暫且稱它們?yōu)?ldquo;全局變量庫(kù)”。然后把LabVIEW實(shí)現(xiàn)的各個(gè)功能看作是一個(gè)子程序,每一個(gè)子程序都是從全局變量庫(kù)中取數(shù)據(jù)或向里寫數(shù)據(jù)。也就是將這個(gè)“全局變量庫(kù)”看作是一個(gè)實(shí)時(shí)數(shù)據(jù)庫(kù),現(xiàn)場(chǎng)每一個(gè)測(cè)量點(diǎn)都與庫(kù)中的參數(shù)一一對(duì)應(yīng)。這種方法在控制點(diǎn)數(shù)少的情況下還是可行的,但是,當(dāng)系統(tǒng)是大中型的情況即現(xiàn)場(chǎng)控制點(diǎn)數(shù)很多的時(shí)候,在實(shí)踐中發(fā)現(xiàn),使用全局變量的方法,不僅編程量大,而且數(shù)據(jù)查找起來(lái)沒(méi)有數(shù)據(jù)庫(kù)查找起來(lái)方便快捷,另外,全局變量一直是編程人員所盡量避免使用的方法。
③由于在實(shí)際的過(guò)程控制監(jiān)視中,要求各個(gè)界面之間來(lái)回的切換,實(shí)現(xiàn)界面的友好操作性。FIX監(jiān)控軟件通過(guò)編程有調(diào)用各個(gè)界面的函數(shù),可以方便的實(shí)現(xiàn)界面之間的切換。然而,在用LabvEIW實(shí)現(xiàn)界面之間切換的過(guò)程中,將上述的“全局變量庫(kù)”作在“數(shù)據(jù)總攬”的界面里,其它各個(gè)子程序(界面),例如,“實(shí)時(shí)和歷史曲線”、“歷史數(shù)據(jù)”、各個(gè)流程圖等,都是和它進(jìn)行數(shù)據(jù)交換。所以“數(shù)據(jù)總攬”子程序起著實(shí)時(shí)數(shù)據(jù)庫(kù)的作用,它在系統(tǒng)運(yùn)行的過(guò)程中不能被關(guān)閉,本課題是利用VI Sevrer技術(shù)使得“數(shù)據(jù)總攬”子程序在系統(tǒng)己開(kāi)運(yùn)行時(shí)就以最小化的形式開(kāi)始運(yùn)行,保證數(shù)據(jù)的實(shí)時(shí)性。但是,考慮到“歷史數(shù)據(jù)”和“歷史曲線”兩個(gè)子程序由于需要存取歷史數(shù)據(jù)的原因,而在系統(tǒng)運(yùn)行的過(guò)程中不能被關(guān)閉,所以也將它們始終處于最小化的狀態(tài)運(yùn)行。按照上述的做法,發(fā)現(xiàn)在系統(tǒng)運(yùn)行過(guò)程中,各個(gè)界面之間切換起來(lái)速度較慢,這不能充分滿足現(xiàn)場(chǎng)過(guò)程控制的實(shí)時(shí)性和可靠性的要求。
(2)基于DSC模塊的問(wèn)題解決方法
第一個(gè)問(wèn)題,數(shù)據(jù)讀和寫的速度有明顯的差別。利用Datasocket技術(shù)編程實(shí)現(xiàn)數(shù)據(jù)的讀和寫,寫數(shù)據(jù)的速度卻很快。所以可能是編程中出現(xiàn)的數(shù)據(jù)緩沖或者程序中等待事件的發(fā)生執(zhí)行效率低的原因,決定數(shù)據(jù)顯示部分通過(guò)在前面板直接用Datasocket連接OPC服務(wù)器。結(jié)果數(shù)據(jù)顯示速度明顯達(dá)到幾百毫秒,滿足了實(shí)時(shí)要求。而且這種方法開(kāi)發(fā)時(shí)間短,效率高。
評(píng)論