当前位置:首页 > 单片机 > 单片机
[导读]定时器TIM3产生四路PWM波输出。首先介绍一下PWM吧,算是给自己充电,脉冲宽度调制(PWM),是英文“Pulse Width Modulation ”的缩写,简称脉宽调制,是利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技

定时器TIM3产生四路PWM波输出。

首先介绍一下PWM吧,算是给自己充电,脉冲宽度调制(PWM),是英文“Pulse Width Modulation ”的缩写,简称脉宽调制,是利用
微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术。简单一点,就是对脉冲宽度的控制。

一、这个程序的主函数相当简单:


/*******由于没有做外设测试的程序是:按键PA0仅一个LED灯******/

/*******由于没有做外设测试的程序是:串口采用的是PA9->(T<->T),PA9->(R<->R)*****/

#include"stm32f10x.h"

#include"LED.h"

#include"SysTick.h"

#include"Delay.h"

#include"Usart.h"

#include"stdio.h"

#include"Timer3.h"

volatileu32time;//ms计时变量

intmain(void)

{

//初初始化GPIO

LED_GPIO_Config();

//初始化系统定时器

SysTick_Init();

USART1_Config();

printf("rn("__DATE__"-"__TIME__")rn");

/*TIM3PWM波输出初始化,并使能TIM3PWM输出*/

TIM3_PWM_Init();

while(1);

}

呵呵,看到这样的函数是最爽的了,但是有得必有失,你在主函数里面少了的操作,你在子函数里面也别想跑掉


二、着重来分析这个PWM的初始化函数了。

1、配置GPIO这个是少不了的!看代码,能够明白了


staticvoidTIM3_GPIO_Config(void)

{

GPIO_InitTypeDefGPIO_InitStructure;

/*TIM3clockenable*/

//PCLK1经过2倍频后作为TIM3的时钟源等于36MHz

RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);

/*GPIOAandGPIOBclockenable*/

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB,ENABLE);

/*GPIOAConfiguration:TIM3channel1and2asalternatefunctionpush-pull*/

GPIO_InitStructure.GPIO_Pin=GPIO_Pin_6|GPIO_Pin_7;

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

GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;

GPIO_Init(GPIOA,&GPIO_InitStructure);

/*GPIOBConfiguration:TIM3channel3and4asalternatefunctionpush-pull*/

GPIO_InitStructure.GPIO_Pin=GPIO_Pin_0|GPIO_Pin_1;

GPIO_Init(GPIOB,&GPIO_InitStructure);

}


2、重点是接下来的TIM3_Mode_Config这个配置函数,先上代码,然后一步步分析吧!


/*

*函数名:TIM3_Mode_Config

*描述:配置TIM3输出的PWM信号的模式,如周期、极性、占空比

*输入:无

*输出:无

*调用:内部调用

*/

staticvoidTIM3_Mode_Config(void)

{

TIM_TimeBaseInitTypeDefTIM_TimeBaseStructure;

TIM_OCInitTypeDefTIM_OCInitStructure;

/*PWM信号电平跳变值*/

u16CCR1_Val=500;

u16CCR2_Val=375;

u16CCR3_Val=250;

u16CCR4_Val=125;

/*-----------------------------------------------------------------------

TIM3Configuration:generate4PWMsignalswith4differentdutycycles:

TIM3CLK=36MHz,Prescaler=0x0,TIM3counterclock=36MHz

TIM3ARRRegister=999=>TIM3Frequency=TIM3counterclock/(ARR+1)

TIM3Frequency=36KHz.

TIM3Channel1dutycycle=(TIM3_CCR1/TIM3_ARR)*100=50%

TIM3Channel2dutycycle=(TIM3_CCR2/TIM3_ARR)*100=37.5%

TIM3Channel3dutycycle=(TIM3_CCR3/TIM3_ARR)*100=25%

TIM3Channel4dutycycle=(TIM3_CCR4/TIM3_ARR)*100=12.5%

-----------------------------------------------------------------------*/

/*Timebaseconfiguration*/

TIM_TimeBaseStructure.TIM_Period=999;//当定时器从0计数到999,即为1000次,为一个定时周期

TIM_TimeBaseStructure.TIM_Prescaler=0;//设置预分频:不预分频,即为36MHz

TIM_TimeBaseStructure.TIM_ClockDivision=0;//设置时钟分频系数:不分频

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

TIM_TimeBaseInit(TIM3,&TIM_TimeBaseStructure);

/*PWM1Modeconfiguration:Channel1*/

TIM_OCInitStructure.TIM_OCMode=TIM_OCMode_PWM1;//配置为PWM模式1

TIM_OCInitStructure.TIM_OutputState=TIM_OutputState_Enable;

TIM_OCInitStructure.TIM_Pulse=CCR1_Val;//设置跳变值,当计数器计数到这个值时,电平发生跳变

TIM_OCInitStructure.TIM_OCPolarity=TIM_OCPolarity_High;//当定时器计数值小于CCR1_Val时为高电平

TIM_OC1Init(TIM3,&TIM_OCInitStructure);//使能通道1

TIM_OC1PreloadConfig(TIM3,TIM_OCPreload_Enable);

/*PWM1Modeconfiguration:Channel2*/

TIM_OCInitStructure.TIM_OutputState=TIM_OutputState_Enable;

TIM_OCInitStructure.TIM_Pulse=CCR2_Val;//设置通道2的电平跳变值,输出另外一个占空比的PWM

TIM_OC2Init(TIM3,&TIM_OCInitStructure);//使能通道2

TIM_OC2PreloadConfig(TIM3,TIM_OCPreload_Enable);

/*PWM1Modeconfiguration:Channel3*/

TIM_OCInitStructure.TIM_OutputState=TIM_OutputState_Enable;

TIM_OCInitStructure.TIM_Pulse=CCR3_Val;//设置通道3的电平跳变值,输出另外一个占空比的PWM

TIM_OC3Init(TIM3,&TIM_OCInitStructure);//使能通道3

TIM_OC3PreloadConfig(TIM3,TIM_OCPreload_Enable);

/*PWM1Modeconfiguration:Channel4*/

TIM_OCInitStructure.TIM_OutputState=TIM_OutputState_Enable;

TIM_OCInitStructure.TIM_Pulse=CCR4_Val;//设置通道4的电平跳变值,输出另外一个占空比的PWM

TIM_OC4Init(TIM3,&TIM_OCInitStructure);//使能通道4

TIM_OC4PreloadConfig(TIM3,TIM_OCPreload_Enable);

TIM_ARRPreloadConfig(TIM3,ENABLE);//使能TIM3重载寄存器ARR

/*TIM3enablecounter*/

TIM_Cmd(TIM3, ENABLE); //使能定时器3

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

单片机定时器通过晶振频率来产生精准的计数脉冲,从而实现微秒级别的时间控制。 单片机定时器依托于一个稳定的计数器,该计数器与单片机上的晶振部件相连。晶振经过12分频后,为单片机提供稳定且精准的1MHZ脉冲。由于晶振的频率极...

关键字: 单片机 定时器

编码器‌是一种传感器,主要用于测量旋转运动的角度、角速度和位移等参数。常见的编码器类型包括增量式编码器和绝对值编码器,前者通过检测脉冲的增加或减少来测量旋转方向和距离,后者则直接输出当前的绝对位置信息‌。

关键字: 编码器‌ 定时器

一款语音控制的番茄时间定时器,内置Seeed Studio XIAO ESP32S3感测和圆形显示。用免提时间管理保持高效!

关键字: 定时器 ESP32S3 语音控制

【2025年3月20日, 德国慕尼黑讯】全球功率系统和物联网领域的半导体领导者英飞凌科技股份公司(FSE代码:IFX / OTCQX代码: IFNNY)近日宣布,其旗下ModusToolboxTM开发平台中的AIROC™...

关键字: MCU 物联网 定时器

众所周知,说到延时,很多人都会想到用软件件来实现,比如定时器之类的。今天就来说说用硬件来实现定时的方式,虽说没有那么准,但是有些场合还是用得到的。

关键字: CD4060 定时器

如果定时器的重装值和分频设置不正确,会导致PWM输出的频率和占空比不准确,从而产生误差‌1。

关键字: 定时器 分频

SysTick定时器的工作原理主要基于一个递减计数器的机制。以下是对SysTick定时器工作原理的详细解释:

关键字: SysTick 定时器

pwm控制的基本原理随着电力需求的不断增加,电源管理技术愈加重要。开关电源作为一种高效能、可靠性高的电源,找到广泛的应用。

关键字: pwm 控制 电源

单片机定时器是一种用于计时和定时操作的功能模块。它通常用于生成延时、计数事件以及产生精确的时间间隔信号。

关键字: 定时器 时钟源

在现代嵌入式系统设计中,51单片机作为一种经典的微控制器,凭借其丰富的功能和广泛的应用领域,仍然受到工程师们的青睐。定时器中断是51单片机中一个非常实用的功能,它可以在特定的时间间隔内自动触发中断,执行预设的操作,从而提...

关键字: 51单片机 定时器
关闭