文档库 最新最全的文档下载
当前位置:文档库 › 关于舵机的控制

关于舵机的控制

关于舵机的控制
关于舵机的控制

电子科技大学:(清晰明了,代码看不懂)

其实在车速不快的情况下只用车前40cm

内的黑线偏差就可以让赛车沿黑线行驶,问题是在赛车高速行驶时需要对前方

更远的赛道信息进行预判,例如控制赛车入弯前减速、使赛车走最优路径等。因此我们使用距离车前第21 行、22 行、23 行的黑线平均位置计算赛车离黑线

的偏差控制舵机拐向,用更远端的黑线来进行赛道预判。计算相邻两段黑线的

斜率还可以判断出小S 弯,让赛车在小S 弯直冲。

如图5.5.3.1 所示,Mid_Erro 为赛车当前的方向偏差,用于控制舵机当前时

刻的转向。Top_Erro 为图像最远端离中线的偏差,用于进行赛车前方赛道预判,Top_Erro 越大,减速越大

如图5.5. 3.2 所示,只要计算相隔S_Row 行的黑线的相对斜率Up_Erro 和Down_Erro ,如果Up_Erro 和Down_Erro 方向相反而且大于预设的阈值就可

以判定出小S 弯,让输出的偏移量Erro 缩小,减小舵机的转向,使小车减小

抖动。

桂林理工:

D_zhongxin

DJ_chu+

(D_Kp

=

+

+

xiu_D_Kp)

(error

dd_error)/

10

-

*

error/10

D_Kd

*

其中,D_zhongxin是车模前轮摆正时的参数,为1460;D_Kp是舵机PD控制的P值;xiu_D_Kp 是舵机P值的修正值;error是当前图像的黑线中心的偏差;D_Kd是舵机PD控制中的D值;dd_error是上次图像黑线中心的偏差。DJ_chu是输出给舵机的PWM值。

军械工程:斜率做赛道判断(同桂林)

void Direction_Control(void)

{

Control_Row = Good_Road_End-1;

if(Control_Row_Far == 1) //40

行控制

{

//Control_Row = Good_Road_End-1;

}

if(Control_Row_Middle == 1) //35

行控制

{

if(Control_Row>34) Control_Row=Control_Row-5;

}

if(Control_Row_Near == 1) //30

行控制

{

if(Control_Row>29) Control_Row=Control_Row-10;

}

Level_Offset = Black_Center[Control_Row] - 30; //

偏差

if(Level_Offset > 0) //

左转参数

{

K1 = L_KH - Control_Row*Control_Row/L_KW;

K2 = 2;

}

if(Level_Offset < 0) //

右转参数

{

K1 = R_KH - Control_Row*Control_Row/R_KW;

K2 = 2;

}

Steer_Value[0] = Straight_Value + K1*Level_Offset + K2* Slope ;

两变量控制

if(Steer_Value[0] > Left_Limit) Steer_Value[0] = Left_Limit;

if(Steer_Value[0] < Right_Limit) Steer_Value[0] = Right_Limit;

if(Bad_Field_Flag) Steer_Value[0] = Steer_Value[1]; //

如果为无效场,舵机值不变

PWMDTY67 = Steer_Value[0];

Steer_Value[1] = Steer_Value[0];

}

上海交大(清晰明了,代码复杂)

5.5.1 舵机顶层控制量选定

简单沿线行驶策略的目标是控制舵机使得赛车尽可能沿着导引线前进。所

以舵机顶层控制量选用的是某一行黑线的中心位置,控制行的选取与

速度进行

线性耦合。

5.5.2 舵机顶层控制量修正

对于S 弯道的最佳行驶路线是沿着中心线行驶,这样可以大大提高赛车速

度,缩短行驶时间。如何能做到这一点呢?一般的想法是将S 弯和普通弯道、直道区分开来。这就要进行模式识别与决策。但是,识别存在着出错的可能,万一识别出错,小车将会很容易冲出赛道。而且,使用判断并分开进行单独控制的方法,与采用统一的方法进行S 道直冲、普通弯道切弯相比,显得比较丑陋。

所以我们最后采用的是较为简洁、优美、统一的方法,通过对顶层控制量

的修正,来一并完成这几项任务。修正使用的信息是控制行之上的黑线位置的

加权平均值。

陕西理工: d0=(int)((4500-route_ps[a0])/scale);

U_PD=(int)(center+Kp_1*d0);

Scale:舵机参数

route_ps[a0]?

西安交通:

rudder=(rudder_kp*err[0]+kd/2*(err[0]-err[1])*10000l)/10000l;

err[0]:相邻三行平均位置

中山大学:边线双曲率

看不懂:复杂

大连理工:最小二乘优化路径,以斜率和截距判断打脚。截距不懂?无代码,复杂

杭电:我们用的舵机打角控制比较简单,只根据光电式编码器反馈来的脉冲数转化为速度再用这个值乘上舵机反应滞后时间得出打角行位置,然后根据这个打角行位置与图像中心位置的偏差来计算出舵机的打角值。(动态单行)

主流三种:单点A加A与远点B斜率

多点平均加权(似乎也算了远近处偏差;华科说多点平均加权,但代码中有远近处偏差分量,西北工业与东秦同华科,北科代码未见,权值如何定?)

单点平均(电子科大,交大,这两个队代码超复杂。杭电也是)

们选择第35 行作为主要的控制行,把这一行黑线的位置与图像中心位置的差作为偏差进行PID 控制。另外用第50 行和第37 行的差即空间上的偏差变化量作

为辅助控制量,目的是充分利用摄像头在前瞻方面的优势,提前判断赛道走势。PD 控制式如公式4:

PWMDTY 45 = K P *error + K D1 *Ec1 + K D2 *Ec2 公式4

其中error 为控制行黑线位置偏离中心位置的值, 1 Ec 为时间上的偏差变化

量,即error 的变化量, 2 Ec 为空间上的偏差变化量。

变参数主要体现在当识别出赛道为直道或小S 时,选用较小的PD 参数,让

小车舵机输出小转角,基本实现沿直线前进。而当为其它赛道类型是则选用较大的PD 参数,实现及时转弯和内切。另外B 型车舵机左右不对称的客观因素在调车过程中也是不容忽视的,为此需先算出PWM 输出,判断小车转向左或是右,然后调用不同的PD 参数。

参数加权则是两个控制量之间的权重分配。要配合着PD 参数在调车过程中

一起调。

/****************************************************************

/

/*** 函数名rudder_control

***/

/*** 功能:根据控制点偏离中心位置实施PID 控制***/

/*** 日期:20100627 ***/

/****************************************************************

/

void rudder_control(void){

static int cha=0,cha2=0,cha3=0;

int last_cha=0;

unsigned char r_i=0;

unsigned int pwm_cal=0;

byte s_high=0;

byte s_low=0;

last_cha=cha;

cha=location[control_point]-centre_location;

if(lie_end_flag){

第五届全国大学生智能汽车邀请赛技术报告

XXIV

lie_end_flag=0;

if(lie_end_hang<20){

if(last_cha>=0)

cha=-50;

else

cha=50;

}

}else if(invalid_c_first){

invalid_c_first=0;

if(last_cha>=0)

cha=-50;

else

cha=50;

}

if(cha>=0){

//右拐

angle.kp=65;

angle.kd=7;

angle.kd1=2;

}

else {

//左拐

angle.kp=60 ;

angle.kd=9;

angle.kd1=4;

}

if(location[lie_end_hang]>80) {

if(lie_end_hang>30) {

angle.kp+=55;

}else if(lie_end_hang>=20) {

angle.kp+=65;

}

}else if(location[lie_end_hang]<20){

附录

XXV

if(lie_end_hang>30) {

angle.kp+=55;

}else if(lie_end_hang>=20) {

angle.kp+=60;

}

}

if(s_flag==1){

if(road_type==2) angle.kp-=10;

}

cha=-cha;

cha2=cha-last_cha;

cha3=location[37]-location[50];

pwm_cal=angle.kp*cha/20+angle.kd*cha2+angle.kd1*cha3+centre_pwm; if(pwm_cal>2300) pwm_cal=2300;

else if(pwm_cal<500) pwm_cal=500;

PWMDTY45=pwm_cal;

详细的舵机控制原理资料

目录 一.舵机PWM信号介绍 (1) 1.PWM信号的定义 (1) 2.PWM信号控制精度制定 (2) 二.单舵机拖动及调速算法 (3) 1.舵机为随动机构 (3) (1)HG14-M舵机的位置控制方法 (3) (2)HG14-M舵机的运动协议 (4) 2.目标规划系统的特征 (5) (1)舵机的追随特性 (5) (2)舵机ω值测定 (6) (3)舵机ω值计算 (6) (4)采用双摆试验验证 (6) 3.DA V的定义 (7) 4.DIV的定义 (7) 5.单舵机调速算法 (8) (1)舵机转动时的极限下降沿PWM脉宽 (8) 三.8舵机联动单周期PWM指令算法 (10) 1.控制要求 (10) 2.注意事项 (10) 3.8路PWM信号发生算法解析 (11) 4.N排序子程序RAM的制定 (12) 5.N差子程序解析 (13) 6.关于扫尾问题 (14) (1)提出扫尾的概念 (14) (2)扫尾值的计算 (14)

一.舵机PWM 信号介绍 1.PWM 信号的定义 PWM 信号为脉宽调制信号,其特点在于他的上升沿与下降沿之间的时间宽度。具体的时间宽窄协议参考下列讲述。我们目前使用的舵机主要依赖于模型行业的标准协议,随着机器人行业的渐渐独立,有些厂商已经推出全新的舵机协议,这些舵机只能应用于机器人行业,已经不能够应用于传统的模型上面了。 目前,北京汉库的HG14-M 舵机可能是这个过渡时期的产物,它采用传统的PWM 协议,优缺点一目了然。优点是已经产业化,成本低,旋转角度大(目前所生产的都可达到185度);缺点是控制比较复杂,毕竟采用PWM 格式。 但是它是一款数字型的舵机,其对PWM 信号的要求较低: (1) 不用随时接收指令,减少CPU 的疲劳程度; (2) 可以位置自锁、位置跟踪,这方面超越了普通的步进电机; 其PWM 格式注意的几个要点: (1 ) 上升沿最少为0.5mS ,为0.5mS---2.5mS 之间; (2) HG14-M 数字舵机下降沿时间没要求,目前采用0.5Ms 就行;也就是说PWM 波形 可以是一个周期1mS 的标准方波; (3) HG0680为塑料齿轮模拟舵机,其要求连续供给PWM 信号;它也可以输入一个周 期为1mS 的标准方波,这时表现出来的跟随性能很好、很紧密。

无人机舵机控制系统的硬件设计与实现_杨百平

1076 计算机测量与控制.2010.18(5) Computer Measurement &Control 控制技术 收稿日期:2009-09-27; 修回日期:2009-11-09。 作者简介:杨百平(1982-),男,陕西人,在读研究生,主要从事电路系统与自动控制方向的研究。 杨金孝(1964-),男,陕西人,副教授,主要从事电子电路的研究与设计、控制理论与控制工程方向的研究。 文章编号:1671-4598(2010)05-1076-03 中图分类号:T P274 5 文献标识码:A 无人机舵机控制系统的硬件设计与实现 杨百平,杨金孝,赵 强 (西北工业大学电子信息学院,陕西西安 710129) 摘要:给出了一种基于ST M 32F103VB 微控制器的无人机全数字舵机控制系统硬件实现方案,该方案以STM 32F103VB 作为主控芯片,无刷直流电机作为该系统的伺服电机,采用三闭环的控制策略,实现了脉宽调制(PWM )控制信号的采样和输出,通过采样PW M 信号实现舵机的控制,针对无人机对数据传输实时性的要求,利用CAN 总线与上位机通讯,很好地满足了要求;该系统具有成本低廉、安全可靠且实现容易的特点,实现了舵机控制系统的数字化与小型化;经多次试验,证明是安全实用的。 关键词:S TM 32F103VB 微控制器;无人机;伺服;电动舵机 Hardware Design and Implementation for a S ervo System of UAV Rudder Yang Baiping ,Yang Jinxiao,Zhao Qiang (Colleg e of Electr onics and Infor mat ion,No rthw ester n P olytechnical U niver sity,Xi an 710129,China) Abstract:A set of fu lly-digital-signal ser vo system bas ed on S TM 32F103VB for UAV electrom echanical rudder is in tr odu ced in th is paper.It takes S TM 32F103VB as the master control unit and bru shless DC m otor as its drive.T his project uses the digital th ree clos ed-loop control strategy,sampled and gen erated puls e width modulation w ave,through sampling one of th e PW M w aves to realize control tran sfer,in view of U AV to data transmis sion tim elin es s r equest,com municated w ith upper sys tem by CAN bu s.It featu red low cos t,s afe,easy to realize,made it smaller and digital,and w as testified that the sy stem is ap plicable and safety. Key words :S TM 32F103VB M CU;UAV;servo;electr om ech anical rudder 0 引言 舵机控制系统是飞行控制计算机和舵机之间的接口,它采集接收机多路PW M 信号,与上位机进行通讯,产生控制舵机的PW M 信号,是舵机系统的核心部分。现有的舵机伺服控制线路大部分还都是模拟的,因其固有的一些缺点而限制了它的使用,相比之下,数字舵机系统具有很多模拟式舵机所没有的优点。本文给出了一种基于ST M 32F103VB 微控制器的无人飞行器舵机伺服控制系统,具有高性能、低功耗、低成本、安全可靠和实现容易的特点,可在线编程并成功应用于实践。 1 系统综述 舵机主要是由无刷电机、舵机控制器、舵机机械结构和传感器4部分组成。其中舵机控制器又包括:数据接口部分、中央控制单元、逻辑单元、隔离放大部分与功率驱动模块。一般舵机的工作过程如下:首先由上位机给出一舵偏角指令,舵机控制器接受该指令后与检测得到的实际舵面偏转角送入舵面位置调节单元从而得到参考P WM 占空比A;然后测量实际转速,当速度大于预设值时输出一给定PW M 占空比B;最后检测实际电流,当电流大于电流预设值时,输出另一给定的PWM 占空比C [1]。无刷直流电机中的H A LL 传感器检测转子位置,产生H A ,H B,H C 三相霍尔信号,H A 、HB 、H C 、和ST M 32输出的P WM 波和电机换相信号逻辑综合得到6路电机控制信号驱动电机转动 [2] 。电机输出轴连接精密减速器和 各种传感器,减速器输出驱动舵面。系统实现图如图1所示。 图1 系统组成结构图 2 舵机控制器的硬件组成 舵机控制器的硬件由图2中框线部分组成,该控制器以ST M 32F103V B 为核心。整个系统的硬件设计主要由ST M 32F103V B 工作电路、可编程逻辑电路、隔离及驱动电路、检测信号处理电路、A D 转换电路、数据接口电路及温度检测电路等部分组成。在系统中ST M 32F103V B 通过其自身的CA N 总线控制器与上位机进行数据传输,并使用自身集成的A D 转换器和内置通用定时器实时监测舵机位置、转速和电流等参数。 控制器根据内置的控制算法进行位置环、速度环和电流环计算,并产生控制数据,控制数据通过转换算法产生控制量(PW M 信号和DI R 信号),控制量进入逻辑阵列CPL D 与无刷电机位置传感器信号(H A L L 信号)进行逻辑综合后,输出6路电机控制信号。电机控制信号经隔离电路后控制电机功率驱动模块进行功率放大,驱动无刷电机运行。2 1 主控芯片STM32F 103VB [3] ST M 32F103VB 是意法半导体(ST )公司推出的基于A RM 32位CORT EX -M 3CPU ,是目前性能比较突出的微处理器之一,其增强型系列特别适合做电机控制。它的主要特点如下:

舵机工作原理

控制思想 该模块的程序框图如图4.5 所示。车模在行驶过程中不断采样赛道信息,并通过分析车模与赛道相对位置判断车模所处赛道路况,是弯道还是直道,弯道时是左转还是右转。直道时小车舵机状态保持不变,弯道时左转或右转,计算转弯半径。我们所用舵机的标准PWM 周期为20ms,转动角度最大为左右90度,PWM调制波如图7.2所示。

当给舵机输入脉宽为0.5ms,即占空比为0.5/20=2.5%的调制波时,舵机右转90度;当给舵机输入脉宽为1.5ms,即占空比为1.5/20=7.5%的调制波时,舵机静止不动;当给舵机输入脉宽为2.5ms,即占空比为2.5/20=12.5%的调制波时,舵机左转90度。可以推导出舵机转动角度与脉冲宽度的关系计算公式为: 注:其中t为正脉冲宽度(ms);θ为转动角度;当左转时取加法计算,右转时取减法计算结果。 当我们根据赛道弯度计算出转动角度以后便可以根据舵机的参数计算出脉冲宽度,控制舵机转动,舵机转角与PWM脉宽关系如表4-1所示。

在具体操作中PWM调制波的周期可以设置在20ms左右一定范围内,比如设置为10ms 或是30ms均可以使舵机正常转动,但是设置周期较长时,系统延迟时间较多,舵机转向会出现滞后,导致赛车冲出跑道;设置周期如果过短,系统输出PWM 调制波不稳定,舵机转动也会受影响,不能实现赛车的精确转向。经过反复测试,最终把输出PWM 调制波周期设定为13ms (用计数器实现)。 运行电机的转速以及舵机的转角,在软件上都是通过对PWM 波占空比进行设置来相应控制的。前面提到,舵机转角控制需要将两个

八位寄存器合成为一个十六位寄存器。程序中的舵机位置信号,当PWM调制波周期设为13ms时,因为总线频率为24MHz,用时钟SB,可计算得到16进制参数为9870H,舵机中间位置时占空比16进制参数为1680H,要分配给PWM6和7,分配时这2个端口的赋值必须是16进制,那么PWM模块初始化赋值为 PWMPER6= 0x98,PWMPER7= 0x70,PWMDTY6= 0x16,PWMDTY7= 0x80,因此这就牵涉到如何将1个十进制数分配为2个十六进制数问题。有2种方案,一种是除法取余,另一种是移位操作,前者编译生成的代码比后者要多,所以采用移位操作来实现,即取高位时与0xFF00先作“&”计算,然后将所得到的数向右移8位(>>8),即可取得高8位;同理,取低8位时只要与0x00FF作“&”计算即可(算法)。 2、结构和控制 一般来讲,舵机主要由以下几个部分组成,舵盘、减速齿轮组、位置反馈电位计5k、直流电机、控制电路板等。 工作原理:控制电路板接受来自信号线的控制信号(具体信号待会再讲),控制电机转动,电机带动一系列齿轮组,减速后传动至输出舵盘。舵机的输出轴和位置反馈电位计是相连的,舵盘转动的同时,带动位置反馈电位计,电位计将输出一个电压信号到控制电路板,进行反馈,然后控制电路板根据所在位置决定电机的转动方向和速度,从而达到目标停止。

舵机的工作原理

基于AT89C2051单片机的多路舵机控制器设计 摘要舵机是机器人、机电系统和航模的重要执行机构。舵机控制器为舵机提供必要的能源和控制信号。本文提出一种以外部中断计数为基础的PWM波形实现方法。该方法具有简单方便,成本低,可实现多路独立PWM输出的优点。 关键词A T89C205l 舵机控制器外部中断PWM 舵机是一种位置伺服的驱动器。它接收一定的控制信号,输出一定的角度,适用于那些需要角度不断变化并可以保持的控制系统。在微机电系统和航模中,它是一个基本的输出执行机构。 1 舵机的工作原理 以日本FUTABA-S3003型舵机为例,图1是FUFABA-S3003型舵机的内部电路。 舵机的工作原理是:PWM信号由接收通道进入信号解调电路BA66881。的12脚进行解调,获得一个直流偏置电压。该直流偏置电压与电位器的电压比较,获得电压差由BA6688的3脚输出。该输出送人电机驱动集成电路BA6686,以驱动电机正反转。当电机转速一定时,通过级联减速齿轮带动电位器R。,旋转,直到电压差为O,电机停止转动。舵机的控制信号是PWM信号,利用占空比的变化改变舵机的位置。 2 舵机的控制方法 标准的舵机有3条导线,分别是:电源线、地线、控制线,如图2所示。 电源线和地线用于提供舵机内部的直流电机和控制线路所需的能源.电压通常介于4~6V,一般取5V。注意,给舵机供电电源应能提供足够的功率。控制线的输入是一个宽度可调的周期性方波脉冲信号,方波脉冲信号的周期为20 ms(即频率为50 Hz)。当方波的脉冲宽度改变时,舵机转轴的角度发生改变,角度变化与脉冲宽度的变化成正比。某型舵机的输出轴转角与输入信号的脉冲宽度之间的关系可用围3来表示。 3 舵机控制器的设计 (1)舵机控制器硬件电路设计 从上述舵机转角的控制方法可看出,舵机的控制信号实质是一个可嗣宽度的方波信号(PWM)。该方波信号可由FPGA、模拟电路或单片机来产生。采用FPGA成本较高,用模拟电路来实现则电路较复杂,不适合作多路输出。一般采用单片机作舵机的控制器。目前采用单片机做舵机控制器的方案比较多,可以利用单片机的定时器中断实现PWM。该方案将20ms的周期信号分为两次定时中断来完成:一次定时实现高电平定时Th;一次定时实现低电平定时T1。Th、T1的时间值随脉冲宽度的变换而变化,但,Th+T1=20ms。该方法的优点是,PWM信号完全由单片机内部定时器的中断来实现,不需要添加外围硬件。缺点是一个周期中的PWM信号要分两次中断来完成,两次中断的定时值计算较麻烦;为了满足20ms 的周期,单片机晶振的频率要降低;不能实现多路输出。也可以采用单片机+8253计数器的实现方案。该方案由单片机产生计数脉冲(或外部电路产生计数脉冲)提供给8253进行计数,由单片机给出8253的计数比较值来改变输出脉宽。该方案的优点是可以实现多路输出,软件设计较简单;缺点是要添加l片8253计数器,增加了硬件成本。本文在综合上述两个单片机舵机控制方案基础上,提出了一个新的设计方案,如图4所示。 该方案的舵机控制器以A T89C2051单片机为核心,555构成的振荡器作为定时基准,单片机通过对555振荡器产生的脉冲信号进行计数来产生PWM信号。该控制器中单片机可以产生8个通道的PWM信号,分别由AT89C2051的P1.0~Pl.7(12~19引脚)端口输出。输出的8路PWM信号通过光耦隔离传送到下一级电路中。因为信号通过光耦传送过程中进行了反相,因此从光耦出来的信号必须再经过反相器进行反相。方波信号经过光耦传输后,前沿和后沿会发生畸变,因此反相器采用CD40106施密特反相器对光耦传输过来的信号进行整形,产生标准的PWM方波信号。笔者在实验过程中发现,舵机在运行过程中要从电源

舵机控制

舵机控制实验 舵机是一种位置伺服的驱动器,主要是由外壳、电路板、无核心马达、齿轮与位置检测器所构成。其工作原理是由接收机或者单片机发出信号给舵机,其内部有一个基准电路,产生周期为20ms,宽度为1.5ms 的基准信号,将获得的直流偏置电压与电位器的电压比较,获得电压差输出。经由电路板上的IC 判断转动方向,再驱动无核心马达开始转动,透过减速齿轮将动力传至摆臂,同时由位置检测器送回信号,判断是否已经到达定位。适用于那些需要角度不断变化并可以保持的控制系统。当电机转速一定时,通过级联减速齿轮带动电位器旋转,使得电压差为0,电机停止转动。一般舵机旋转的角度范围是0 度到180 度。 舵机有很多规格,但所有的舵机都有外接三根线,分别用棕、红、橙三种颜色进行区分,由于舵机品牌不同,颜色也会有所差异,棕色为接地线,红色为电源正极线,橙色为信号线。

舵机的转动的角度是通过调节PWM(脉冲宽度调制)信号的占空比来实现的,标准PWM(脉冲宽度调制)信号的周期固定为20ms (50Hz),理论上脉宽分布应在1ms到2ms 之间,但是,事实上脉宽可由0.5ms 到2.5ms 之间,脉宽和舵机的转角0°~180°相对应。有一点值得注意的地方,由于舵机牌子不同,对于同一信号,不同牌子的舵机旋转的角度也会有所不同。 了解了基础知识以后我们就可以来学习控制一个舵机了,本实验所需要的元器件很少只需要舵机一个、跳线一扎就可以了。 RB—412 舵机*1 面包板跳线*1 扎 用Arduino 控制舵机的方法有两种,一种是通过Arduino 的普通数字传感器接口产生占空比不同的方波,模拟产生PWM 信号进行舵机定位,第二种是直接利用Arduino 自带的Servo 函数进行舵机的控制,

航模舵机控制原理详解

在机器人机电控制系统中,舵机控制效果是性能的重要影响因素。舵机可以在微机电系统和航模中作为基本的输出执行机构,其简单的控制和输出使得单片机系统非常容易与之接口。 舵机是一种位置(角度)伺服的驱动器,适用于那些需要角度不断变化并可以保持的控制系统。目前在高档遥控玩具,如航模,包括飞机模型,潜艇模型;遥控机器人中已经使用得比较普遍。舵机是一种俗称,其实是一种伺服马达。 其工作原理是: 控制信号由接收机的通道进入信号调制芯片,获得直流偏置电压。它内部有一个基准电路,产生周期为20ms,宽度为1.5ms的基准信号,将获得的直流偏置电压与电位器的电压比较,获得电压差输出。最后,电压差的正负输出到电机驱动芯片决定电机的正反转。当电机转速一定时,通过级联减速齿轮带动电位器旋转,使得电压差为0,电机停止转动。当然我们可以不用去了解它的具体工作原理,知道它的控制原理就够了。就象我们使用晶体管一样,知道可以拿它来做开关管或放大管就行了,至于管内的电子具体怎么流动是可以完全不用去考虑的。 3. 舵机的控制: 舵机的控制一般需要一个20ms左右的时基脉冲,该脉冲的高电平部分一般为0.5ms~2.5ms 范围内的角度控制脉冲部分。以180度角度伺服为例,那么对应的控制关系是这样的: 0.5ms--------------0度; 1.0ms------------45度; 1.5ms------------90度; 2.0ms-----------135度; 2.5ms-----------180度; 这只是一种参考数值,具体的参数,请参见舵机的技术参数。 小型舵机的工作电压一般为4.8V或6V,转速也不是很快,一般为0.22/60度或0.18/60度,所以假如你更改角度控制脉冲的宽度太快时,舵机可能反应不过来。如果需要更快速的反应,就需要更高的转速了。 要精确的控制舵机,其实没有那么容易,很多舵机的位置等级有1024个,那么,如果舵机的有效角度范围为180度的话,其控制的角度精度是可以达到180/1024度约0.18度了,从时间上看其实要求的脉宽控制精度为2000/1024us约2us。如果你拿了个舵机,连控制精度为1度都达不到的话,而且还看到舵机在发抖。在这种情况下,只要舵机的电压没有抖动,那抖动的就是你的控制脉冲了。而这个脉冲为什么会抖动呢?当然和你选用的脉冲发生器有

基于Arduino的舵机控制系统设计_蔡睿妍

Computer Knowledge and Technology 电脑知识与技术计算机工程应用技术本栏目责任编辑:梁书第8卷第15期(2012年5月)基于Arduino 的舵机控制系统设计 蔡睿妍 (大连大学信息工程学院,辽宁大连116622) 摘要:舵机是传统的角度控制驱动器,在机器人等领域得到了广泛应用。传统的舵机主要采用单片机系统驱动控制,但单片机系统对多个舵机同时进行驱动效果并不理想,因此,采用了流行的开源Arduino 控制板,通过输出不同脉宽的信号进行舵机转动角度控制,实验证明,该系统实现了舵机角度控制,满足舵机角度控制精度要求,为舵机的驱动提供了新方式。 关键词:Arduino ;舵机;脉宽信号;角度控制 中图分类号:TM383.4 文献标识码:A 文章编号:1009-3044(2012)15-3719-03Design of Servo Control System Based on Arduino CAI Rui-yan (Information and Engineering College of Dalian University,Dalian 116622,China) Abstract:The servo is the traditional angle control driver and has been widely used in robot and other fields.In general,servo is driven by microcontroller system,but the driving effect of microcontroller system is not satisfactory for multiple servos.So,the Arduino,an open source control board,is used to output different pulse width signal to control the servo rotation angle,experiment showed that,this system realizes the angle control of servo,meets the requirement of angle control precision and provides a new way to drive servo. Key words:Arduino;servo;pulse width signal;angle control 舵机是一种位置(角度)伺服的驱动器,适用于那些需要角度不断变化并可以保持的控制系统。目前,在高档遥控玩具,如飞机、潜艇模型,遥控机器人中已经得到了普遍应用。传统对舵机的控制主要采用单片机,利用定时器和中断的方式来完成控制,这样的方式控制一个舵机还是相当有效的,但是随着舵机数量的增加,控制起来就没有那么方便了,尤其对机器人等需要多个舵机同时工作的系统中,单片机驱动复杂且精度难以保证。因此,本文采用目前较为流行的开源Arduino 来实现舵机的精确控制。1Arduino 简介 Arduino 是源自意大利的一个教学用开源硬件项目,主要是为希望尝试创建交互式物理对象的实践者、喜欢创造发明的人及艺术家所构建的,它秉承开源硬件思想,程序开发接口免费下载,也可依需求自己修改。Arduino 引脚如图1所示: 图1Arduino 控制板 其硬件系统是高度模块化的,通过USB 接口与计算机连接,包括14通道数字输入/输出,其中包括6通道PWM 输出、6通道10位 ADC 模拟输入/输出通道,电源电压主要有5V 和3.3V [1]。在核心控制板的外围,有开关量输入输出模块、各种模拟量传感器输入模 块、总线类传感器的输入模块,还有网络通信模块,只要在核心控制板上增加网络控制模块,就可以容易地与互联网连接。Arduino 还提供了自己的开发语言[2,3],支持Windows 、Linux 、MacOS 等主流的操作系统。Arduino 系统是基于单片机开发的,并且大量应用通用和标准的电子元器件,包括硬件和软件在内的整个设计,代码均采用开源方式发布,因此采购的成本较低,在各种电子制作竞赛、收稿日期:2012-04-23 作者简介:蔡睿妍(1979-),黑龙江林甸县人,讲师,硕士,主要从事电子技术、通信与网络方向的研究。 E-mail:kfyj@https://www.wendangku.net/doc/3f6341740.html, https://www.wendangku.net/doc/3f6341740.html, Tel:+86-551-56909635690964 ISSN 1009-3044Computer Knowledge and Technology 电脑知识与技术Vol.8,No.15,May 2012.3719

舵机及舵机的控制

舵机及舵机的控制 1.什么是舵机: 在机器人机电控制系统中,舵机控制效果是性能的重要影响因素。舵机可以在微机电系统和航模中作为基本的输出执行机构,其简单的控制和输出使得单片机系统非常容易与之接口。 舵机是一种位置(角度)伺服的驱动器,适用于那些需要角度不断变化并可以保持的控制系统。目前在高档遥控玩具,如航模,包括飞机模型,潜艇模型;遥控机器人中已经使用得比较普遍。舵机是一种俗称,其实是一种伺服马达。 还是看看具体的实物比较过瘾一点: 2.其工作原理是: 控制信号由接收机的通道进入信号调制芯片,获得直流偏置电压。它内部有一个基准电路,产生周期为20ms,宽度为1.5ms的基准信号,将获得的直流偏置电压与电位器的电压比较,获得电压差输出。最后,电压差的正负输出到电机驱动芯片决定电机的正反转。当电机转速一定时,通过级联减速齿轮带动电位器旋转,使得电压差为0,电机停止转动。当然我们可以不用去了解它的具体工作原理,知道它的控制原理就够了。就象我们使用晶体管一样,知道可以拿它来做开关管或放大管就行了,至于管内的电子具体怎么流动是可以完全不用去考虑的。 3.舵机的控制: 舵机的控制一般需要一个20ms左右的时基脉冲,该脉冲的高电平部分一般为 0.5ms~2.5ms范围内的角度控制脉冲部分。以180度角度伺服为例,那么对应的控制关 系是这样的:

0.5ms--------------0度; 1.0ms------------45度; 1.5ms------------90度; 2.0ms-----------135度; 2.5ms-----------180度; 请看下形象描述吧: 这只是一种参考数值,具体的参数,请参见舵机的技术参数。 小型舵机的工作电压一般为4.8V或6V,转速也不是很快,一般为0.22/60度或0.18/60度,所以假如你更改角度控制脉冲的宽度太快时,舵机可能反应不过来。如果需要更快速的反应,就需要更高的转速了。 要精确的控制舵机,其实没有那么容易,很多舵机的位置等级有1024个,那么,如果舵机的有效角度范围为180度的话,其控制的角度精度是可以达到180/1024度约0.18度了,从时间上看其实要求的脉宽控制精度为2000/1024us约2us。如果你拿了个舵机,连控制精度为1度都达不到的话,而且还看到舵机在发抖。在这种情况下,只要舵机的电压没有抖动,那抖动的就是你的控制脉冲了。而这个脉冲为什么会抖动呢?当然和你选用的脉冲发生器有关了。一些前辈喜欢用555来调舵机的驱动脉冲,如果只是控制几个点位置伺服好像是可以这么做的,可以多用几个开关引些电阻出来调占空比,这么做简单吗,应该不会啦,调试应该是非常麻烦而且运行也不一定可靠的。其实主要还是他那个年代,单片机这东西不流行呀,哪里会哟! 使用传统单片机控制舵机的方案也有很多,多是利用定时器和中断的方式来完成控制的,这样的方式控制1个舵机还是相当有效的,但是随着舵机数量的增加,也许控制起来就没有那么方便而且可以达到约2微秒的脉宽控制精度了。听说AVR也有控制32个舵机的试验板,不过精度能不能达到2微秒可能还是要泰克才知道了。其实测试起来很简单,你只需要将其控制信号与示波器连接,然后让试验板输出的舵机控制信号以2微秒的宽度递增。

舵机工作原理要点

舵机工作原理 标准的舵机有3条导线,分别是:电源线、地线、控制线,如图2所示。 以日本FUTABA-S3003型舵机为例,图1是FUFABA-S3003型舵机的内部电路。

3003舵机的工作原理是:PWM信号由接收通道进入信号解调电路BA6688的12脚进行解调,获得一个直流偏置电压。该直流偏置电压与电位器的电压比较,获得电压差由BA6688的3脚输出。该输出送入电机驱动集成电路BAL6686,以驱动电机正反转。当电机转动时,通过级联减速齿轮带动电位器Rw1旋转,直到电压差为O,电机停止转动。 舵机的控制信号是PWM信号,利用占空比的变化,改变舵机的位置。

有个很有趣的技术话题可以稍微提一下,就是BA6688是有EMF控制的,主要用途是控制在高速时候电机最大转速。 原理是这样的: 收到1个脉冲以后,BA6688内部也产生1个以5K电位器实际电压为基准的脉冲,2个脉冲比较以后展宽,输出给驱动使用。当输出足够时候,马达就开始加速,马达就能产生EMF,这个和转速成正比的。 因为取的是中心电压,所以正常不能检测到的,但是运行以后就电平发生倾斜,就能检测出来。超过EMF判断电压时候就减小展宽,甚至关闭,让马达减速或者停车。这样的好处是可以避免过冲现象(就是到了定位点还继续走,然后回头,再靠近) 一些国产便宜舵机用的便宜的芯片,就没有EMF控制,马达、齿轮的机械惯性就容易发生过冲现象,产生抖舵电源线和地线用于提供舵机内部的直流电机和控制线路所需的能源.电压通常介于4~6V,一般取5V。注意,给舵机供电电源应能

提供足够的功率。控制线的输入是一个宽度可调的周期性方波脉冲信号,方波脉冲信号的周期为20 ms(即频率为50 Hz)。当方波的脉冲宽度改变时,舵机转轴的角度发生改变,角度变化与脉冲宽度的变化成正比。某型舵机的输出轴转角与输入信号的脉冲宽度之间的关系可用图3来表示。 可变脉宽输出试验(舵机控制) 原创:xidongs 整理:armok / 2004-12-05 / https://www.wendangku.net/doc/3f6341740.html,

舵机控制板使用说明(中文)

舵机控制板使用说明V1.2 产品特点 ●采用32位ARM 内核的处理器芯片 ●独创的在线升级机制,用户可以在线升级固件 ●自动识别波特率 ●采用USB和UART通讯接口 ●1us的控制精度(相当于舵机的0.09度) ●可以同时同步控制32个舵机(24路舵机控制板可以同时同步控制24个,16路舵机控制板可以同时 同步控制16个舵机) ●内置512K 存储芯片,可存储上百个动作组 ●功能强大的电脑软件(内置3种语言,简体中文、繁体中文、英语) ●拥有Android手机控制软件 供电 舵机控制板需要2个电源: 舵机电源和芯片电源 舵机电源(正极):VS(图中3号位置的蓝色接线端子的左端) 舵机电源(负极):GND(图中3号位置的蓝色接线端子的中间) 舵机电源的参数根据实际所接舵机的参数而定,如TR213舵机的供电电压是4.8-7.2V,那么舵机电源就可以用电压在4.8-7.2V之间的电源。 芯片电源(正极):VSS(图中3号位置的蓝色接线端子的右端)

芯片电源(负极):GND(图中3号位置的蓝色接线端子的中间) VSS的要求是6.5-12V,如果芯片供电是从VSS端口输入的,那么电源的电压必须是6.5-12V之间。 另外: 1. 图中2号位置的USB接口可以给芯片供电,所以USB接口和VSS端口,任选其一即可。 2. 图中1号位置也可以给芯片供电,标记为5V和GND,5V是正极,GND是负极,供电电源的电压必 须是5V。 3. 图中1、2、3号位置都可以给芯片供电,任选其一即可。 4. 图中4号位置的绿色LED灯是芯片电源正常的指示灯,绿色灯亮,表示芯片供电正常,绿色灯灭,表 示芯片供电异常。 5. 图中5号位置的绿色LED灯是舵机电源正常的指示灯,绿色灯亮,表示舵机供电正常,绿色灯灭,表 示舵机供电异常。 如果需要控制舵机,2个绿色的LED灯都亮是前提条件。

51控制舵机程序大全

#include void InitTimer0(void) { TMOD = 0x01; TH0 = 0x0B1; TL0 = 0x0E0; EA = 1; ET0 = 1; TR0 = 1; }void delay(1)(void) { unsigned char a,b,c; for(c=1;c>0;c--) for(b=142;b>0;b--) for(a=2;a>0;a--); } void main(void) { InitTimer0(); P1_2=0; while(1); } void Timer0Interrupt(void) interrupt 1 { //20ms中断 TH0 = 0x0B1; TL0 = 0x0E0; P1_2=1; delay(1); P1_2=0; }

#include #include #include #define uchar unsigned char #define uint unsigned int sbit IN1=P0^0; sbit IN2=P0^1; sbit EA1=P0^5; sbitdj=P0^7; //舵机口 uint t=0;//中断次数 ucharzk;//高电平中断次数uchar p=0;//定义pwm占空比void delay(uint z) { uinti,j; for(i=0;i>8;//100us一次中断TL0=-100%256; if(t==0)zk=p; if(t=zk) dj=0; t++; if(t>=200) t=0;//20mspwm周期 } void turn_left() { IN1=1;IN2=0;EA1=1;//电机工作p=5;//0.5ms delay(600); } void turn_right() { IN1=1;IN2=0;EA1=1;//电机工作p=25;//2.5ms delay(600);

舵机及转向控制原理

舵机及转向控制原理 令狐采学 1、概述 2、舵机的组成 3、舵机工作原理 4、舵机选购 5、舵机使用中应注意的事项 6、辉盛S90舵机简介 7、如何利用程序实现转向 8、51单片机舵机测试程序 1、概述 舵机也叫伺服电机,最早用于船舶上实现其转向功能,由于可以通过程序连续控制其转角,因而被广泛应用智能小车以

实现转向以及机器人各类关节运动中,如图1、图2所示。 令狐采学创作 图1舵机用于机器人 图2舵机用于智能小车中 舵机是小车转向的控制机构,具有体积小、力矩大、外部机械设计简单、稳定性高等特点,无论是在硬件设计还是软件设计,舵机设计是小车控制部分重要的组成部分,图3为舵机的外形图。 图3舵机外形图 2、舵机的组成 一般来讲,舵机主要由以下几个部分组成,舵盘、减速齿 轮组、位置反馈电位计、直流电机、控制电路等,如图4、图5所示。 图4舵机的组成示意图 图5舵机组成

舵机的输入线共有三条,如图6所示,红色中间,是电源线,一边黑色的是地线,这辆根线给舵机提供最基本的能源保证,主要是电机的转动消耗。电源有两种规格,一是4.8V, —令狐采学创作是6.0V,分别对应不同的转矩标准,即输出力矩不 同,6.0V对应的要大一些,具体看应用条件;另外一根线是控制信号线,Futaba的一般为白色,JR的一般为桔黄色。另外要注意一点,SANWA的某些型号的舵机引线电源线在边上而不是中间,需要辨认。但记住红色为电源,黑色为地线,一般不会搞错。 图6舵机的输出线 3、舵机工作原理 控制电路板接受来自信号线的控制信号,控制电机转动,电机带动一系列齿轮组,减速后传动至输出舵盘。舵机的输出轴和位置反馈电位计是相连的,舵盘转动的同时,带动位置反馈电位计,电位计将输出一个电压信号到控制电路板,进行反馈,然后控制电路板根据所在位置决定电机转动的方向和速度,从而达到目标停止。其工作流程为:控制信号一控制电路板―电机转动-齿轮组减速-舵盘转动?位置反馈电位计-控制电路板反馈。

舵机控制型机器人设计要点

课程设计项目说明书 舵机控制型机器人设计 学院机械工程学院 专业班级2013级机械创新班 姓名吴泽群王志波谢嘉恒袁土良指导教师王苗苗 提交日期 2016年4 月1日

华南理工大学广州学院 任务书 兹发给2013级机械创新班学生吴泽群王志波谢嘉恒袁土良 《产品设计项目》课程任务书,内容如下: 1. 题目:舵机控制型机器人设计 2.应完成的项目: 1.设计舵机机器人并实现运动 2.撰写机器人说明书 3.参考资料以及说明: [1] 孙桓.机械原理[M].北京.第六版;高等教育出版社,2001 [2] 张铁,李琳,李杞仪.创新思维与设计[M].国防工业出版社,2005 [3] 周蔼如.林伟健.C++程序设计基础[M].电子工业出版社.北京.2012.7 [4] 唐增宏.常建娥.机械设计课程设计[M].华中科技大学出版社.武汉.2006.4 [5] 李琳.李杞仪.机械原理[M].中国轻工业出版社.北京.2009.8 [6] 何庭蕙.黄小清.陆丽芳.工程力学[M].华南理工大学.广州.2007.1 4.本任务书于2016 年2 月27 日发出,应于2016 年4月2 日前完 成,然后提交给指导教师进行评定。 指导教师(导师组)签发2016年月日

评语: 总评成绩: 指导教师签字: 年月日

目录 摘要 (1) 第一章绪论 (2) 1.1机器人的定义及应用范围 (2) 1.2舵机对机器人的驱动控制 (2) 第二章舵机模块 (3) 2.1舵机 (3) 2.2舵机组成 (3) 2.3舵机工作原理 (4) 第三章总体方案设计与分析 (6) 3.1 机器人达到的目标动作 (6) 3.2 设计原则 (6) 3.3 智能机器人的体系结构 (6) 3.4 控制系统硬件设计 (6) 3.4.1中央控制模块 (7) 3.4.2舵机驱动模块 (7) 3.5机器人腿部整体结构 (8) 第四章程序设计 (9) 4.1程序流程图 (9) 4.2主要中断程序 (9) 4.3主程序 (11) 参考文献 (13) 附录 (14) 一.程序 (14) 二.硬件图 (17)

舵机控制C程序

舵机控制C程序 #include #defineucharunsignedchar #defineuintunsignedint /* 变量定义 */ ucharkey_stime_counter,hight_votage=15,timeT_counter; bitkey_stime_ok; /* 引脚定义 */ sbitcontrol_signal=P0^0; sbitturn_left=P3^4; sbitturn_right=P3^5; /***************************************************************** 名称:定时器0初始化 功能:20ms定时,11.0592M晶振 初值20ms 初值0.1ms *****************************************************************/ voidTimerInit() { control_signal=0; TMOD=0x01;//设置定时器0为工作方式1 EA=1;//开总中断 ET0=1;//定时器0中断允许 TH0=0xFF;//定时器装初值 TL0=0xA3; TR0=1;//启动定时器0 } /********************************************** 定时器0中断服务函数 ***********************************************/ voidtimer0(void)interrupt1using0 { TH0=0xFF; TL0=0xA3;//定时器0重新装入数值

舵机原理及其使用详解

舵机的原理,以及数码舵机VS模拟舵机 一、舵机的原理 标准的舵机有3条导线,分别是:电源线、地线、控制线,如图2所示。 以日本FUTABA-S3003型舵机为例,图1是FUFABA-S3003型舵机的内部电路。 3003舵机的工作原理是:PWM信号由接收通道进入信号解调电路BA6688的12脚进行解调,获得一个直流偏置电压。该直流偏置电压与电位器的电压比较,获得电压差由BA6688的3脚输出。该输出送入电机驱动集成电路BAL6686,以驱动电机正反转。当电机转动时,通过级联减速齿轮带动电位器Rw1旋转,直到电压差为O,电机停止转动。 舵机的控制信号是PWM信号,利用占空比的变化,改变舵机的位置。 有个很有趣的技术话题可以稍微提一下,就是BA6688是有EMF控制的,主要用途是控制在高速时候电机最大转速。 原理是这样的:

收到1个脉冲以后,BA6688内部也产生1个以5K电位器实际电压为基准的脉冲,2个脉冲比较以后展宽,输出给驱动使用。当输出足够时候,马达就开始加速,马达就能产生EMF,这个和转速成正比的。 因为取的是中心电压,所以正常不能检测到的,但是运行以后就电平发生倾斜,就能检测出来。超过EMF 判断电压时候就减小展宽,甚至关闭,让马达减速或者停车。这样的好处是可以避免过冲现象(就是到了定位点还继续走,然后回头,再靠近) 一些国产便宜舵机用的便宜的芯片,就没有EMF控制,马达、齿轮的机械惯性就容易发生过冲现象,产生抖舵 电源线和地线用于提供舵机内部的直流电机和控制线路所需的能源.电压通常介于4~6V,一般取5V。注意,给舵机供电电源应能提供足够的功率。控制线的输入是一个宽度可调的周期性方波脉冲信号,方波脉冲信号的周期为20ms(即频率为50Hz)。当方波的脉冲宽度改变时,舵机转轴的角度发生改变,角度变化与脉冲宽度的变化成正比。某型舵机的输出轴转角与输入信号的脉冲宽度之间的关系可用围3来表示。

PWM控制舵机 C程序

#include "reg52.h" sbit control_signal=P0^0; sbit turn_left=P3^0; sbit turn_right=P3^1; unsigned char PWM_ON=15 ;//定义高电平时间 /******************************************************************/ /* 延时函数 */ /******************************************************************/ void delay(unsigned int cnt) { while(--cnt); } void display() { if(PWM_ON>=5&&PWM_ON<=7) P1=0xFD; //1灯亮,舵机接近或到达右转极限位置if(PWM_ON>7&&PWM_ON<=10) P1=0xFB; //2灯亮 if(PWM_ON>10&&PWM_ON<=13) P1=0xF7; //3灯亮 if(PWM_ON>13&&PWM_ON<=16) P1=0xEF; //4灯亮,舵机到达中间位置 if(PWM_ON>16&&PWM_ON<=19) P1=0xDF; //5灯亮 if(PWM_ON>19&&PWM_ON<=22) P1=0xBF; //6灯亮 if(PWM_ON>22&&PWM_ON<=25) P1=0x7F; //7灯亮,舵机接近或到达左转极限位置} /******************************************************************/ /* 主函数 */ /******************************************************************/ void main() { //bit Flag; TMOD |=0x01; //定时器设置 0.1ms in 11.0592M crystal TH0=(65536-78)/256; TL0=(65536-78)%256; //定时0.1mS ET0=1;//定时器中断打开 EA=1;//总中断 //IE= 0x82; //打开中断 TR0=1; // PWM_ON=15 //的取值范围是6-25 while(1) { if(turn_left==0) { delay(1000); if(turn_left==0) { while(!turn_left){}

相关文档
相关文档 最新文档