www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > 小麥大叔
[導(dǎo)讀]這篇文章肝了好久,控制有時(shí)候給人的感覺是披著數(shù)學(xué)外衣的,但是脫下外衣,發(fā)現(xiàn)還是控制,本文有一些基本的推導(dǎo),無(wú)非是為最后的算法C實(shí)現(xiàn)做鋪墊,最終目的是能在實(shí)踐中進(jìn)行應(yīng)用和系統(tǒng)調(diào)優(yōu)。

0 前面的話

這篇文章肝了好久,控制有時(shí)候給人的感覺是披著數(shù)學(xué)外衣的,但是脫下外衣,發(fā)現(xiàn)還是控制,本文有一些基本的推導(dǎo),無(wú)非是為最后的算法C實(shí)現(xiàn)做鋪墊,最終目的是能在實(shí)踐中進(jìn)行應(yīng)用和系統(tǒng)調(diào)優(yōu)。

這首歌是趙小雷在參加訪談節(jié)目錄制過(guò)程中即興演唱的作品,但這個(gè)無(wú)心之舉卻受到了眾多聽眾的喜愛,包括我,推薦給大家。

目錄

  • 0 前面的話

  • 目錄

  • 1 先說(shuō)噪聲

  • 2 噪聲對(duì)于系統(tǒng)的影響

  • 3 對(duì)于PID控制器的影響

  • 4 加入濾波器

    • 4.1 傳遞函數(shù)

    • 4.2 串聯(lián)微分的等效形式反饋積分

  • 5 C語(yǔ)言實(shí)現(xiàn)

  • 6 參考

1? 先說(shuō)噪聲

在電子設(shè)備等電路系統(tǒng)中,噪聲是不被系統(tǒng)需要的電信號(hào);電子設(shè)備產(chǎn)生的噪聲會(huì)由于多種不同的影響而產(chǎn)生很大的差異。在通信系統(tǒng)中,噪聲是一個(gè)錯(cuò)誤或不希望出現(xiàn)的隨機(jī)干擾從而作用于有效的信號(hào)。

2? 噪聲對(duì)于系統(tǒng)的影響

噪聲出現(xiàn)的第一個(gè)場(chǎng)景,當(dāng)我們?cè)诮淌依镒鲇⒄Z(yǔ)聽力,然后旁邊的同學(xué)手機(jī)忽然來(lái)了一條短信,這時(shí)候往往可以聽到放英語(yǔ)聽力的喇叭會(huì)被干擾,然后會(huì)發(fā)出嗶嗶嗶的聲音;

下面是一個(gè)正弦信號(hào)跌加噪聲的例子,在原始信號(hào)上疊加一定幅度的高斯噪聲,可以看到信號(hào)不再像原來(lái)的正弦信號(hào)那樣完美,具體如下圖所示;

或者,很久很久以前,數(shù)字電視還沒有普及,那時(shí)候的顯像管的黑白電視,也容易出現(xiàn)這樣的雪花一樣的噪聲,疊加在圖片上就會(huì)出現(xiàn)這樣的效果,具體如下圖所示;

從上述的例子中可以看到,噪聲往往會(huì)對(duì)系統(tǒng)造成一定程度的影響,但是如果噪聲的幅度減小到一定程度,對(duì)于系統(tǒng)的影響可能就沒有那么容易被發(fā)現(xiàn)。

下面做一個(gè)實(shí)驗(yàn);在一張黑色圖片上疊加幅度很小幅度的高斯噪聲;從第二張圖片中發(fā)現(xiàn)噪聲沒有影響到整體圖片;??

然后我嘗試提高了整幅圖片的亮度,發(fā)現(xiàn),噪點(diǎn)便開始出來(lái)了,這像極平時(shí)那些槍版影片的馬賽克畫質(zhì);整體的實(shí)驗(yàn)結(jié)果如下圖所示;


3 對(duì)于PID控制器的影響

既然噪聲的幅度減小到一定程度,對(duì)于系統(tǒng)的影響可能就沒有那么容易被發(fā)現(xiàn),那么對(duì)理想的PID控制器又有什么影響呢?

不要忘了,在理想PID控制器中,微分控制器會(huì)對(duì)偏差的變化率(斜率)進(jìn)行累加,從而產(chǎn)生積分器的輸出;

對(duì)于微分器來(lái)說(shuō),即使噪聲幅度足夠小,但是只要達(dá)到足夠高頻率,偏差的變化率一樣可以變得很大,下面舉個(gè)例子;

這里有一個(gè)固定頻率 和賦值 的噪聲為信號(hào)1,這個(gè)信號(hào)可以表示為:

于是我們嘗試將信號(hào)1的幅度減半,頻率變?yōu)樵瓉?lái)的兩倍,得到了信號(hào)2

以此類推,在信號(hào)2的基礎(chǔ)上,幅度再減半,頻率乘以2,得到信號(hào)3

簡(jiǎn)單畫了一下這個(gè)信號(hào),具體如下圖所示;

假設(shè)分別取三個(gè)信號(hào)位于 該點(diǎn)的斜率,從圖中可以看到,斜率1,斜率2,斜率3是相同的,簡(jiǎn)單驗(yàn)證一下,在 時(shí)刻,可以得到:

所以這里就是求復(fù)合函數(shù)的微分,由于選取的點(diǎn)比較特殊,發(fā)現(xiàn)最終計(jì)算得到的結(jié)果 ,因此也可以發(fā)現(xiàn),即使減小了噪聲的幅度,但是對(duì)于較高頻率的噪聲,依然會(huì)產(chǎn)生較大斜率。

遇到高頻噪聲,那么微分器會(huì)產(chǎn)生較大的輸出,從而最終對(duì)系統(tǒng)造成影響,這是我們不希望出現(xiàn)的結(jié)果,因此在反饋回路中并不希望高頻噪聲進(jìn)入PID控制器的計(jì)算,這里就需要低通濾波器將噪聲濾除。

4 加入濾波器

低通濾波器可以濾除高頻信號(hào),這樣保留了有效信號(hào),可以設(shè)置所需的截止頻率;系統(tǒng)處理有效信號(hào),由于低頻部分信噪比較高,因此噪聲對(duì)于系統(tǒng)的影響較小,而高頻部分,信噪比就很低,這時(shí)候?qū)τ谙到y(tǒng)來(lái)說(shuō),噪聲就會(huì)造成不小的影響,具體如下圖所示;

信噪比:有效信號(hào)和噪聲的比值,英文名稱叫做SNR或S/N(SIGNAL-NOISE RATIO);

所以下面我們會(huì)在PID控制器的微分部分加入低通濾波器,這樣對(duì)反饋的信號(hào)進(jìn)行一部分處理,從而減小系統(tǒng)干擾,如下圖所示;

4.1 傳遞函數(shù)

概念拉普拉斯變換是對(duì)于 函數(shù)值不為零的連續(xù)時(shí)間函數(shù) 通過(guò)關(guān)系式 (式中 為自然對(duì)數(shù)底 的指數(shù))變換為復(fù)變量 的函數(shù) 。它也是時(shí)間函數(shù) 的“復(fù)頻域”表示方式。

也就是說(shuō)拉式變換可以將時(shí)域關(guān)系變換到頻域中,這樣可以便于系統(tǒng)進(jìn)行分析。

下面是本文下面會(huì)用到的時(shí)域函數(shù)對(duì)應(yīng)的拉普拉斯變換:

  • 積分:
  • 微分:
  • 低通濾波器的傳遞函數(shù):

低通濾波器中的截止頻率即為 ,單位是 ;

4.2 串聯(lián)微分的等效形式反饋積分

串聯(lián)等效傳遞函數(shù)的關(guān)系為,兩個(gè)方框串聯(lián)等于各個(gè)方框傳遞函數(shù)的乘積;具體如下所示;

因此低通濾波串聯(lián)微分的傳遞函數(shù)為:

閉環(huán)負(fù)反饋的等效傳遞函數(shù)的關(guān)系如下所示;

這里我們可以使用負(fù)反饋積分的方式,構(gòu)建等效于串聯(lián)微分的傳遞函數(shù),最終的傳遞函數(shù)結(jié)果是相同的,具體如下圖所示;

串聯(lián)微分的形式,可能在算法的實(shí)現(xiàn)上會(huì)更加直觀,但是會(huì)比較費(fèi)資源;

使用負(fù)反饋積分的等效形式進(jìn)行實(shí)現(xiàn),則進(jìn)一步減少了算法的資源消耗,下面給出一個(gè)TI公司的PID算法實(shí)現(xiàn)就是通過(guò)負(fù)反饋積分的等效形式進(jìn)行實(shí)現(xiàn)的。

5 C語(yǔ)言實(shí)現(xiàn)

這里直接使用了TI公司的PID算法,對(duì)于微分部分做了濾波的處理,并且使用的是負(fù)反饋積分的方式, 具體可以參考controlSUITE\libs\app_libs\motor_control\math_blocks\v4.2\pid_grando.hPID控制器的整體框圖如下所示,我們只關(guān)心微分部分;

首先可以發(fā)現(xiàn) 滿足:

這里濾波器有兩個(gè)系數(shù) ,它們必須滿足截止頻率 (單位Hz)和采樣周期 (單位秒)以下的關(guān)系:

C語(yǔ)言實(shí)現(xiàn)如下:

/*?=================================================================================
File?name:???????PID_GRANDO.H?
===================================================================================*/



#ifndef?__PID_H__
#define?__PID_H__

typedef?struct?{??_iq??Ref;??????//?Input:?reference?set-point
??????_iq??Fbk;??????//?Input:?feedback
??????_iq??Out;??????//?Output:?controller?output?
??????_iq??c1;??????//?Internal:?derivative?filter?coefficient?1
??????_iq??c2;??????//?Internal:?derivative?filter?coefficient?2
????}?PID_TERMINALS;
????//?note:?c1?&?c2?placed?here?to?keep?structure?size?under?8?words

typedef?struct?{??_iq??Kr;????//?Parameter:?reference?set-point?weighting?
??????_iq??Kp;????//?Parameter:?proportional?loop?gain
??????_iq??Ki;???????//?Parameter:?integral?gain
??????_iq??Kd;???????????//?Parameter:?derivative?gain
??????_iq??Km;???????????//?Parameter:?derivative?weighting
??????_iq??Umax;???//?Parameter:?upper?saturation?limit
??????_iq??Umin;???//?Parameter:?lower?saturation?limit
????}?PID_PARAMETERS;

typedef?struct?{??_iq??up;????//?Data:?proportional?term
??????_iq??ui;????//?Data:?integral?term
??????_iq??ud;????//?Data:?derivative?term
??????_iq??v1;????//?Data:?pre-saturated?controller?output
??????_iq??i1;????//?Data:?integrator?storage:?ui(k-1)
??????_iq??d1;????//?Data:?differentiator?storage:?ud(k-1)
??????_iq??d2;????//?Data:?differentiator?storage:?d2(k-1)?
??????_iq??w1;????//?Data:?saturation?record:?[u(k-1)?-?v(k-1)]
????}?PID_DATA;


typedef?struct?{??PID_TERMINALS?term;
??????PID_PARAMETERS?param;
??????PID_DATA??data;
????}?PID_CONTROLLER;

/*-----------------------------------------------------------------------------
Default?initalisation?values?for?the?PID?objects
-----------------------------------------------------------------------------*/
?????????????????????

#define?PID_TERM_DEFAULTS?{????\
???????? ?0,????\
???????????????????????????0,????\
???????????????????????????0,????\
???????????????????????????0,????\
???????? ?0????\
???????????????????}


#define?PID_PARAM_DEFAULTS?{???\
???????????????????????????_IQ(1.0),?\
???????????????????????????_IQ(1.0),??\
???????????????????????????_IQ(0.0),?\
???????????????????????????_IQ(0.0),?\
???????????????????????????_IQ(1.0),?\
???????????????????????????_IQ(1.0),?\
???????????????????????????_IQ(-1.0)??\
???????????????????}


#define?PID_DATA_DEFAULTS?{???????\
???????????????????????????_IQ(0.0),?\
???????????????????????????_IQ(0.0),??\
???????????????????????????_IQ(0.0),?\
???????????????????????????_IQ(0.0),?\
???????????????????????????_IQ(0.0),??\
???????????????????????????_IQ(0.0),?\
???????????????????????????_IQ(0.0),?\
???????????????????????????_IQ(1.0)??\
???????????????????}



/*------------------------------------------------------------------------------
??PID?Macro?Definition
------------------------------------------------------------------------------*/


#define?PID_MACRO(v)??????????\
???????????????\
/*?proportional?term?*/??????????\
v.data.up?=?_IQmpy(v.param.Kr,?v.term.Ref)?-?v.term.Fbk;?\
???????????????\
/*?integral?term?*/???????????\
v.data.ui?=?_IQmpy(v.param.Ki,?_IQmpy(v.data.w1,????\
(v.term.Ref?-?v.term.Fbk)))?+?v.data.i1;?????\
v.data.i1?=?v.data.ui;??????????\
???????????????\
/*?derivative?term?*/???????????\
v.data.d2?=?_IQmpy(v.param.Kd,?_IQmpy(v.term.c1,????\
(_IQmpy(v.term.Ref,?v.param.Km)?-?v.term.Fbk)))?-?v.data.d2;\
v.data.ud?=?v.data.d2?+?v.data.d1;???????\
v.data.d1?=?_IQmpy(v.data.ud,?v.term.c2);?????\
???????????????\
/*?control?output?*/???????????\
v.data.v1?=?_IQmpy(v.param.Kp,?????????\
(v.data.up?+?v.data.ui?+?v.data.ud));??????\
v.term.Out=?_IQsat(v.data.v1,?v.param.Umax,?v.param.Umin);?\
v.data.w1?=?(v.term.Out?==?v.data.v1)???_IQ(1.0)?:?_IQ(0.0);\
?

#endif?//?__PID_H__


6 參考

https://en.wikipedia.org/wiki/Low-pass_filter?

自動(dòng)控制原理 第五版 胡壽松 P47

雖然寫的不一定是最好,但是每一個(gè)字、每一個(gè)公式都是用心碼的,每一張圖都是用心畫的,每一句話都是加入了自己的理解,如果幫到了你,請(qǐng)無(wú)情三連吧;另外筆者能力有限,文中難免存在錯(cuò)誤和紕漏,望輕拍指正。

三面大疆慘敗,因?yàn)椴欢甈ID的積分抗飽和

增量式PID到底是什么?

?簡(jiǎn)易PID算法的快速掃盲?

?一文教你搞懂C語(yǔ)言的Q格式

??現(xiàn)成輪子OSAL操作系統(tǒng)抽象層的移植

?一招教你單片機(jī)固件快速瘦身

基礎(chǔ)知識(shí) | hex文件格式詳解


—— The End?—


長(zhǎng)按識(shí)別二維碼關(guān)注獲取更多內(nèi)容




免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉