四轮两驱小车(二):TIM8输出比较方式驱动520电机

目录

前言:

原理简述:

代码部分:

大坑来了:


前言:

        对于这篇文章,我在制作小车并且调试的时候遇到了一个非常大的坑,电机响应有延迟!这对于后续的PID调控来说非常致命,不过好在是最后解决了,写下这篇博客来给大家避一下坑。

原理简述:

        在强调这个致命错误之前,简单给大家说一下输出比较的原理。

         中文版的数据手册上给我们介绍了这一功能:计数器在不断计数,而当计数器(CNT)内的之和比较寄存器(CCR)中值相同时,输出引脚的值可以进行反转,而正是根据它的这一特性,我们可以进行PWM的输出。

        接下来我们就可以根据手册给我们提供的配置步骤,来写我们响应的代码了

代码部分:

void Motor3_Init()
{
	//PC7 	    -> TIM8_CH2
	GPIO_InitTypeDef GPIO_InitStructure;
	TIM_TimeBaseInitTypeDef	TIM_TimeBaseStructure;
	TIM_OCInitTypeDef	TIM_OCInitStructure;
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM8|RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOC,ENABLE);
	
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;//PC7为PWM
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOC, &GPIO_InitStructure);//PC7
	
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;//PB0用做推挽输出
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOB, &GPIO_InitStructure);//PB0
	GPIO_WriteBit(GPIOB, GPIO_Pin_0, Bit_RESET);// 0 0 状态是AS4950休眠状态
	
	TIM_TimeBaseStructure.TIM_ClockDivision = 0x0;
	TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
	TIM_TimeBaseStructure.TIM_Period = 9999;
	TIM_TimeBaseStructure.TIM_Prescaler = (uint16_t) (SystemCoreClock / 1000000) - 1;
	TIM_TimeBaseInit(TIM8, &TIM_TimeBaseStructure);
	
	TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //选择定时器模式:TIM脉冲宽度调制模式1
	TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能
//	TIM_OCInitStructure.TIM_OCNIdleState = TIM_OutputNState_Disable;//CH2N通道失能
//	TIM_OCInitStructure.TIM_OCPolarity = ;
	TIM_OCInitStructure.TIM_Pulse = 0;                            //设置待装入捕获比较寄存器的脉冲值
	TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;     //输出极性:TIM输出比较极性高
	TIM_OC2Init(TIM8, &TIM_OCInitStructure);  //根据TIM_OCInitStruct中指定的参数初始化外设TIMx
	TIM_CtrlPWMOutputs(TIM8,ENABLE);	//MOE 主输出使能	

	TIM_OC2PreloadConfig(TIM8, TIM_OCPreload_Disable);  //CH2预装载使能	  
	
	TIM_ARRPreloadConfig(TIM8, ENABLE); //使能TIMx在ARR上的预装载寄存器
	
	TIM_Cmd(TIM8, ENABLE);  //使能TIM8
}

void Motor4_Init()
{
	//PC8 	    -> TIM8_CH3
	GPIO_InitTypeDef GPIO_InitStructure;
	TIM_TimeBaseInitTypeDef	TIM_TimeBaseStructure;
	TIM_OCInitTypeDef	TIM_OCInitStructure;
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM8|RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOC,ENABLE);
	
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;//PC8作为PWM
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOC, &GPIO_InitStructure);//PC8
	
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;//PB1作为输出
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOB, &GPIO_InitStructure);//PB1
	GPIO_WriteBit(GPIOB, GPIO_Pin_1, Bit_RESET);// 0 0 状态是AS4950休眠状态
	
	TIM_TimeBaseStructure.TIM_ClockDivision = 0x0;
	TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
	TIM_TimeBaseStructure.TIM_Period = 9999;
	TIM_TimeBaseStructure.TIM_Prescaler = (uint16_t) (SystemCoreClock / 1000000) - 1;
	TIM_TimeBaseInit(TIM8, &TIM_TimeBaseStructure);
	
	TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //选择定时器模式:TIM脉冲宽度调制模式1
	TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能
	TIM_OCInitStructure.TIM_Pulse = 0;                            //设置待装入捕获比较寄存器的脉冲值
	TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;     //输出极性:TIM输出比较极性高
	TIM_OC3Init(TIM8, &TIM_OCInitStructure);  //根据TIM_OCInitStruct中指定的参数初始化外设TIMx
	TIM_CtrlPWMOutputs(TIM8,ENABLE);	//MOE 主输出使能	

	TIM_OC3PreloadConfig(TIM8, TIM_OCPreload_Disable);  //CH3预装载使能	  
	
	TIM_ARRPreloadConfig(TIM8, ENABLE); //使能TIMx在ARR上的预装载寄存器
	
	TIM_Cmd(TIM8, ENABLE);  //使能TIM8
}

大坑来了:

        就是这个地方,一定要选成TIM_OCPreload_Disable!

TIM_OC3PreloadConfig(TIM8, TIM_OCPreload_Disable);  //CH3预装载使能	  

        最开始我没有去过多的了解这个函数的含义,我直接用的ENABLE,结果电机响应变慢了,好一顿找啊,最后查看了一下数据手册才明白真正的含义,TIMx_CCRx寄存器能够在任何时候通过软件进行更新以控制输出波形,条件是未使用预装载寄 存器(OCxPE=’0’,否则TIMx_CCRx的影子寄存器只能在发生下一次更新事件时被更新)。而这个对应到库函数上来说,正是下面这个函数

 TIM_OCPreload_Disable对应的才是OCxPE为0,而电机有延迟的原因就是影子寄存器智能在下一次更新事件时被更新!!!

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
四轮独立驱动小车是一种能够在不同地形和环境中行驶的机器人。它们通常由四个独立驱动的轮子组成,每个轮子都有自己的电机和控制系统,可以独立控制。这种设计使机器人能够灵活地移动,以适应各种不同的场景和任务。 以下是四轮独立驱动小车的一些详细知识: 1. 轮子和电机四轮独立驱动小车通常使用四个轮子和电机,每个轮子都可以独立转动。电机通常由一个控制器控制,可以改变速度和方向。 2. 控制系统:四轮独立驱动小车的控制系统通常由一个微控制器或单片机控制。这个控制器可以接收传感器数据、用户输入和其他信息,然后控制电机以实现机器人的运动。 3. 传感器:四轮独立驱动小车通常安装有多种传感器,包括距离传感器、颜色传感器、惯性传感器和摄像头等。这些传感器可以提供有关机器人周围环境的信息,帮助机器人进行导航和避障。 4. 程序控制:四轮独立驱动小车的程序控制通常由一个控制系统完成。该系统可以使用各种编程语言进行编写,例如C、C++、Python等。程序应具有适当的算法,以实现机器人的自主运动和导航。 5. 能源供应:四轮独立驱动小车通常使用电池作为能量来源。电池应具有足够的容量,以保证机器人可以长时间运行。 总之,四轮独立驱动小车是一种非常灵活和多功能的机器人。它们可以用于各种不同的应用,例如自动化制造、物流和安全巡逻等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值