Bootstrap

基于STM32单片机的风力摆控制系统

     

本系统采用STM32F103V开发板作为控制中心,与万向节、摆杆、直流风机(无刷电机+扇叶)、激光头、反馈装置一起构成摆杆运动状态与风机速度分配的双闭环调速系统。单片机输出可变的PWM波给电机调速器,控制4个方向上风机的风速,从而产生大小不同的力。利用加速度计模块MPU6050,准确测出摆杆移动的位置与中心点位置之间的关系,采样后反馈给单片机,使风机及时矫正,防止脱离运动轨迹。使用指南针模块判别方向,控制系统向指定方向偏移。控制方式采用PID算法,比例环节进行快速响应,积分环节实现无静差,微分环节减小超调,加快动态响应。从而使该系统具有良好的性能,能很好地实现自由摆运动、快速制动静止、画圆、指定方向偏移,具有很好地稳定性。

 

关键词:STM32F103V、直流风机、MPU6050、PID、指南针GY-273

 

 

 

Abstract:This system adopts the STM32F103V development board as the control center, and the universal joint, swinging rod, dc fan (brushless motor + blades), laser, feedback device together form the swinging rod motion state and fan speed distribution of the double closed loop speed regulation system. MCU output variable PWM waves to the motor speed, control four directions wind speed of the fan, to produce different size. Using accelerometer module MPU6050, accurately measure the position of swinging rod mobile and center position, the relationship between the sampling after feedback to the single chip microcomputer, the fan timely correction, prevent from the trajectory. Use the compass module judging direction, deviation control system to a specified direction. Using PID algorithm control method, proportion link for quick response, integral element to realize astatic, differential link decrease overshoot, speed up the dynamic response. So that the system has good performance, which can well realize the pendulum movement, fast brake static, circle, specify the direction deviation, has a good stability.

Keywords: STM32F103V, dc fan, MPU6050, PID, compass GY - 273

 

一、系统方案

1.1 系统基本方案

1.1.1 控制方案设计

为了实现题目要求我们采用STM32F103V单片机做为主控芯片,用加速度计陀螺仪模块MPU6050来计算角度和风机状态,用直流风机带动摆杆运动。当MPU6050检测到摆杆的角度时,可根据三角函数公式计算出摆杆现在距离中心的具体位置(方向、距离),单片机会控制PWM波的输出大小来控制风机的风速与方向,使摆杆达到在特定位置静止或按照一定的轨迹运动。当摆杆处于自然下垂状态时,给四个风机同时上电且风向都向外,此时摆杆仍处于受力平衡——静止状态。此时降低X轴上一个风机的转速,摆杆将会带动激光头在X轴上画一条直线,当达到一定的倾斜角度时,单片机可根据角度计算出此时距离中心的距离是否>=25cm,若达到要求后,此风机减速,X轴反方向上电机逐渐加速,恢复到初始速度,反方向做相同的运动。在此过程中,单片机做出A/D采样,Y轴方向方向风机随时做出矫正,防止发生轨迹偏移。角度传感器控制系统框图如图1所

 

  1.1.2 机械结构方案设计

由于摆杆长度(60cm~70cm)较长,且要求激光头在地面画出15cm~35cm的圆,所以要求横杆的距离要足够长。横杆长度较长加之摆杆重量较大,所以要求底座要有足够的重量来支撑整个系统。如果结构不稳或者重量不够,摆杆运动过程中将会产生倾倒或者抖动等现象,影响测试结果。于是,底座采用了“工”型结构,保证了整个系统的稳定性。摆杆材料方面,我们选用轻便的硬质铁质材料与风机进行刚性连接,既能保证连接处的稳定,又可达到减轻底座负担的目的。风机选择方面,既要保证风力够大,能够实现题目基本要求中的自由摆运动、快速制动静止。又要有一定的重量,质量越大,惯性越大,越不容易改变原来的运动状态,在实现发挥部分(2)时,受到外界干扰,不容易改变原来的圆周运动状态机械结构如图2

 

 

 

  1. 底座;2.竖杆;3.横杆;4.螺栓;5.万向节;6.摆杆;7.风机(1);8.风机(2);9.风机(3);10.风机(4)

1.2 各部分方案选择与论证

1.2.1电机选择

方案一: 采用小型轴流风机(大功率),使用双滚珠轴承,采用滚动摩擦的形式,轴承中有数颗微小钢珠围绕轴心,当扇叶转动时,钢珠即跟着转动。因为都是球体,摩擦力较小,所以转速较高。能达到8000RMP,同时产生较大的风力。风机内力矩较大,是因为机内绕了大量的铜线,导致重量较大,当4个风机固定到一起时,重量更大,风机产生的风力带动风机运动困难加大,更难做到题目中按要求运动。另一方面,此风机功率较大,所需电流较大,驱动与供电方面也有很大问题。

方案二:采用双环强磁空心杯电机,内部使用强磁,转速较高。风力也足够大,基本能达到要求。但是到题目发挥部分(2)时,面对外界风力干扰时,由于本身重量较轻,极易受到外界干扰,而不容易保持原来状态。另外,空心杯电机使用3.7V供电,供电电压较低,单片机控制电机转速时,空心杯的电压线性度较小,而不易被精准控制。

方案三: 采用无刷电机,风力较大,重量适中,完全能达到题目运动状态要求,速度控制精确,但须配套电机调速器。

综合考虑,我们选择方案三。

1.2.2 电机驱动的选择

由于上述电机选择了无刷电机,此驱动只能选择电机调速器。

1.2.3 摆杆与横杆的连接选择

方案一:摆杆使用粗单股导线直接与横杆连接,连接简单且自由度较好,给风机供电等方面都比较容易,但是导线容易产生自旋,风机固定困难也增大,增加了调试难度。

方案二:摆杆使用硬质铁质材料,通过万向轴与横杆相连。用此材料强度能够达到要求,且风机固定容易。硬件搭建合理,配重平衡的前提下,摆杆来回摆动不易发生偏移,可轻松解决基本要求(1),减少了编写代码的工作量。

综上考虑,我们选择方案二,节约时间。

1.2.4 摆杆与风机的连接选择

方案一:摆杆与风机之间使用一个直流电机或者舵机连接,这样可以随时改变风机的方向,同时可减少风机的数量,控制量减少。但是此方案连接结构较为复杂,发挥部分圆周运动稳定性不高。

方案二:摆杆与风机之间采用刚性连接,连接较为简单,稳定性能较好。

综上考虑,我们选择方案二。

  • 系统理论分析与计算

2.1风力摆位置的计算与分析

通过加速度计陀螺仪模块MPU6050检测风力摆摆杆的倾角数据。MPU6050集成了3轴MEMS陀螺仪,3轴MEMS加速度计。可根据三角函数公式,可计算出此时摆杆距离中心位置的距离(见图3)。内部有一个数字运动处理器DMP。MPU6050和所有设备寄存器之间通信采用400Khz的I2C接口,实现高速通信。测试过程中,MPU6050与单片机之间进行通信,距离较长,走线较多,干扰较大导致读数不准确,所以在SCL与SDA上拉2K电阻,解决采样问题。内置卡尔曼滤波器,采用最优化自回归数据处理算法精确测量风力摆当前姿态角。MPU6050对陀螺仪和加速度计分别采用了16位的ADC,将其测量的模拟量转化为可输出的数字量,通过DMP处理器读取测量数据然后通过串口输出。

 

正在上传…重新上传取消

                                            MPU6050可测量出出θ1的角度

                          由图中可知

                      

 

 

                                                                   

                  

2.2风力摆运动状态的分析

基本要求(1)中属于开环控制系统,激光笔绘制的轨迹超过50cm即可。我们可以设置摆杆倾角超过一个阈值θ,θ可通过摆动半径R(R>=25cm)直接计算出。然后,通过开环调节,从低到高改变风机的风速,直到摆杆的角度超过阈值,记下此时PWM波脉宽级作用时间。

 

 

 

 

要绘制50cm直线,只需R>25cm(R为地面运动轨迹的一半)在平面内运动即可则其中L为摆杆与激光头的长度,a为激光头到地面的距离(a<=20cm)基本要求(2)摆动幅度可控,属于闭环控制系统,公式计算与(1)相同设置直线长度▽θ(30cm<▽θ<60cm)MPU6050将倾角,角速度送给单片机,单片机控制风机来产生推力使摆杆摆动。

2.3控制算法的分析

系统采用PID算法来控制风机转动的速度,风机开始工作后,MPU6050不断采集当前摆杆摆脚状态,并与之前的状态进行比较,使得摆杆运动状态趋于稳定。PID算法控制器由4个风机速度分配比例P角度误差积分I角度微分D组成。

其输入e(t)与输出U(t)关系为:

 

他的传递函数为:

正在上传…重新上传取消

在发挥部分(1)时,要求做圆周运动。四个直流风机1、2、3、4,1和3用来使摆杆与重力方向呈现设置的夹角,2和4用来推动摆杆沿切线方向运动,这样通过控制1、3电机的PID参数使摆杆达到设定的角度,通过2和4推动摆杆,摆杆就会沿切线运动,绘制圆形轨迹。

电路与程序设计

3.1电路的设计

3.1.1风力摆控制系统总电路原理图见附件1

 

3.1.2部分电路详细原理图

 

 

 

3.1.3电源

系统整体采用电脑电源供电,最大可输出10A电流,无刷电机平均所需电流为2A,电源可满足需求。12V供给4个并联电机驱动(电调)带动风机转动,5V给单片机供电,单片机自带稳压输出3.3V给MPU6050供电,电机驱动本身也可稳压输出5V,给激光头(5V)供电。此系统中所有电源共地。

3.2程序的设计

3.2.1程序功能描述与设计思路

  1、程序功能描述

    系统采用独立按键控制进行模式选择,设置有7个按键,按键1~6分别代表4个基本要求和2个发挥部分。使用12864液晶做显示模块,系统开机后进入初始化状态出现欢迎界面,然后通过按键进行模式选择,执行不同的要求。

  2、程序设计思路

    基本要求(1)属于全开环控制,通过粗略控制便可实现,设定倾角阈值,从低到高不断增加X风机转速,直到倾角超过阈值,记录此时PWM脉宽级作用时间。

    基本要求(2)需要采用闭环控制算法,计算公式与(1)相同,设定好范围后,可与(1)使用相同的方法调试。

基本要求(3)要采用受力分析,使用力的合成。

基本要求(4)拉起一定角度后,如果不提供动力,摆杆将逐渐衰减,但是速度缓慢,因此需要提供与运 动方向相反的力,阻碍摆杆运动。这个过程需要注意,实时采集摆杆的角度(比例项 P),进行 微分从而确定角速度(陀螺仪直接测量亦可),为微分项 D,采用类似于自平衡的 PD 控制算法 即可

发挥部分(1)可以明确,径向风机控制采用 PID 控制算法,使摆杆稳定在某一设定角度,切 线方向控制 2、4电机产生推力,推动摆杆圆周运动。那么,很明显,关键在于如何使摆杆稳 定在某一个角度(认为设定),使用 PID 算法即可,原理类似于基本部分(4),只不过基本部分(4)将竖直方向(重力方向)视为设定值,而发挥部分中是将设定的半径转换成的角度视为设 定值。

发挥部分(2)这个项目主要是评价发挥部分(1)控制算法的稳定性,无需特别的算法,事实上只要发挥部分(1)做得好,这一部分即可实现。

发挥部分(3)使用了指南针模块,可以确定方向,无论将系统怎么放置,摆杆可始终指向一个指定的方向。

 

 

 

 

测试方案与测试结果

4.1测试方案

  1. 驱动风机带动摆杆来回摆动,使激光头在地面上打出一条大于50cm的直线。记录由平衡位置到完成划线要求时所用的时间以及最大偏差距离。重复6次,记录在表1中。
  2. 人为的设定激光头划线的长度,从30cm开始测量,记录到达规定长度所用时间和最大误差,测量3次,时间取平均值。然后依次记录40cm、50cm、60cm的数据,记录在表2中。
  3. 人为的设定激光头划线的方向,使激光头在地面上打出一条大于20cm的直线。从 0°直线开始。记录达到规定长度所用时间和最大误差,测量3次,时间取平均值。然后依次测量  90°、 180°、270°、360°直线,记录在表3中。
  4. 将摆杆拉倒一定的角度然后放下,驱动风机,记录摆杆恢复到中心位置所用时间,记录在表4。
  5. 以摆杆静止时的位置为圆心,设置画圆半径,记录激光头划线旋转3周后所用时间,以及偏差的最大距离,重复3次。然后改变半径长度,在一次测量,记录在表5中。
  6. 加入外界台扇干扰后,依次测量记录恢复到(5)状态所用时间,记录在表5中。

4.2测试条件与仪器

秒表、自制角度测量板、量角器、直尺、示波器、信号源(由于使用无刷电机,使用电调精确控制速度需要信号源产生、示波器测量PWM波的频率、占空比等)

4.3测试结果及分析

(1测试结果

                            1 风力摆画长于 50cm 直线测试

 

第一次测试

第二次测试

第三次测试

第四次测试

第五次测试

第六次测试

时间/S

17

16

14

13

10

10

误差/cm

4.5

3.8

2.2

2.1

2.3

2.2

 2 风力摆画不同长度直线测试

 

 

30cm 直线

40cm 直线

50cm 直线

画60cm 直线

平均时间(s)

6

6.5

8

10.5

误差 1

1.1

1.2

2.6

1.4

误差 2

0.9

1.0

1.1

2.5

误差 3

1.3

1.3

0.8

1.6

 3 风力摆画不同角度直线测试

 

 

0°直线

90°直线

180°直线

270°直线

360°直线

平均时间(s)

7.0

6.5

7.7

7.5

10.0

误差 1

2.0

1.8

1.0

2.1

1.8

误差 2

1.6

1.5

1.9

1.6

1.6

误差 3

2.2

1.1

1.3

1.4

1.2

                           4 风力摆恢复静止测试

 

 

时间(1)

时间(2)

时间(3)

时间(4)

时间(5)

拉起 30°

2.2

2.5

2.1

3.0

2.4

拉起 35°

2.9

3.7

3.3

3.7

2.9

拉起 40°

3.3

3.2

2.9

3.1

3.3

拉起 45°

3.6

5.1

3.8

3.6

5.5

                            5 风力摆画圆测试

 

 

半径 15cm

半径 20cm

半径 25cm

半径 30cm

半径 35cm

时间(1)

26

20

22

24

20

偏差距离(1)

1.9

2.2

1.3

1.6

2.0

恢复时间(1)

3

2

2

3

3

时间(2)

22

18

14

19

25

偏差距离(2)

1.1

1.0

2.2

3.0

2.2

恢复时间(2)

4

5

3

5

4

时间(3)

18

20

22

23

26

偏差距离(3)

1.5

1.8

1.9

1.9

2.0

恢复时间(3)

4

4

3

4

3

(2测试分析与结论

根据上述测试数据,该风力摆控制系统已能达到基本部分和发挥部分的全部要求和性能指标,由此可以得出以下结论:

  1. 风机的性能是决定系统能否完成题目要求的关键,风机性能由其本身决定,包括重量、产生的最大风速、以及所需的电流。任何一个达不到要求,将会给程序调控大大增加难度,所以硬件搭建很重要。
  2. 好的算法,也起到至关重要的作用,为了能达到题目要求,四个风机的速度分配比例很重要,这就需要良好的算法加合适的参数。
  3. 此控制系统,需要时间上的配合,时间参数同样重要,要能保证在规定时间内完成任务。

 

 

 

;