datasheet

STM32学习笔记——PWM基础知识与720电机驱动

2019-01-09来源: eefocus关键字:STM32  PWM  电机驱动

1. 定义

脉冲宽度调制:是利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术,广泛应用在从测量、通信到功率控制与变换的许多领域中。(百度百科)它是一种对模拟信号电平进行数字编码的方法,通过对一系列脉冲的宽度进行调制,来等效地获得所需要波形(含形状和幅值)。


**SPWM波形:**脉冲宽度按正弦规律变化而和正弦波等效的 PWM 波形。


在这里插入图片描述


把正弦半波波形分成N等份,就可把正弦半波看成由N个彼此相连的脉冲所组成的波形。如果把上述脉冲序列用同样数量的等幅而不等宽的矩形脉冲序列代替,使矩形脉冲的中点和相应正弦等分的中点重合,且使矩形脉冲和相应正弦部分面积(即冲量)相等,就得到一组脉冲序列,这就是PWM波形。根据冲量相等,效果相同的原理,PWM波形和正弦半波是等效的,如上图。


pwm的频率:指每秒钟信号从高电平到低电平再回到高电平的次数。


**占空比:**输出的PWM中,高电平保持的时间与该 PWM 的时钟周期的时间之比。


在这里插入图片描述

**分辨率:**是占空比最小能达到多少,如8位的PWM:理论的分辨率就是1:255(单斜率), 16位的的PWM理论就是1:65535(单斜率)。


PWM 是一种对模拟信号电平进行数字编码的方法。通过高分辨率计数器的使用,方波的占空比被调制用来对一个具体模拟信号的电平进行编码。PWM信号仍然是数字的,因为在给定的任何时刻,满幅值的直流供电要么完全有(ON),要么完全无(OFF)。电压或电流源是以一种通(ON)或断(OFF)的重复脉冲序列被加到模拟负载上去的。通的时候即是直流供电被加到负载上的时候,断的时候即是供电被断开的时候。只要带宽足够,任何模拟值都可以使用PWM进行编码。


PWM 调制出的交流电压值主要取决于我们所控制的占空比(电压 = 占空比 X 幅值),调制出来的交流电压的波形精度取决于所设定的载波频率。


2. 电机驱动

对于 PWM 波的输出配置,可以参考STM32学习笔记一一PWM 输出


2.1 电路连接:


在这里插入图片描述


2.2 软件实现:

头文件:

#ifndef __MOTOR__H_

#define __MOTOR__H_


#include "system.h"


#define MOTOR1_PWM GPIO_Pin_6


#define MOTOR_PWMMAX 1000


void MOTOR_GPIO_Init(void);

void TIM3_PWM_Init(void);

void MOTOR_Control(int16_t motor1_pwm);


#endif

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15


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

* 函  数:void MOTOR_GPIO_Init(void)

* 功  能:电机引脚初始化

* 参  数:无

* 返回值:无

* 备  注:TIM3 CH1(PWM1) -> PA6

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

void MOTOR_GPIO_Init(void)

{

GPIO_InitTypeDef GPIO_InitStructure;


RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);


GPIO_InitStructure.GPIO_Pin = MOTOR1_PWM;

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; // GPIO复用推挽输出

GPIO_Init(GPIOA,&GPIO_InitStructure);

//GPIO_SetBits(GPIOA,MOTOR1_PWM);

}


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

* 函  数:void TIM3_PWM_Init(void)

* 功  能:定时器输出和PWM配置

* 参  数:无

* 返回值:无

* 备  注:TIM3 CH1

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

void TIM3_PWM_Init(void)

{

TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure; //定时器变量

TIM_OCInitTypeDef TIM_OCInitStructure; //输出比较结构体变量


RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);


TIM_TimeBaseInitStructure.TIM_Period = 1000-1; //设置自动重装载的周期值;f=72M/1000=72KHz

TIM_TimeBaseInitStructure.TIM_Prescaler = 100; //设置预分频值

TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up; //向上计数模式

TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割

TIM_TimeBaseInit(TIM3,&TIM_TimeBaseInitStructure);


TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //PWM1模式

TIM_OCInitStructure.TIM_Pulse = 0; //初始化占空比为0

TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;//输出极性高

TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能

TIM_OC1Init(TIM3,&TIM_OCInitStructure);

TIM_OC1PreloadConfig(TIM3,TIM_OCPreload_Enable); //使能TIMx在ARR上的预装载寄存器


TIM_Cmd(TIM3,ENABLE);

}


测试:


#include "stm32f10x.h"

#include "led.h"

#include "systick.h"

#include "motor.h"


int main(void)

{

uint8_t dir=1;

uint16_t motor1_pwmval=0;

SysTick_Init();

LED_Init();

MOTOR_GPIO_Init();

TIM3_PWM_Init();


while(1)

{

USER_LED_ON();

delay_ms(500);

USER_LED_OFF();

delay_ms(500);



if(dir)

motor1_pwmval++;

else 

motor1_pwmval--;  

  if(motor1_pwmval>999)

dir=0;

if(motor1_pwmval==0)

dir=1;      

TIM_SetCompare1(TIM3,motor1_pwmval); //设置占空比0-999

}

}



连接好电路,下载程序,可观察到小电机停止–转动–停止循环。


关键字:STM32  PWM  电机驱动

编辑:什么鱼 引用地址:http://www.eeworld.com.cn/mcu/2019/ic-news010942846.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:STM32程序移植技巧总结
下一篇:STM32驱动NRF24L01

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

STM32堆栈设置

1.堆和栈大小 定义大小在startup_stm32f2xx.sStack_Size      EQU     0x00000400                AREA    STACK, NOINIT, READWRITE, ALIGN=3Stack_Mem      
发表于 2019-04-16
STM32堆栈设置

STM32堆和栈(Heap & Stack)的资料理解

源起:在移植cjson的过程中,解析json包的时候发现动态内存分配不足而导致解析失败,为解决这一问题,而深入了解stm32的堆和栈。stm32的存储器结构。Flash,SRAM寄存器和输入输出端口被组织在同一个4GB的线性地址空间内。可访问的存储器空间被分成8个主要块,每个块为512MB。FLASH存储下载的程序。SRAM是存储运行程序中的数据。而SRAM一般分这几个部分:静态存储区:内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。它主要存放静态数据、全局数据和常量。栈区:在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率
发表于 2019-04-16
STM32堆和栈(Heap & Stack)的资料理解

STM32定义堆栈地址到ram区顶部

本设置针对stm32f103rbt6的设置,该芯片RAM大小为20kB,故RAM区地址范围为0x20000000—0x20005000,芯片信息如下图所示;第一步:设置.sct文件;;*************************************************************; *** Scatter-Loading Description Filegenerated by uVision ***; *************************************************************LR_IROM1 0x08000000 0x00020000  
发表于 2019-04-16
STM32定义堆栈地址到ram区顶部

STM32之程序如何防止堆栈溢出

近日为某个项目写了个草稿程序,即非正式程序,后来发现老是进入hardfaulthandler,原来是堆栈溢出,后仔细查看发现函数调用纵深太深,最多的时候可保持7个函数在堆栈中调用。因此有心得如下:一、函数调用不要纵深太深,即以下模式:main(){   fun1();}fun1(){  fun2();}fun2(){   fun3();}fun3(){  fun4();}fun4(){  fun5();}fun5(){  fun6();}fun6(){   fun7();}这样子main函数要调用fun1函数完成某个功能,则要一直调到
发表于 2019-04-16

stm32之堆栈

stm32中的堆栈设置keil编译完成时存储情况当编译成功时,会出现: BUILD://Program Size: Code=340 RO-data=252 RW-data=0 ZI-data=1632Code:程序代码部分RO-data: 程序定义的常量const tempRW-data:已初始化的全局变量ZI-data:未初始化的全局变量片中的:flash=Code+RO-data+RW-dataRAM=RW-data+ZI-data通过上面的BUILD可以看出,这个程序已经用了1600多的RAM,为什么会出用到这么多的RAM呢?在startup_stm32f10x_md.s文件中存在:St
发表于 2019-04-16

说说STM32的堆栈与内存

1.概念这里所说的堆栈,是针对单片机所说的“堆”与“栈”,指的是内存中一片特殊用途的区域。而不是数据结构中的堆栈(虽然其实规则一样)。这里所说的内存,是指RAM,RAM包括SRAM,DRAM等。而不是什么手机内存卡之类。这里所说的flash,指的是用作为ROM的存储器,保存代码与常量数据。而不是动画制作。。。栈的生长方向:指的是入栈方向,从高地址向低地址生长叫做向下生长,或逆向生长;反过来就叫向上生长,或正向生长。STM32的栈是向下生长。2.内存中的堆栈安排确切地说,是keil mdk根据STM32的特性,对stm32的RAM甚至flash进行部署。编译工程后,在生成的.map文件里可以看到具体的安排。双击工程界面的工程根目录
发表于 2019-04-16
说说STM32的堆栈与内存

小广播

何立民专栏

单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2019 EEWORLD.com.cn, Inc. All rights reserved