STM32-PWM输出总结讲课讲稿
STM32之PWM

配置TIM3的ARR寄存器和PSC寄存器,确定PWM频率。
这里配置的这两个定时器确定了PWM的频率,我的理解是:PWM 的周期(频率)就是ARR寄存器值与PSC寄存器值相乘得来,但不是简单意义上的相乘,例如要设置PWM的频率参考上次通用定时器中设置溢出时间的算法,例如输出100HZ频率的PWM,首先,确定TIMx的时钟,除非APB1的时钟分频数设置为1,否则通用定时器TIMx的时钟是APB1时钟的2倍,这时的TIMx时钟为72MHz,用这个TIMx时钟72MHz除以(PSC+1),得到定时器每隔多少秒涨一次,这里给PSC赋7199,计算得定时器每隔0.0001秒涨一次,即此时频率为10KHz,再把这个值乘以(ARR+1)得出PWM频率,假如ARR 值为0,即0.0001*(0+1),则输出PWM频率为10KHz,再假如输出频率为100Hz的PWM,则将ARR寄存器设置为99即可。
如果想调整PWM占空比精度,则只需降低PSC寄存器的值即可。
TIMx_CCRx寄存器,确定PWM的占空比。
TIMx_CCR1—TIMx_CCR4确定定时器的CH1—CH4四路PWM 的占空比。
直接给该寄存器赋0—65535值即可确定占空比。
占空比计算方法:TIMx_CCRx的值除以ARR寄存器的值即为占空比,因为占空比在0—100%之间,所以一般TIMx_CCRx寄存器值不能超过ARR寄存器的值,否则可能会引起PWM的频率或占空比的准确性。
STM32输出不同频率PWM

STM32一定时器产生不同频率的PWM(转载)2011-05-05 12:07平时记性实在太差,调试完的程序,过两天又忘了,往往需要一阵子才能想起来,有时以前的资料找不到了,更是恼火,不得不重复到网上搜索。
刚刚调试成功了一个类型的程序,立刻记下来,呵呵,不要又忘记了。
STM32产生PWM是非常的方便的,要需要简单的设置定时器,即刻产生!当然,简单的设置对于新手来产,也是麻烦的,主要包括:(1)使能定时器时钟:RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE);(2)定义相应的GPIO:/* PA2,3,4,5,6输出->Key_Up,Key_Down,Key_Left,Key_Right,Key_Ctrl */GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_ Pin_6;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; //下拉接地,检测输入的高电平GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //50M时钟速度GPIO_Init(GPIOA, &GPIO_InitStructure);/* PA7用于发出PWM波,即无线数据传送 */GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //50M时钟速度GPIO_Init(GPIOA, &GPIO_InitStructure);(3)如果是产生PWM(频率不变,占空比可变),记得打开PWM控制,在TIM_Configurat ion()中。
stm32pwm输出三角波原理

stm32pwm输出三角波原理
在STM32微控制器中,PWM 输出可以实现多种波形,包括方波、正弦波、三角波等。
其中,三角波是一种非常常见的波形,在很多应用场景中都有广泛的应用。
三角波是一种连续的、平滑的波形,其特点是从低电平逐渐升高到高电平,然后再逐渐降低到低电平,如同一个长长的三角形。
在STM32 中,输出三角波需要使用 PWM 模块和定时器,并对定时器的计数器进行配置。
具体来说,输出三角波的原理如下:
1. 配置定时器为向上计数模式,并设置一个合适的计数频率,例如 10 kHz。
2. 配置 PWM 输出通道为定时器输出比较功能,并选择合适的输出极性和时钟分频系数。
3. 在每次定时器计数器达到设定值时,PWM 输出通道会自动翻转输出电平,这将导致三角波的上升和下降。
4. 在每次计数器溢出时,需要重新设置计数器的初始值,以保证连续输出三角波。
5. 如果需要改变三角波的频率或幅值,可以通过改变定时器的计数频率或 PWM 输出通道的占空比来实现。
通过上述方法,可以在 STM32 微控制器中实现三角波的输出。
这种波形非常适合一些需要连续、平滑的变化的应用场景,例如音频信号发生器、电机驱动等。
STM32F103学习笔记(八)PWM输出

STM32F103学习笔记(八)PWM输出脉冲宽度调制(PWM),是对脉冲宽度的控制。
STM32 的定时器除了 TIM6 和 7。
其他的定时器都可以用来产生PWM 输出。
其中高级定时器 TIM1 和 TIM8 可以同时产生多达 7 路的 PWM 输出。
而通用定时器也能同时产生多达 4路的 PWM 输出,这样, STM32 最多可以同时产生 30 路 PWM 输出!本实验是利用TIM3 的通道2,把通道2 重映射到PB5,产生PWM 来控制 DS0 的亮度。
TIM3_CH2 默认是接在 PA7上面的,而我们的 DS0 接在 PB5 上面,可以通过重映射功能,把 TIM3_CH2映射到 PB5 上。
关于重映射,有一个TIM3的重映射表:每个通道都是映射到固定的GPIO口上。
下面是关于time.c文件:[csharp] view plain copy1.//TIM3 PWM 部分初始化2.//PWM 输出初始化3.//arr:自动重装值4.//psc:时钟预分频数5.void TIM3_PWM_Init(u16 arr,u16 psc)6.{7.GPIO_InitTypeDef GPIO_InitStructure;8.TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;9.TIM_OCInitTypeDef TIM_OCInitStructure;10.RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, EN ABLE); //①使能定时器 3 时钟11.RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|12.RCC_APB2Periph_AFIO, ENABLE); //①使能 GPIO 和 AFIO 复用功能时钟13.GPIO_PinRemapConfig(GPIO_PartialRemap_TIM3, ENA BLE); //②重映射 TIM3_CH2->PB514.//设置该引脚为复用输出功能,输出 TIM3 CH2 的 PWM 脉冲波形 GPIOB.515.GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5; //TIM_CH 216.GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出17.GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz ;18.GPIO_Init(GPIOB, &GPIO_InitStructure); //①初始化 GPIO19.//初始化 TIM320.TIM_TimeBaseStructure.TIM_Period = arr; //设置在自动重装载周期值21.TIM_TimeBaseStructure.TIM_Prescaler =psc; //设置预分频值22.TIM_TimeBaseStructure.TIM_ClockDivision = 0; //设置时钟分割:TDTS = Tck_tim23.TIM_TimeBaseStructure.TIM_CounterMode = TIM_Cou nterMode_Up; //TIM 向上计数模式24.TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure); //③初始化 TIMx25.//初始化 TIM3 Channel2 PWM 模式26.TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_P WM2; //选择 PWM 模式 227.TIM_OCInitStructure.TIM_OutputState = TIM_OutputSt ate_Enable; //比较输出使能28.TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity _High; //输出极性高29.TIM_OC2Init(TIM3, &TIM_OCInitStructure); //④初始化外设 TIM3 OC230.TIM_OC2PreloadConfig(TIM3, TIM_OCPreload_Enable); //使能预装载寄存器31.TIM_Cmd(TIM3, ENABLE); //⑤使能 TIM332.}主函数:[csharp] view plain copy1.int main(void)2.{3.u16 led0pwmval=0;4.u8 dir=1;5.delay_init(); //延时函数初始化6.NVIC_Configuration(); //设置 NVIC 中断分组 2:2 位抢占优先级, 2 位响应优先级7.uart_init(9600); //串口初始化波特率为 96008.LED_Init(); //LED 端口初始化9.TIM3_PWM_Init(899,0); //不分频,PWM 频率=72000/900=8Khz10.while(1)11.{12.delay_ms(10);13.if(dir)led0pwmval++;14.else led0pwmval--;15.if(led0pwmval>300)dir=0;16.if(led0pwmval==0)dir=1;17.TIM_SetCompare2(TIM3,led0pwmval);18.}19.}。
stm32的pwm输出及频率计算方法

stm32的pwm输出及频率计算方法
一、stm32的pwm输出引脚是使用的IO口的复用功能。
二、T2~T5这4个通用定时器均可输出4路PWM——CH1~CH4。
三、我们以tim3的CH1路pwm输出为例来进行图文讲解(其它类似),并在最后给出tim3的ch1和ch2两路pwm输出的c代码(已在STM32F103RBT6上测试成功,大家放心使用!)。
四、给出了PWM频率和占空比的计算公式。
步骤如下:
1、使能TIM3时钟
RCC->APB1ENR |= 1 2、配置对应引脚(PA6)的复用输出功能
GPIOA->CRL //PA6清0GPIOA->CRL |= 0X0B000000;//复用功能输出(推挽50MHz输出)GPIOA->ODR |= 1
3、设定计数器自动重装值及是否分频
TIM3->ARR = arr;//设定计数器自动重装值(决定PWM的频率)TIM3->PSC = psc;//预分频器,0为不分频
4、设置PWM的模式(有1和2两种模式,区别在于输出电平极性相反),根据需求选一种即可
注:TIMX_CCMR1决定CH1~CH2路,TIMX_CCMR2决定CH3~CH4路。
//TIM3->CCMR1 |= 6 TIM3->CCMR1 |= 7 TIM3->CCMR1 |= 1
5、输出使能设置
TIM3->CCER |= 1。
如何采用STM32单片机来产生PWM输出

如何采用STM32单片机来产生PWM输出1. TIMER输出PWM基本概念脉冲宽度调制(PWM),是英文“Pulse Width ModulaTIon”的缩写,简称脉宽调制,是利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术。
简单一点,就是对脉冲宽度的控制。
一般用来控制步进电机的速度等等。
STM32的定时器除了基本定时器TIM6和TIM7之外,其他的定时器都可以用来产生PWM 输出,其中高级定时器TIM1和TIM8可以同时产生7路的PWM输出,而通用定时器也能同时产生4路的PWM输出。
1.1 PWM输出模式STM32的PWM输出有两种模式,模式1和模式2,由TIMx_CCMRx寄存器中的OCxM 位确定的(“110”为模式1,“111”为模式2)。
模式1和模式2的区别如下:110:PWM模式1-在向上计数时,一旦TIMx_CNTTIMx_CCR1时通道1为无效电平(OC1REF=0),否则为有效电平(OC1REF=1)。
111:PWM模式2-在向上计数时,一旦TIMx_CNTTIMx_CCR1时通道1为有效电平,否则为无效电平。
由此看来,模式1和模式2正好互补,互为相反,所以在运用起来差别也并不太大。
而从计数模式上来看,PWM也和TIMx在作定时器时一样,也有向上计数模式、向下计数模式和中心对齐模式,关于3种模式的具体资料,可以查看《STM32参考手册》的“14.3.9 PWM模式”一节。
1.2 PWM输出管脚PWM的输出管脚是确定好的,具体的引脚功能可以查看《STM32参考手册》的“8.3.7 定时器复用功能重映射”一节。
在此需要强调的是,不同的TIMx有分配不同的引脚,但是考虑到管脚复用功能,STM32提出了一个重映像的概念,就是说通过设置某一些相关的寄存器,来使得在其他非原始指定的管脚上也能输出PWM。
但是这些重映像的管脚也是由参考手册给出的。
比如说TIM3的第2个通道,在没有重映像的时候,指定的管脚是PA.7,。
STM32Cube学习之七:PWM输出

STM32Cube学习之七:PWM输出假设已经安装好STM32CubeMX和STM32CubeF4支持包。
Step1.打开STM32CubeMX,点击“New Project”,选择芯片型号,STM32F407ZETx。
Step2. 在Pinout界面下配置TIM14的PWM输出,正好是LED0控制引脚。
Step3.在Clock Configuration界面配置使用内部16MHz时钟源,参数默认即可。
Step4.配置TIM14参数。
在configuration界面中点击TIM14按钮,可以进入参数配置界面。
在Parameter Settings页配置预分频系数为15,计数周期(自动加载值)为99,定时器溢出频率,即PWM的周期,就是16MHz/(15+1)/(99+1) = 10kHz。
之所以将极性设置为Low,是因为LED0点亮方式是低电平。
Step5.生成源代码。
点击生成源代码按钮。
在设置界面中输入工程名,保存路径,工程IDE类型,点OK即可。
生成代码完成后可直接打开工程。
弹出如下对话框时,如果已经安装了F4的支持包,则点击OK关闭。
如果没有安装,则点击界面中的/...链接,找到芯片的支持包,然后安装。
关闭后面的界面。
点击“是”,然后选择芯片型号。
可以在搜索框中输入关键字,加快选择速度。
Step6.添加功能代码。
在main函数中定义一个变量pwm_val用于控制PWM输出的占空比。
在while(1)之前使能PWM输出通道CH1。
在while(1)中不断改变PWM输出的占空比,控制LED0的亮度变化,实现一个呼吸灯的效果。
周期约为5秒。
要注意的是,配置的自动加载参数是99,而LED的发光亮度和PWM的占空比并不成正比,当占空比>50%之后,变化就很小了,因此在while(1)中,占空比的变化是范围是0~50。
特别说明:本例的Step4,配置的参数中,控制PWM周期的是预分频器和自动加载寄存器,分别配置了15和99。
STM32定时器PWM输出总结

STM32定时器PWM输出总结STM32是意法半导体(STMicroelectronics)公司推出的一系列32位微控制器(MCU)的产品,相较于传统的8位和16位MCU,STM32具有更强的处理能力和更多的外设资源。
其中,定时器是STM32系列MCU的重要外设之一,可以用于实现各种定时、计数和PWM输出等功能。
定时器是STM32系列MCU中一个非常重要的外设,可以提供一些基本的定时、计数和计时功能。
除了基本功能外,定时器还可以通过配置不同的工作模式、输入捕获和输出比较等功能来实现更多的应用。
在STM32中,每个定时器可以被划分为多个通道,每个通道可以配置为不同的工作模式。
其中,PWM输出功能通常使用定时器的输出比较模式来实现,通过配置不同的占空比来实现不同的PWM波形输出。
使用STM32定时器的PWM输出功能,一般需要进行以下步骤:1.选择合适的定时器和通道:在STM32系列MCU中,一般会有多个定时器可供选择,根据实际需求选择合适的定时器和通道。
2.配置定时器的工作模式:定时器的工作模式取决于具体的应用需求,可以选择定时模式、计数模式、输入捕获模式或者输出比较模式。
3.配置输出比较模式:输出比较模式是实现PWM输出的关键,通过配置不同的比较值和占空比来实现不同的PWM波形输出。
4.配置GPIO引脚:将定时器的输出引脚与GPIO引脚相连,实现PWM波形的输出。
使用STM32定时器的PWM输出功能,可以实现多种应用。
比如:-控制电机的转速和方向:通过调整PWM波形的占空比,可以控制电机的转速和方向。
-LED灯的亮度调节:通过调整PWM波形的占空比,可以实现LED灯的亮度调节。
-蜂鸣器的声音控制:通过调整PWM波形的频率,可以实现蜂鸣器的声音控制。
总结起来,STM32定时器的PWM输出功能是一种非常有用且灵活的功能,可以通过配置不同的定时器和通道,实现多种不同的应用。
通过控制输出比较模式和占空比,可以实现精确的PWM波形输出。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
学习后发现stm32的定时器功能确实很强大,小总结一下方便以后使用的时候做参考。
Stm32定时器一共分为三种:tim1和tim8是高级定时器,6和7是基本定时器,2—5是通用定时器。
从名字就可以看得出来主要功能上的差异。
今天我主要是用定时器做pwm输出,所以总结也主要是针对pwm方面的。
先大致说下通用和高级定时器的区别。
通用的可以输出四路pwm信号互不影响。
高级定时器可以输出三对互补pwm信号外加ch4通道,也就是一共七路。
所以这样算下来stm32一共可以生成4*5+7*2=30路pwm信号。
接下来还有功能上的区别:通用定时器的pwm信号比较简单,就是普通的调节占空比调节频率(别的不常用到的没去深究);高级定时器的还带有互补输出功能,同时互补信号可以插入死区,也可以使能刹车功能,从这些看来高级定时器的pwm天生就是用来控制电机的。
Pwm输出最基本的调节就是频率和占空比。
频率当然又和时钟信号扯上了关系。
高级定时器是挂接到APB2上,而通用定时器是挂接到APB1上的。
APB1和APB2的区别就要在于时钟频率不同。
APB2最高频率允许72MH,而APB1最高频率为36MHZ。
这样是不是通用定时器只最高36MHZ频率呢,不是的;通用定时器时钟信号完整的路线应该是下面这样的:AHB(72mhz)→APB1分频器(默认2)→APB1时钟信号(36mhz)→倍频器(*2倍)→通用定时器时钟信号(72mhz)。
在APB1和定时器中间的倍频器起到了巨大的作用,假如红色字体的“APB1分频器”假如不为1(默认是2),倍频器会自动将APB1时钟频率扩大2倍后作为定时器信号源,这个它内部自动控制的不用配置。
设置这个倍频器的目的很简单就是在APB1是36mhz的情况下通用定时器的频率同样能达到72mhz。
我用的库函数直接调用函数SystemInit(); 这个函数之后时钟配置好了:通用定时器和高级定时器的时钟现在都是72mhz(你也可以自己再配置一下RCC让他的频率更低,但是不能再高了)。
定时器接下来还有一个分频寄存器:TIMX_PSC 经过他的分频后,才是定时器计数的频率。
所以真正的时钟频率应该是72mhz/(TIMX_PSC-1),我们设为tim_frepuency下面还会用到。
stm32的时钟频率弄得确实是很饶人的,所以关键就是先要把思路理清楚。
时钟的频率弄好了下面终于可以开说重点PWM了。
当然还少不了频率:pwm主要就是控制频率和占空比的:这两个因素分别通过两个寄存器控制:TIMX_ARR和TIMX_CCRX。
ARR寄存器就是自动重装寄存器,也就是计数器记到这个数以后清零再开始计,这样pwm的频率就是tim_frequency/(TIMX_ARR-1)。
在计数时会不停的和CCRX寄存器中的数据进行比较,如果小于的话是高电平或者低电平,计数值大于CCRX值的话电平极性反相。
所以这也就控制了占空比。
下面是定时器1的配置代码:
GPIO_InitTypeDef GPIO_InitStructure2;
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
TIM_OCInitTypeDef TIM_OCInitStructure;
TIM_BDTRInitTypeDef TIM_BDTRInitStructure;
//第一步:配置时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|
RCC_APB2Periph_GPIOB|RCC_APB2Periph_TIM1 ,ENABLE);
//第二步,配置goio口
/********TIM1_CH1 引脚配置*********/
GPIO_InitStructure2.GPIO_Pin=GPIO_Pin_8;
GPIO_InitStructure2.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_InitStructure2.GPIO_Mode=GPIO_Mode_AF_PP; //设置为复用浮空输出
GPIO_Init(GPIOA,&GPIO_InitStructure2);
/*********TIM1_CH1N 引脚配置********/
GPIO_InitStructure2.GPIO_Pin=GPIO_Pin_13;
GPIO_InitStructure2.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_InitStructure2.GPIO_Mode=GPIO_Mode_AF_PP; //设置为复用浮空输出
GPIO_Init(GPIOB,&GPIO_InitStructure2);
//第三步,定时器基本配置
TIM_TimeBaseStructure.TIM_Period=1000-1; // 自动重装载寄存器的值TIM_TimeBaseStructure.TIM_Prescaler=72-1; // 时钟预分频数
TIM_TimeBaseStructure.TIM_ClockDivision=TIM_CKD_DIV1; // 采样分频
TIM_TimeBaseStructure.TIM_CounterMode=TIM_CounterMode_Up;//向上计数
TIM_TimeBaseStructure.TIM_RepetitionCounter=0;//重复寄存器,用于自动更新pwm占空比TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure);
//第四步pwm输出配置
TIM_OCInitStructure.TIM_OCMode=TIM_OCMode_PWM2; //设置为pwm1输出模式
TIM_OCInitStructure.TIM_Pulse=500; //设置占空比时间
TIM_OCInitStructure.TIM_OCPolarity=TIM_OCPolarity_Low; //设置输出极性
TIM_OCInitStructure.TIM_OutputState=TIM_OutputState_Enable; //使能该通道输出
//下面几个参数是高级定时器才会用到,通用定时器不用配置
TIM_OCInitStructure.TIM_OCNPolarity=TIM_OCNPolarity_High; //设置互补端输出极性
TIM_OCInitStructure.TIM_OutputNState=TIM_OutputNState_Enable;//使能互补端输出
TIM_OCInitStructure.TIM_OCIdleState=TIM_OCIdleState_Reset; //死区后输出状态
TIM_OCInitStructure.TIM_OCNIdleState=TIM_OCNIdleState_Reset;//死区后互补端输出状态
TIM_OC1Init(TIM1,&TIM_OCInitStructure); //按照指定参数初始化
//第五步,死区和刹车功能配置,高级定时器才有的,通用定时器不用配置
TIM_BDTRInitStructure.TIM_OSSRState = TIM_OSSRState_Disable;//运行模式下输出
选择
TIM_BDTRInitStructure.TIM_OSSIState = TIM_OSSIState_Disable;//空闲模式下输出选择
TIM_BDTRInitStructure.TIM_LOCKLevel = TIM_LOCKLevel_OFF; //锁定设置
TIM_BDTRInitStructure.TIM_DeadTime = 0x90; //死区时间设置
TIM_BDTRInitStructure.TIM_Break = TIM_Break_Disable; //刹车功能使能
TIM_BDTRInitStructure.TIM_BreakPolarity = TIM_BreakPolarity_High;//刹车输入极性TIM_BDTRInitStructure.TIM_AutomaticOutput = TIM_AutomaticOutput_Enable;//自动输出使能
TIM_BDTRConfig(TIM1,&TIM_BDTRInitStructure);
//第六步,使能端的打开
TIM_OC1PreloadConfig(TIM1, TIM_OCPreload_Enable); //使能TIMx在CCR1上的预装载寄存器
TIM_ARRPreloadConfig(TIM1, ENABLE); //使能TIMx在ARR上的预装载寄存器
TIM_Cmd(TIM1,ENABLE); //打开TIM2
//下面这句是高级定时器才有的,输出pwm必须打开
TIM_CtrlPWMOutputs(TIM1, ENABLE); //pwm输出使能,一定要记得打开
TIM_OC1PreloadConfig(),TIM_ARRPreloadConfig();这两个函数控制的是ccr1和arr的预装在使能,使能和失能的区别就是:使能的时候这两个局存期的读写需要等待有更新事件发生时才能被改变(比如计数溢出就是更新时间)。
失能的时候可以直接进行读写而没有延迟。
另外在运行当中想要改变pwm的频率和占空比调用:TIM_SetAutoreload()
TIM_SetCompare1()这两个函数就可以了。