avr或51单片机pwm控制小车左右电机并调速.docx

avr或51单片机pwm控制小车左右电机并调速.docx

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
avr或51单片机pwm控制小车左右电机并调速

avr或51单片机pwm控制小车左右电机并调速,红外对管检测的程序 // Crystal: 8.0000Mhz #include iom16v.h #include macros.h #define uchar unsigned char #define uint unsigned int uint discrepancy=0; //function declaration void port_init(void); void motor(uchar index, uchar speed);//input PWM wave void sensor_state(void);//get the running condition void revise_to_line(void );//0=run forward,1=left,2=right,3=sever left,4=sever right void delayms(uint MS) ; //call this routine to initialize all peripherals调用这个例程初始化所有外设 void init_devices0(void) { //stop errant interrupts until set up CLI(); //disable all interrupts timer0_init(); MCUCR = 0x00; GICR = 0x00; TIMSK = 0x02; //timer interrupt sources SEI(); //re-enable interrupts //all peripherals are now initialized } //initialize T/C1 void timer1_init(void) { TCCR1B = 0x00;//停止定时器 TIMSK |= 0x00;//中断允许 TCNT1H = 0x00; TCNT1L = 0x00;//初始值 OCR1AH = 0x00; OCR1AL = 0xF0;//匹配A值 OCR1BH = 0x00; OCR1BL = 0xF0;//匹配B值 ICR1H = 0xFF; ICR1L = 0xFF;//输入捕捉匹配值 TCCR1A = 0xA1; TCCR1B = 0x01;//启动定时器 } //call this routine to initialize all peripherals void init_devices1(void) { CLI(); //禁止所有中断 timer1_init( ); MCUCR = 0x00; MCUCSR = 0x80;//禁止JTAG GICR = 0x00; SEI();//开全局中断 } //PWM 调速,通过改变占空比,周期性地开闭使能端,调节电机的有效电压。 //use PD4,PD5 to output PWM,speed(0~255) void motor(uchar index, uchar speed) { if(index==1) {OCR1AH = 0x00; OCR1AL =speed; } if(index==2) {OCR1BH = 0x00; OCR1BL =speed; } } //delay time by ms void delayms(uint MS) { uint i,j; for( i=0;iMS;i++) for(j=0;j1141;j++); //1141是在8MHz晶振下 } //port initial void port_init( ) { DDRA = 0x00;//input running state DDRB = 0xFF;//control two motors DDRC = 0x00; DDRD = 0x30;//PWM wave PORTA = 0x00; PORTB = 0x00; PORTC = 0x00; PORTD = 0x30; } /*****************传感器函数********************/ //获取小车的行驶状态。0(直线),1(左偏),2(右偏),3(严重左偏),4(严重右偏) //从左到右传感器(光电对管)对应的输入端口:PA0,PA1,PA2,PA3,PA4 //正常行驶时引导线夹在PA1,PA3之间 //根据端口PA0,PA1,PA3,PA4的值判断行驶状态。(中间传感器PA2并未使用) void sensor_state(void)//传感器状态 { uchar state,state

文档评论(0)

liudao + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档