STM32 PWM模板

感谢PWM,让模拟信号的实现不用再拖着一个大盒子,还要忍受磁场、温度等环境带来的极大误差的影响。

通过导通时间的改变,从而实现稳压电源输出的改变,可以实现输出模拟信号

 其中PWM模式1、2在CNT与CRR处于不同的比较状态下输出相反的电平(有效/无效)

而(有效/无效电平并非是单纯的高/低电平)

通过   

 TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low/TIM_OCPolarity_Low;

设置有效电平为高/低电平,也就是说:

PWM模式1&高电平有效     与     PWM模式2&低电平有效 效果一样

PWM模式2&高电平有效     与     PWM模式2&低电平有效 效果一样

void pwm_init(u32 arr, u32 psc)
{
	GPIO_InitTypeDef GPIO_InitStructure;
	TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
	TIM_OCInitTypeDef  TIM_OCInitStructure;
	
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM14,ENABLE);  	//TIM14时钟使能    
	RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOF, ENABLE); 	//使能PORTF时钟	
	
	GPIO_PinAFConfig(GPIOF,GPIO_PinSource9,GPIO_AF_TIM14); //GPIOF9复
	
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;           //GPIOF9
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;        //复用功能
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;	//速度100MHz
	GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;      //推挽复用输出
	GPIO_Init(GPIOF,&GPIO_InitStructure);              //初始化PF9
  
	TIM_TimeBaseStructure.TIM_Prescaler=psc;  //定时器分频
	TIM_TimeBaseStructure.TIM_CounterMode=TIM_CounterMode_Up; //向上计数模式
	TIM_TimeBaseStructure.TIM_Period=arr;   //自动重装载值
	TIM_TimeBaseStructure.TIM_ClockDivision=TIM_CKD_DIV1; 
	
	TIM_TimeBaseInit(TIM14,&TIM_TimeBaseStructure);//初始化定时器14
	
	//初始化TIM14 Channel1 PWM模式	 
	TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //选择定时器模式:TIM脉冲宽度调制模式2
 	TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能
	TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low; //输出极性:TIM输出比较极性低
	TIM_OC1Init(TIM14, &TIM_OCInitStructure);  //根据T指定的参数初始化外设TIM1 4OC1

	TIM_OC1PreloadConfig(TIM14, TIM_OCPreload_Enable);  //使能TIM14在CCR1上的预装载寄存器
 
  TIM_ARRPreloadConfig(TIM14,ENABLE);//ARPE使能 
	
	TIM_Cmd(TIM14, ENABLE);  //使能TIM14
}
int main(void)
{
   pwm_init(n-1,84-1);
   int cnt;
   while(1) 
	{
		TIM_SetCompare1(TIM14,cnt);	//修改比较值,修改占空比
	}
}

猜你喜欢

转载自blog.csdn.net/wu58430/article/details/117338068