基于BP神經(jīng)網(wǎng)絡的PID控制器及仿真
1.引言
PID(比例-積分-微分)控制器作為最早實用化的控制器已有50多年歷史,因其具有算法簡單、魯棒性好、可靠性高、直觀性好等優(yōu)點被廣泛的應用于工業(yè)過程控制及運動控制中[1]。常規(guī)PID控制效果的優(yōu)劣,不僅僅取決于控制系統(tǒng)模型的精確程度,還必須調整好三個參數(shù)的關系,而這種關系不一定是簡單的線性組合。實際的工業(yè)過程及運動過程往往具有時變性、變參數(shù)、變結構等不確定性及很強的非線性,精確的數(shù)學模型難以建立,此外,常規(guī)PID還有實現(xiàn)在線調整困難,參數(shù)間相互影響,參數(shù)整定時間長等缺點,難以取得理想的控制效果。
隨著控制理論的發(fā)展,將應用廣泛的PID控制器與智能控制理論相結合[2]成為智能控制研究的新方向,神經(jīng)網(wǎng)絡算法具有逼近任意非線性表達能力,很強的自學習能力和概括推廣能力,在解決高度非線性和不確定系統(tǒng)方面有很大的的潛能,應用神經(jīng)網(wǎng)絡,可以從復雜的PID三個參數(shù)組合中尋求最佳的線性組合,使神經(jīng)網(wǎng)絡和PID本質結合。從而使得控制器具有較好的自適應性,實現(xiàn)參數(shù)的自動實時調節(jié),適應過程的變化,提高系統(tǒng)了的魯棒性和可靠性。
2.BP神經(jīng)網(wǎng)絡
2.1BP神經(jīng)網(wǎng)絡的構成及設計[3]
BP神經(jīng)網(wǎng)絡是一種具有三層或三層以上的神經(jīng)網(wǎng)絡,包括輸入層、隱含層、輸出層,上下層之間實現(xiàn)全連接,而每層神經(jīng)元之間無連接。當一對學習樣本提供給網(wǎng)絡后,神經(jīng)元的激活值從輸入層經(jīng)各中間層向輸出層傳播,在輸出層的各神經(jīng)元獲得網(wǎng)絡的輸入響應。接下來,按照減少目標輸出與實際誤差的方向,從輸出層經(jīng)過各中間層逐層修正各連接權值,最后回到輸入層,這種算法即BP算法。隨著這種誤差逆的傳播修正不斷進行,網(wǎng)絡對輸入模式響應的正確率也不斷上升。
(1)輸入輸出層的設計
輸入層的設計可以根據(jù)需要求解的問題和數(shù)據(jù)表示方式確定,若輸入信號為模擬波形,那么輸入層可以根據(jù)波形的采樣點數(shù)目撅腚輸入單元的維數(shù),也可以用一個單元輸入,這是輸入樣本為采樣的時間序列。輸出層的維數(shù)可以根據(jù)使用者的要求確定。如果BP網(wǎng)絡用作分類器,類別模式一共有m個,那么輸出層神經(jīng)元的個數(shù)為m或者。
(2)隱層的設計
隱層單元的數(shù)目與問題的要求、輸入/輸出單元的數(shù)目都有直接的關系,隱單元的數(shù)目太多會導致學習時間過長、誤差不一定最佳,也會導致容錯性差、不能識別以前沒有的樣本等等,因此,一定存在一個最佳的隱單元數(shù),通常用以下三個公式來選擇最佳隱單元數(shù):
1),其中k為樣本數(shù),n為輸入單元數(shù)。
2),其中m為輸出神經(jīng)元數(shù),n為輸入單元數(shù),a為[1,10]之間的常數(shù)。
3),其中n為輸入單元數(shù)。
2.2 典型神經(jīng)網(wǎng)絡結構
一個典型的三層神經(jīng)網(wǎng)絡結構如下圖所示:
圖1 BP神經(jīng)網(wǎng)絡結構圖
其中: 、 、…、 為 BP網(wǎng)絡的輸入; 、 、…、 為 BP網(wǎng)絡的輸出,對應PID控制器的三個參數(shù);為輸層到隱含層的連接權值;
為隱含層到輸出層的連接權值。通過神經(jīng)網(wǎng)絡的自學習、加權系數(shù)的調整,使神經(jīng)網(wǎng)絡輸出對應于某種最優(yōu)控制規(guī)律下的PID控制器參數(shù)。
圖一中各參數(shù)之間的關系[4]如下:
輸入層:
隱含層:
輸出層:
取性能指標為:,按照梯度下降法修正網(wǎng)絡的權值,使
最小,修正方法如下:
隱含層:
輸出層:
pid控制器相關文章:pid控制器原理
評論