蓝桥杯嵌入式学习记录 -十一届

在STM32开发中遇到一个挑战,当设置输出比较的占空比为0%或100%时,由于配置为TIM_OCMode_Toggle模式,导致无法达到预期效果。为了解决这个问题,采用了一种新的策略,即根据占空比值动态调整输出模式为TIM_OCMode_Inactive或TIM_OCMode_Active。这样在0%和100%时避免了不必要的翻转,提高了效率。尽管直接操作寄存器可以提升性能,但也增加了资源消耗,因此作者正在寻求更高效的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

输出比较的一点问题

	在编写第十一届赛题时发现stm32的输出比较在将占空比设置为0%或100%时是无法达到预期的结果的,因为我们
设置的模式为TIM_OCMode_Toggle所以每次达到比较值就会进行一次翻转。
	我的解决方案是通过改变输出模式为TIM_OCMode_Inactive和TIM_OCMode_Active来解决的,每次改变占空比
会进行一次模式处理。
	在这里要注意因为这是在程序中要反复调用的函数所以直接进行寄存器操作会提高效率。但始终会消耗资源,所
以也正在寻找是否有更高效的方案。
//怕以后忘记写所以在这里


在这里插入图片描述


void Duty_Deal()
{
	switch ((uint)(setDuty1*100))
	{
		case 0:
		{
			TIM3->CCMR1&=0xff0f;  //
	        TIM3->CCMR1|=0x0010;// TIM_OCMode_Active
		}break;
		
		case 100:
		{
		    TIM3->CCMR1&=0xff0f;
		    TIM3->CCMR1|=0x0020;//TIM_OCMode_Inactive
		}break;
		
		default:
		{
		    TIM3->CCMR1&=0xff0f;
		    TIM3->CCMR1|=0x0030;//TIM_OCMode_Toggle
			}break;
	}
	
	switch ((uint)(setDuty2*100))
	{
		case 0:
		{
			TIM3->CCMR1&=0x0fff;
		    TIM3->CCMR1|=0x1000;//TIM_OCMode_Active
		}break;
		
		case 100:
		{
		    TIM3->CCMR1&=0x0fff;
		    TIM3->CCMR1|=0x2000;//TIM_OCMode_Inactive
		}break;
		
		default:
		{
		    TIM3->CCMR1&=0x0fff;
		    TIM3->CCMR1|=0x3000;//TIM_OCMode_Toggle
		}break;
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值