毕业设计_基于stm32的智能小车设计.docx
《毕业设计_基于stm32的智能小车设计.docx》由会员分享,可在线阅读,更多相关《毕业设计_基于stm32的智能小车设计.docx(46页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、基于 stm32 的智能小车设计摘要本次试验主要分析了基于 STM32F103 微处理器的智能小车控制系统的系统设计过程。此智能系统的组成主要包括 STM32F103 控制器、电机驱动电路、红外探测电路、超声波避障电路。本次试验采用 STM32F103 微处理器为核心芯片,利用 PWM 技术对速度以及舵机转向进行控制,循迹模块进行黑白检测,避障模块进行障碍物检测并避障功能,其他外围扩展电路实现系统整体功能。小车在运动时, 避障程序优先于循迹程序,用超声波避障电路进行测距并避障,在超声波模块下我们使用舵机来控制超声波的发射方向,用红外探测电路实现小车循迹功能。在硬件设计的基础上提出了实现电机控制
2、功能、智能小车简单循迹和避障功能的软件设计方案,并在 STM32 集成开发环境 Keil 下编写了相应的控制程序,并使用mcuisp 软件进行程序下载。关键词:stm32;红外探测;超声波避障;PWM;电机控制- 1 -基于 stm32 的智能小车设计AbstractThis experiment mainly analyzes the control system of smart car based on microprocessor STM32F103 system design process. The composition of the intelligent system mai
3、nly including STM32F103 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 blac
4、k and white, obstacle avoidance module for obstacle detection and obstacle avoidance function, otherperipheral extended circuit to realize the whole system functio 。n Whenthe car is moving, obstacle avoidance program prior to tracking, using ultrasonic ranging and obstacle avoidance obstacle avoidan
5、ce circuit, we use steering 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 obstacl
6、e avoidance function of 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- 2 -基于 stm32 的智能小车设计目录1.绪
7、论.-4-1.1 研究概况.-4-1.2 研究思路.-4-2.软硬件设计.-5-2.1 中央处理模块.-5-2.1.1 stm32f103 内部结构.-6-2.1.2 stm32 最小系统电路设计.-7-2.1.3 stm32 软件设计的基本思路.-9-2.1.4 stm32 中断介绍.-10-2.1.5 stm32 定时/计数器介绍.-11-2.1.6 主程序设计流程图.-12-2.2 电机驱动模块.-13-2.2.1 驱动模块结构及其原理.-13-2.2.2 驱动模块电路设计.-14-2.2.3 驱动软件程序设计.-14-2.3 避障模块设计.-18-2.3.1 避障模块器件结构及其原理.
8、-19-2.3.2 HC-SR04 模块硬件电路设计.-21-2.3.3 HC-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-致谢.-38- 3 -基于 stm32 的智能小车设计参考文献.- 39 -附录.- 41 -1. 绪论智能小车通过各种感应器获得外部环境信息和内部运动状态,实现在复杂环境背景下的自主运动,从而完成具有特定功能的机器人系统。
9、而随着智能化电器时代的到来,它们在为人们提供的舒适的Th活环境的同时,也提高了制造智能化电器对于人才要求的门槛.智能小车是集成了多种高新技术,它不仅融合了电子、传感器、计算机硬件、软件等许多学科的知识,而且还涉及到当今许多前沿领域的技术,它是一个国家高科技技术水平的重要体现。通过建立起简易智能小车的设计,引导学Th从理论走向实践,培养同学们的动手能力,使同学们在了解智能化电器的工作原理的基础上,还使同学们获得完成整体项目的能力,并掌握了Stm32 开发板的编程原理,为同学们进入ARM 领域提供了基础。另外,本次课程设计,使同学们了解自己的不足之处,从而使同学们有目标的提升自己的能力。1.1 研
10、究概况国外研究概况:上世纪 50 年代初,国外就有智能车辆的研究,从 90 年代开始, 智能车辆的研究就进入了系统化、大规模的研究阶段。尤其突出的是美国卡内基-梅陇大学机器人研究所已经完成了 Navlab 系列的自主车辆的研究,这一研究成果代表了国外智能车辆的主要研究方向。国内研究概况:我国对于智能车辆的研究较晚,始于上世纪 80 年代,而且现在大部分还是使用入门级别的 51 单片机进行设计与研究的,为了弥补与国外研究的差距,开设了全国大学Th电子设计竞赛。1.2 研究思路系统将采集的传感器信号送入 stm32 微控制器中,stm32 微控制器根据采集的信号做出不同的判断,从而控制电机运动方向
11、和运动速度。系统以 stm32 微控制器为核心,通过传感器采集不同的信号做出判断,继而改变电机的运动方向和运动速度。实验系统结构如图 1.1 所示:- 4 -基于 stm32 的智能小车设计图 1。1 实验系统结构图2. 软硬件设计智能小车控制系统具备了障碍物检测、自主避障、自主循迹等功能。相应的控制系统主要由以下四个模块组成:避障模块、循迹模块、电机驱动模块、中央处理模块四个模块组成,系统总体框架如图 2.1 所示:图 2.1 系统框架图我们本节主要任务是了解各个模块的功能,掌握各个模块所使用的器件的使用方法,并能够编写相应的程序代码.掌握各个模块的功能。2.1 中央处理模块在人类身体结构中
12、,大脑可以根据各个器官所传输的信息做出相应的行为动作用以保证人体所必须的Th理原料,而 stm32 处理器之于智能小车就相当于大脑之于人类,它可以从各个模块之间获得数据,并对所传输的数据进行实时处理,来驱使电机模块做出相应的行为动作。由ARM 公司设计的基于ARMv7 架构的Cortex 系列的标准体系结构在 2006 年推出,此结构是用来满足日渐复杂的不同性能要求的软件设计,根据所面向的领域,Cortex 系列可以分为 A、R、M 三个分工明确的系列1。Stm32 处理器的出现为微控制系统、工业控制系统、汽车车身系统和无线网络等对功耗和成本敏感的嵌入式应用领域实现高系统性能系统提供了基础,使
13、编程的复杂性,集高性能、低功耗、低成本大大简化,并使它们融为于一体2。意法半导体 ST 公司作为一个半导体制造厂商,是 ARM 公司 Cortex-M3 内核开发项目一个主要合作方。2007- 5 -基于 stm32 的智能小车设计年 6 月 11 日由 ST 公司率先推出的基于 CortexM3 内核的 STM32 系列微控处理器研发而出。此中,A 系列是面向复杂的尖端应用程序,用于运行开放式的复杂操作系统;R 是 Real 的首字母缩写,是面向实时系统开发的;M 是 Mirco 的首字母缩写,专门面向低成本的微控制领域开发研究。因此,Cortex-M3 处理器是由ARM 公司设计的首款基于
14、ARMv7-M 体系结构的 32 位标准处理器,它不仅具有低功耗、少门数等优点,而且还具有短中断延迟、低调试成本等众多优点,使它在众多的处理器中脱颖而出。目前为止,STM32 系列处理器暂分为2 个系列。其中,STM32F101 系列是标准型系列,工作频率设定在 36MHZ;STM32F103 系列是增强型系列,工作频率设定在 72MHZ,其带有更多片内 RAM 和更丰富的外设资源。这两个系列的产品在软件和引脚封装方面具有兼容性,并且拥有相同的片内Flash 资源,使软件的开发和升级更加方便。本次试验,我们使用的是 stm32f103 处理器。2.1.1 stm32f103 内部结构STM32
15、F103 系列微处理器是首款基于 ARMv7M 体系结构的 32 位标准 RISC(精简指令集)处理器,具有执行代码效率高,外设资源丰富等众多优点。该系列微处理器工作频率设定在 72MHz,高达 128K 字节的内置 Flash 存储器和 20K 字节的 SRAM,方便程序编写,而且具有丰富的通用 I/O 端口。其内部结构图如图2。2 所示:- 6 -基于 stm32 的智能小车设计图 2。2 内部结构图Stm32 处理器主系统主要由 4 个被动单元和 4 个驱动单元构成。4 个驱动单元是:通用 DMA1,通用 DMA2,内核 DCode 总线和系统总线。4 个被动单元由 APB 桥,APB
16、设备,内部 Flash 闪存,内部 SRAM、FSMC。我们实验所采用的芯片具有64KBSRAM、512KBFLASH、2 个基本定时器,4 个通用定时器,2 个高级定时器,3 个 SPI,2 个 IIC,5 个串口,1 个 USB,1 个 CAN,3 个 12 位的 ADC,1 个 12 位 DAC、1 个 SDIO 接口,1 个 FSMC 接口以及 112 个通用 I/O 口。2.1.2 stm32 最小系统电路设计Stm32 的最小系统电路主要由系统时钟电路、实时时钟电路、JTAG 调试接口电路,复位电路和启动模式选择电路组成。最小系统电路原理图如图 2-13 所示:图 2。3 最小系统
17、电路原理图主要电路原理图的设计及功能如下所示:1. 系统时钟电路系统时钟电路主要作用是提供节拍,就相当于人类的心脏跳动,随着心脏的跳动,血液就会到达全身部位,所以系统时钟的重要性就不言而喻啦。系统时钟的电路设计如图 2.4 所示:- 7 -基于 stm32 的智能小车设计图 2。4 系统时钟电路图在时钟电路中,我们选用 8M 的晶振。2。复位电路复位电路的设计如图 2.5 所示:图 2。5 复位电路图本次试验所采用的开发板为低电平复位。如图所示,当按键悬空时 RST 输入为高电平,当按键按下时,RST 脚输入为低电平,从而电路复位.3.JTAG 电路JTAG 电路原理图如图 2。6 所示:图
18、2。6 JAG 电路原理图JTAG 的主要功能是使目标文件烧到核处理器中。4。启动模式电路启动模式电路原理图如图 2。7 所示:- 8 -基于 stm32 的智能小车设计图 2。7 启动模式电路原理图通过设置BOOT1:0引脚可以选择三种不同启动模式,启动模式如表2-1 所示:表 2-1 启动模式表启动模式选择引脚BOOT1BOOT0启动模式说明X0主闪存存储器主闪存存储器被选为启动区域01系统存储器系统存储器被选为启动区域11内置 SRAM内置 SRAM 被选为启动区域2。1。3 stm32 软件设计的基本思路在对其他模块设计之前,我们必须了解 stm32 的编程规则.任何处理器,包括stm
19、32 处理器,想要处理器完成某项相应的动作,就必须对处理器的寄存器进行操作。比如,我们在单片机C51 中,同样,我们在 stmM32 的开发中过程中,我们同样可以对寄存器直接操作:GPIOxBRR=0x0011。(x 可以是 A,B,C,D,E比如 GPIOA 就是端口A)但是,对于stm32 这种级别的处理器 ,几百个寄存器记起来谈何容易。所以,ST(意法半导体)提出了固件库的概念,利用固件库进行编程。固件库的本质就是函数的集合,固件库将那些寄存器的底层操作都封装起来,提供一整套API 供开发者使用。比如,上面通过控制 BRR 寄存器来控制电平的变化,官方库封装了一个函数:Void GPIO
20、_ResetBits(GPIO_TypeDef GPIOx,uint16_t GPIO_Pin)GPIOxBRR = GPIO_Pin;(x 可以是 A,B,C,D,E比如 GPIO_A就是端口 A)通过使用 GPIO_ResetBits()函数就可以直接对寄存器进行操作啦。- 9 -基于 stm32 的智能小车设计2。1。4 stm32 中断介绍本方案中,我们要使用 stm32 的中断,在程序设计中,我们要开启各个管道的中断,打开各个中断通道,配置中断方式,我们先来讲述下 stm32 单片机的中断机制。结构图如下所示:图 2。32 stm32 外部中断/事件控制器结构图图中的实线箭头,为外部
21、中断信号的传输路径。首先外部信号从编号为 1 的输入线进入。其次这个外部信号通过编号 2 的边沿检测电路,这个边沿检测电路受到“上升沿选择寄存器”、“下降沿选择寄存器”的控制,我们可以控制这两个寄存器来选择中断的触发方式。我们可以在程序中进行设置,比如 EXTI_InitStructure。EXTI_Trigger = EXTI_Trigger_Rising;设置为上升沿触发中断然后该外部信号进入编号为 3 或门,或门另一端是软件中断寄存器,如果,软件中断/事件寄存器的对应位置 1,编号 3 的输出总是为有效信号 1。之后进入“中断挂起请求寄存器”,该寄存器记录了外部信号的电平变化。最后经过编
22、号为 4 的与门进入 NVIC 中断控制器,如果 “中断屏蔽寄存器”的对应位置 0,外部的中断请求信号不能传输到 NVIC 中断控制器,从而实现中断的屏蔽。由于我们采用的是外部信号触发中断,所以我们只需了解外部中断的请求机制,对于事件的中断请求机制,我们在这里不做介绍。我们以 PE1 为例,介绍下外部中断的一般步骤。步骤如下: 开启 I/O 的复用时钟RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE|RCC_APB2Periph_AFIO,ENABLE);- 10 -基于 stm32 的智能小车设计 初始化 I/O 为输入GPIO_InitStructur
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 毕业设计 基于 stm32 智能 小车 设计
限制150内