智能车制作

 找回密码
 注册

扫一扫,访问微社区

查看: 20112|回复: 31
打印 上一主题 下一主题

c51做智能小车

  [复制链接]

0

主题

4

帖子

0

精华

注册会员

Rank: 2

积分
138
QQ
威望
186
贡献
22
兑换币
0
注册时间
2009-2-26
在线时间
2 小时
跳转到指定楼层
1#
发表于 2009-4-5 15:04:11 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
/**********飞思卡尔智能汽车程序***/
//资源分配如下
//舵机用定时器0频率为50HZ
//直流用定时器1频率为10KHZ
//测速用外部中断0周期为50ms
#include<AT89X52.h>
#define  uchar  unsigned char
#define  uint   unsigned int   
sbit   PWM_Steer=P1^0;
sbit   PWM_IN1=P1^2;
sbit   PWM_IN2=P1^3;

//****舵机控制量************
//====f=24MHz
uchar  angle=8;
/*
uchar   Low_Angle_L[]={0x6d,0xdc,0x4b,0xba,0x29,0x98,0x07,0x77,0xe6, 0x55,0xc4,0x34,0xa2,0x11,0x80};
uchar   High_Angle_L[]={0x6c,0x6c,0x6d,0x6d,0x6e,0x6e,0x6f,0x6f,0x6f,0x70,0x70,0x71,0x71,0x72,0x72};
uchar   Low_Angle_H[]={0x50,0xe1,0x72,0x03,0x94,0x25,0xb6,0x47,0xd7,0x68,0xf9,0x8a,0x1b,0xac,0x3d};
uchar   High_Angle_H[]={0xf7,0xf6,0xf6,0xf6,0xf5,0xf5,0xf4,0xf4,0xf3,0xf3,0xf2,0xf2,0xf2,0xf1,0xf1};
*/
//===f=11.0592
uchar   Low_Angle_L[]={0x00,0x33,0x66,0x99,0xcc,0x00,0x33,0x66,0x99,0xcc,0x00,0x33,0x66,0x99,0xcc};
uchar   High_Angle_L[]={0xbc,0xbc,0xbc,0xbc,0xbc,0xbd,0xbd,0xbd,0xbd,0xbd,0xbe,0xbe,0xbe,0xbe,0xbe};
uchar   Low_Angle_H[]={0x00,0xcc,0x99,0x66,0x33,0x00,0xcc,0x99,0x66,0x33,0x00,0xcc,0x99,0x66,0x33};
uchar   High_Angle_H[]={0xfc,0xfb,0xfb,0xfb,0xfb,0xfa,0xfa,0xfa,0xfa,0xfa,0xf9,0xfb,0xf9,0xf9,0xf9};
/*
//****直流电机控制量********
uchar   code speed_hope[]={52,78,104,130,130,156,182,208,182,156,130,130,104,78,52};      //期望的速度值
uchar   PWM_H_D=0x00;
uchar   PWM_L_D=0xff;        //PID运算之后
uchar   last_error=0,pre_error=0;
uchar  times_stopline=0;
uchar  stop=0;
*/
//******子程序*************
void  Init();   
void  Route_Detect();
void  Start_Delay(uchar);
//******主程序*************
void main()
{
    PWM_IN1=1;
PWM_IN2=0;
    Init();
    Start_Delay(2);
    while(1)
    {
      Route_Detect();
    }
}
//*********初始化************************
void  Init()
{
    IE=0X8b;
    TMOD=0X11;
    TH0=0XF4;
    TL0=0X48;
    TH1=0X38;
    PWM_IN1=1;
    PWM_IN2=0;
    TCON=0X53;
}
//********路径检测*****************
void Route_Detect()
{   
    uchar led1,led2;
    led1=P0;
    led2=P2;
   
    if(((led1==0xf3)||(led1==0xfb)||(led1==0xfc)||(led1==0xfe)||(led1==0xfd)||(led1==0xf9))&&(led2==0xff))
      angle=0;            //-35
    else if((led1==0xf7)&&(led2==0xff))
      angle=1;            //-30
    else if((led1==0xe7)&&(led2==0xff))
      angle=2;           //-25
    else if((led1==0xef)&&(led2==0xff))
      angle=3;           //-20
    else if((led1==0xcf)&&(led2==0xff))
      angle=4;           //-15
    else if((led1==0xdf)&&(led2==0xff))
      angle=5;           //-10
    else if((led1==0x9f)&&(led2==0xff))
      angle=6;           //-5
    else if((led1==0xbf)&&(led2==0xff))
      angle=7;           //0
    else if((led1==0x3f)&&(led2==0xff))
      angle=8;          //5
    else if((led1==0x7f)&&(led2==0xff))
      angle=9;          //10
    else if((led1==0x7f)&&(led2==0xfe))
      angle=10;         //15
    else if((led1==0xff)&&(led2==0xfe))
      angle=11;         //20
    else if((led1==0xff)&&(led2==0xfc))
      angle=12;         //25
    else if((led1==0xff)&&(led2==0xfd))
      angle=13;         //30
    else if((led1==0xff)&&((led2==0xf9)||(led2==0xfb)||(led2==0xf3)||(led2==0xf7)||(led2==0xef)||(led2==0xe7)))
      angle=14;         //35
    else
      angle=9;
}

//********舵机控制*****************
void  Steer_Control() interrupt 1  
{   
     if(PWM_Steer==1)
     {
       TL0=Low_Angle_L[angle];
       TH0=High_Angle_L[angle];      
       PWM_Steer=0;
     }
     else
     {
       TL0=Low_Angle_H[angle];
       TH0=High_Angle_H[angle];
       PWM_Steer=1;
     }
} /*
//*******速度检测***************
void  Speed_Test()  interrupt 0
{   
    speed_count++;
}
//********速度运算*****************
void  speed_cal()
{
    if(speed_t>=100)     
    {  
       EX0=0;
       speed=26*speed_count;  //(cm/s)
       speed_count=0;
       EX0=1;
    }
}

//*********PID运算******************
void PID()
{   
    int PID;
    int error;
    int derror;
    int pre_derror;
    error=speed_hope[angle]-speed;
    derror=error-last_error;
    pre_derror=last_error-pre_error;
    PID=PID_P*derror+PID_I*error+PID_D*(derror-pre_error);
    PWM_H_D=256-(PWM_H_D+PID);
    PWM_L_D=256-(PWM_L_D-PID);
    pre_error=last_error;
    last_error=error;
}

//*************************
void Motor_Contol() interrupt 3
{
    speed_t++;
    if(stop==1)      //当停车标志为1时给直流电机制动脉冲
    {
      if(PWM_IN2==0)  
      {
        TH1=trig_H_TH1;
        TL1=trig_H_TL1;
        PWM_IN2=1;
        PWM_IN1=0;
      }
      else
      {
        TH1=trig_L_TH1;
        TL1=trig_L_TL1;
        PWM_IN2=0;
        PWM_IN1=0;
      }
      if(speed<=0)    //当速度减少到0时停车
      {
        TR1=0;
        PWM_IN1=0;
        PWM_IN2=0;
      }
            
    }
    else
    {
      
      if(((angle>=11)||(angle<=3))&&(speed_hope[angle]<speed))
      {
       if(PWM_IN2==1)
       {
          TL1=speed_d_l;
          TH1=0xff;
          PWM_IN1=0;
          PWM_IN2=0;
       }
       else
       {
          TL1=speed_d_h;
          TH1=0xff;
          PWM_IN1=0;
          PWM_IN2=1;
       }
      }      
      else
      {
        if(PWM_IN1==1)
        {
          TH1=0XFF;
          TL1=0x38;
          PWM_IN1=0;
          PWM_IN2=0;
        }
        else
        {
          TH1=0XFF;
          TL1=0xff;
          PWM_IN1=1;
          PWM_IN2=0;
        }
      }   
    }  
}   */
//===========
void Start_Delay(uchar k)
{
    int i=4000;             //当K为1时定时1S
    int j=1000;
    for(;k>=0;k--)
    for(;i>=0;i--)
      for(;j>=0;j--)
    ;
}

0

主题

7

帖子

0

精华

注册会员

Rank: 2

积分
53
威望
38
贡献
9
兑换币
13
注册时间
2015-10-3
在线时间
3 小时
毕业学校
长春理工大学
32#
发表于 2015-10-7 10:45:04 | 只看该作者
厉害:):)
回复 支持 反对

使用道具 举报

0

主题

2

帖子

0

精华

注册会员

Rank: 2

积分
27
威望
97
贡献
20
兑换币
0
注册时间
2012-4-9
在线时间
0 小时
毕业学校
厦门理工
31#
发表于 2012-4-9 15:16:41 | 只看该作者
顶下
回复 支持 反对

使用道具 举报

1

主题

34

帖子

0

精华

高级会员

Rank: 4

积分
537
QQ
威望
349
贡献
188
兑换币
0
注册时间
2010-11-29
在线时间
0 小时
30#
发表于 2010-11-29 13:43:47 | 只看该作者
这个  …… 啊
回复 支持 反对

使用道具 举报

3

主题

17

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
497
QQ
威望
266
贡献
173
兑换币
2
注册时间
2010-10-20
在线时间
29 小时
29#
发表于 2010-11-23 19:46:41 | 只看该作者
给力
回复 支持 反对

使用道具 举报

1

主题

35

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
380
威望
287
贡献
83
兑换币
14
注册时间
2010-7-14
在线时间
5 小时
28#
发表于 2010-11-18 09:01:26 | 只看该作者
交流!!
回复 支持 反对

使用道具 举报

0

主题

14

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
222
威望
184
贡献
38
兑换币
0
注册时间
2010-11-8
在线时间
0 小时
27#
发表于 2010-11-8 20:06:01 | 只看该作者
回复 支持 反对

使用道具 举报

7

主题

89

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
401
QQ
威望
321
贡献
38
兑换币
0
注册时间
2010-4-17
在线时间
21 小时
26#
发表于 2010-4-17 19:15:25 | 只看该作者
谢谢
回复 支持 反对

使用道具 举报

0

主题

18

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
210
威望
188
贡献
22
兑换币
0
注册时间
2010-4-15
在线时间
0 小时
25#
发表于 2010-4-16 14:55:58 | 只看该作者
回复 支持 反对

使用道具 举报

0

主题

8

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
253
QQ
威望
208
贡献
45
兑换币
0
注册时间
2010-4-16
在线时间
0 小时
24#
发表于 2010-4-16 10:57:39 | 只看该作者
回复 支持 反对

使用道具 举报

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

本版积分规则

关于我们|联系我们|小黑屋|智能车制作 ( 黑ICP备2022002344号

GMT+8, 2024-12-26 13:59 , Processed in 0.057812 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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