Subversion Repositories svnkaklik

Rev

Rev 238 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log

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