基于stm32循迹小车运动实例

基于stm32循迹小车运动实例

#include “motor.h”
#include “Math.h”
#include “delay.h”
#include “stm32f10x.h” // Device header

signed short sPWMR,sPWML,dPWM;

//GPIOÅäÖú¯Êý
/*void MotorGPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB, ENABLE);

GPIO_InitStructure.GPIO_Pin = LEFT_MOTOR_GO;         
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; 	
GPIO_Init(LEFT_MOTOR_GO_GPIO, &GPIO_InitStructure);    

GPIO_InitStructure.GPIO_Pin = LEFT_MOTOR_PWM;	
GPIO_Init(LEFT_MOTOR_PWM_GPIO, &GPIO_InitStructure); 


GPIO_InitStructure.GPIO_Pin = RIGHT_MOTOR_PWM;	
GPIO_Init(RIGHT_MOTOR_PWM_GPIO, &GPIO_InitStructure); 

GPIO_InitStructure.GPIO_Pin = RIGHT_MOTOR_GO;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; 		
GPIO_Init(RIGHT_MOTOR_GPIO, &GPIO_InitStructure); 

}

void run() //Ç°½ø
{
RIGHT_MOTOR_GO_SET;
RIGHT_MOTOR_PWM_RESET;//PB9

LEFT_MOTOR_GO_SET;
LEFT_MOTOR_PWM_RESET;//PB8

}
*/

void TIM4_PWM_Init(unsigned short arr,unsigned short psc)
{
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
TIM_OCInitTypeDef TIM_OCInitStructure;
GPIO_InitTypeDef GPIO_InitStructure;

RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);// 
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB , ENABLE); 

GPIO_InitStructure.GPIO_Pin = LEFT_MOTOR_GO; ×óµç»ú·½Ïò¿ØÖÆ PB7
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(LEFT_MOTOR_GO_GPIO, &GPIO_InitStructure);

GPIO_InitStructure.GPIO_Pin = LEFT_MOTOR_PWM;         //×óµç»úPWM¿ØÖÆ PB8
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; 	   //¸´ÓÃÍÆÍìÊä³ö
GPIO_Init(LEFT_MOTOR_PWM_GPIO, &GPIO_InitStructure);  

GPIO_InitStructure.GPIO_Pin = RIGHT_MOTOR_GO; //ÓÒµç»ú·½Ïò¿ØÖÆ PA4
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(RIGHT_MOTOR_GPIO, &GPIO_InitStructure);

GPIO_InitStructure.GPIO_Pin = RIGHT_MOTOR_PWM;       //ÓÒµç»úPWM¿ØÖÆ  PB9
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; 	   //¸´ÓÃÍÆÍìÊä³ö
GPIO_Init(RIGHT_MOTOR_PWM_GPIO, &GPIO_InitStructure);  

TIM_TimeBaseStructure.TIM_Period = arr; //ÉèÖÃÔÚÏÂÒ»¸ö¸üÐÂʼþ×°Èë»î¶¯µÄ×Ô¶¯ÖØ×°ÔؼĴæÆ÷ÖÜÆÚµÄÖµ	 80K
TIM_TimeBaseStructure.TIM_Prescaler =psc; //ÉèÖÃÓÃÀ´×÷ΪTIMxʱÖÓƵÂʳýÊýµÄÔ¤·ÖƵֵ  ²»·ÖƵ
TIM_TimeBaseStructure.TIM_ClockDivision = 0; //ÉèÖÃʱÖÓ·Ö¸î:TDTS = Tck_tim
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIMÏòÉϼÆÊýģʽ
TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure); //¸ù¾ÝTIM_TimeBaseInitStructÖÐÖ¸¶¨µÄ²ÎÊý³õʼ»¯TIMxµÄʱ¼ä»ùÊýµ¥Î»

TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM2; //Ñ¡Ôñ¶¨Ê±Æ÷ģʽ:TIMÂö³å¿í¶Èµ÷ÖÆģʽ2
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //±È½ÏÊä³öʹÄÜ
TIM_OCInitStructure.TIM_Pulse = 0; //ÉèÖôý×°È벶»ñ±È½Ï¼Ä´æÆ÷µÄÂö³åÖµ
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; //Êä³ö¼«ÐÔ:TIMÊä³ö±È½Ï¼«ÐÔ¸ß
TIM_OC3Init(TIM4, &TIM_OCInitStructure);  //¸ù¾ÝTIM_OCInitStructÖÐÖ¸¶¨µÄ²ÎÊý³õʼ»¯ÍâÉèTIMx
TIM_OC4Init(TIM4, &TIM_OCInitStructure);  //¸ù¾ÝTIM_OCInitStructÖÐÖ¸¶¨µÄ²ÎÊý³õʼ»¯ÍâÉèTIMx

TIM_CtrlPWMOutputs(TIM4,ENABLE);	//MOE Ö÷Êä³öʹÄÜ	

TIM_OC3PreloadConfig(TIM4, TIM_OCPreload_Enable);  //CH1ԤװÔØʹÄÜ	 
TIM_OC4PreloadConfig(TIM4, TIM_OCPreload_Enable);  //CH1ԤװÔØʹÄÜ

TIM_ARRPreloadConfig(TIM4, ENABLE); //ʹÄÜTIMxÔÚARRÉϵÄԤװÔؼĴæÆ÷
TIM_Cmd(TIM4, ENABLE); //ʹÄÜTIM1
}

void SetMotorSpeed(unsigned char ucChannel,signed char cSpeed)
{
// static short sMotorSpeed = 0;
short sPWM;
// float fDir = 1;

	if (cSpeed>=100) cSpeed = 100;
  if (cSpeed<=-100) cSpeed = -100;

sPWM = 7201 - fabs(cSpeed)*72;
switch(ucChannel)
{
	case 0://ÓÒÂÖ
		TIM_SetCompare3(TIM4,sPWM);
		if (cSpeed>0) 
			RIGHT_MOTOR_GO_RESET;
		else if(cSpeed<0) 
			RIGHT_MOTOR_GO_SET;		
		break;
	case 1://×óÂÖ
	  TIM_SetCompare4(TIM4,sPWM); 
		if (cSpeed>0) 
			LEFT_MOTOR_GO_SET;
		else if (cSpeed<0)
			LEFT_MOTOR_GO_RESET;
		break;			
}

}

//----------------------------------Ô˶¯º¯Êý--------------------------------
void ZYSTM32_run(signed char speed,int time) //Ç°½øº¯Êý
{
signed char f_speed = - speed;
SetMotorSpeed(1,f_speed);//×óÂÖ //Ϊ¸ºÊý
SetMotorSpeed(0,speed);//ÓÒÂÖ //ΪÕýÊý
delay_ms(time); //ʱ¼äΪºÁÃë

}

void ZYSTM32_brake(int time) //ɲ³µº¯Êý
{
SetMotorSpeed(1,0);//×óÂÖ //Ϊ0
SetMotorSpeed(0,0);//ÓÒÂÖ //Ϊ0
RIGHT_MOTOR_GO_RESET;
LEFT_MOTOR_GO_RESET;
delay_ms(time); //ʱ¼äΪºÁÃë
}

void ZYSTM32_Left(signed char speed,int time) //×óתº¯Êý
{
SetMotorSpeed(1,0);//×óÂÖ //×óÂÖ²»¶¯
SetMotorSpeed(0,speed); //ÓÒÂÖΪÕý
delay_ms(time); //ʱ¼äΪºÁÃë

}
void ZYSTM32_Spin_Left(signed char speed,int time) //×óÐýתº¯Êý
{
SetMotorSpeed(1,speed);//×óÂÖ //×óÂÖΪÕý
SetMotorSpeed(0,speed); //ÓÒÂÖΪÕý
delay_ms(time); //ʱ¼äΪºÁÃë

}
void ZYSTM32_Right(signed char speed,int time) //ÓÒתº¯Êý
{
signed char f_speed = - speed;
SetMotorSpeed(1,f_speed);//×óÂÖ //×óÂÖΪ¸º
SetMotorSpeed(0,0); //ÓÒÂÖΪ0
delay_ms(time); //ʱ¼äΪºÁÃë

}
void ZYSTM32_Spin_Right(signed char speed,int time) //ÓÒÐýתº¯Êý
{
signed char f_speed = - speed;
SetMotorSpeed(1,f_speed);//×óÂÖ //×óÂÖΪ¸º
SetMotorSpeed(0,f_speed); //ÓÒÂÖΪ¸º
delay_ms(time); //ʱ¼äΪºÁÃë

}
void ZYSTM32_back(signed char speed,int time) //ºóÍ˺¯Êý
{
signed char f_speed = - speed;
SetMotorSpeed(1,speed);//×óÂÖ //ΪÕýÊý
SetMotorSpeed(0,f_speed);//ÓÒÂÖ //Ϊ¸ºÊý
delay_ms(time); //ʱ¼äΪºÁÃë

}

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: STM32循迹小车PWM是利用STM32单片机实现循迹小车控制的一种方法。PWM(Pulse Width Modulation)是一种通过改变脉冲宽度的方式来控制电子设备的技术。而CSND是中国最大的IT技术社区CSDN的简称。 在STM32循迹小车中,我们可以利用PWM技术控制电机的速度和方向。通过设置占空比来控制电机驱动器的输出电压,从而改变电机的转速。通过改变PWM信号的频率和占空比,可以实现车辆的前进、后退以及转弯等动作。 在循迹小车中,循迹传感器可以检测到黑线与白线的交界处,并将传感器检测到的信号通过模数转换器(ADC)转换为数字信号输入给STM32单片机。根据传感器的检测结果,我们可以通过编程算法判断车辆应该采取的动作,并利用PWM技术控制电机的输出从而实现循迹。 为了编写循迹小车的控制程序,我们可以借助CSDN这一IT技术社区,参考其他人的经验与分享,获取相关代码及开发工具的使用教程等。借助CSDN的开放性和交流性质,我们可以更好地学习和解决在开发循迹小车过程中遇到的问题。 总之,STM32循迹小车PWM CSND是一种利用STM32单片机和PWM技术实现循迹小车控制的方法,而借助CSDN这个IT技术社区,我们可以更好地学习和开发循迹小车的相关知识。 ### 回答2: STM32循迹小车是一种基于STM32单片机的智能小车,它能够通过PWM(脉宽调制)技术实现精确的速度调节和转向控制。CSND(CSDN)是一家提供在线技术交流和分享的平台。 循迹小车是一种能够在预定路径上进行移动的智能小车,它通常通过红外传感器等感知模块来检测路径上的黑线,并根据检测结果进行控制。使用STM32单片机作为控制核心,可以实现进行实时数据采集和控制计算。PWM技术是一种通过控制信号的占空比来调节输出信号的平均值的方法,可以实现精确的速度调节和转向控制。循迹小车通常会根据红外传感器检测到的黑线位置来调整左右轮的PWM信号,从而使小车能够在路径上保持平稳运行。 CSDN是全球最大的中文IT社区和技术交流平台,许多开发者和学习者都会在CSDN上发布他们的技术文章和分享经验。对于循迹小车的PWM控制,CSDN上有许多相关的技术文章和实例代码,开发者可以从中学习和借鉴。在CSDN上,通过搜索关键词"STM32循迹小车PWM",可以找到一些相关的技术博文和论坛贴子,其中包含了循迹小车PWM控制的详细实现方法和代码示例。借助CSDN这样的技术社区,开发者可以更好地理解和掌握循迹小车PWM控制的原理和实践应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值