OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3077|回复: 3

有没有试过用输出比较模式,CCR的值装个0?

[复制链接]

4

主题

66

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
279
金钱
279
注册时间
2015-10-5
在线时间
27 小时
发表于 2016-5-22 21:01:18 | 显示全部楼层 |阅读模式
1金钱
首先定时器装的是输出比较模式
ARR里面的值是999,71分频,系统时钟是72MHZ
总的来说CNT1us记一次,然后方波的频率是500HZ

这个图片CCR1 CCR2 CCR3 CCR4的值分别是1 100 500 999
1和999的方波的相位差接近180度
1和500的方波的相位差接近90度
这都是按正常逻辑走的
微信截图_20160522195017.png
问题来了!
下图是当CCR1 CCR2 CCR3 CCR4 的值分别为0 1 500 999的时候
按道理来说,0是一开始就反转极性,1是过1us才反转极性,0和1的方波是差不多一样的才对
但是现实是1和0的方波是接近互补的,0和999的方波是差不多一样的
0119.png

然后我把方波放大到最开始的位置,发现一开始的0并没有反转极性
但是第二次0的时候方波的极性是会反转的,说明0是存在的
那么一开始的0为什么不反转极性呢?0去哪了呢?
为什么1就会,0就不会呢?这是为什么呢?
QQ截图20160522205206.png



最佳答案

查看完整内容[请看2#楼]

根据结论推原因:因为CNT的初始值就是0; 你把CCR1装0,只有在CNT从某个值变到零的瞬间CH1才反转。 谢谢xkwy
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

66

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
279
金钱
279
注册时间
2015-10-5
在线时间
27 小时
 楼主| 发表于 2016-5-22 21:01:19 | 显示全部楼层
根据结论推原因:因为CNT的初始值就是0;
你把CCR1装0,只有在CNT从某个值变到零的瞬间CH1才反转。
谢谢xkwy
回复

使用道具 举报

4

主题

66

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
279
金钱
279
注册时间
2015-10-5
在线时间
27 小时
 楼主| 发表于 2016-5-23 12:02:16 | 显示全部楼层
这是定时器初始化的代码:
[mw_shl_code=c,true]u32 Channel1Pulse=0;
u32 Channel2Pulse=1;
u32 Channel3Pulse=500;
u32 Channel4Pulse=900;
/**
  * @brief  TIM2初始化
  * @param  None
  * @retval None
  */
void TIM2_MODE_Config(void)
{
        TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
        TIM_OCInitTypeDef  TIM_OCInitStructure;
       
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);

        TIM_DeInit(TIM2);       
        /* Time base configuration */
        TIM_TimeBaseStructure.TIM_Period = 999;       
        TIM_TimeBaseStructure.TIM_Prescaler = 71;
        TIM_TimeBaseStructure.TIM_ClockDivision = 0;                                                                                                                                         
        TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;       
        TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
       
        /* Channel 1, 2,3 and 4 Configuration in PWM mode */
        TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_Toggle;
        TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
        TIM_OCInitStructure.TIM_Pulse = Channel1Pulse;
        TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
        TIM_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Set;
       
        TIM_OC1Init(TIM2,&TIM_OCInitStructure);
       
        TIM_OCInitStructure.TIM_Pulse = Channel2Pulse;
        TIM_OC2Init(TIM2, &TIM_OCInitStructure);

        TIM_OCInitStructure.TIM_Pulse = Channel3Pulse;
        TIM_OC3Init(TIM2, &TIM_OCInitStructure);

        TIM_OCInitStructure.TIM_Pulse = Channel4Pulse;
        TIM_OC4Init(TIM2, &TIM_OCInitStructure);
       
        /* TIM1 counter enable */
        TIM_Cmd(TIM2, ENABLE);
       
        /* TIM1 Main Output Enable */
        TIM_CtrlPWMOutputs(TIM2, ENABLE);

}
[/mw_shl_code]


IO口的
[mw_shl_code=c,true]/**
  * @brief  TIM2GPIO初始化
  * @param  None
  * @retval None
  */
void TIM2_GPIO_Config(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
       
        RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOA , ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_AFIO, ENABLE);
       
        /* GPIOA Configuration: TIM2 Channe1-4 as alternate function push-pull */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
       
        GPIO_Init(GPIOA, &GPIO_InitStructure);
}
[/mw_shl_code]

主函数就这两条加个while(1);
回复

使用道具 举报

29

主题

492

帖子

0

精华

高级会员

Rank: 4

积分
810
金钱
810
注册时间
2016-4-7
在线时间
123 小时
发表于 2016-5-25 09:59:59 | 显示全部楼层
装入0,输出要么是高电平要么是低电平,看你怎么设置的
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-9 14:58

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表