智能循迹小车实训报告Word文档下载推荐.docx
《智能循迹小车实训报告Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《智能循迹小车实训报告Word文档下载推荐.docx(21页珍藏版)》请在冰豆网上搜索。
四号黑体左起,四号黑体,段前、段后均为12磅。
三级标题:
小四号黑体左起,段前、段后均为6磅。
图名、表名五号黑体,英文、数字字体为TimesNewRoman
页边距:
上、下、左3厘米,右2厘米,A4纸打印。
1系统硬件组成与工作原理
1.1.1控制器与最小系统
最小系统:
要使一块单片机芯片工作起来最简陋的接线方式就是单片机的最小系统。
下面STC89C52单片机的最小系统(注意:
不同封装的单片机引脚位置不同,下图是DIP40封装)。
将一块单片机芯片接成这样就能工作了。
下面分析一下电路中各个部分的作用:
1.供电电路:
40脚接电源+5V,20脚接地,这样便完成了单片机的供电。
2.选择使用内部ROM:
我们下载程序的时候是将程序下载的单片机内部的ROM里面存放的,将EA/VPP端接到高电平(+5V),就告诉单片机系统我们选择的是内部的ROM,这样单片机工作的时候就会执行内部ROM里面的代码了。
如果将EA/VPP接地,单片机就会执行扩展的外部ROM,我们没有扩展ROM呀,以后在没有扩展ROM的时候我们都将它接高电平就OK。
3.复位电路:
复位电路由电阻R1和电容C1组成。
复位电路是用以完成单片机的复位初始化操作的(复位单片机RAM和各个寄存器的值的)。
也就是说,在单片机还没工作之前,我们先把寄存器的值全部复位成初始的默认值然后再开始工作,避免执行程序的时候发生错乱。
那复位电路的工作原理是怎样的呢?
在单片机没上电的时候,电容C1两个极板没有电荷,在单片机上电的瞬间,电容C1两端获得电压开始充电,既然C1要充电那么就必定有电流通过R1,所以在R1两端产生了瞬时电压,这个电压被加到了单片机的RST端,单片机的RST端得到了一个高电平便复位了。
随着时间的推移,C1充满电了,再也没电流通过R1了,R1两端便没有了电压,单片机的RST引脚又由高电平变成了低电平,这时,单片机便开始工作了。
值得注意的是,要引起单片机的复位,加在RST端的高电平必须保持在一定的时间以上(连续2个机器周期以上高电平)。
4.时钟电路:
时钟电路由C2、C3和晶振Y1组成。
时钟电路的作用是给单片机提供时钟脉冲,只有给单片机提供时钟脉冲单片机才会执行程序。
1.2.1显示模块学习目标
认识数码管是什么东西?
用HJ-1G点亮第一个数码管,认识一个新的芯片HJ573
集成电路的应用。
1.2.4单个数码管原理图
如果需要显示“3”字符,则“E”“F”“DP”段都不显示,其
他段点亮
可以根据上图算出需要的8位段码值:
共阴16进制:
0x4F
共阳16进制:
0xB0
本开发板使用共阴数码管
1.2.5开发板数码管模块原理图
1.3源码编写
开始写程序之前认识一下锁存器(74HC573):
顾名思义,就是把输入端的数据锁存(或送)到输出端,请看下图中的U3元件,第11角(锁存端)为高电平的时候,右边D0-D7的输入与左边Q0-Q7的输出是直通的,就是说,输入端是什么电平,输出端就是什么电平,可以把它当作不存在。
当第11角为低电平的时候,左右两端就被断开了,无论输入端怎么变化,输出端都不会变化,当第11角由低电平变为高电平的一瞬间,输入端的数据立刻被传送到输出端,并且在11角保持为高电平期间,输出端数据始终与输入端数据相同,如果此时我们再次把第11角设置为低电平,那么以后当输入端无论再怎么变化,输出端都不会变化而是保持刚才第11角在下降沿(由高电平到低电平跳变)之间时输入端的值,这样就达到了锁存数据的目的,这也就是所谓的总线设计思路,一个8位的数据线加一个锁存器后就可以扩接多个元件,当选通哪个元件的片选信号,就送数据给那个元件。
先说这个元件,以后用到别的元件我们再解释。
74HC57311脚接高电平,锁存不起作用,相当于直通。
相应的段赋值“1”有效。
74HC138A、B、C赋值0~7,则输出端分别是Y0~Y7置“0”,如P2=0,
则Y0=0;
P2=6;
则Y6=0;
即选通第七个数码管。
程序如下
/*-----------------------------------------------
内容:
数码管使用动态扫描显示,所以可以同时看到数码管同时显示数字或者
字符,扫描原理可以参
#include<
reg51.h>
#defineuintunsignedint
#defineucharunsignedchar
sbitdula=P2^6;
sbitwela=P2^7;
voiddelay(uintz)
{
uintx,y;
for(x=z;
x>
0;
x--)
for(y=110;
y>
y--);
}
voidmain(void)//每一个C语言程序有且只有一个主函数,
while
(1)//循环条件永远为真,以下程序一直执行下去。
dula=1;
P0=0x5b;
//显示一个2
dula=0;
wela=1;
P0=0xfe;
//显示一位数码管?
可以自己修改显示位数
wela=0;
delay
(1);
多个数码管同时显示
上一节单个数码管显示,实际使用中单个数码管往往不能满足要求,这就需要多个数码管组合使用,单个数码管一般用静态显示,占用IO口线较多,如果使用普通的静态显示,单片机的IO口是不够用的。
所以就需要使用动态扫描。
通过程序让任意一位数码管显示任意一种字符,这样我们可以以时间为轴,循环显示每个数码管需要的数值,当循环显示的时间比较小时,眼睛就不能分辨出闪烁,而是看到一个静态的数值显示,可以通过下载“数码管动态扫描”和“数码管动态扫描演示”,就可以深入了解这个原理,以后使用的数码管显示的部分都是基于这个原理的。
1.4总结
数码管是最常用的显示输出模块,可以显示温度,时间,步进电机转速等,数码管里面简单一点说是集成了8个发光管,由点变成线,由7条线1个点组成1个数码管,发光管我们会写程序控制它了,这个数码管一定难不到我们,原理方法是一样的,这次不是单片机IO口直接驱动的,是加了573还有138共同来控制数码管的点亮,主要是为了节省单片机IO口,一口多用,一个8位IO口实现多功能控制。
1.5.1学习目标
独立按键是区别于矩阵键盘的一种按键方式,主要是按键直接连接到IO口,另外一端连接VCC或者GND,一般情况连接到GND(地),也就是按键按下的时候,IO口的电平被强制拉低,即0,而通过IO输入检测该端口电平就可以判断按键是否按下。
1.5.2硬件电路
1.6原理图
1.6.1触点存在抖动现象说明
由于按键本身都存在不同的机械抖动,单片机属于高速检测器件,可以很容易检测出抖动,但抖动并不是我们需要的,容易造成误操作,所以正常使用过程中需要添加去抖动程序,主要用于跳过抖动,避免造成干扰。
1.6.2开发板独立按键模块原理图
1.7源码编写
独立按键软件操作简单,主要检测按键连接的IO口是否为“0”,为“0”表
示按键按下。
用以下语句:
SbitKEY1=P3^0;
If(!
KEY1){//添加按键按下时需要执行的操作}
实际使用中按键有固定的机械抖动,根据不同按键抖动时间不同,一般4-15mS,根据这个特点,需要延时躲避抖动,由于按下和释放都会存着抖动,实际使用程序需要进行2次去抖。
具体程序如下:
#include<
reg52.h>
sbitBY1=P3^4;
//定义按键的输入端S2键
unsignedcharcount;
//按键计数,每按一下,count加1
unsignedchartemp;
unsignedchara,b;
voiddelay10ms(void)//延时程序
unsignedchari,j;
for(i=20;
i>
i--)
for(j=248;
j>
j--);
key()//按键判断程序
if(BY1==0)//判断是否按下键盘
delay10ms();
//延时,软件去干扰
if(BY1==0)//确认按键按下
count++;
//按键计数加1
if(count==8)//计8次重新计数
count=0;
//将count清零
while(BY1==0);
//按键锁定,每按一次count只加1.
move()//广告灯向左移动移动函数
a=temp<
<
count;
b=temp>
>
(8-count);
P1=a|b;
main()
//初始华参数设置
temp=0xfe;
P1=0xff;
P1=temp;
while
(1)//永远循环,扫描判断按键是否按下
key();
//调用按键识别函数
move();
//调用广告灯移动函数
//如果有干扰请加去抖程序
//红外接收头部分用黑色物质遮光,防止干扰按键,因为红外接收和按键使用同
一个端口
一、蜂鸣器介绍
蜂鸣器有两种:
一种是有源蜂鸣器,只要给它加上恒定的电压,就能发声,另一
种是无源蜂鸣器,必须给它加上一定频率的方波或正弦波才能发声,一般实验板
配的是无源蜂鸣器,HJ-1G开发板也不例外,由于驱动蜂鸣器电流要求比较大,
所以我们使用8550三极管来放大驱动,电路如下:
FMIO口为P2.3
图2蜂鸣器外形图
注意:
喇叭和蜂鸣器不同,如果蜂鸣器直接加5V电源则发出固定频率的
声音。
掉电后会消失。
喇叭不同,加5V电压后是不发声的,但是器件处
于最大功耗状态,会有非常大的热功耗。
长时间会烧毁喇叭。
所以使
用的时候要注意,如果不是专门针对它操作,请断开它的输入信号端
子,防止误操作导致意外损坏。
二、蜂鸣器编程实例
具体编程时我们间隔一段时间将BZ线置反,就能输出一个固定频率的方波,让
蜂鸣器响起来。
大家可能会问,给蜂鸣器多少频率的方波呢?
首先这个频率必须在音频范围内,
也就是20Hz到20KHZ之间,但是20Hz到20KHZ的频率送给蜂鸣器后,只有某一
点的频率是最响的,这个频率称为蜂鸣器的谐振频率,离它越远,蜂鸣器发出的
声音越轻。
1G/3G开发板配的蜂鸣器的谐振频率是2KHZ,其半周期是250us,这样我们就确
定了BZ口线每延时250us就要变反。
下面是一个蜂鸣器发声的实例程序:
/*以下程序为FM程序,晶振频率为11.0592MHz*/
sbitSPK=P2^3;
//定义蜂鸣器端口
voiddelay(unsignedintcnt)//延时
while(--cnt);
unsignedinti;
while
(1)
for(i=0;
i<
200;
i++)//喇叭发声的时间循环,改变大小可以改变发声时间长短
delay(80);
//参数决定发声的频率,估算值
SPK=!
SPK;
SPK=1;
//喇叭停止工作,间歇的时间,可更改
delay(20000);
电机驱动原理图
电机驱动接口图
1.4.1电机驱动模块
采用功率三极管作为功率放大器的输出控制直流电机。
线性型驱动的电路结构和原理简单,加速能力强,采用由达林顿管组成的H型桥式电路。
用单片机控制达林顿管使之工作在占空比可调的开关状态下,精确调整电动机转速。
这种电路由于工作在管子的饱和截止模式下,效率非常高,H型桥式电路保证了简单的实现转速和方向的控制,电子管的开关速度很快,稳定性也极强,是一种广泛采用的PWM调速技术。
这种调速方式有调速特性优良、调整平滑、调速范围广、过载能力大,能承受频繁的负载冲击,还可以实现频繁的无级快速启动、制动和反转等优点。
因此决定采用使用功率三极管作为功率放大器的输出控制直流电机。
1.6避障模块的工作原理与接口
本次功能设计为智能小车循迹加避障,循迹指寻黑线走,避障指遇到障碍物小车会自动避开,寻找无障碍路线走下去;
以及小车快速前进走直线后慢速后退走直线功能。
2.2.1程序设计要求
赛道一:
小车循迹黑线,在桌子上用黑线画出一个椭圆赛道,小车将沿着黑线做循迹运动;
中间会设置障碍物,看小车能否自动避障。
2.2.4程序代码
AT89X52.H>
//包含51单片机头文件,内部有各种寄存器定义
HJ-4WD_PWM.H>
//包含HL-1蓝牙智能小车驱动IO口定义等函数
#ifndef_LED_H_
#define_LED_H_
//定义小车驱动模块输入IO口
sbitIN1=P1^2;
sbitIN2=P1^3;
sbitIN3=P1^6;
sbitIN4=P1^7;
sbitEN1=P1^4;
sbitEN2=P1^5;
/***蜂鸣器接线定义*****/
sbitBUZZ=P2^3;
#defineLeft_1_ledP3_3//左传感器(循迹)
#defineRight_1_ledP3_2//右传感器(循迹)
#defineLeft_2_ledP3_5//左传感器(避障)
#defineRight_2_ledP3_4//右传感器(避障)
#defineLeft_moto_pwmP1_5//PWM信号端
#defineRight_moto_pwmP1_4//PWM信号端
#defineLeft_moto_go{P1_2=0,P1_3=1;
}//左电机向前走
#defineLeft_moto_back{P1_2=1,P1_3=0;
}//左边电机向后转
#defineLeft_moto_Stop{P1_5=0;
}//左边电机停转
#defineRight_moto_go{P1_6=1,P1_7=0;
}//右边电机向前走
#defineRight_moto_back{P1_6=0,P1_7=1;
}//右边电机向后走
#defineRight_moto_Stop{P1_4=0;
}//右边电机停转
unsignedcharpwm_val_left=0;
//变量定义
unsignedcharpush_val_left=0;
//左电机占空比N/20
unsignedcharpwm_val_right=0;
unsignedcharpush_val_right=0;
//右电机占空比N/20
bitRight_moto_stop=1;
bitLeft_moto_stop=1;
unsignedinttime=0;
/************************************************************************/
//延时函数
voiddelay(unsignedintk)
{
unsignedintx,y;
for(x=0;
x<
k;
x++)
for(y=0;
y<
2000;
y++);
/************************************************************************/
//前速前进
voidrun(void)
push_val_left=6;
//速度调节变量0-20。
。
0最小,20最大
push_val_right=6;
Left_moto_go;
//左电机往前走
Right_moto_go;
//右电机往前走
//后退函数如果看不明白,请看慧净电子51智能小车视频教程
voidbackrun(void)
Left_moto_back;
//左电机往后走
Right_moto_back;
//右电机往后走
//左转
voidleftrun(void)
push_val_left=5;
push_val_right=5;
//右转
voidrightrun(void)
Right_moto_back;
//右电机往后走
/*PWM调制电机转速*/
/*左电机调速*/
/*调节push_val_left的值改变电机转速,占空比*/
voidpwm_out_left_moto(void)
if(Left_moto_stop)
{
if(pwm_val_left<
=push_val_left)
Left_moto_pwm=1;
//Left_moto_pwm1=1;
}
else
Left_moto_pwm=0;
//Left_moto_pwm1=0;
if(pwm_val_left>
=20)
pwm_val_left=0;
}
//Left_moto_pwm1=0;
/******************************************************************/
/*右电机调速*/
voidpwm_out_right_moto(void)
if(Right_moto_stop)
{
if(pwm_val_right<
=push_val_right)
Right_moto_pwm=1;
//Right_moto_pwm1=1;
Right_moto_pwm=0;
//Right_moto_pwm1=0;
if(pwm_val_right>
pwm_val_right=0;
Right_moto_pwm=0;
//Right_moto_pwm1=0;
/***************************************************/
///*TIMER0中断服务子函数产生PWM信号*/
voidtimer0()interrupt1using2
TH0=0XFc;
//1Ms定时
TL0=0X18;
time++;
pwm_val_left++;
pwm_val_right++;
pwm_out_left_moto();
pwm_out_right_moto();
}
/*********************************************************************/
#endif
//主函数
voidmain(void)
unsignedchari;
P1=0X00;
//关电车电机
//本实验学习的按键启动知识
B:
for(i=0;
50;
i++)//判断K4是否按下
{
delay
(1);
//1ms内判断50次,如果其中有一次被判断到K4没按下,便重新检测
if(P3_7!
=0)//当K4按下时,启动小车前进,如有不明,请看慧净51单片机视频教程
gotoB;
//跳转到标号B,重新检测
}
//本实验学习的知识蜂鸣器,注意要在HJ-4WD头文件里定义IO口
BUZZ=0;
//50次检测K4确认是按下之后,蜂鸣器发出“滴”声响,然后启动小车。
delay(50);
BUZZ=1;
//响50ms后关闭蜂鸣器
TMOD=0X01;
TH0=0XFc;
//1ms定时
TL0=0X18;
TR0=1;
ET0=1;
EA=1;
//开总中断
while
(1)//无限循环
//有信号为0没有信号为1
if(Left_1_led==0&
&
Right_1_led==0&
Left_2_led==1&
Right_2_led==1||Left_1_led==1&
Right_1_led==1&
Right_2_le