1、(完整word版)毕业设计_基于stm32的智能小车设计摘要本次试验主要分析了基于STM32F103微处理器的智能小车控制系统的系统设计过程。此智能系统的组成主要包括STM32F103控制器、电机驱动电路、红外探测电路、超声波避障电路。本次试验采用STM32F103微处理器为核心芯片,利用PWM技术对速度以及舵机转向进行控制,循迹模块进行黑白检测,避障模块进行障碍物检测并避障功能,其他外围扩展电路实现系统整体功能。小车在运动时,避障程序优先于循迹程序,用超声波避障电路进行测距并避障,在超声波模块下我们使用舵机来控制超声波的发射方向,用红外探测电路实现小车循迹功能。在硬件设计的基础上提出了实现电
2、机控制功能、智能小车简单循迹和避障功能的软件设计方案,并在STM32集成开发环境Keil下编写了相应的控制程序,并使用mcuisp软件进行程序下载。关键词:stm32;红外探测;超声波避障;PWM;电机控制AbstractThis experiment mainly analyzes the control system of smart car based on microprocessor STM32F103 system design process. The composition of the intelligent system mainly including STM32F103
3、 controller, motor drive circuit, infrared detection circuit, circuit of ultrasonic obstacle avoidance. This experiment adopts STM32F103 microprocessor as the core chip, using PWM technique to control speed and steering gear steering, tracking module is used to detect the black and white, obstacle a
4、voidance module for obstacle detection and obstacle avoidance function, other peripheral extended circuit to realize the whole system function. When the car is moving, obstacle avoidance program prior to tracking, using ultrasonic ranging and obstacle avoidance obstacle avoidance circuit, we use ste
5、ering gear under ultrasonic module to control the emission direction of ultrasonic, infrared detection circuit is used to implement the car tracking function. On the basis of the hardware design is proposed for motor control function, simple intelligent car tracking and obstacle avoidance function o
6、f software design, and in the STM32 integrated development environment under the Keil. Write the corresponding control program, and use McUisp program download software.Keywords:STM32;Infrared detection;Ultrasonic obstacle avoidance;PWM;Motor control目录1.绪论- 4 -1.1研究概况- 4 -1.2研究思路- 4 -2.软硬件设计- 5 -2.1
7、中央处理模块- 5 -2.1.1 stm32f103内部结构- 6 -2.1.2 stm32最小系统电路设计- 7 -2.1.3 stm32软件设计的基本思路- 9 -2.1.4 stm32中断介绍- 9 -2.1.5 stm32定时/计数器介绍- 11 -2.1.6 主程序设计流程图- 12 -2.2 电机驱动模块- 13 -2.2.1 驱动模块结构及其原理- 13 -2.2.2 驱动模块电路设计- 13 -2.2.3驱动软件程序设计- 14 -2.3 避障模块设计- 18 -2.3.1 避障模块器件结构及其原理- 19 -2.3.2 HC-SR04模块硬件电路设计- 21 -2.3.3 H
8、C-SR04模块程序设计- 21 -2.4循迹模块设计- 28 -2.4.1 循迹模块结构及其原理- 28 -2.4.2 循迹模块电路设计- 30 -2.4.3 红外循迹模块程序设计- 30 -3.软件调试- 33 -3.1 程序仿真- 33 -3.2 程序下载- 34 -4.系统测试- 35 -5.总结- 37 -致谢- 39 -参考文献- 40 -附录- 41 -1.绪论智能小车通过各种感应器获得外部环境信息和内部运动状态,实现在复杂环境背景下的自主运动,从而完成具有特定功能的机器人系统。而随着智能化电器时代的到来,它们在为人们提供的舒适的生活环境的同时,也提高了制造智能化电器对于人才要求
9、的门槛。智能小车是集成了多种高新技术,它不仅融合了电子、传感器、计算机硬件、软件等许多学科的知识,而且还涉及到当今许多前沿领域的技术,它是一个国家高科技技术水平的重要体现。通过建立起简易智能小车的设计,引导学生从理论走向实践,培养同学们的动手能力,使同学们在了解智能化电器的工作原理的基础上,还使同学们获得完成整体项目的能力,并掌握了Stm32开发板的编程原理,为同学们进入ARM领域提供了基础。另外,本次课程设计,使同学们了解自己的不足之处,从而使同学们有目标的提升自己的能力。1.1研究概况国外研究概况:上世纪50年代初,国外就有智能车辆的研究,从90年代开始,智能车辆的研究就进入了系统化、大规
10、模的研究阶段。尤其突出的是美国卡内基-梅陇大学机器人研究所已经完成了Navlab系列的自主车辆的研究,这一研究成果代表了国外智能车辆的主要研究方向。国内研究概况:我国对于智能车辆的研究较晚,始于上世纪80年代,而且现在大部分还是使用入门级别的51单片机进行设计与研究的,为了弥补与国外研究的差距,开设了全国大学生电子设计竞赛。1.2研究思路系统将采集的传感器信号送入stm32微控制器中,stm32微控制器根据采集的信号做出不同的判断,从而控制电机运动方向和运动速度。系统以stm32微控制器为核心,通过传感器采集不同的信号做出判断,继而改变电机的运动方向和运动速度。实验系统结构如图1.1所示:图1
11、.1 实验系统结构图2.软硬件设计智能小车控制系统具备了障碍物检测、自主避障、自主循迹等功能。相应的控制系统主要由以下四个模块组成:避障模块、循迹模块、电机驱动模块、中央处理模块四个模块组成,系统总体框架如图2.1所示:这个图调整下,和下面的编号看起来位置不协调图2.1 系统框架图我们本节主要任务是了解各个模块的功能,掌握各个模块所使用的器件的使用方法,并能够编写相应的程序代码。掌握各个模块的功能。2.1中央处理模块在人类身体结构中,大脑可以根据各个器官所传输的信息做出相应的行为动作用以保证人体所必须的生理原料,而stm32处理器之于智能小车就相当于大脑之于人类,它可以从各个模块之间获得数据,
12、并对所传输的数据进行实时处理,来驱使电机模块做出相应的行为动作。由ARM公司设计的基于ARMv7架构的Cortex系列的标准体系结构在2006年推出,此结构是用来满足日渐复杂的不同性能要求的软件设计,根据所面向的领域,Cortex系列可以分为A、R、M三个分工明确的系列1。Stm32处理器的出现为微控制系统、工业控制系统、汽车车身系统和无线网络等对功耗和成本敏感的嵌入式应用领域实现高系统性能系统提供了基础,使编程的复杂性,集高性能、低功耗、低成本大大简化,并使它们融为于一体2。意法半导体ST公司作为一个半导体制造厂商,是ARM公司Cortex-M3内核开发项目一个主要合作方。2007年6月11
13、日由ST公司率先推出的基于Cortex-M3内核的STM32系列微控处理器研发而出。此中,A系列是面向复杂的尖端应用程序,用于运行开放式的复杂操作系统;R是Real的首字母缩写,是面向实时系统开发的;M是Mirco的首字母缩写,专门面向低成本的微控制领域开发研究。因此,Cortex-M3处理器是由ARM公司设计的首款基于ARMv7-M体系结构的32位标准处理器,它不仅具有低功耗、少门数等优点,而且还具有短中断延迟、低调试成本等众多优点,使它在众多的处理器中脱颖而出。目前为止,STM32系列处理器暂分为2个系列。其中,STM32F101系列是标准型系列,工作频率设定在36MHZ;STM32F10
14、3系列是增强型系列,工作频率设定在72MHZ,其带有更多片内RAM和更丰富的外设资源。这两个系列的产品在软件和引脚封装方面具有兼容性,并且拥有相同的片内Flash资源,使软件的开发和升级更加方便。本次试验,我们使用的是stm32f103处理器。2.1.1 stm32f103内部结构STM32F103系列微处理器是首款基于ARMv7-M体系结构的32位标准RISC (精简指令集)处理器,具有执行代码效率高,外设资源丰富等众多优点。该系列微处理器工作频率设定在72MHz,高达128K 字节的内置Flash存储器存储器 存储器是用来存储程序和数据的部件,有了存储器,计算机才有记忆功能,才能保证正常工
15、作。它根据控制器指定的位置存进和取出信息。 全文和20K 字节的SRAM,方便程序编写,而且具有丰富的通用I/O 端口。其内部结构图如图2.2所示:图2.2 内部结构图Stm32处理器主系统主要由4个被动单元和4个驱动单元构成。4个驱动单元是:通用DMA1,通用DMA2,内核DCode总线和系统总线。4个被动单元由APB桥,APB设备,内部Flash闪存,内部SRAM、FSMC。我们实验所采用的芯片具有64KBSRAM、512KBFLASH、2个基本定时器,4个通用定时器,2个高级定时器,3个SPI,2个IIC,5个串口,1个USB,1个CAN,3个12位的ADC,1个12位DAC、1个SDI
16、O接口,1个FSMC接口以及112个通用I/O口。2.1.2 stm32最小系统电路设计Stm32的最小系统电路主要由系统时钟电路、实时时钟电路、JTAG调试接口电路,复位电路和启动模式选择电路组成。最小系统电路原理图如图2-1-3所示:图2.3 最小系统电路原理图主要电路原理图的设计及功能如下所示: 1.系统时钟电路系统时钟电路主要作用是提供节拍,就相当于人类的心脏跳动,随着心脏的跳动,血液就会到达全身部位,所以系统时钟的重要性就不言而喻啦。系统时钟的电路设计如图2.4所示:图2.4 系统时钟电路图在时钟电路中,我们选用8M的晶振。2.复位电路 复位电路的设计如图2.5所示:图2.5 复位电
17、路图本次试验所采用的开发板为低电平复位。如图所示,当按键悬空时RST输入为高电平,当按键按下时,RST脚输入为低电平,从而电路复位。3.JTAG电路 JTAG电路原理图如图2.6所示:图2.6 JAG电路原理图JTAG的主要功能是使目标文件烧到核处理器中。4.启动模式电路 启动模式电路原理图如图2.7所示:图2.7 启动模式电路原理图通过设置BOOT1:0引脚可以选择三种不同启动模式,启动模式如表2-1所示:表2-1 启动模式表启动模式选择引脚启动模式说明BOOT1BOOT0X0主闪存存储器主闪存存储器被选为启动区域01系统存储器系统存储器被选为启动区域11内置SRAM内置SRAM被选为启动区
18、域2.1.3 stm32软件设计的基本思路在对其他模块设计之前,我们必须了解stm32的编程规则。任何处理器,包括stm32处理器,想要处理器完成某项相应的动作,就必须对处理器的寄存器进行操作。比如,我们在单片机C51中,同样,我们在stmM32的开发中过程中,我们同样可以对寄存器直接操作:GPIOx-BRR=0x0011。 (x可以是A,B,C,D,E比如GPIOA就是端口A)但是,对于stm32这种级别的处理器,几百个寄存器记起来谈何容易。所以,ST(意法半导体)提出了固件库的概念,利用固件库进行编程。固件库的本质就是函数的集合,固件库将那些寄存器的底层操作都封装起来,提供一整套API供开
19、发者使用。比如,上面通过控制BRR寄存器来控制电平的变化,官方库封装了一个函数:Void GPIO_ResetBits(GPIO_TypeDef * GPIOx,uint16_t GPIO_Pin)GPIOx-BRR = GPIO_Pin; (x可以是A,B,C,D,E比如GPIO_A就是端口A)通过使用GPIO_ResetBits()函数就可以直接对寄存器进行操作啦。2.1.4 stm32中断介绍本方案中,我们要使用stm32的中断,在程序设计中,我们要开启各个管道的中断,打开各个中断通道,配置中断方式,我们先来讲述下stm32单片机的中断机制。结构图如下所示:图2.32 stm32外部中断
20、/事件控制器结构图图中的实线箭头,为外部中断信号的传输路径。首先外部信号从编号为1的输入线进入。其次这个外部信号通过编号2的边沿检测电路,这个边沿检测电路受到“上升沿选择寄存器”、“下降沿选择寄存器”的控制,我们可以控制这两个寄存器来选择中断的触发方式。我们可以在程序中进行设置,比如所有段落设置为首行缩进2个字符EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising;设置为上升沿触发中断然后该外部信号进入编号为3或门,或门另一端是软件中断寄存器,如果,软件中断/事件寄存器的对应位置1,编号3的输出总是为有效信号1。之后进入“中断挂起请求寄存器
21、”,该寄存器记录了外部信号的电平变化。最后经过编号为4的与门进入NVIC中断控制器,如果 “中断屏蔽寄存器”的对应位置0,外部的中断请求信号不能传输到NVIC中断控制器,从而实现中断的屏蔽。由于我们采用的是外部信号触发中断,所以我们只需了解外部中断的请求机制,对于事件的中断请求机制,我们在这里不做介绍。我们以PE1为例,介绍下外部中断的一般步骤。步骤如下: 开启I/O的复用时钟RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE|RCC_APB2Periph_AFIO,ENABLE); 初始化I/O为输入GPIO_InitStructure.GPIO_Pin
22、= GPIO_Pin_1;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; GPIO_Init(GPIOE, &GPIO_InitStructure); 初始化线上中断,设置触发条件GPIO_EXTILineConfig(GPIO_PortSourceGPIOE,GPIO_PinSource1); EXTI_InitStructure.EXTI_Line=EXTI_Line1; EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;EXTI_InitStructure.EXTI_Trigger = EXT
23、I_Trigger_Rising_Falling;EXTI_InitStructure.EXTI_LineCmd = ENABLE; EXTI_Init(&EXTI_InitStructure); 配置中断分组NVIC,并使能中断NVIC_InitStructure.NVIC_IRQChannel = EXTI1_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x00; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x06; NVIC_InitStructure.NV
24、IC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); 编写中断服务函数void EXTI1_IRQHandler(void)主要代码详见附录2.2.1.5 stm32定时/计数器介绍Stm32系列的单片机一般包含8个计数/定时器,TIM1、TIM8分别为高级控制定时器,TIM2TIM5为通用定时器,TIM6以及TIM7为基本定时器。对于定时器的详细内容,我们不在这里一一介绍。然后我们介绍一下本实验采用了那些定时器,以及这些定时器所要完成的功能有哪些。本实验所采用的定时器以及功能如下表所示:表2-2定时器介绍表定时器名称定时器配置模
25、式主要功能TIM2定时器中断模式通过定时器中断,控制超声波的扫描周期TIM3PWM复用输出模式控制小车速度及舵机转向TIM5输入捕获模式采集超声波发射到接受的高电平持续时间t2.1.6 主程序设计流程图在本节实验中,循迹模块以及避障模块都是采用中断方式进行工作的,因此其主程序流程图如下图所示:图1.2 主程序流程图根据程序设计图,主程序设计如下: int main(void) u8 TIM5CH1_CAPTURE_STA=0;/输入捕获状态 u16TIM5CH1_CAPTURE_VAL;/输入捕获值delay_init(); /延时函数初始化 NVIC_Configuration(); /设置
26、NVIC中断分组2:2位抢占优先级,2位响应优先级 LED_Init(); GPIO_Configuration(); /端口初始化EXTIX_Init(); /扫描轨迹TIM2_Int_Init(4999,7199); /控制超声波扫描周期 TIM3_PWM_Init(1999,719); /控制舵机方向 TIM5_Cap_Init(0XFFFF,72-1);/以1Mhz的频率计数 while(1) farward_Low();delay_ms(10);2.2 电机驱动模块Stm32对小车的控制,就是对电机的控制,通过控制电机的转向,小车的运动状态就会发生改变。电机驱动模块的主要器件为LM2
27、93N,我们下面就详细讲解下电机驱动模块。2.2.1 驱动模块结构及其原理电机驱动模块的实物图如图2.8所示:图2.8 驱动电路实物图电机驱动模块的主要器件是芯片LM293D,内部原理图如图2.9所示:K4K2K1K3S4图2.9 电机驱动内部原理图全桥式驱动电路的4只开关管都工作在斩波状态,如图1.2所示,K1、K2为一组,K3、K4 为另一组,两组的状态互补,一组导通则另一组必定关断。当K1、K2导通时,K3、K4关断,电机两端加正向电压,电机实现正转或反转制动;当K3、K4导通时,K1、K2关断,电机两端为反向电压,电机实现反转或正转制动。2.2.2 驱动模块电路设计电机驱动模块的电路原
28、理如图2.10所示:图2.10 驱动模块电路原理图表2-2是各个端口状态与运动方向的关系,其关系如下表所示:表2-2 端口与运动方向关系表电机M1IN1IN2电机M2IN3IN4停止00停止00正转10正转10反转01反转0111112.2.3驱动软件程序设计车轮电机的动作由GPIO口的输出实现,本节主要配置运动方向和运动速度,对于运动速度的控制,我们必须使用PWM,通过改变PWM的占空比来调节速度的大小,其主要代码设计如下所示:void TIM3_PWM_Init(u16 arr,u16 psc) .要想使stm32的通用定时器TIMx产生PWM输出,需要用到的寄存器有:预分频寄存器(TIM
29、x_PSC)、自动重装载寄存器(TIMx_ARR)、捕获/比较模式寄存器(TIMx_CCMR1/2)、捕获/比较使能寄存器(TIMx_CCER)、捕获/比较寄存器(TIMx_CCR14)。我们先介绍这几个寄存器,然后介绍如何使用库函数产生PWM输出。下面我们就简单介绍下这些寄存器:首先是预分频寄存器(TIMx_PSC),该寄存器可以用设置对时钟进行分频,然后在提供给计数器作为计数器的时钟。该寄存器的各位功能如图所示:图2.11 TIMx_PSC寄存器各位描述接下来介绍自动重装载寄存器(TIMx_ARR),该寄存器的各位描述如下图所示:图2.12 TIMx_ARR寄存器各位描述通过设置这两个寄存
30、器,我们就可以算出PWM的输出周期,计算公式为:Tout=(arr+1)*(psc+1)/Tclk。其中Tclk为系统时钟周期。其次我们介绍捕获/比较模式寄存器(TIMx_CCMR1/2),总共有两个,TIMx_CCMR1和TIMx_CCMR2,TIMx_CCMR1控制通道CH1和CH2,TIMx_CCMR2控制CH3和CH4。因为这2个寄存器差不多,我们仅以通道CH1为例,介绍其中的TIMx_CCMR1为例,该寄存器的各位描述如下图所示:图2.13 TIMx_CCMR1/2寄存器各位描述这里我们只介绍该寄存器的OCxM位,我们就以TIMx_CCMR1中的OC1M(控制通道CH1)为例,该位功
31、能如下图所示:图2.14 OC1M功能描述我们使用的是PWM输出模式,所以OC1M必须设置为110/111。OC2M(控制通道CH2)各位描述与OC1M相同,我们这要不在叙述。然后我们介绍捕获/比较使能寄存器(TIMx_CCER),该寄存器控制着各个输入/输出通道的开关,对于该寄存器,各位描述如下图所示:图2.15 TIMx_CCER寄存器描述该寄存器比较简单,因为我们只介绍通道1,所以我们只讲CC1E位。如果我们想使能输入/捕获1,我们只需使用CC1E位。要想使PWM从I/O口输出,此位必须设置为1。最后介绍捕获/比较寄存器(TIMx_CCR14),总共有4个,分别对应CH14,因为这4个寄
32、存器相似,我们仅以TIMx_CCR1为例,该寄存器的给位介绍如下图所示:图2.16 TIMx_CCR1寄存器各位描述在输出模式下,该寄存器的值与CNT中的值进行比较,根据结果,实现电平的翻转。至此,我们把用到的几个寄存器都介绍完毕,下面我们就介绍如何通过库函数来配置实现PWM三路输出。 开启TIM3时钟以及复用功能输出。使能GPIO和端口复用功能时钟。库函数使能TIM3、GPIO以及复用功能时钟的方法是:RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE);RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA
33、| RCC_APB2Periph_AFIO, ENABLE); 初始化TIM3,设置TIM3的PSC和ARR。在开启了TIM3的时钟之后,我们要设置PSC和ARR寄存器的值来控制PWM的输出周期。调用的格式如下:TIM_TimeBaseStructure.TIM_Period=arr;TIM_TimeBaseStructure.TIM_Prescaler=psc;TIM_TimeBaseStructure.TIM_ClockDivision=0;TIM_TimeBaseStructure.TIM_CounterMode=TIM_CounterMode_Up; TIM_TimeBaseInit(
34、TIM3, &TIM_TimeBaseStructure); 设置TIM3_CH1、CH2、CH3的PWM模式,使能TIM3的CH1、CH2、CH3输出。在库函数中PWM通道设置是通过TIM_OC1InitTIM_OC4Init来设置的,这里我们需要3路PWM输出,所以我们需要使用函数TIM_OC1Init、TIM_OC2Init、TIM_OC3Init。库函数的调用格式如下:TIM_OCInitStructure.TIM_OCMode=TIM_OCMode_PWM1;TIM_OCInitStructure.TIM_OutputState=TIM_OutputState_Enable;TIM_
35、OCInitStructure.TIM_Pulse = 0; TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; TIM_OC2Init(TIM3, &TIM_OCInitStructure);TIM_OC1Init(TIM3, &TIM_OCInitStructure);TIM_OC3Init(TIM3, &TIM_OCInitStructure); 使能TIM3。完成以上配置后,我们要使能定时器TIM3。库函数调用格式如下:TIM_Cmd(TIM3, ENABLE); 通过修改TIM3_CCRx(x为1,2,3)来控制占空比。
36、库函数格式如下:Void TIM_SetComparex(TIM3,uint16_t Compare2);我们可以知道,通过定时器3控制PWM波的占空比,从而实现速度方面的控制。其中arr和psc可以控制PWM波的周期,TIM3_CCRx可以控制PWM波的占空比。我们只需要调用此函数就可以实现不同的速度控制。对于运动方向控制的代码我们就以后退为例,由于端口寄存器过于简单,我们不在此介绍端口的寄存器。我们仅介绍如何通过库函数进行端口配置。对各个I/O端口配置的过程相似,我们仅以PD8为例:主要过程如下所示: 使能I/O口时钟,调用格式如下所示:RCC_APB2PeriphClockCmd(RCC
37、_APB2Periph_GPIOD|RCC_APB2Periph_GPIOC, ENABLE); 初始化I/O参数,调用格式如下所示:GPIO_InitStructure.GPIO_Pin=GPIO_Pin_8;GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOD, &GPIO_InitStructure); 操作I/0口GPIO_SetBits(GPIOD,GPIO_Pin_8);PD8置1GPIO_ResetBits(GPI
38、OD,GPIO_Pin_8);PD8置0我们知道了如何对端口进行操作之后就可以随意的控制小车的运动啦,运动方向的程序设计,其基本函数单元如下所示:void Left_Low(void);我们调用这些函数,就可以实现不同运动方向的控制。主要代码详见附录3.2.3 避障模块设计在人类身体构造系统中,眼睛可以使我们非常方便的采集到外界环境的信息,然后把信息及时的传输到大脑,并对外界环境信息的变化做出相应的处理。而对智能小车来说,避障模块之于小车就相当于眼睛之于人类。避障模块可以采集外部地形数据,然后把所采集的地形数据传输到中央处理模块,从而实现躲避障碍的功能。避障模块所采用的器件在市场中有许多类型,
39、比如红外检测,光位移检测,超声波检测等。本次试验我们使用的是HC-SR04超声波检测,超声波由于具有检测能力强,传播路径宽,因此我们决定使用HC-SR04器件。在使用HC-SR04模块进行超声波测距的同时,我们可以使用舵机进行辅助。舵机的主要作用是改变HC-SR04模块的照射方向,从而控制超声波的发射方向。在程序编写过程中,如果小车前方遇见障碍时,我们可以直接控制舵机的转向,而小车的车身可以保持不变,在测量结束后,小车再做相应的动作。2.3.1 避障模块器件结构及其原理HC-SR04超声波测距模块测量范围在2cm-400cm之间,可以实现无接触式测距功能。HC-SR04超声波测距模块由一个超声
40、波发射器、一个超声波接收器和控制电路组成,避障模块的实物结构图如图2.17所示:图2.17 实物正反面结构图如结构图所示VCC提供5v电源,GND为接地线,TRIG为触发信号线,ECHO为回向信号输出线。基本原理如下:采用IO口TRIG触发测距,给至少10us的高电平信号,在TRIG触发沿到来后,超声波发射器会自动发出8个40KHz的方波,并且检测是否有信号返回,当超声波接收器接收到超声波时,表明有信号返回,通过IO口ECHO输出一高电平,高电平持续的时间就是超声波从发射到返回的时间。因此测量距离=(高电平持续时间*340m/s)/2。测量时序图如图2.18所示:图2.18 超声波时序图我们根
41、据时序图,可以编写相应的程序代码。为了防止发射信号对回向信号的影响,我们的测量周期不易过小。并且由于HC-SR04的感应角度不大于15,所以测距时,为了防止发射信号丢失,我们要求被测物体的面积不应小于0.5平方米,否则可能导致测量结果不准确。舵机在避障模块的主要作用前面已经提到,本节主要讲解舵机的工作特性。舵机的实物图如图2.19所示:图2.19 舵机实物图舵机的工作工作原理是stm32微处理器发出数据给舵机,舵机内部有一个基准电路,它会产生周期为20ms,宽度为1.5ms的基准信号,它将微处理器传输的直流偏置电压与电位器的电压数据进行比较,获得电压差输出。经由电路板上的IC判断转动方向,再驱
42、动无核心马达开始转动,透过减速齿轮将动力传至摆臂,同时由位置检测器送回反馈信号。舵机的转动角度与stm32所提供的PWM信号相关。标准信号PWM周期为20ms,理论上来讲脉宽为12ms,实际我们的脉宽为0.52.5ms,脉宽与所转的角度一一对应。角度与脉宽的对应图如图2.20所示:图2.20 舵机角度与脉宽对应图2.3.2 HC-SR04模块硬件电路设计超声波模块硬件原理图如下图所示:图2.21 超声波硬件原理图HC-SR04模块主要由发射器、接收器和部分电路组成。在此试验中,我们只需简单了解电路的设计,对于其基本原理可以不用过多涉猎,我们只需明白它们的工作原理,并且能够简单运用即可。2.3.
43、3 HC-SR04模块程序设计根据硬件电路的设计,我们对避障子程序进行设计,程序流程图如图2.22所示:图2.22 避障程序流程图避障模块在程序设计中,我们的工作主要是:1、控制超声波的扫描周期2、采集超声波发射到接受的高电平持续时间t3、对采集的高电平持续时间t进行处理,判断前方是否有障碍下面我们就详细介绍我们是怎么通过软件设计来完成这几个步骤的:1、控制超声波的扫描周期根据表2-2,我们采用的是TIM2来控制超声波的扫描周期。首先我们把TIM2设置为定时器中断模式,代码格式为void TIM2_Int_Init(u16 arr,u16 psc); 由于配置定时器中断模式十分简单,我们就不在
44、详细介绍,其详细代码见附录4.定时器TIM2的中断周期计算公式为T=(arr+1)*(psc+1)/Tclk。Tclk为系统周期,一般为72Mhz.我们在中断服务程序中控制超声波的发射,我们采用PC7作为触发信号,根据超声波时序图,我们需要在中断程序中给PC7一个持续10ms的高电平,中断服务程序如下:void TIM2_IRQHandler(void) /TIM2中断if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET)TIM_ClearITPendingBit(TIM2, TIM_IT_Update ); GPIO_SetBits(GPIOC,
45、GPIO_Pin_7); delay_ms(10); GPIO_ResetBits(GPIOC,GPIO_Pin_7);2、采集超声波发射到接受的持续时间t在本节试验中,我们使用了通用定时器TIM5的输入捕获功能,输入捕获模式具有测量频率或者测量脉冲的宽度的功能。我们开启TIM5通道CH1(定时器5)的输入捕获模式,采集ECHO端口的高电平持续时间。配置定时器5代码格式为:void TIM5_Cap_Init(u16 arr,u16 psc)下面我们就详细讲解一下,如何开启并使用通用定时器的输入捕获功能。输入捕获的原理,简单的讲就是通过检测TIM5(定时器)通道CH1的边沿信号,当边沿信号发生
46、变化时,当前寄存器的值TIM1_CNT存放到通道的捕获/比较寄存器(TIM5_CCR1)里面。我们的实验就是采集捕获/比较寄存器(TIM5_CCR1)中的值并进行处理,完成相应的动作。为了使TIM5通道CH1具有捕获功能,我们需要用到TIM5_PSC、TIM5_ARR、捕获/比较模式寄存器(TIM5_CCMR1)、捕获/比较使能寄存器(TIM5_CCER)、捕获/比较寄存器(TIM5_CCR1)、DMA/中断使能寄存器(TIM5_DIER)、控制寄存器(TIM5_CR1)。我们下面就简单介绍下下这几个寄存器。TIM5_PSC、TIM5_ARR、TIM5_CCR1这3个寄存器用法与前节中相同,我们就不在赘述,而在本实验中,捕获/比较寄存器TIM5_CCMR1非常重要,该寄存器的各位描述如下图所示:图2.23 TIMx_CCMR1各位描述我们使用的是TIM5捕获/比较通道CH1,所以图中只介绍7:0位。本次试验我们设置CC1S1:0=01,IC1PSC1:0=00,IC1F3:0=0000。接着我们再来看看捕获/比较使能寄存器TIMx_CCER,本节用到了CC1E和CC1P两位,描述如下图所示:图2.24 TIMx_CCER最低两位描述所以要使能通道CH1输入捕获,CC1E必须设置为1,而CC1P则可