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

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

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

機器人搭建過程中的坑和未來的改進方向

STM32嵌入式開發(fā) ? 來源:CSDN博客 ? 作者: Jumping潤 ? 2021-09-26 10:59 ? 次閱讀

機器人整體開源,同時總結一下機器人搭建過程中遇到的坑和未來的改進方向。在分享的文件里包含了結構設計、程序控制、電路設計以及其他模塊相關資料供大家參考。

機器人原理分析

該機器人根據(jù)陀螺儀的位姿數(shù)據(jù),通過三個全向輪驅(qū)動底部球體調(diào)整自己在球上的位置,保持動態(tài)平衡的同時實現(xiàn)全向移動。

保持動態(tài)平衡過程需要對機器人進行運動學分析,這里參考了平衡小車之家的運動學方程:

自平衡控制問題轉化為三步:輸入X、Y角度—控制器計算—輸出A、B、C電機轉速的控制模型。

控制器設計

首先考慮參考平衡車控制,球上自平衡機器人本質(zhì)上依然是一個一階倒立擺問題。

這里參考了飛思卡爾直立車的控制方法,采用串級PID控制器,外環(huán)PD角度環(huán),內(nèi)環(huán)速度PI環(huán)。

由于我的驅(qū)動方案選擇的是42步進電機,在速度閉環(huán)的時候有些問題。正常的直流電機+編碼器的控制方案可以通過編碼器將輪子的真實速度計算出來,從而和控制器的理想轉速作差,實現(xiàn)速度控制。

而我這里的速度閉環(huán)是通過計算上一個時鐘周期時給步進電機的控制量,通過運動學方程分解,得到機器人的虛擬速度,與理想轉速作差控制。我認為這種速度閉環(huán)方式還是存在一定缺陷的,但是在網(wǎng)上查看論文的時候我發(fā)現(xiàn)有很多自平衡機器人都是用42步進電機來實現(xiàn)速度閉環(huán)的,不知道是什么方法。

這里還可以好好思考一下為什么角度環(huán)要用PD控制,速度環(huán)要PI控制,角度環(huán)的P部分和D部分對機器人控制有什么影響?在很多CSDN調(diào)試平衡車的博客中都有解釋,這里就留給大家思考了。

硬件及結構設計

自平衡機器人的硬件清單有:

56mm全向輪 45元/個

42步進電機 25/個

42步進閉環(huán)模塊 59.8元/個

LM2596S降壓模塊 20元

STM32F103C8T6-4飛控板 59.8元

GY-521六軸陀螺儀 25元

用到的模塊大致如上所示,C8T6的價格隨著最近芯片漲價直線上升,我白嫖了實驗室的兩塊板子,現(xiàn)在買一塊實在太貴,可以等芯片價格穩(wěn)定一些再買。其余開關排針等常見元件不再贅述。

電路原理圖如下所示:

7cbf0d6e-136a-11ec-8fb8-12bb97331649.png

機器人使用solidworks設計整體結構,底板可在某寶定制6050太空鋁切割,藍色件為正常3D打印件。

程序部分

keil 5中開發(fā)STM32。

控制程序采用定時器0.5ms定時中斷的方式進行計算,每觸發(fā)兩次中斷計算對電機控制一次,這里還是推薦大家采用外部中斷讀取GY-521上的INT引腳的方式,控制計算周期。GY-521上的INT引腳每5ms觸發(fā)一次跳變,采用外部中斷的方式可以嚴格保證讀取位姿數(shù)據(jù)與計算處理同步。

int TIM1_UP_IRQHandler (void) { u8 key_cal; if(TIM_GetITStatus(TIM1,TIM_IT_Update) != RESET) { TIM_ClearITPendingBit(TIM1,TIM_IT_Update); flag_target=!flag_target; key_cal=KEY_Scan(0); if(state_flag==1)//矯正結束 { if(flag_target==1)//每讀取兩次陀螺儀控制一次 { Read_DMP(); //===讀取傾角 scope();

return 0; } } if(key_cal==1)//矯正按鍵 { Angle_Zero_X=Angle_Balance_X; Angle_Zero_Y=Angle_Balance_Y; key_cal=0; Flag_Stop=0; } if(key_cal==2||key_cal==3)//矯正按鍵 { Flag_Stop=1;//關閉速度環(huán)I積分 key_cal=0; } Angle_Bias_X =Angle_Balance_X-Angle_Zero_X;

//獲取Y方向的偏差 Angle_Bias_Y =Angle_Balance_Y-Angle_Zero_Y; //獲取Y方向的偏差 if(control_mode==0)//PID控制模式 { Encoder_Analysis(Motor_A,Motor_B,Motor_C); //正運動學分析,得到X Y方向的速度 Balance_Pwm_X= balance_X(Angle_Bias_X,Gyro_Balance_X);

//X方向的傾角控制 Balance_Pwm_Y=-balance_Y(Angle_Bias_Y,Gyro_Balance_Y); //Y方向的傾角控制// if(++flag_target_2==4)//速度環(huán)頻率慢于加速度環(huán) 但是還沒加速度環(huán) // { Velocity_Pwm_X=velocity_X(compute_X);

//X方向的速度控制 Velocity_Pwm_Y=velocity_Y(compute_Y); //Y方向的速度控制 // flag_target_2=0;// } Move_X =Balance_Pwm_X+Velocity_Pwm_X;

//===X方向控制量累加 Move_Y =Balance_Pwm_Y+Velocity_Pwm_Y; //===Y方向控制量累加 Move_Z=0; Kinematic_Analysis(Move_X,Move_Y,Move_Z);//逆運動學分析得到ABC電機控制量 } Motor_A=Target_A;//直接調(diào)節(jié)PWM頻率 Motor_B=Target_B;//直接調(diào)節(jié)PWM Motor_C=Target_C;//直接調(diào)節(jié)PWM//以下都是為了速度連續(xù)化處理防止突變

if(Motor_A==0) Motor_A=motor_a_last; if(Motor_B==0) Motor_B=motor_b_last; if(Motor_C==0)

Motor_C=motor_c_last; Xianfu_Pwm(2000); Set_Pwm(Motor_A,Motor_B,Motor_C);

Gyro_Balance_X_last=Gyro_Balance_X; Gyro_Balance_Y_last=Gyro_Balance_Y;

Gyro_Balance_Z_last=Gyro_Balance_Z; Angle_Balance_X_last=Angle_Balance_X;

Angle_Balance_Y_last=Angle_Balance_Y; Angle_Balance_Z_last=Angle_Balance_Z;

motor_a_last=Motor_A; motor_b_last=Motor_B; motor_c_last=Motor_C; } return 0;}

對于電機控制,由于采用的驅(qū)動方案是步進電機,調(diào)速的方式是改變驅(qū)動步進電機的脈沖頻率。我這里選擇了三個定時器,動態(tài)調(diào)節(jié)定時器的頻率,具體方式是在初始化時設定好定時器的預分頻系數(shù)psc的值,然后在程序里動態(tài)更改ARR寄存器的值,從而改變定時器的定時頻率。

//這里以A電機的速度控制為例 輸入為 電機方向和電機速度void set_motorA_speed(u8 dir,u16 speed){ u32 arr; arr=speed; TIM_ARRPreloadConfig(TIM3,DISABLE); TIM3-》ARR=arr;//計數(shù)到10000在歸零重新計數(shù) TIM3-》CCR4=arr/2;//保持占空比為50% TIM_ARRPreloadConfig(TIM3,ENABLE); TIM_Cmd(TIM3,ENABLE);

if(dir==0) { GPIO_SetBits(GPIOA,GPIO_Pin_1); } else { GPIO_ResetBits(GPIOA,GPIO_Pin_1); }}

小車的運動學分解代碼實現(xiàn)如下,參考了平衡小車之家的代碼:

/**********************************************************函數(shù)功能:小車運動數(shù)學模型入口參數(shù):X Y Z 三軸速度或者位置返回 值:無***********************************************************/void Kinematic_Analysis(float Vx,float Vy,float Vz)

{ Target_A = Vx + L_PARAMETER*Vz; Target_B = -X_PARAMETER*Vx + Y_PARAMETER*Vy + L_PARAMETER*Vz; Target_C = -X_PARAMETER*Vx - Y_PARAMETER*Vy + L_PARAMETER*Vz;}/*****************************************************************函數(shù)功能:小車運動 正運動學分析 入口參數(shù):A B C三個電機的速度返回 值:無******************************************************************/void Encoder_Analysis(float Va,float Vb,float Vc){ compute_X=(Va*2-Vb-Vc); compute_Y=((Vb-Vc)*sqrt(3)); compute_Z=(Va+Vb+Vc); }

其余代碼不全放出,可在文末點擊“閱讀原文”下載查看。

總結與展望

球上自平衡機器人可以作為算法試驗平臺, 輸入輸出固定,更換不同控制器,將數(shù)據(jù)導入MATLAB進行分析即可比較控制器性能。

個人認為結構有兩個改進方向,一方面參考以下論文:余義。 單球驅(qū)動自平衡機器人位姿解算與控制系統(tǒng)研究[D]。武漢科技大學,2019。論文中采用的四足式驅(qū)動結構更有利于機器人自平衡控制。

另一方面可以增加球體和機器人固定裝置,利用機械結構將機器人與底部驅(qū)動球結合成一個整體防止機器人跳輪等問題。同時驅(qū)動球?qū)τ跈C器人平衡的影響較大,最好還是定制空心鋼球,然后噴漆增大摩擦力,最有利于機器人自平衡控制。

控制部分的改進,首先是控制原理,本文是針對建立好的運動學方程進行分析,通過串級PID算法來實現(xiàn)自平衡運動。該機器人的控制問題本質(zhì)上是一階倒立擺問題,可以采用動力學建模的方式,通過動力學分析算出平衡需要的虛擬力矩,再對電機進行力矩控制。

其次是控制器,PID控制算法應用廣泛但也有一定的缺點,可以考慮采用模糊PID,ADRC自抗擾控制器,強化學習等智能控制算法對機器人自平衡進行控制。

原文鏈接:https://blog.csdn.net/qq_42823167/article/details/118085368

責任編輯:haq

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

    關注

    211

    文章

    28466

    瀏覽量

    207330
  • STM32
    +關注

    關注

    2270

    文章

    10904

    瀏覽量

    356367

原文標題:STM32自平衡機器人項目,附代碼、電路圖等資料

文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發(fā)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    【「具身智能機器人系統(tǒng)」閱讀體驗】2.具身智能機器人大模型

    的設計不僅提高了機器人對環(huán)境的理解能力,還使其能夠更精準地執(zhí)行復雜任務。 擴散模型的新思路 除了大模型,擴散模型的引入為機器人控制開辟了新的研究方向。在以UniPi為代表的創(chuàng)新工作
    發(fā)表于 12-29 23:04

    【「具身智能機器人系統(tǒng)」閱讀體驗】1.初步理解具身智能

    、家庭服務機器人等。具身智能機器人技術與市場的融合閉環(huán)是自主經(jīng)濟重要的發(fā)展方向之一。 具身智能機器人是一種能夠在沒有人類直接控制的情況下自
    發(fā)表于 12-28 21:12

    【「具身智能機器人系統(tǒng)」閱讀體驗】+數(shù)據(jù)在具身人工智能的價值

    嵌入式人工智能(EAI)將人工智能集成到機器人等物理實體,使它們能夠感知、學習環(huán)境并與之動態(tài)交互。這種能力使此類機器人能夠在人類社會中有效地提供商品及服務。 數(shù)據(jù)是一種貨幣化工具 數(shù)據(jù)是互聯(lián)網(wǎng)
    發(fā)表于 12-24 00:33

    【「具身智能機器人系統(tǒng)」閱讀體驗】+初品的體驗

    解決許多技術的和非技術的挑戰(zhàn),如提高智能體的自主性、處理復雜環(huán)境互動的能力及確保行為的倫理和安全性。 未來的研究需要將視覺、語音和其他傳感技術與機器人技術相結合,以探索更加先進的知識表示和記憶模塊,利用強化學習進一步優(yōu)化決策過程
    發(fā)表于 12-20 19:17

    移動機器人的技術突破和未來展望

    移動機器人已經(jīng)成為現(xiàn)代社會不可或缺的一部分,在各個領域發(fā)揮著越來越重要的作用。在這個過程中,富唯智能機器人以其卓越的技術突破,引領著移動機器人領域的發(fā)展潮流。
    的頭像 發(fā)表于 12-13 17:57 ?194次閱讀
    移動<b class='flag-5'>機器人</b>的技術突破和<b class='flag-5'>未來</b>展望

    【書籍評測活動NO.51】具身智能機器人系統(tǒng) | 了解AI的下一個浪潮!

    復雜環(huán)境互動的能力及確保行為的倫理和安全性。 未來的研究需要將視覺、語音和其他傳感技術與機器人技術結合,探索更加先進的知識表示和記憶模塊,利用強化學習進一步優(yōu)化決策過程。 具身智能的發(fā)展需要更多跨學科
    發(fā)表于 11-11 10:20

    焊接機器人使用過程中要注意哪些問題

    操作過程中需要注意以下幾個方面的問題。 焊接機器人使用過程中要注意哪些問題? 1. 設備維護與保養(yǎng) 焊接機器人作為高精度設備,日常維護保養(yǎng)必不可少。定期檢查各類傳感器、機械臂的關節(jié)、導
    的頭像 發(fā)表于 10-22 17:43 ?187次閱讀
    焊接<b class='flag-5'>機器人</b>使用<b class='flag-5'>過程中</b>要注意哪些問題

    人形機器人感知變化的未來

    電子皮膚作為一種新型的仿生柔性觸覺傳感系統(tǒng),在人形機器人的感知過程中扮演著至關重要的角色。盡管國內(nèi)部分廠商已經(jīng)開始布局柔性觸覺傳感器的生產(chǎn),但多數(shù)仍處于早期階段,多功能柔性觸覺傳感技術仍是國內(nèi)
    的頭像 發(fā)表于 08-05 00:00 ?862次閱讀
    人形<b class='flag-5'>機器人</b>感知變化的<b class='flag-5'>未來</b>

    在用機器人未來機器人并行推進的權重關系

    在用機器人未來機器人并行推進的權重關系
    的頭像 發(fā)表于 08-01 08:14 ?497次閱讀
    在用<b class='flag-5'>機器人</b>與<b class='flag-5'>未來</b><b class='flag-5'>機器人</b>并行推進的權重關系

    FMEA在焊接機器人研發(fā)的應用

    在現(xiàn)代工業(yè)制造領域,焊接機器人的應用越來越廣泛,它們的高效、精確和可靠性已成為提升制造業(yè)競爭力的關鍵。然而,隨著焊接機器人技術的不斷進步,其研發(fā)過程中也面臨著諸多挑戰(zhàn)。今天,我們將探討一種重要
    的頭像 發(fā)表于 07-23 11:33 ?504次閱讀

    Al大模型機器人

    豐富的知識儲備。它們可以涵蓋各種領域的知識,并能夠回答相關問題。靈活性與通用性: AI大模型機器人具有很強的靈活性和通用性,能夠處理各種類型的任務和問題。持續(xù)學習和改進: 這些模型可以通過持續(xù)的訓練
    發(fā)表于 07-05 08:52

    FMEA在手術機器人研發(fā)的應用

    在醫(yī)療科技飛速發(fā)展的今天,手術機器人已經(jīng)成為精準醫(yī)療的重要工具。然而,如何確保手術機器人在研發(fā)過程中能夠穩(wěn)定、可靠地運行,避免潛在的風險和失誤,是擺在研發(fā)團隊面前的一大挑戰(zhàn)。此時,失效模式與影響分析
    的頭像 發(fā)表于 06-18 11:25 ?511次閱讀

    其利天下技術·搭載無刷電機的掃地機器人的前景如何?

    重要因素,如何提高電池效能和減少充電時間,是行業(yè)亟待解決的問題,此外還有噪音、智能控制等問題也需要重視。 在客戶體驗方面,掃地機器人還存在一些主要問題。例如,部分機器人在清潔過程中可能無法完全覆蓋所有
    發(fā)表于 05-05 15:03

    機器人運動學的非完整約束與運動模型推導

    機器人運動學的運動學約束是指機器人在運動過程中受到的限制,包括位置、姿態(tài)、速度和加速度等因素。這些約束會對機器人的自由度產(chǎn)生影響,從而影響機器人
    的頭像 發(fā)表于 01-18 16:45 ?1941次閱讀
    <b class='flag-5'>機器人</b>運動學<b class='flag-5'>中</b>的非完整約束與運動模型推導

    5個問題,洞悉自主移動機器人未來發(fā)展方向

    隨著科技的日新月異,人類與機器人的互動將愈發(fā)頻繁。從早晨在本地咖啡店里,協(xié)作機器人(cobot)為顧客精心沖泡咖啡,到在倉庫,自主移動機器人(AMR)自由穿梭各處揀選包裹。協(xié)作
    的頭像 發(fā)表于 01-09 08:30 ?696次閱讀
    5個問題,洞悉自主移動<b class='flag-5'>機器人</b><b class='flag-5'>未來</b>發(fā)展<b class='flag-5'>方向</b>