Subversion Repositories svnkaklik

Rev

Rev 236 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log

Rev 236 Rev 238
1
// **** Objeti cihly vlevo **** LLLL
1
// **** Objeti cihly vlevo **** LLLL
2
 
2
 
3
#define L_TOUCH 1    // Cara vlevo
3
#define L_TOUCH 1    // Cara vlevo
4
#define R_TOUCH 2    // Cata vpravo
4
#define R_TOUCH 2    // Cata vpravo
5
#define B_TOUCH 3    // Both
5
#define B_TOUCH 3    // Both
6
 
6
 
7
int8 n;
7
int8 n;
8
int8 r1,r2,rr;
8
int8 r1,r2,rr;
9
int8 touch;
9
int8 touch;
10
enum okolo_cihly {pred_carou,na_care,po_care};
10
enum okolo_cihly {pred_carou,na_care,po_care};
11
okolo_cihly ridic;       // V jakem jsme stavu objizdeni cihly
11
okolo_cihly ridic;       // V jakem jsme stavu objizdeni cihly
12
int8 vzdalenost;
12
int8 vzdalenost;
13
 
13
 
-
 
14
   stav=cihla; // Dalsi prekazku uz nezaznamenavej (je to s velkou pravdepodobnosti cil)
14
   touch=0;    // Indikator detekce cary pri objizdeni
15
   touch=0;    // Indikator detekce cary pri objizdeni
15
 
16
 
16
cihla:
17
cihla:
17
 
18
 
18
   rr=20;   //!!! Rozumna rychlost pro objizdeni cihly (bylo by lepsi rychlost zvysovat) a pri detekci pohybu zase snizit
19
   rr=RR_CIHLA;   //!!! Rozumna rychlost pro objizdeni cihly (bylo by lepsi rychlost zvysovat) a pri detekci pohybu zase snizit
19
   disp(0x99);
20
   disp(0x99);
20
   set_pwm1_duty(0);    // zabrzdi levym kolem, prave vpred
21
   set_pwm1_duty(0);    // zabrzdi levym kolem, prave vpred
21
   set_pwm2_duty(150);
22
   set_pwm2_duty(150);
22
   output_high(MOT_L);
23
   output_high(MOT_L);
23
   output_low(MOT_R);
24
   output_low(MOT_R);
24
   odocounter=get_timer1();
25
   odocounter=get_timer1();
25
   while(true) // Na zacatku se vyhni cihle, zatoc co muzes
26
   while(true) // Na zacatku se vyhni cihle, zatoc co muzes
26
   {
27
   {
27
      cas=CASMIN-5;       // jeste vic nez hodne do leva
28
      cas=CASMIN-5;       // jeste vic nez hodne do leva
28
 
29
 
-
 
30
      if(BUMPER) // Narazili jsme do cihly, musime couvnout!
-
 
31
      {
-
 
32
         bum();
-
 
33
         SaveLog(log-1);      // Zapis Black Boxu do EEPROM
-
 
34
         goto cihla; // Znovu zacni cihlu objizdet
-
 
35
      };
-
 
36
 
29
      set_pwm1_duty(0);
37
      set_pwm1_duty(0);
30
      set_pwm2_duty(200);
38
      set_pwm2_duty(200);
31
      output_high(MOT_L);     // leve kolo reverz
39
      output_high(MOT_L);     // leve kolo reverz
32
      output_low(MOT_R);      // prave kolo vpred
40
      output_low(MOT_R);      // prave kolo vpred
33
      if(get_timer1()>(odocounter+5))  // konec zatacky?
41
      if(get_timer1()>(odocounter+5))  // konec zatacky?
34
      {
42
      {
35
         disp(0x66);
43
         disp(0x66);
36
         break;
44
         break;
37
      }
45
      }
38
      SetServoQ(cas);
46
      SetServoQ(cas);
39
      delay_ms(18);
47
      delay_ms(18);
40
   };
48
   };
41
 
49
 
42
   //------ Objeti cihly v konstantni vzdalenosti ------
50
   //------ Objeti cihly v konstantni vzdalenosti ------
43
   ridic=pred_carou;
51
   ridic=pred_carou;
44
   cas=CASAVR-CASMIN;   // rovne
52
   cas=CASAVR-CASMIN;   // rovne
45
   output_low(MOT_L);   // vpred
53
   output_low(MOT_L);   // vpred
46
   output_low(MOT_R);
54
   output_low(MOT_R);
47
   while(true)
55
   while(true)
48
   {
56
   {
49
      if(BUMPER) // Narazili jsme do cihly, musime couvnout!
57
      if(BUMPER) // Narazili jsme do cihly, musime couvnout!
50
      {
58
      {
51
         set_pwm1_duty(0);    // couvni, rovne dozadu
-
 
52
         set_pwm2_duty(0);
-
 
53
         output_high(MOT_L);
-
 
54
         output_high(MOT_R);
-
 
55
         disp(0xA5);
59
         bum();
56
         SetServo(CASAVR-CASMIN);
-
 
57
         SaveLog(log-1);      // Zapis Black Boxu do EEPROM
60
         SaveLog(log-1);      // Zapis Black Boxu do EEPROM
58
         goto cihla; // Znovu zacni cihlu objizdet
61
         goto cihla; // Znovu zacni cihlu objizdet
59
         // Pozor! Pamatuje se, jestli jsme uz neprejeli caru!
62
         // Pozor! Pamatuje se, jestli jsme uz neprejeli caru!
60
      };
63
      };
61
 
64
 
62
      if(IRRX) // hrozi celni srazka s cihlou v prubehu objizdeni
65
      if(IRRX) // hrozi celni srazka s cihlou v prubehu objizdeni
63
      {
66
      {
64
         cas=CASMIN;
67
         cas=CASMIN;
65
      }
68
      }
66
      else
69
      else
67
      {
70
      {
68
         if((vzdalenost!=0)||!input(PROXIMITY)) // Udrzovani konstantni vzdalenosti od cihly
71
         if((vzdalenost!=0)||!input(PROXIMITY)) // Udrzovani konstantni vzdalenosti od cihly
69
         {
72
         {
70
            if(cas>(CASMIN+20)) cas-=20;
73
            if(cas>(CASMIN+20)) cas-=20;
71
         }
74
         }
72
         else
75
         else
73
         {
76
         {
74
            if(cas<(CASMAX-20)) cas+=20;
77
            if(cas<(CASMAX-20)) cas+=20;
75
         };
78
         };
76
      };
79
      };
77
      // Elektronicky diferencial
80
      // Elektronicky diferencial
78
      if(cas<CASAVR) {r1=cas-CASMIN; r2=CASAVR-CASMIN;}; // Normovani vystupni hodnoty radkoveho snimace
81
      if(cas<CASAVR) {r1=cas-CASMIN; r2=CASAVR-CASMIN;}; // Normovani vystupni hodnoty radkoveho snimace
79
      if(cas==CASAVR) {r1=cas-CASMIN; r2=cas-CASMIN;};   // pro rizeni rychlosti motoru
82
      if(cas==CASAVR) {r1=cas-CASMIN; r2=cas-CASMIN;};   // pro rizeni rychlosti motoru
80
      if(cas>CASAVR) {r1=CASAVR-CASMIN; r2=CASMAX-cas;}; // Rozsah 1 az 92
83
      if(cas>CASAVR) {r1=CASAVR-CASMIN; r2=CASMAX-cas;}; // Rozsah 1 az 92
81
 
84
 
82
      if (r1>(CASAVR-CASMIN-rr)) r1=(r1<<1)+rr-(CASAVR-CASMIN);     // Neco jako nasobeni
85
      if (r1>(CASAVR-CASMIN-rr)) r1=(r1<<1)+rr-(CASAVR-CASMIN);     // Neco jako nasobeni
83
      if (r2>(CASAVR-CASMIN-rr)) r2=(r2<<1)+rr-(CASAVR-CASMIN);
86
      if (r2>(CASAVR-CASMIN-rr)) r2=(r2<<1)+rr-(CASAVR-CASMIN);
84
 
87
 
85
      set_pwm1_duty(r1);   // Nastav rychlost motoru
88
      set_pwm1_duty(r1);   // Nastav rychlost motoru
86
      set_pwm2_duty(r2);
89
      set_pwm2_duty(r2);
87
 
90
 
88
      SetServoQ(cas);
91
      SetServoQ(cas);
89
 
92
 
90
      i2c_start();     // Sonar Ping
93
      i2c_start();     // Sonar Ping
91
      i2c_write(SONAR_ADR);
94
      i2c_write(SONAR_ADR);
92
      i2c_write(0x0);
95
      i2c_write(0x0);
93
      i2c_write(0x52);  // mereni v us
96
      i2c_write(0x52);  // mereni v us
94
      i2c_stop();
97
      i2c_stop();
95
 
98
 
96
      for(n=1;n<=90;n++) // 18ms testovani cary do dalsi korekce serva
99
      for(n=1;n<=90;n++) // 18ms testovani cary do dalsi korekce serva
97
      {
100
      {
98
         set_adc_channel(LMAX);
101
         set_adc_channel(LMAX);
99
         delay_us(100);
102
         delay_us(100);
100
         if(read_adc()<THR) touch|=L_TOUCH;
103
         if(read_adc()<THR) touch|=L_TOUCH;
101
         set_adc_channel(RMAX);
104
         set_adc_channel(RMAX);
102
         delay_us(100);
105
         delay_us(100);
103
         if(read_adc()<THR) touch|=R_TOUCH;
106
         if(read_adc()<THR) touch|=R_TOUCH;
104
      };
107
      };
105
 
108
 
106
      i2c_start();     // Odraz ze sonaru
109
      i2c_start();     // Odraz ze sonaru
107
      i2c_write(SONAR_ADR);
110
      i2c_write(SONAR_ADR);
108
      i2c_write(0x3);
111
      i2c_write(0x3);
109
      i2c_stop();
112
      i2c_stop();
110
      i2c_start();
113
      i2c_start();
111
      i2c_write(SONAR_ADR+1);
114
      i2c_write(SONAR_ADR+1);
112
      vzdalenost=i2c_read(0);
115
      vzdalenost=i2c_read(0);
113
      i2c_stop();
116
      i2c_stop();
114
 
117
 
115
      if(touch==L_TOUCH) disp(0xC0);
118
      if(touch==L_TOUCH) disp(0xC0);
116
      if(touch==R_TOUCH) disp(0x03);
119
      if(touch==R_TOUCH) disp(0x03);
117
      if((touch==B_TOUCH)&&(ridic==pred_carou)) ridic=na_care;
120
      if((touch==B_TOUCH)&&(ridic==pred_carou)) ridic=na_care;
118
      if((ridic==na_care)&&(touch==0)) break;
121
      if((ridic==na_care)&&(touch==0)) break;
119
      if(ridic==na_care) touch=0;
122
      if(ridic==na_care) touch=0;
120
   };
123
   };
121
   disp(0xC3);
124
   disp(0xC3);
122
 
125
 
123
   set_pwm1_duty(20);
126
   set_pwm1_duty(20);
124
   set_pwm2_duty(200);
127
   set_pwm2_duty(200);
125
   output_high(MOT_L);
128
   output_high(MOT_L);
126
   output_low(MOT_R);
129
   output_low(MOT_R);
127
   delay_us(40);
130
   delay_us(40);
128
   odocounter=get_timer1();    // Poznamenej aktualni stav odometrie
131
   odocounter=get_timer1();    // Poznamenej aktualni stav odometrie
129
   while (true)  // Znovu se musime dotknout cary
132
   while (true)  // Znovu se musime dotknout cary
130
   {
133
   {
131
      for(n=1;n<=90;n++) // 18ms testovani cary do dalsi korekce serva
134
      for(n=1;n<=90;n++) // 18ms testovani cary do dalsi korekce serva
132
      {
135
      {
133
         set_adc_channel(LMAX);    // Levy UV sensor
136
         set_adc_channel(LMAX);    // Levy UV sensor
134
         delay_us(100);
137
         delay_us(100);
135
         if(read_adc()<THR)   // Dotkli jsme se levym senzorem
138
         if(read_adc()<THR)   // Dotkli jsme se levym senzorem
136
         {
139
         {
137
            disp(0xE0);
140
            disp(0xE0);
138
            cas=CASAVR-CASMIN; // nastavime, ze cara je rovne
141
            cas=CASAVR-CASMIN; // nastavime, ze cara je rovne
139
            goto cara;
142
            goto cara;
140
         };
143
         };
141
         set_adc_channel(RMAX);    // Pravy UV sensor
144
         set_adc_channel(RMAX);    // Pravy UV sensor
142
         delay_us(100);
145
         delay_us(100);
143
         if((get_timer1()>=(odocounter+2)) && (read_adc()<THR)) // Pravym senzorem nesmime caru prejet!
146
         if((get_timer1()>=(odocounter+2)) && (read_adc()<THR)) // Pravym senzorem nesmime caru prejet!
144
         {
147
         {
145
            disp(0x07);
148
            disp(0x07);
146
            cas=CASMAX; // kdyz prejedem, tak nastavime, ze cara je vpravo
149
            cas=CASMAX; // kdyz prejedem, tak nastavime, ze cara je vpravo
147
            goto cara;
150
            goto cara;
148
         };
151
         };
149
      }
152
      }
150
      SetServoQ(CASMIN-5);   // max. max. doleva                 L
153
      SetServoQ(CASMIN-5);   // max. max. doleva                 L
151
   }
154
   }
152
 
155
 
153
cara:
156
cara:
154
 
157
 
155
   output_low(MOT_L); // oba motory vpred
158
   output_low(MOT_L); // oba motory vpred
156
   output_low(MOT_R);
159
   output_low(MOT_R);