文獻標識碼:B文章編號:1003-0492(2023)08-066-04中圖分類號:TP392
★朱國海(浙江巨化熱電有限公司,浙江衢州324000)
關鍵詞:PI;PI-SDK;PI-API;接口
1 引言
隨著計算機信息技術的飛速發展,電廠都已經實現了底層生產用DCS系統、上層管理用MIS系統。為了實現上層MIS系統和底層DCS系統的溝通,SIS系統(Supervisory Information System in Plant Level)應運而生。隨著SIS系統的產生和發展,逐漸為多數業內人士所接受,電廠信息化已經走向SIS+MIS時代。SIS系統和MIS系統是電廠實現電力生產過程自動化和管理現代化的兩種不可缺少的工具,它們是相輔相成的。
2 SIS系統和PI實時數據庫
實時數據庫是SIS系統最基礎、最重要的核心組成部分。說到實時數據庫系統,目前的產品有很多,PI(Plant Information System)是由美國OSI Software公司開發的一套商品化軟件應用平臺,由于采用基于“螺旋門”的專利壓縮技術而使得存儲效率非常高。PI可在線存貯每個工藝過程點的多年數據。它提供了清晰、精確的操作情況畫面,用戶既可瀏覽工廠當前的生產情況,也可回顧過去的生產情況,所以PI在國內擁有很大的市場占有率,特別是在電力系統得到廣泛的運用。
電廠建設SIS系統是為了可以開發各種應用,從而使信息系統發揮出更大的作用。PI系統本身客戶端的應用程序可使用戶很容易對工廠實施管理,諸如改進工藝,TQC,故障預防維護等。通過PI可集成產品計劃、維護管理、專家系統、LIMS和優化/建模等應用程序,PI在業務管理和實時生產之間起到橋梁作用。同時PI數據庫也有完善的二次開發手段,包括應用開發接口和數據庫訪問手段等。PI提供了對OPC、ODBC以及OLEDB等的支持。另外,它還有C/C++、VB環境下的SDK開發工具包和PI-API接口函數庫,利用PI-API和PISDK,用戶可以比較方便地進行二次開發。
3 PI-SDK和PI-API
某熱電廠雖然已經建立了全廠的網絡和PI實時數據庫,但上層的應用大多處于起步階段,還沒有多少成熟的應用,本文打算初步探索下PI-SDK和PI-API技術,為今后二次開發做準備。
PI-API(PI Application Programming Interface)即PI應用程序接口,包含很多函數可以用來讀寫數據庫。利用這些函數,用VB、C++或C#、甚至連PI-PROCESSBOOK中內嵌的VBA都可以對PI數據庫進行數據讀寫。
PI-SDK(PI Software Development Kit)即基于面向對象的訪問PI數據庫的軟件開發工具包。作者個人感覺PI-SDK是把PI-API封裝了一下,讓開發人員更容易連接數據庫進行讀寫。兩種方式本文都嘗試了一下,后面會分別探討。
4 PI-API的基本應用
在開始編程之前,首先需要安裝OSI提供的PI-API,安裝后會在系統的SYSTEM32目錄中生成PIAPI32.DLL和PILOG32.DLL,在PI系統目錄下的INCLUDE目錄中生成PIAPI32.BAS。
下面以VB為例說明PI-API的大致用法。首先在VB程序中引用上面提到的PIAPI32.BAS,將它作為一個公用模塊,然后就可以按照以下步驟連接數據庫了。首先是連接數據庫、其次是獲取測點的內部標識號、然后通過內部標識號訪問數據、最后斷開數據庫的連接,調用相關API函數,完成對PI數據庫的讀寫操作。下面是幾個主要函數:
pilg_registerapp,piut_setservernode,piut_login,pipt_findpoint,pisn_getsnapshot,pisn_putsnapshot,piut_disconnect()。
作者編寫了一個讀寫PI數據庫的小程序,作者對每個函數后面都做了說明,這樣看起來更加直觀。程序界面如圖1所示,通過輸入點名可以讀取快照值,也可以寫入快照值。
圖1 程序界面
Private Sub commandread_Click()
Dim pv '讀取到的值
Dim pd As Long 'pointid
Dim TagName As String ’PI數據庫點名
pilg_registerapp "piapi32.dll" {這是注冊PI的動態連接庫}
piut_setservernode "piserver" {設置要登錄的PI服務器}
piut_login "piuser", "password", 0 {根據用戶名和密碼登錄到上面設置的PI服務器,第一個參數是用戶名,第二個參數是密碼。}
TagName = Text1.Text {在文本框中輸入PI數據庫點名}
pipt_findpoint TagName,pd{根據輸入的PI數據庫點名獲取對應的pointid,函數中的pd就是獲得的pointid。用戶平時應用的時候一般習慣都是用TAGNAME,也就是PI數據庫點名,但是PI-API函數是用POINTID來存取的,所以要先根據TAGNAME來獲得POINTID號。}
pisn_getsnapshotpd,pv,0,0{獲取對應點的快照值,第一個函數是POINTID,PV就是獲取到的值,第三和第四個參數值本文設的0,就是獲取當前值}
Text2.Text=pv
pilg_disconnect{斷開與PI服務器的連接}
End Sub
以上就是獲取快照值的全部過程,寫入值和獲取值的過程差不多,就是最后用寫入函數。
Private Sub commandwrite_Click()
Dim pv '寫入的值
Dim pd As Long 'pointid
Dim TagName As String ’PI數據庫點名
pilg_registerapp "piapi32.dll"
piut_setservernode "piserver"
piut_login "piuser", "password", 0
TagName = Text1.Text
pipt_findpoint TagName, pd
pv= Text2.Text
pisn_putsnapshot pd,pv,0,0{寫入對應點的快照值,第一個函數是POINTID,PV就是要寫入的值,第三和第四個參數值本文設的0。}
pilg_disconnect{斷開與PI服務器的連接}
EndSub
以上就是最基礎的利用PI-API讀取和寫入PI數據庫的操作,按照以上步驟用戶就能順利地把數據寫入到PI實時數據庫的快照中。除了能對快照進行讀寫操作,PI-API還提供了能對已經存檔的數據進行讀寫的函數,比如piar_value,可以獲取特定時間的存檔值,piar_putvalue可以把數據寫入數據存檔文件。
初步掌握PI-API數據庫讀寫操作后,本文進行了簡單的開發嘗試。某熱電廠的蒸汽用戶比較分散,用戶的用汽量數據是利用無線數據通訊方式傳回來的,并沒有寫入到PI數據庫,造成全廠實時數據的不完整,所以作者打算把這部分用戶用汽數據寫入PI數據庫中。要對PI數據庫進行寫的操作,感覺用PI-API更容易操作,所以本文用的是PI的API函數開發了數據采集程序,程序界面如圖2所示。
圖2 程序界面
部分代碼截圖如圖3所示,代碼中用戶名和密碼隱去。該段代碼是程序接收第三方系統發送過來的數據,經過處理后用PI-API函數寫入PI數據庫的代碼。
圖3 部分代碼截圖
5 PI-SDK的簡單應用
PI-SDK是面向對象的軟件開發工具包,在開始編程之前,首先需要安裝OSI提供的PI-SDK,安裝后會在PI的目錄中生成PISDK目錄,里面是PI的類庫文件,PISDK.dll為核心類,大部分主要功能都在該類中,PISDKCommon.dll是通用類,PITimeServer.dll是PI自定義的時間類,我們利用上述三個類庫就能夠完成訪問PI服務的主要功能。PISDK頂級類,下面是SERVERS類,在SERVERS類下面最重要的是SERVER類,SERVER類下面有很多類,其中我們要用到的最重要的是PIPOINTS類,其他類都有各自的功能,本文暫時用不到或者很少用到。
下面仍然以VB為例說明PI-SDK的大致用法。首先在VB程序中引用上面提到的PISDK.dll、PISDKCommon.dll、PITimeServer.dll三個類,然后就可以連接數據庫進行讀寫操作了。本文同樣編寫了一個讀寫PI數據庫的小程序,本文同樣在后面都做了說明,這樣看起來更加直觀。程序界面如圖4所示,通過輸入點名可以讀取快照值,也可以讀取指定時間的值。
圖4 程序界面
Private Sub Command1_Click() {讀取快照值}
Dim srv As server
Dim pn As PIPoint
Dim dt As PITimeFormat
Dim pv As PIValue
Dim t1 As String
Set srv = Servers("piserver") {指定要連接的PI服務器}
srv.Open "UID=piuser;pwd=password" {根據用戶和密碼連接上面的服務器}
Set pn = srv.PIPoints(Text1.Text) {想要取值的點名}
Set pv = pn.Data.Snapshot {取快照的值}
Text2.Text = pv.Value
End Sub
讀取快照值很簡單,比API更簡單。但是要讀取歸檔值就要麻煩一點,因為要給定讀取的時間和模式。
Private Sub Command2_Click() {讀取歸檔值}
Dim srv As server
Dim pn As PIPoint
Dim dt As PITimeFormat
Dim pv As PIValue
Dim t1 As String
Set srv = Servers("piserver") {指定要連接的PI服務器}
srv.Open "UID=piuser;pwd=password" {根據用戶和密碼連接上面的服務器}
Set pn = srv.PIPoints(Text1.Text) {想要取值的 點名}
Set dt = New PITimeFormat
t1=Format (text3.text , "YY-MMM - DDHH:MM:SS")
dt.InputString = t1 {把指定的時間轉換成PI的時間格式}
Setpv=pn.Data.ArcValue(dt,rtInterpolated){獲取指定時間的歸檔值,第一個參數就是時間,第二個參數是取數的模式,因為PI數據庫并不是每個時間都存有數據的,所以用戶可以選擇模式是讀取用戶輸入時間的當前點,后面一個點,前面一個點或者插值表示的時間}
Text2.Text = pv.Value
End Sub
PI-API嘗試過了,PI-SDK當然也要嘗試一下。某熱電廠的新建的#10#11機組準備上一塊LED大屏,用來顯示機組的主要運行參數,方便員工了解機組運行狀況。為了能方便地顯示機組運行參數,打算從PI數據庫中獲取相關運行參數,然后寫入到大屏顯示數據庫中,大屏控制軟件能通過讀取大屏數據庫顯示相關參數,程序界面截圖如圖5所示。
圖5 程序界面
部分代碼截圖如圖6所示。該段代碼是程序利用PI-SDK從PI數據庫中獲取相關數據,經過處理后寫入大屏顯示數據庫的部分代碼。程序應用了定時器,定時從PI數據庫中獲取數據,從而達到刷新大屏參數的目的。
圖6 部分代碼截圖
6 結束語
PI作為工廠底層控制系統與上層管理信息系統之間連接的橋梁,在工廠的信息化建設中扮演著特殊和重要的角色。PI是一個通用性的實時數據平臺,開發接口也比較方便,經過一段時間的摸索,在看了PI系統的幫助文件,對PI的開發有了初步的認識。總的說來,利用OSI提供的PI-API和PI-SDK開發也很方便,兩種方法各有各的優點,可以滿足不同場合的不同需求的應用。
作者簡介:
朱國海(1977-),男,浙江紹興人,工程師,學士,現就職于浙江巨化熱電有限公司,主要從事信息化管理工作。
參考文獻:
[1] OSIsoft. PI Server System Management Guide[Z]. 2011.
[2] OSIsoft. PI Server Reference Guide[Z]. 2011.
[3] 陳衛. 火力發電廠SISI建設的思考[J]. 電力信息化. 2006, (12) : 31 - 34.
摘自《自動化博覽》2023年8月刊