国产欧美日韩精品a在线观看-国产欧美日韩精品一区二区三区-国产欧美日韩精品综合-国产欧美中文字幕-一区二区三区精品国产-一区二区三区精品国产欧美

ACS880-07C
關(guān)注中國自動化產(chǎn)業(yè)發(fā)展的先行者!
CAIAC 2025
2024
工業(yè)智能邊緣計(jì)算2024年會
2023年工業(yè)安全大會
OICT公益講堂
當(dāng)前位置:首頁 >> 案例 >> 案例首頁

案例頻道

PI實(shí)時數(shù)據(jù)庫簡單開發(fā)的探索
  • 企業(yè):    
  • 點(diǎn)擊數(shù):1756     發(fā)布時間:2023-08-30 13:04:16
  • 分享到:
本文簡單介紹了PI實(shí)時數(shù)據(jù)庫的相關(guān)信息,然后利用PI-SDK、PIAPI技術(shù)對PI實(shí)時數(shù)據(jù)庫進(jìn)行讀寫的一些方法,從而實(shí)現(xiàn)在PI實(shí)時數(shù)據(jù)庫的基礎(chǔ)上進(jìn)行簡單的二次開發(fā)的初步探索。

文獻(xiàn)標(biāo)識碼:B文章編號:1003-0492(2023)08-066-04中圖分類號:TP392

★朱國海(浙江巨化熱電有限公司,浙江衢州324000)

關(guān)鍵詞:PI;PI-SDK;PI-API;接口

1 引言

隨著計(jì)算機(jī)信息技術(shù)的飛速發(fā)展,電廠都已經(jīng)實(shí)現(xiàn)了底層生產(chǎn)用DCS系統(tǒng)、上層管理用MIS系統(tǒng)。為了實(shí)現(xiàn)上層MIS系統(tǒng)和底層DCS系統(tǒng)的溝通,SIS系統(tǒng)(Supervisory Information System in Plant Level)應(yīng)運(yùn)而生。隨著SIS系統(tǒng)的產(chǎn)生和發(fā)展,逐漸為多數(shù)業(yè)內(nèi)人士所接受,電廠信息化已經(jīng)走向SIS+MIS時代。SIS系統(tǒng)和MIS系統(tǒng)是電廠實(shí)現(xiàn)電力生產(chǎn)過程自動化和管理現(xiàn)代化的兩種不可缺少的工具,它們是相輔相成的。

2 SIS系統(tǒng)和PI實(shí)時數(shù)據(jù)庫

實(shí)時數(shù)據(jù)庫是SIS系統(tǒng)最基礎(chǔ)、最重要的核心組成部分。說到實(shí)時數(shù)據(jù)庫系統(tǒng),目前的產(chǎn)品有很多,PI(Plant Information System)是由美國OSI Software公司開發(fā)的一套商品化軟件應(yīng)用平臺,由于采用基于“螺旋門”的專利壓縮技術(shù)而使得存儲效率非常高。PI可在線存貯每個工藝過程點(diǎn)的多年數(shù)據(jù)。它提供了清晰、精確的操作情況畫面,用戶既可瀏覽工廠當(dāng)前的生產(chǎn)情況,也可回顧過去的生產(chǎn)情況,所以PI在國內(nèi)擁有很大的市場占有率,特別是在電力系統(tǒng)得到廣泛的運(yùn)用。

電廠建設(shè)SIS系統(tǒng)是為了可以開發(fā)各種應(yīng)用,從而使信息系統(tǒng)發(fā)揮出更大的作用。PI系統(tǒng)本身客戶端的應(yīng)用程序可使用戶很容易對工廠實(shí)施管理,諸如改進(jìn)工藝,TQC,故障預(yù)防維護(hù)等。通過PI可集成產(chǎn)品計(jì)劃、維護(hù)管理、專家系統(tǒng)、LIMS和優(yōu)化/建模等應(yīng)用程序,PI在業(yè)務(wù)管理和實(shí)時生產(chǎn)之間起到橋梁作用。同時PI數(shù)據(jù)庫也有完善的二次開發(fā)手段,包括應(yīng)用開發(fā)接口和數(shù)據(jù)庫訪問手段等。PI提供了對OPC、ODBC以及OLEDB等的支持。另外,它還有C/C++、VB環(huán)境下的SDK開發(fā)工具包和PI-API接口函數(shù)庫,利用PI-API和PISDK,用戶可以比較方便地進(jìn)行二次開發(fā)。

3 PI-SDK和PI-API

某熱電廠雖然已經(jīng)建立了全廠的網(wǎng)絡(luò)和PI實(shí)時數(shù)據(jù)庫,但上層的應(yīng)用大多處于起步階段,還沒有多少成熟的應(yīng)用,本文打算初步探索下PI-SDK和PI-API技術(shù),為今后二次開發(fā)做準(zhǔn)備。

PI-API(PI Application Programming Interface)即PI應(yīng)用程序接口,包含很多函數(shù)可以用來讀寫數(shù)據(jù)庫。利用這些函數(shù),用VB、C++或C#、甚至連PI-PROCESSBOOK中內(nèi)嵌的VBA都可以對PI數(shù)據(jù)庫進(jìn)行數(shù)據(jù)讀寫。

PI-SDK(PI Software Development Kit)即基于面向?qū)ο蟮脑L問PI數(shù)據(jù)庫的軟件開發(fā)工具包。作者個人感覺PI-SDK是把PI-API封裝了一下,讓開發(fā)人員更容易連接數(shù)據(jù)庫進(jìn)行讀寫。兩種方式本文都嘗試了一下,后面會分別探討。

4 PI-API的基本應(yīng)用

在開始編程之前,首先需要安裝OSI提供的PI-API,安裝后會在系統(tǒng)的SYSTEM32目錄中生成PIAPI32.DLL和PILOG32.DLL,在PI系統(tǒng)目錄下的INCLUDE目錄中生成PIAPI32.BAS。

下面以VB為例說明PI-API的大致用法。首先在VB程序中引用上面提到的PIAPI32.BAS,將它作為一個公用模塊,然后就可以按照以下步驟連接數(shù)據(jù)庫了。首先是連接數(shù)據(jù)庫、其次是獲取測點(diǎn)的內(nèi)部標(biāo)識號、然后通過內(nèi)部標(biāo)識號訪問數(shù)據(jù)、最后斷開數(shù)據(jù)庫的連接,調(diào)用相關(guān)API函數(shù),完成對PI數(shù)據(jù)庫的讀寫操作。下面是幾個主要函數(shù):

pilg_registerapp,piut_setservernode,piut_login,pipt_findpoint,pisn_getsnapshot,pisn_putsnapshot,piut_disconnect()。

作者編寫了一個讀寫PI數(shù)據(jù)庫的小程序,作者對每個函數(shù)后面都做了說明,這樣看起來更加直觀。程序界面如圖1所示,通過輸入點(diǎn)名可以讀取快照值,也可以寫入快照值。

image.png 

圖1 程序界面

Private Sub commandread_Click()

Dim pv '讀取到的值

Dim pd As Long 'pointid

Dim TagName As String ’PI數(shù)據(jù)庫點(diǎn)名

pilg_registerapp "piapi32.dll" {這是注冊PI的動態(tài)連接庫}

piut_setservernode "piserver" {設(shè)置要登錄的PI服務(wù)器}

piut_login "piuser", "password", 0 {根據(jù)用戶名和密碼登錄到上面設(shè)置的PI服務(wù)器,第一個參數(shù)是用戶名,第二個參數(shù)是密碼。}

TagName = Text1.Text {在文本框中輸入PI數(shù)據(jù)庫點(diǎn)名}

pipt_findpoint TagName,pd{根據(jù)輸入的PI數(shù)據(jù)庫點(diǎn)名獲取對應(yīng)的pointid,函數(shù)中的pd就是獲得的pointid。用戶平時應(yīng)用的時候一般習(xí)慣都是用TAGNAME,也就是PI數(shù)據(jù)庫點(diǎn)名,但是PI-API函數(shù)是用POINTID來存取的,所以要先根據(jù)TAGNAME來獲得POINTID號。}

pisn_getsnapshotpd,pv,0,0{獲取對應(yīng)點(diǎn)的快照值,第一個函數(shù)是POINTID,PV就是獲取到的值,第三和第四個參數(shù)值本文設(shè)的0,就是獲取當(dāng)前值}

Text2.Text=pv

pilg_disconnect{斷開與PI服務(wù)器的連接}

End Sub

以上就是獲取快照值的全部過程,寫入值和獲取值的過程差不多,就是最后用寫入函數(shù)。

Private Sub commandwrite_Click()

Dim pv '寫入的值

Dim pd As Long 'pointid

Dim TagName As String ’PI數(shù)據(jù)庫點(diǎn)名

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{寫入對應(yīng)點(diǎn)的快照值,第一個函數(shù)是POINTID,PV就是要寫入的值,第三和第四個參數(shù)值本文設(shè)的0。}

pilg_disconnect{斷開與PI服務(wù)器的連接}

EndSub

以上就是最基礎(chǔ)的利用PI-API讀取和寫入PI數(shù)據(jù)庫的操作,按照以上步驟用戶就能順利地把數(shù)據(jù)寫入到PI實(shí)時數(shù)據(jù)庫的快照中。除了能對快照進(jìn)行讀寫操作,PI-API還提供了能對已經(jīng)存檔的數(shù)據(jù)進(jìn)行讀寫的函數(shù),比如piar_value,可以獲取特定時間的存檔值,piar_putvalue可以把數(shù)據(jù)寫入數(shù)據(jù)存檔文件。

初步掌握PI-API數(shù)據(jù)庫讀寫操作后,本文進(jìn)行了簡單的開發(fā)嘗試。某熱電廠的蒸汽用戶比較分散,用戶的用汽量數(shù)據(jù)是利用無線數(shù)據(jù)通訊方式傳回來的,并沒有寫入到PI數(shù)據(jù)庫,造成全廠實(shí)時數(shù)據(jù)的不完整,所以作者打算把這部分用戶用汽數(shù)據(jù)寫入PI數(shù)據(jù)庫中。要對PI數(shù)據(jù)庫進(jìn)行寫的操作,感覺用PI-API更容易操作,所以本文用的是PI的API函數(shù)開發(fā)了數(shù)據(jù)采集程序,程序界面如圖2所示。

image.png 

圖2 程序界面

部分代碼截圖如圖3所示,代碼中用戶名和密碼隱去。該段代碼是程序接收第三方系統(tǒng)發(fā)送過來的數(shù)據(jù),經(jīng)過處理后用PI-API函數(shù)寫入PI數(shù)據(jù)庫的代碼。

image.png 

圖3  部分代碼截圖

5 PI-SDK的簡單應(yīng)用

PI-SDK是面向?qū)ο蟮能浖_發(fā)工具包,在開始編程之前,首先需要安裝OSI提供的PI-SDK,安裝后會在PI的目錄中生成PISDK目錄,里面是PI的類庫文件,PISDK.dll為核心類,大部分主要功能都在該類中,PISDKCommon.dll是通用類,PITimeServer.dll是PI自定義的時間類,我們利用上述三個類庫就能夠完成訪問PI服務(wù)的主要功能。PISDK頂級類,下面是SERVERS類,在SERVERS類下面最重要的是SERVER類,SERVER類下面有很多類,其中我們要用到的最重要的是PIPOINTS類,其他類都有各自的功能,本文暫時用不到或者很少用到。

下面仍然以VB為例說明PI-SDK的大致用法。首先在VB程序中引用上面提到的PISDK.dll、PISDKCommon.dll、PITimeServer.dll三個類,然后就可以連接數(shù)據(jù)庫進(jìn)行讀寫操作了。本文同樣編寫了一個讀寫PI數(shù)據(jù)庫的小程序,本文同樣在后面都做了說明,這樣看起來更加直觀。程序界面如圖4所示,通過輸入點(diǎn)名可以讀取快照值,也可以讀取指定時間的值。

image.png 

圖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服務(wù)器}

srv.Open "UID=piuser;pwd=password" {根據(jù)用戶和密碼連接上面的服務(wù)器}

Set pn = srv.PIPoints(Text1.Text) {想要取值的點(diǎn)名}

Set pv = pn.Data.Snapshot {取快照的值}

Text2.Text = pv.Value

End Sub

讀取快照值很簡單,比API更簡單。但是要讀取歸檔值就要麻煩一點(diǎn),因?yàn)橐o定讀取的時間和模式。

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服務(wù)器}

srv.Open "UID=piuser;pwd=password" {根據(jù)用戶和密碼連接上面的服務(wù)器}

Set pn = srv.PIPoints(Text1.Text) {想要取值的 點(diǎn)名}

Set dt = New PITimeFormat

t1=Format (text3.text , "YY-MMM - DDHH:MM:SS")

dt.InputString = t1 {把指定的時間轉(zhuǎn)換成PI的時間格式}

Setpv=pn.Data.ArcValue(dt,rtInterpolated){獲取指定時間的歸檔值,第一個參數(shù)就是時間,第二個參數(shù)是取數(shù)的模式,因?yàn)镻I數(shù)據(jù)庫并不是每個時間都存有數(shù)據(jù)的,所以用戶可以選擇模式是讀取用戶輸入時間的當(dāng)前點(diǎn),后面一個點(diǎn),前面一個點(diǎn)或者插值表示的時間}

Text2.Text = pv.Value

End Sub

PI-API嘗試過了,PI-SDK當(dāng)然也要嘗試一下。某熱電廠的新建的#10#11機(jī)組準(zhǔn)備上一塊LED大屏,用來顯示機(jī)組的主要運(yùn)行參數(shù),方便員工了解機(jī)組運(yùn)行狀況。為了能方便地顯示機(jī)組運(yùn)行參數(shù),打算從PI數(shù)據(jù)庫中獲取相關(guān)運(yùn)行參數(shù),然后寫入到大屏顯示數(shù)據(jù)庫中,大屏控制軟件能通過讀取大屏數(shù)據(jù)庫顯示相關(guān)參數(shù),程序界面截圖如圖5所示。

image.png 

圖5 程序界面

部分代碼截圖如圖6所示。該段代碼是程序利用PI-SDK從PI數(shù)據(jù)庫中獲取相關(guān)數(shù)據(jù),經(jīng)過處理后寫入大屏顯示數(shù)據(jù)庫的部分代碼。程序應(yīng)用了定時器,定時從PI數(shù)據(jù)庫中獲取數(shù)據(jù),從而達(dá)到刷新大屏參數(shù)的目的。

image.png 

圖6 部分代碼截圖

6 結(jié)束語

PI作為工廠底層控制系統(tǒng)與上層管理信息系統(tǒng)之間連接的橋梁,在工廠的信息化建設(shè)中扮演著特殊和重要的角色。PI是一個通用性的實(shí)時數(shù)據(jù)平臺,開發(fā)接口也比較方便,經(jīng)過一段時間的摸索,在看了PI系統(tǒng)的幫助文件,對PI的開發(fā)有了初步的認(rèn)識。總的說來,利用OSI提供的PI-API和PI-SDK開發(fā)也很方便,兩種方法各有各的優(yōu)點(diǎn),可以滿足不同場合的不同需求的應(yīng)用。

作者簡介:

朱國海(1977-),男,浙江紹興人,工程師,學(xué)士,現(xiàn)就職于浙江巨化熱電有限公司,主要從事信息化管理工作。

參考文獻(xiàn):

[1] OSIsoft. PI Server System Management Guide[Z]. 2011.

[2] OSIsoft. PI Server Reference Guide[Z]. 2011.

[3] 陳衛(wèi). 火力發(fā)電廠SISI建設(shè)的思考[J]. 電力信息化. 2006, (12) : 31 - 34.

摘自《自動化博覽》2023年8月刊

熱點(diǎn)新聞

推薦產(chǎn)品

x
  • 在線反饋
1.我有以下需求:



2.詳細(xì)的需求:
姓名:
單位:
電話:
郵件:
主站蜘蛛池模板: 天天拍拍夜夜出水| 午夜日韩视频| 亚洲欧美一区二区三区久本道 | 亚洲欧美在线免费观看| 视色4setv.com| 久草经典视频| 最新亚洲精品国自产在线| 日本aaaa级片| 国产亚洲一区二区三区在线| 91视频免费播放| 日本草草影院| 成年人在线观看网站| 日韩成人毛片高清视频免费看 | 国产成人啪精品视频免费软件| 亚洲最大情网站在线观看| 欧美国产日本| 在线看片中文字幕| 男人天堂亚洲| 国产成人综合高清在线观看| 亚洲欧美另类日本久久影院| 免费成年人视频网站| 一道本久久| 国内精品久久久久久久aa护士| 一区二区三区精品视频| 可以看毛片的网址| 亚洲精品国产福利一区二区三区 | a级片在线观看视频| 日本免费一区二区三区看片| 99色在线播放| 精品午夜久久网成年网| 中文字幕日本一区波多野不卡| 美女扒开腿让男生桶爽网站| 午夜欧美成人久久久久久 | 日本黄区| 伊人久久国产免费观看视频| 九一精品国产| 亚洲黄色软件| caoporen免费公开视频上传| 久久精品视频8| 亚洲一区日韩一区欧美一区a| 国外免费一级|