說句實話,一開始,和大家一樣,我對模擬量是不太當回事的。
我現在正在做的把LBP的架構從S7-1500移植到S7-1200,然后再到SMART 200 +KTP觸摸屏。做了其它的塊,但對模擬量是不在乎的。心里想,自己都有80模擬量的標準答案例程在手了, 就沒必要在這方面多花心思了。 需要的時候隨時可以拿出來把例程的程序用上快速的很。
所以,就越過了模擬量, 想動手搞PID塊的移植。
但卻感覺無從下手。 那些參數值設定值和運行值的處理,完全沒有感覺。不知道對LBP的PID塊該如何解耦,哪些部分改掉換成SMART自己的控制, 哪些部分借用。
所以決定, 還是先把模擬量部分完善了吧!
然而一旦動手開始搞了,才發現這里面的問題反而是最多的。
當然,這里講到的問題并不是說原本我做的80模擬量的例子錯了,或者不夠完善,不夠標準答案。
那里展示的只是調用的過程。
而我現在在做的就是FB塊的處理。 例子里面用到的那個模擬量處理的程序塊,功能還是太簡單了。
反對把物理單位作為一個參數,還要在觸摸屏上運行中或者設計模式進行修改。 然而即便去掉了單位, 對一個模擬量的處理,也還是有許多參數的。
在對LBP的程序塊進行簡化以后,它需要的參數分別有:
SP_rangeBegin | 量程下限 |
SP_rangeEnd | 量程上限 |
SP_limitAH | 高報警 |
SP_limitWH | 高警告 |
SP_limitWL | 低警告 |
SP_limitAL | 低報警 |
SP_timeout | 超時時間 |
SP_hysteresis | 遲滯區間 |
其中前兩者用于標定量程范圍, 3-6用于判斷觸發報警,7-8用于對報警的遲滯處理。
有人或許會覺得啰嗦,就簡單標定下量程的事, 搞這么復雜有意義嗎?
是的, 如果你還只是剛入門階段實現控制任務就萬事大吉, 有人提出整改意見的時候再專心整改,那確實沒啥。
但如果你希望有一個一勞永逸的標準化的設計,但凡客戶有可能提出的刁難問題,都提前想到,都事先做在里面,就有必要提前做些準備了。 多做比不做強,做了不用比用到的時候發現沒有相應的功能而需要臨時打補丁,要強。
比如量程,如果設備運行期間有需要進行校準,那么就會有需求要你給做成參數。 而如果系統中有模擬量不僅僅用于顯示,還要參與邏輯判斷, 那么多數情況下需要比較限定值后做出邏輯處理,那么就有了限定值參數和遲滯參數的需求。 哪怕系統中只有個別模擬量有需要,也應該盡量全部都做到,即為標準化。
而這些參數值,一方面需要運行中修改設定,另一方面又不可能全部指望下載程序后在運行畫面中輸入參數。 最理想的方式是,參數需要有一個初始值。 這個初始值未必準確,未必符合最終設備運行需要的參數,但它至少有個八九不離十,大致可用。 總比一開機全部都是0, 全部都是報警提示要好得多。
有過軟件開發的程序員都應該了解這樣一個常識,所有軟件安裝后都要有一個初始配置。 比如微信軟件安裝后,會有基本的字體和配色,然而可以個性化修改設定。
對應到工業系統工業設備,也存在一樣的需求。
然而,凡是對PLC編程有一定了解的人,都會知道,這個事情沒那么容易。 比如FB的IN管腳上一個參數值,你如果調用時給賦值了實參作為初始值,那么運行中就不再可以修改。 除非修改程序源代碼完全重新下載程序。
而如果不給設置實參, 那么它就會以統一的初始值,大部分為0。而且FB的多個實例之間還都是同一套初始值配置。
所以,要兼具上述兩種功能的話,上述的參數值其實需要2套,分別對應上述的功能。 那么在程序初次運行時,先采用初始值,而后運行中這個值才可以修改。
對于模擬量信號,后面的3-8條重要程度低一些,甚至可以統一設置,比如限制值都分別設置為90%, 80%, 20%, 10%,總差不多。
然而量程的上下限,則只能分成2套了。
由此,我在SMART 200中規劃的模擬量函數庫的變量接口表:
這是已經做到了極致的簡化,已經沒有再簡化的余地了。
然而看到,最后一個變量的地址是LD55, 即用到了LB58,已經接近了SMART子程序的上限。后面只剩下 LB59一個BYTE了。
即地址空間已經用光了,再無空間可用了。
問題就出現在了這里。
我按照LBP的架構功能實現的邏輯,其中有LOG15功能記錄了設備的運行記錄,最終觸摸屏顯示這個記錄時, 需要這個記錄的地址指針。 應該是一個DWORD, 原本是在L1層中生成的,需要輸出到其OUT管腳, 外層使用這個管腳獲得地址。
然而因為SMART 200的資源限制,我已經窮困到程序塊中接收這個地址的TEMP變量都沒有了。
所以迫不得已,我只好暫時先用了一個MD20的變量做了傳遞。
我實在是太難了!
因為這一段的功能,是LBP也尚未考慮到的,所以多出來的邏輯還是自己再想辦法實現的。
有人會替我擔憂我在子程序塊中使用了M變量,是否會帶來錯誤,會導致程序塊不能被重復調用。 這完全不必擔心。 因為再多的對象實例, 使用的同一個變量,用過就丟了,無所謂。
也會有人指責我違背了自己承諾的PLC編程不使用全局變量的規則。 沒錯,我這兒也難受著呢!
如果不較真,整個程序中僅次一處使用M量,也不傷大雅。 如果較真,以后可以再看看想辦法做個場景保存和恢復的功能。
即,打一個補丁處理一下。
審核編輯:劉清
-
模擬量
+關注
關注
5文章
491瀏覽量
25579 -
SMART
+關注
關注
3文章
224瀏覽量
44720 -
S7-1200
+關注
關注
11文章
331瀏覽量
18010 -
LBP
+關注
關注
0文章
14瀏覽量
8964 -
S7-1500
+關注
關注
3文章
300瀏覽量
6451
原文標題:0323 【萬泉河】 最難還是模擬量
文章出處:【微信號:PLC標準化編程,微信公眾號:PLC標準化編程】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論