一、平衡小车原理: 自平衡小车是利用车模自身动力使小车保持相对的平衡,是一个动态平衡的过程。维持车模平衡的动力来自车轮的运动,由两个直流电机驱动。对车模的控制可以分解为三个控制任务: 1、控制小车平衡:通过控制小车车轮正反转使小车保持直立平衡。 2、控制小车速度:通过控制小车的倾角实现小车前后运动和速度的控制,其实最终的仍是通过控制电机的转速实现。 3、控制小车方向:通过控制小车两个电机之间的转速差来实现转向控制。 分解为三个控制任务显得相对简单一点,但是在最终的控制过程中都归结为对一个控制量的控制,这样三个任务之间就会存在耦合,会相互干扰。三个任务中控制平衡是关键,所以对小车的速度和方向控制应该尽量的平滑。 二、硬件方案设计 小车的硬件分为三个部分,分别是主控部分、小车姿态获取部分以及电机驱动部分。主控板采用目前常用的arduino UNO,同时也可以使用其他arduino通用控制板做主控。 小车姿态获取可以有很多方案,使用最多的就是通过加速度计和陀螺仪获取小车姿态。理论上只需要两轴加速度计(垂直方向Z轴和沿小车运动方向X轴)和一个单轴陀螺仪(沿小车车轮轴方向,获取绕小车轮轴的角速度)。陀螺仪通过角度积分可以获得小车角度,但是经过积分会产生累计误差,并且会越来越大,X轴与Z轴加速度计的值也可以算出小车的倾角,但是加速度计的瞬时误差较大,所以结合陀螺仪和加速度计两者获得的角度做数据融合可得真实角度。我们使用一个集成了三轴加速度计和三轴陀螺仪的集成芯片MPU6050,这样极大的简化了我们的传感器电路。 小车通过两个直流电机驱动车轮运动来获得动力,直流电机的驱动电路设计关系到整个系统的稳定性,因为电机反转时会产生反向电动势会干扰到电源系统内其他设备的运行。我们选用L298P做电机驱动器,它内部包含4通道逻辑驱动电路,可同时驱动两个直流电机,输出电流可达2.5A。 三、软件设计之小车姿态获取---卡尔曼滤波 在开始之前应该对MPU6050进行设置,主要设置角速度以及加速度的量程,加速度量程有±2g、±4g±8g与±16g,角速度量程分别为±250、±500、±1000与±2000°/sec (dps),可准确的追踪快速动作与慢速动作。在使用之前先设置好量程以便后面的换算。我们小车轮轴与传感器Y轴平行,即绕Y轴旋转则有: 那竖直方向弧度计算公式为: angle = atan2(x, z) //结果以弧度表示并介于 -pi 到 pi 之间(不包括 -pi) 如果要换算成具体角度: angle = atan2(x, z) *(180/3.14) 陀螺仪获取角速度积分得到角度公式为:anglen = anglen-1 + gyronn*dt ,式中anglen 为第N次采样的角度值,anglen-1 为第N-1次的角度值,gyronn为两次采样值之间的角速度值,dt为两次采样之间的时间。然后将换算后的两个角度数据进行卡尔曼滤波融合,可获得小车真实角度,也可以采用更简单的互补滤波算法。 注意加速度计所得角度与陀螺仪积分角度的方向。 四、软件设计之小车姿态调整---PID参数整定 小车的姿态获取最终结果是一个角度,就是小车偏离平衡位置的倾角。通过以小车的这个倾角为变量进行PID控制,输出用于控制车轮转速的PWM值,那么相当于小车只有一个角度反馈环路,虽然能使小车平衡,但是增加了控制难度,所以通常会使用带测速的电机,再加入一个小车速度反馈环路,这样使得小车更容易控制。关于PID的有下面一个简单易懂的描述: 假设我们想把一个小球稳定在一个光滑的坡顶,这显然是一个不平衡的系统,稍有扰动小球就会滚下来。假设恰好平衡的位置坐标是L,我们可以测量到小球的位置是x,那么怎么给小球施加f(x)的力反馈,让它能够平衡呢? 最直观的想法就是f(x) =Kp*(L-x),简单的说就是你在左边我就向右推,你在右边我就向左推,这就是比例因子P; 现在考虑两种情况,同样是在x位置,小球静止和小球具有速度V这两种情况。很明显,如果V>0,我们只需要施加更小的力,因为小球自身的惯性会让它运动向平衡位置。所以可以修正f(x) = Kp*(L-x) – Kd*V。因为速度一般不容易测量,我们常常用位置的变化Δx除以测量的时间差Δt来计算速度,所以这就是微分因子D; 情况继续发生变化,上面考虑的是斜坡静止的情况,如果这个变态的斜坡是移动的怎么办呢?(例如两轮平衡机器人实际上是可以运动的,对于静止的磁悬浮来说,不需要考虑这个参数)这时候我们需要不断的累加并平均x值,来计算平衡位置的L,这个就是积分因子I; 当PID用在我们自平衡小车中时,我们使用角度PD环与速度PI环进行控制。 pwm=angle*k1+angle_dot*k2+range*k3+wheel
2021-12-06 17:43:59 257KB 自平衡小车 原理硬件设计 源代码
1
这是自己做的自平衡小车的原理图以及PCB,主控芯片采用stm32f103,姿态传感器采用MPU6050
2021-12-06 17:29:07 42KB 自平衡 PCB 电机驱动
1
MsTime2,霍尔编码器测速 100毫秒触发一次中断,打印出这100毫秒内,霍尔编码器测到的脉冲数。 代码如下: #include //TB6612引脚定义 const int right_R1=8; const int right_R2=12; const int PWM_R=10; const int left_L1=7; const int left_L2=6; const int PWM_L=9; const int PinA_left = 5; //定义检测左电机脉冲的引脚为D5 const int PinA_right = 4; //定义检测右电机脉冲
2021-11-30 09:46:28 31KB ar arduino du
1
avl_tree AVL树的python实现(自平衡二叉树) 描述: 这是具有以下外部方法的平衡二叉搜索树的实现: insert (data) 将数据插入树中,如果它尚未包含在树中 insertList (list)通过迭代调用insert将list中的数据元素插入到树中 如果数据在树中,则包含(数据)返回 True,否则返回 False str () 使用 BFS 遍历漂亮地打印树(用于测试目的) 其余的是用于维护 AVL 树要求的内部例程。 要测试树,请导航到 shell 中的 avl_tree 目录并键入: $ python 进入python解释器。 (确保解释器的路径 - 通常 /usr/local/bin/python 在 shell 的路径中)。 然后输入: >>> from tree import * 从 tree.py 导入类。 使用以下内容测试树:
2021-11-27 11:23:44 6KB Python
1
STM32实现的两轮自平衡车(原理图、源代码、APP)
2021-11-22 09:02:41 2.01MB 平衡小车 STM32 自平衡
两轮自平衡机器人在斜坡上的动力学建模与控制,阮晓钢,彭奎,针对两轮自平衡机器人在斜坡上的建模和控制问题,首先采用Lagrange方法建立了斜坡面上的动力学模型,然后对模型的平衡状态进行了分�
2021-11-17 21:08:18 306KB 机器人控制
1
arduino nano 平衡车教程
2021-11-09 17:08:35 6KB 单片机
1
很好的程序,绝对可靠,实现显示,运动,稳定性很好,绝对值得看看
2021-11-09 15:27:56 43.56MB 自平衡小车
1
自平衡小车详解_陀螺仪和加速度详细介绍(第七届飞思卡尔大赛网站下载的)
2021-10-12 14:25:31 6.12MB 自平衡 陀螺仪
1
基于单片机的两轮自平衡车控制系统设计说明.doc
2021-10-01 09:07:09 1.18MB 文档