0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

淺談四旋翼飛行器的設(shè)計

兆易創(chuàng)新科技 ? 作者:兆易創(chuàng)新科技 ? 2019-10-25 10:07 ? 次閱讀

前言:

相比直升機來說,四旋翼乃至多旋翼飛行器的機械結(jié)構(gòu)簡單,操控靈活,飛行穩(wěn)定,體積也能做的更小,當(dāng)然也能更大,它將直升機復(fù)雜的機械結(jié)構(gòu)設(shè)計難度轉(zhuǎn)化到了電子電路和算法上面,因此四旋翼飛行器的設(shè)計更容易上手,更民眾化。

四旋翼飛行器的軟件核心包括兩大部分:姿態(tài)融合算法和控制算法;硬件核心便是MCU傳感器。

先介紹下姿態(tài)融合算法,姿態(tài)融合說白了就是將3軸加速度、3軸角速度和3軸磁場強度融合成四元數(shù),再將四元數(shù)轉(zhuǎn)化為歐拉角,最后將歐拉角最為控制量輸送到所有電機以達控制飛行器姿態(tài)的目的。歐拉角包括偏航角Yaw、俯仰角Pitch和滾動角Roll。我用的算法是Madgwick寫的AHRSUpdateIMUUpdate,簡單有效,其中AHRSUpdate是融合了陀螺儀、加速度計和磁力計,而IMUUpdate只融合了陀螺儀和加速度計,就優(yōu)缺點來說,IMUupdate算法只融合了加速度計和陀螺儀的數(shù)據(jù),還需要使用互補濾波算法來融合磁力計以修正偏航角Yaw,不然飛行器會找不到北,但是這種互補濾波有個小問題,就是假如定義偏航角的范圍是0-360度,那么當(dāng)機頭大概從北偏西1度轉(zhuǎn)到北偏東364度時,機頭會經(jīng)過0(360)這個點,那么這時,yaw不會直接1-0-364這么變化,而是會被逆向積分從 1-20-180-270-364這么轉(zhuǎn)一圈,這是個不好的現(xiàn)象,實驗了半天也沒有解決,而AHRSupdate很好的解決了這個問題,不過由于AHRSupdate把磁力計的數(shù)據(jù)融合進了所有歐拉角,因此當(dāng)傳感器受到外圍強磁場干擾時,就會造成全方位失控,導(dǎo)致墜機,而使用IMUupdate算法,頂多飛行器會轉(zhuǎn)圈而已。

傳感器我用的是invensense公司MPU9150,MPU9150芯片集成了加速度計、陀螺儀和磁力計,并且內(nèi)置硬件DMP用于姿態(tài)融合,不過不好用;MCU則用是Gigadevice公司的GD32F103系列,由于我也是剛接觸四旋翼飛行器,第一個目的當(dāng)然是能夠平穩(wěn)的飛起來,暫不考慮加入其他外圍設(shè)備。后續(xù)可能會考慮使用GD32F107或者GD32F2xx系列,可擴展攝像頭小玩一把航拍,當(dāng)然更好的是GD32F4xx系列(期盼中),自帶浮點運算單元,由于我軟件太菜,算法中出現(xiàn)大量的浮點運算導(dǎo)致姿態(tài)更新頻率和控制頻率達不到很高。

做四軸飛行器也是為了好玩,目前我只完成了第一步:姿態(tài)融合。接下來才是更重要的,選擇合適的機架、電調(diào)、電機、螺旋槳,寫PID控制代碼,系統(tǒng)整合以后還要調(diào)試各種參數(shù),抗干擾,抗震動,最后還要加各種應(yīng)用器件。在此鼓勵一下自己,堅持就是勝利,慢慢磨洋工。

我現(xiàn)在軟件實現(xiàn)的功能:算法用AHRSupdate、陀螺儀零偏校準(zhǔn)、加速度計平滑濾波、磁力計平面校準(zhǔn),以后看情況可能會慢慢更新加速度計精確校準(zhǔn)、磁力計橢球擬合校準(zhǔn)、陀螺儀溫度補償?shù)取?/span>

第一部分:硬件

1.傳感器:MPU9150INVENSENSE公司的,單芯片內(nèi)集成了加速度計、陀螺儀和磁力計,并且內(nèi)置DMP用于姿態(tài)融合,不過只融合了加速度計和陀螺儀,沒有融合磁力計進去,具有自校準(zhǔn)功能,價格比MPU6050貴很多,但是省PCB面積,省事,軸向重合度高。實際上就是把MPU6050和磁力計AK8975放在同一個芯片里,程序還是使用MPU6050的驅(qū)動,缺點是會偶爾丟失數(shù)據(jù),自帶的姿態(tài)融合算法的更新頻率不高);

2.MCUGD32F103CBGigadevice公司的,ARMcortex-M3內(nèi)核,32MCU,主頻最高108Mhz,48Pin,與ST同型號的32MCU 直接兼容,性價比更高,外接8M晶振,也可使用內(nèi)部8M晶振,晶振遠離傳感器,避免干擾磁力計,不過當(dāng)時考慮不周,這個芯片的timer太少了,以后會先采用GD32F103VCT6或者GD32F107VCT6);

3.電源芯片TLV70233DBVRTILDO,輸入2-6V,輸出3.3V,只需要外接2X7R無極性陶瓷電容,價格太高)

4.串口:MAX3232(方便調(diào)試)

5.USB供電,輸出電壓5V

6.目前機架、電調(diào)、電池、電機和螺旋槳已買好,來張圖,比較大眾化:

上圖:

1PCB3D效果圖,測試版,先追求調(diào)通得出姿態(tài)角,后續(xù)改版會做大的調(diào)整:

第二部分:軟件

1.使用keiluvision4.1.0,工具鏈:RealViewMDK-ARM Version4.12

2.驅(qū)動:官方的MPU6050驅(qū)動inv_mpu.cinv_mpu_dmp_motion_driver.c;

先看幾個圖,然后再說坐標(biāo)軸的設(shè)定和算法部分。

上圖:

1:系統(tǒng)初始化,順序從上到下依次是:初始化MPU、設(shè)置需要使用哪些傳感器、設(shè)置陀螺儀測量范圍(我設(shè)的是正負500/s)、設(shè)置加速度計測量范圍(我設(shè)的是正負4g)、配置fifo、設(shè)置采樣率、裝載DMP、設(shè)置陀螺儀軸向(比較重要)、使能DMP的一些玩意兒、設(shè)置DMPFIFO、自校準(zhǔn)陀螺儀和加速度計、開啟DMP、開始姿態(tài)融合,見下圖:

2:由四元數(shù)求出的最終姿態(tài)角,其中Yaw為航向角,表示機頭偏離正北方多少度,范

-180+180;Pitch為俯仰角,表示機頭正方向與水平線的夾角,范圍-90+90;Roll為翻滾角,表示機翼與水平線的夾角,范圍:-180+180。下圖為機身水平,且機頭正北偏西37度左右的數(shù)據(jù):

3:下圖為機翼水平,機頭指向正北,且機頭向下25度的數(shù)據(jù)

4:下圖為機頭指向正北,保持水平,且機翼的右翼向下傾斜23度的數(shù)據(jù)

5:看下歐拉角的奇異點,在奇異點處一個轉(zhuǎn)動狀態(tài)對應(yīng)無窮多組自由度值,當(dāng)物體轉(zhuǎn)到這些奇異點附近,便沒法求解。圖中當(dāng)Pitch+90度時,機體的姿態(tài)便沒法控制,Roll的軸向發(fā)生了變化。如下圖:

第三部分:如何確定自己的軸向

首先,軸向的定義跟初始化四元數(shù)和最后結(jié)算的歐拉角有關(guān),跟四元數(shù)更新算法無關(guān),換句話說,不管你的軸向如何定義,姿態(tài)融合算法隨便用,但是初始化四元數(shù)的公式和最后結(jié)算歐拉角的公式要做適當(dāng)?shù)母淖?,這個后面算法中有說。加速度計也好,陀螺儀也好,磁力計也好,他們的軸向都要滿足右手定理,如下圖:

再附上一段注釋用于解釋如何定義合理的軸向,以及如何正確旋轉(zhuǎn)傳感器的軸向,解釋這么多其實就是說定義好的軸向要滿足右手定理,如下圖:

下圖,旋轉(zhuǎn)前是[x y z],旋轉(zhuǎn)后就是[-y x z]

下圖是如何確定旋轉(zhuǎn)角度的正方向,用右手握住坐標(biāo)軸,拇指指向軸向的正方向,四個指頭彎曲的方向就是旋轉(zhuǎn)角度的正方向,在初始化四元數(shù)時,計算出的歐拉角的正方向也要滿足這個條件:

我的程序使用的軸向如下圖所示,未作任何改變:

第四部分:算法

第一步是校準(zhǔn),加速度計和陀螺儀我用的是MPU9150內(nèi)部自校準(zhǔn),磁力計的校準(zhǔn)采用如下方法:見附件-磁力計校準(zhǔn)

第二步是初始化四元數(shù),常見的軸向定義是繞x軸旋轉(zhuǎn)是Roll,繞y軸旋轉(zhuǎn)是Pitch,繞z軸旋轉(zhuǎn)是Yaw,我的程序中也有這樣的定義,不過被我注釋掉了,這里舉個另外一種軸向定義來對初始化四元數(shù)進行說明,方便比較,也是我目前正在用的軸定義。

下面我們來定義繞x軸旋轉(zhuǎn)是Pitch,繞y軸旋轉(zhuǎn)是Roll,繞z軸旋轉(zhuǎn)是Yaw,軸向的正方向如上圖一樣,不變。

先對加速度計和磁力計的數(shù)據(jù)進行處理,得到init_xx來供我們使用如下圖:

然后通過公式計算出初始化的RollPitch、Yaw,注意加負號保證旋轉(zhuǎn)角度的正方向,如下圖:

其中Yaw的正方向未必對,可以自己去驗證下,具體參考公式見附件-ST電子羅盤計算Yaw

然后由上面的歐拉角求出初始化四元數(shù),這時要注意旋轉(zhuǎn)順序的不同,公式也不同,大部分旋轉(zhuǎn)順序是Z-Y-X,我的程序里也用的這個順序,在這里我們按Z-X-Y的順序來旋轉(zhuǎn),并得出求四元數(shù)的公式以做比較,其旋轉(zhuǎn)矩陣:

q=qyaw*qpitch*qroll=

(cos(0.5*Yaw)+ksin(0.5*Yaw)) *(cos(0.5*Pitch)+isin(0.5* Pitch)) * (cos(0.5*Roll)+jsin(0.5* Roll))

得出初始化四元數(shù)計算公式如下圖所示:

其中i,j,k之間相乘的順序不能隨意變,在前的先計算,在后的后計算相乘的公式如下圖:

至此初始化四元數(shù)完成。

第三步就是使用AHRSUpdate算法了,用完以后再根據(jù)公式計算出歐拉角,此公式跟旋轉(zhuǎn)順序和旋轉(zhuǎn)使用的軸向有關(guān),我們的旋轉(zhuǎn)順序是Z-X-Y,且繞ZYaw,繞XPitch,繞YRoll,推到過程如下圖:

首先得出3個方向余旋矩陣:

下圖繞ZYaw

下圖繞Xpitch

下圖繞YRoll

然后按照我們的Z-X-Y順序求得C=Croll * Cpitch * Cyaw,如下圖:

將上圖的方向余旋矩陣C與下圖的四元數(shù)姿態(tài)矩陣做對比,即可求出歐拉角,注意上圖的方向余旋矩陣C是隨著我們對坐標(biāo)軸的定義變化而變化的,而下圖的四元數(shù)姿態(tài)矩陣是固定的:

最后一步就是求出歐拉角,公式如下圖:

以下是靜止時,剛上電時的數(shù)據(jù):

以下是上電半個小時以后的數(shù)據(jù):

可以看出正常的靜止?fàn)顟B(tài)下,數(shù)據(jù)的波動范圍是不超過1度的,也不會有漂移。具體效果還需要上機架飛起來以后再做調(diào)整。

最后總結(jié)一下:

我的代碼中,,并且我定義:Yaw北偏西為正,pitch往上為正,roll“右翼下沉為正。傳感器坐標(biāo)軸:繞y旋轉(zhuǎn)是 roll,繞x旋轉(zhuǎn)為pitch,繞z旋轉(zhuǎn)為yaw。代碼里只有姿態(tài)更新,72Mhz主頻下更新頻率在350-400Hz,108Mhz下可以達到400-500Hz,目前我采用定時器定時,代碼跑108Mhz,使姿態(tài)更新頻率控制在400Hz

注意跑108Mhz時,需要修改延遲函數(shù)和串口函數(shù),適當(dāng)增加一下延遲函數(shù)的數(shù)值避免I2C通信失敗,修改串口函數(shù)是為了避免108Mhz下串口亂碼問題,具體修改方式參考論壇頂置帖子http://bbs.21ic.com/iclist-182-1.html。

最后感謝所有幫助過我的人。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式主板
    +關(guān)注

    關(guān)注

    7

    文章

    6081

    瀏覽量

    34936
  • 四旋翼飛行器
    +關(guān)注

    關(guān)注

    18

    文章

    76

    瀏覽量

    40243
  • 兆易創(chuàng)新科技

    關(guān)注

    1

    文章

    14

    瀏覽量

    2932
收藏 人收藏

    評論

    相關(guān)推薦

    飛行器的設(shè)計

    微型飛行器是一種以4個電機作為動力裝置.通過調(diào)節(jié)電機轉(zhuǎn)速來控制飛行的欠驅(qū)動系統(tǒng);為了實現(xiàn)
    發(fā)表于 11-28 09:29

    飛行器電路

    有木有飛行器電路的?
    發(fā)表于 05-15 20:01

    飛行器資料

    飛行器資料
    發(fā)表于 06-06 20:06

    基于stm32的飛行器

    基于stm32的飛行器
    發(fā)表于 07-13 13:38

    【MiCOKit申請】基于物聯(lián)網(wǎng)的飛行器

    申請理由:本人想利用MICOKIt主板和其配套的擴展板設(shè)計一個基于網(wǎng)的飛行器,其擴展板上的WIfi模塊、溫濕度傳感、大氣壓傳感
    發(fā)表于 07-31 21:17

    飛行器

    `一.飛行器簡介
    發(fā)表于 10-23 11:30

    飛行器設(shè)計(1

    飛行器設(shè)計(1
    發(fā)表于 06-10 10:52

    飛行器結(jié)構(gòu)和原理+飛行diy全套入門教程

    飛行器結(jié)構(gòu)和原理+飛行diy全套入門教程基于STM32的
    發(fā)表于 01-14 22:06

    飛行器設(shè)計指南(原理、程序、電機資料)

    推薦課程:張飛飛行器視頻套件,76小時吃透軸算法http://t.elecfans.com/topic/40.html?elecfa
    發(fā)表于 02-18 15:02

    淺析飛行器

    1.選題的背景與意義1.1的發(fā)展背景早在1907年,由Breguet-Richet發(fā)明的世界上第一家
    發(fā)表于 08-06 08:22

    飛行器控制模型

    飛行器控制模型為便于建立模型,現(xiàn)對
    發(fā)表于 09-15 07:22

    飛行器怎么樣?

    飛行器怎么樣?
    發(fā)表于 12-20 07:35

    飛行器基本知識

    飛行器基本知識(
    發(fā)表于 11-10 15:14 ?0次下載

    飛行器資料

    飛行器資料。
    發(fā)表于 03-14 09:43 ?80次下載

    飛行器的設(shè)計與制作

    簡述飛行器的核心制作
    發(fā)表于 12-17 10:06 ?15次下載