利用STM32实现自平衡机器人功能与方法

news2025/1/12 23:09:17

       将机器人整体开源,同时总结一下机器人搭建过程中遇到的坑和未来的改进方向。在分享的文件里包含了结构设计、程序控制、电路设计以及其他模块相关资料供大家参考。

第一:机器人原理分析

    首先来看成品图:

    如图所示,该机器人根据陀螺仪的位姿数据,通过三个全向轮驱动底部球体调整自己在球上的位置,保持动态平衡的同时实现全向移动。

    保持动态平衡过程需要对机器人进行运动学分析,这里参考了平衡小车之家的运动学方程:

    自平衡控制问题转化为三步:输入X、Y角度—控制器计算—输出A、B、C电机转速的控制模型。

​第二:控制器设计

    首先考虑参考平衡车控制,球上自平衡机器人本质上依然是一个一阶倒立摆问题。

    这里参考了飞思卡尔直立车的控制方法,采用串级PID控制器,外环PD角度环,内环速度PI环。

    由于我的驱动方案选择的是42步进电机,在速度闭环的时候有些问题。正常的直流电机+编码器的控制方案可以通过编码器将轮子的真实速度计算出来,从而和控制器的理想转速作差,实现速度控制。

    而我这里的速度闭环是通过计算上一个时钟周期时给步进电机的控制量,通过运动学方程分解,得到机器人的虚拟速度,与理想转速作差控制。我认为这种速度闭环方式还是存在一定缺陷的,但是在网上查看论文的时候我发现有很多自平衡机器人都是用42步进电机来实现速度闭环的,不知道是什么方法。

    这里还可以好好思考一下为什么角度环要用PD控制,速度环要PI控制,角度环的P部分和D部分对机器人控制有什么影响?在很多CSDN调试平衡车的博客中都有解释,这里就留给大家思考了。

​第三:硬件及结构设计

自平衡机器人的硬件清单有:

56mm全向轮 45元/个

42步进电机 25/个 

42步进闭环模块 59.8元/个 

LM2596S降压模块 20元 

STM32F103C8T6-4飞控板 59.8元 

GY-521六轴陀螺仪 25元

     用到的模块大致如上所示,C8T6的价格随着最近芯片涨价直线上升,我白嫖了实验室的两块板子,现在买一块实在太贵,可以等芯片价格稳定一些再买。其余开关排针等常见元件不再赘述。

    电路原理图如下所示:

    机器人使用solidworks设计整体结构,底板可在某宝定制6050太空铝切割,蓝色件为正常3D打印件。

​第四:程序部分

    在keil 5中开发STM32。

    控制程序采用定时器0.5ms定时中断的方式进行计算,每触发两次中断计算对电机控制一次,这里还是推荐大家采用外部中断读取GY-521上的INT引脚的方式,控制计算周期。GY-521上的INT引脚每5ms触发一次跳变,采用外部中断的方式可以严格保证读取位姿数据与计算处理同步。

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;//关闭速度环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)//速度环频率慢于加速度环 但是还没加速度环 //          {            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;//直接调节PWM频率             Motor_B=Target_B;//直接调节PWM            Motor_C=Target_C;//直接调节PWM//以下都是为了速度连续化处理防止突变            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;}

    对于电机控制,由于采用的驱动方案是步进电机,调速的方式是改变驱动步进电机的脉冲频率。我这里选择了三个定时器,动态调节定时器的频率,具体方式是在初始化时设定好定时器的预分频系数psc的值,然后在程序里动态更改ARR寄存器的值,从而改变定时器的定时频率。

//这里以A电机的速度控制为例 输入为 电机方向和电机速度void set_motorA_speed(u8 dir,u16 speed){    u32 arr;    arr=speed;        TIM_ARRPreloadConfig(TIM3,DISABLE);        TIM3->ARR=arr;//计数到10000在归零重新计数        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);  }}

    小车的运动学分解代码实现如下,参考了平衡小车之家的代码:

/**********************************************************函数功能:小车运动数学模型入口参数: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;}/*****************************************************************函数功能:小车运动 正运动学分析 入口参数: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);  }

    其余代码不全放出,可在文末点击“阅读原文”下载查看。

​第五:总结与展望

     球上自平衡机器人可以作为算法试验平台, 输入输出固定,更换不同控制器,将数据导入MATLAB进行分析即可比较控制器性能。

     个人认为结构有两个改进方向,一方面参考以下论文:余义. 单球驱动自平衡机器人位姿解算与控制系统研究[D].武汉科技大学,2019。论文中采用的四足式驱动结构更有利于机器人自平衡控制。

     另一方面可以增加球体和机器人固定装置,利用机械结构将机器人与底部驱动球结合成一个整体防止机器人跳轮等问题。同时驱动球对于机器人平衡的影响较大,最好还是定制空心钢球,然后喷漆增大摩擦力,最有利于机器人自平衡控制。

     控制部分的改进,首先是控制原理,本文是针对建立好的运动学方程进行分析,通过串级PID算法来实现自平衡运动。该机器人的控制问题本质上是一阶倒立摆问题,可以采用动力学建模的方式,通过动力学分析算出平衡需要的虚拟力矩,再对电机进行力矩控制。

    其次是控制器,PID控制算法应用广泛但也有一定的缺点,可以考虑采用模糊PID,ADRC自抗扰控制器,强化学习等智能控制算法对机器人自平衡进行控制。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/436070.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

宝塔面板设置虚拟内存Swap降低的方法

宝塔面板可以通过设置Swap/虚拟内存的方式来降低内存使用率和负载,使用宝塔面板的Linux工具箱即可设置虚拟内存,新手站长来详细说下宝塔Linux面板设置Swap/虚拟内存的方法: 宝塔面板设置虚拟内存 设置虚拟内存是通过Linux工具箱&#xff0c…

4.0、Java继承与多态 - 抽象类与抽象方法

4.0、Java继承与多态 - 抽象类与抽象方法 先给大家举个例子 -> 创建一个父类 - 图形类;图形类中有一个计算面积的方法 calculateArea(); 创建三个子类 - 正方形、三角形、圆形 类; 由于我们图形类父类中未明确指明是什么图形&#xff0c…

内网域环境搭建学习

建立的关系就是这样,接下来就开始讲解遇到的困难 虚拟机中我们可以克隆来实现域的搭建 可能会出现这样的问题,原因是你的虚拟机没有关闭,所以才会导致这样的原因,解决方法 将虚拟机打开后,电源 -> 关闭客户机&…

MySQL学习笔记第二天

第03章 基本的SELECT语句 1.SQL概述 1.1 SQL背景知识 1946年,世界上第一台电脑诞生,如今,借由这台电脑发展起来的互联网已经自成江湖。在这几十年里,无数的技术、产业在这片江湖里沉浮,有的方兴未艾,有的…

reactxp搭建,start:windows运行不起来

1、官网 reactxp 2、VSCode和Visual Studio2019 安装VSCode Visual Studio 下载地址 先不用勾选工作负荷,直接安装 3、安装nvm 访问下载地址下载安装nvm: 百度云分享 官网直装链接 nvm的github发行界面下载nvm-setup.exe GitCode镜像下载nvm-setup…

ACL配置学习(附练习题)------ensp

从此文了解ACL配置,欢迎学习、指导。 目录 基本ACL配置举例 高级ACL配置举例 ACL配置练习题 定义 访问控制列表ACL(Access Control List)本质上是一种报文过滤器。 范围: OSI七层模型中的网络层、传输层的信息。 滤芯:五…

2023年4月实时获取地图边界数据方法,省市区县街道多级联动【附实时geoJson数据下载】

首先,来看下效果图 在线体验地址:https://geojson.hxkj.vip,并提供实时geoJson数据文件下载 可下载的数据包含省级geojson行政边界数据、市级geojson行政边界数据、区/县级geojson行政边界数据、省市区县街道行政编码四级联动数据&#xff0…

大型医院体检管理系统源码,PEIS体检系统源码 丰富的诊断模板,自动产生小结、综述和建议

PEIS体检管理系统源码 体检条码化管理,体检数据比对,丰富的诊断模板,自动产生小结、综述和建议。 文末获取联系 PEIS体检管理系统对医院体检中心进行系统化和规范化的管理,大大提高体检中心的综合管理水平、工作效率。系统从业务…

设计模式-结构型模式之享元模式

5. 享元模式 5.1. 模式动机 面向对象技术可以很好地解决一些灵活性或可扩展性问题,但在很多情况下需要在系统中增加类和对象的个数。当对象数量太多时,将导致运行代价过高,带来性能下降等问题。 享元模式正是为解决这一类问题而诞生的。享元模…

GoF代理模式

在java中代理模式的作用: 1.一个对象需要受到保护的时候,可以考虑使用代理对象取完成某个行为. 2.需要给某个对象的功能进行功能增强的时候,可以考虑找一个代理进行增强 3.A对象无法和B对象无法直接沟通,也可以使用代理模式解决 代理模式有三…

WPF mvvm框架Stylet使用教程-窗体交互用法

窗体操作 打开窗体 在stylet框架中,要打开一个窗口或者对话框,只需要直接使用窗口管理器 在要使用的ViewModel中注入IWindowManager,然后使用他的方法操作窗口。 ShowDialog(object viewModel)模态显示ShowWindow(object viewModel) 非模…

修改OPNET帮助文档的默认打开浏览器 给Edge浏览器配置IE Tab插件

我在使用 OPENT Modeler 软件时经常会用到帮助文档,但是其默认打开的是 IE 浏览器,想要其在 Edge 浏览器中打开,但是会出现网页无法打开的情况,这时需要给 Edge 浏览器安装一个 IE Tab 插件。 IE Tab 插件是专门针对浏览器而开发的…

vue3的介绍和两种创建方式(cli和vite)

目录 一、vue3的介绍 (一)vue3的简介 (二)vue3对比vue2带来的性能提升 二、vue3的两种创建方式 方式一:使用vue-cli创建(推荐--全面) 操作步骤 方式二:使用vite创建 操作步…

Spring是什么?关于Spring家族

初识Spring 什么是Spring? Spring是一个开源的Java企业级应用程序开发框架,由Rod Johnson于2003年创建,并在接下来的几年里得到了广泛的发展和应用。它提供了一系列面向对象的编程和配置模型,支持开发各种类型的应用程序&#x…

黑客网站攻击的主要手段

版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl 黑客与白帽子 有的童鞋觉得黑客和白帽子是同一回事儿,其实不然;而且,他们的工作方式与目标也有很大的差异。 黑客是指一群专门使用计算机…

9.2 变量的指针和指向变量的指针变量

9.2 变量的指针和指向变量的指针变量 一.指针变量的定义二.指针变量的引用三.整理至https://appd872nnyh9503.pc.xiaoe-tech.com/index的笔记 一.指针变量的定义 变量的指针 就是变量的地址。 我们可以定义一个指向 变量 的指针变量。 这种指针变量,我们在定义的时…

信创办公–基于WPS的EXCEL最佳实践系列 (筛选重要数据)

信创办公–基于WPS的EXCEL最佳实践系列 (筛选重要数据) 目录 应用背景操作步骤1、筛选2、高级筛选 应用背景 在WPS里,筛选有两种,一种是筛选,另外一种则是高级筛选。 操作步骤 1、筛选 可以根据学号、准考证号、考…

MyBatisPlus基础入门学习

系列文章目录 MyBatisPlus基础入门学习 文章目录 系列文章目录前言一、MyBatisPlus简介1.入门案例2.MyBatisPlus概述 二、标准数据层开发1.标准数据层CRUD功能2.分页功能 三、DQL控制1.条件查询方式2.查询投影3.查询条件设定4.字段映射与表名映射 四、DML控制1.Insert2.Delete…

原创文章生成器在线版-ai写作生成器

随着人工智能技术的迅猛发展,越来越多的人开始意识到,利用AI可以实现许多以前不可能想象的事情。其中,一种最能体现人工智能技术优势的应用就是“ai原创文章生成器”。它可以为营销从业者提供一种全新的营销推广方式。 那么,什么是…

AIGC技术赋能下 CRM将迎来怎样的变革?

今年以来,随着ChatGPT的爆火,人工智能(AI)迎来新一轮的热潮,开始更多地走入人们的视野。如果说2016年“阿尔法狗”(Alpha Go)大战围棋世界冠军还只是人工智能的“昙花一现”,那么Cha…