Subversion Repositories svnkaklik

Rev

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

Rev 180 Rev 181
1
#include ".\camerus.h"
1
#include ".\camerus.h"
2
 
2
 
3
#USE FAST_IO (C)     // Brana C je ve FAST_IO modu, aby slo rychle cteni z kamery
3
#USE FAST_IO (C)     // Brana C je ve FAST_IO modu, aby slo rychle cteni z kamery
4
 
4
 
5
// A/D vstupy
5
// A/D vstupy
6
#define  DALKOMER 4  // AN4/RA5 - dalkomer na cihlu
6
#define  DALKOMER 4  // AN4/RA5 - dalkomer na cihlu
7
#define  CERNA    3  // AN3/RA3
7
#define  CERNA    3  // AN3/RA3
8
#define  CERVENA  2  // AN2/RA2 - cervene kroutitko
8
#define  CERVENA  2  // AN2/RA2 - cervene kroutitko
9
#define  ZELENA   1  // AN1/RA0 - zelene kroutitko
9
#define  ZELENA   1  // AN1/RA0 - zelene kroutitko
10
#define  MODRA    0  // AN0/RA1 - modre kroutitko
10
#define  MODRA    0  // AN0/RA1 - modre kroutitko
11
 
11
 
12
// I/O
12
// I/O
13
#define HREF   PIN_C5      // Signal HREF z kamery (v H po celou dobu radku)
13
#define HREF   PIN_C5      // Signal HREF z kamery (v H po celou dobu radku)
14
#define PIX    PIN_C6      // Vstup pro body z kamery (za trivstupim hradlem OR (dig. komparator))
14
#define PIX    PIN_C6      // Vstup pro body z kamery (za trivstupim hradlem OR (dig. komparator))
15
#define SERVO  PIN_B4      // Vystup na servo (1 az 2ms po cca 20ms (synchronizovano snimkovym kmitoctem))
15
#define SERVO  PIN_B4      // Vystup na servo (1 az 2ms po cca 20ms (synchronizovano snimkovym kmitoctem))
16
#define MOT_L  PIN_B5      // Smer otaceni leveho motoru; druhy pol je RC2
16
#define MOT_L  PIN_B5      // Smer otaceni leveho motoru; druhy pol je RC2
17
#define MOT_R  PIN_B6      // Smer otaceni praveho motoru; druhy pol je RC1
17
#define MOT_R  PIN_B6      // Smer otaceni praveho motoru; druhy pol je RC1
18
#define DATA   PIN_B2      // K modulu LEDbar data
18
#define DATA   PIN_B2      // K modulu LEDbar data
19
#define CP     PIN_B1      // K modulu LEDbar hodiny
19
#define CP     PIN_B1      // K modulu LEDbar hodiny
20
#define ODO    PIN_A4      // Ze snimace z odometrie z praveho kola
20
#define ODO    PIN_A4      // Ze snimace z odometrie z praveho kola
21
 
21
 
22
#define CASMIN 6           // Rozsah radku snimace
22
#define CASMIN 6           // Rozsah radku snimace
23
#define CASMAX 192
23
#define CASMAX 192
24
#define CASAVR ((CASMAX+CASMIN) / 2)
24
#define CASAVR ((CASMAX+CASMIN) / 2)
25
 
25
 
26
// Zobrazeni jednoho byte na modulu LEDbar
26
// Zobrazeni jednoho byte na modulu LEDbar
27
void disp(int8 x)
27
void disp(int8 x)
28
{
28
{
29
   int n;
29
   int n;
30
 
30
 
31
   x=~x;
31
   x=~x;
32
   for(n=0;n<=7;n++)
32
   for(n=0;n<=7;n++)
33
   {
33
   {
34
      if (x & 1 == 1) output_high(DATA); else output_low(DATA);
34
      if (x & 1 == 1) output_high(DATA); else output_low(DATA);
35
      output_high(CP);
35
      output_high(CP);
36
      x>>=1;
36
      x>>=1;
37
      output_low(CP);
37
      output_low(CP);
38
   }
38
   }
39
}
39
}
40
 
40
 
41
// Blikani LEDbarem ve stilu Night Rider
41
// Blikani LEDbarem ve stilu Night Rider
42
void NightRider(int x)
42
void NightRider(int x)
43
{
43
{
44
   int n,i,j;
44
   int n,i,j;
45
 
45
 
46
   for(j=0;j<x;j++)
46
   for(j=0;j<x;j++)
47
   {
47
   {
48
      i=0x01;
48
      i=0x01;
49
      for(n=0;n<7;n++)
49
      for(n=0;n<7;n++)
50
      {
50
      {
51
         disp(i);
51
         disp(i);
52
         rotate_left(&i, 1);
52
         rotate_left(&i, 1);
53
         delay_ms(100);
53
         delay_ms(50);
54
      }
54
      }
55
      for(n=0;n<7;n++)
55
      for(n=0;n<7;n++)
56
      {
56
      {
57
         disp(i);
57
         disp(i);
58
         rotate_right(&i, 1);
58
         rotate_right(&i, 1);
59
         delay_ms(100);
59
         delay_ms(50);
60
      }
60
      }
61
   }
61
   }
62
   disp(i);
62
   disp(i);
63
   delay_ms(100);
63
   delay_ms(30);
64
   i=0;
64
   i=0;
65
   disp(i);
65
   disp(i);
66
}
66
}
67
 
67
 
68
void main()
68
void main()
69
{
69
{
70
   int8 cas;      // Cas hrany bila/cerna v radce
70
   int8 cas;      // Cas hrany bila/cerna v radce
71
   int8 offset;   // Promena pro ulozeni ovsetu
71
   int8 offset;   // Promena pro ulozeni ovsetu
72
   int8 rr;       // Promenna na ulozeni Rozumne rychlost
72
   int8 rr;       // Promenna na ulozeni Rozumne rychlost
73
   int8 r1;       // Rychlost motoru 1
73
   int8 r1;       // Rychlost motoru 1
74
   int8 r2;       // Rychlost motoru 2
74
   int8 r2;       // Rychlost motoru 2
75
   enum stavy {start,rozjezd,jizda,cihla,cil};
75
   enum stavy {start,rozjezd,jizda,cihla,cil};
76
   stavy stav;    // Kde jsme na trati
76
   stavy stav;    // Kde jsme na trati
77
   int16 trasa;   // Pocitadlo ujete vzdalenosti
77
   int16 trasa;   // Pocitadlo ujete vzdalenosti
78
 
78
 
79
   setup_adc_ports(ALL_ANALOG);              // Zapnuti A/D prevodniku pro cteni kroutitek
79
   setup_adc_ports(ALL_ANALOG);              // Zapnuti A/D prevodniku pro cteni kroutitek
80
   setup_adc(ADC_CLOCK_INTERNAL);
80
   setup_adc(ADC_CLOCK_INTERNAL);
81
   setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);  // Casovac pro mereni casu hrany W/B v radce
81
   setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);  // Casovac pro mereni casu hrany W/B v radce
82
   setup_timer_1(T1_DISABLED);
82
   setup_timer_1(T1_DISABLED);
83
   setup_timer_2(T2_DIV_BY_16,255,1);        // Casovac PWM motoru
83
   setup_timer_2(T2_DIV_BY_16,255,1);        // Casovac PWM motoru
84
   setup_ccp1(CCP_PWM); // RC1               // PWM pro motory
84
   setup_ccp1(CCP_PWM); // RC1               // PWM pro motory
85
   setup_ccp2(CCP_PWM); // RC2
85
   setup_ccp2(CCP_PWM); // RC2
86
   setup_comparator(NC_NC_NC_NC);
86
   setup_comparator(NC_NC_NC_NC);
87
   setup_vref(FALSE);
87
   setup_vref(FALSE);
88
 
88
 
89
   set_tris_c(0b11111000);     // Nastaveni vstup/vystup pro branu C, protoze se nedela automaticky
89
   set_tris_c(0b11111000);     // Nastaveni vstup/vystup pro branu C, protoze se nedela automaticky
90
 
90
 
91
   set_pwm1_duty(0);   // Zastav motory
91
   set_pwm1_duty(0);   // Zastav motory
92
   set_pwm2_duty(0);
92
   set_pwm2_duty(0);
93
   output_low(MOT_L);
93
   output_low(MOT_L);
94
   output_low(MOT_R);
94
   output_low(MOT_R);
95
 
95
 
96
   NightRider(1);    // Aby se poznalo, ze byl RESET
96
   NightRider(1);    // Aby se poznalo, ze byl RESET
97
                     // Musi se pockat, nez se rozjede kamera, nez se do ni zacnou posilat prikazy
97
                     // Musi se pockat, nez se rozjede kamera, nez se do ni zacnou posilat prikazy
98
 
98
 
99
   //... Nastaveni kamery ...
99
   //... Nastaveni kamery ...
100
   i2c_start();      // Soft RESET kamery
100
   i2c_start();      // Soft RESET kamery
101
   i2c_write(0xC0);        // Pro single slave musi mit vsechny zapisy adresu C0h
101
   i2c_write(0xC0);        // Pro single slave musi mit vsechny zapisy adresu C0h
102
   i2c_write(0x12);        // Adresa registru COMH
102
   i2c_write(0x12);        // Adresa registru COMH
103
   i2c_write(0x80 | 0x24); // Zapis ridiciho slova
103
   i2c_write(0x80 | 0x24); // Zapis ridiciho slova
104
   i2c_stop();
104
   i2c_stop();
105
 
105
 
106
   i2c_start();      // BW
106
   i2c_start();      // BW
107
   i2c_write(0xC0);
107
   i2c_write(0xC0);
108
   i2c_write(0x28);
108
   i2c_write(0x28);
109
   i2c_write(0b01000001);
109
   i2c_write(0b01000001);
110
   i2c_stop();
110
   i2c_stop();
111
 
111
 
112
/*
112
/*
113
   i2c_start();      // Contrast
113
   i2c_start();      // Contrast
114
   i2c_write(0xC0);
114
   i2c_write(0xC0);
115
   i2c_write(0x05);
115
   i2c_write(0x05);
116
   i2c_write(0xA0);  // 48h
116
   i2c_write(0xA0);  // 48h
117
   i2c_stop();
117
   i2c_stop();
118
*/
118
 
119
   i2c_start();      // Brightness
119
   i2c_start();      // Brightness
120
   i2c_write(0xC0);
120
   i2c_write(0xC0);
121
   i2c_write(0x06);
121
   i2c_write(0x06);
122
   i2c_write(0x9A);  // 80h
122
   i2c_write(0x0);  // 80h //9Ah
123
   i2c_stop();
123
   i2c_stop();
124
 
124
 
125
/*
-
 
126
   i2c_start();      // Band Filter
125
   i2c_start();      // Band Filter
127
   i2c_write(0xC0);
126
   i2c_write(0xC0);
128
   i2c_write(0x2D);
127
   i2c_write(0x2D);
129
   i2c_write(0x04 | 0x03);
128
   i2c_write(0x04 | 0x03);
130
   i2c_stop();
129
   i2c_stop();
131
*/
130
*/
-
 
131
 
-
 
132
   i2c_start();      // Fame Rate
-
 
133
   i2c_write(0xC0);
-
 
134
   i2c_write(0x2B);
-
 
135
   i2c_write(0x00);  // cca 17ms (puvodni hodnota 5Eh = 20ms)
-
 
136
   i2c_stop();
-
 
137
 
132
   i2c_start();      // VSTRT
138
   i2c_start();      // VSTRT
133
   i2c_write(0xC0);
139
   i2c_write(0xC0);
134
   i2c_write(0x19);
140
   i2c_write(0x19);
135
   i2c_write(45);
141
   i2c_write(118);   // prostredni radka
136
   i2c_stop();
142
   i2c_stop();
137
 
143
 
138
   i2c_start();      // VEND
144
   i2c_start();      // VEND
139
   i2c_write(0xC0);
145
   i2c_write(0xC0);
140
   i2c_write(0x1A);
146
   i2c_write(0x1A);
141
   i2c_write(45);
147
   i2c_write(118);
142
   i2c_stop();
148
   i2c_stop();
143
 
149
 
144
   NightRider(1);    // Musi se dat cas kamere na AGC a AEC
150
   NightRider(1);    // Musi se dat cas kamere na AGC a AEC
145
 
151
 
-
 
152
{ // Kalibrace kamery
-
 
153
   int8 t1,t2;
-
 
154
   
-
 
155
   for(offset=0;offset<=255;offset+=0x04) // Cita porad dokola
-
 
156
   {
-
 
157
      i2c_start();      // Brightness
-
 
158
      i2c_write(0xC0);
-
 
159
      i2c_write(0x06);
-
 
160
      i2c_write(offset);  // 80h default
-
 
161
      i2c_stop();
-
 
162
      disp(offset);
-
 
163
      delay_ms(100);
-
 
164
 
-
 
165
      t1=0;
-
 
166
      t2=0;
-
 
167
      while(!input(HREF));    // Cekej nez se zacnou posilat pixely z radky
-
 
168
      delay_ms(5);     
-
 
169
      while(!input(HREF));    // Cekej nez se zacnou posilat pixely z radky
-
 
170
      set_timer0(0);          // Vynuluj pocitadlo casu
-
 
171
      if(!input(PIX)) continue;
-
 
172
      while(input(PIX));
-
 
173
      t1=get_timer0();    // Precti cas z citace casu hrany
-
 
174
      set_timer0(0);          // Vynuluj pocitadlo casu     
-
 
175
      while(!input(PIX));
-
 
176
      t2=get_timer0();   
-
 
177
      
-
 
178
      if((t1>60) && (t1<140) && (t2>5) && (t2<=10)) break;
-
 
179
      
-
 
180
      delay_ms(2);
-
 
181
   }
-
 
182
}
-
 
183
 
-
 
184
delay_ms(1000);
-
 
185
 
146
   cas=128;  // Inicializace promenych, aby neslo servo za roh a aby se to rozjelo jeste dneska
186
   cas=128;  // Inicializace promenych, aby neslo servo za roh a aby se to rozjelo jeste dneska
147
   stav=start;
187
   stav=start;
148
   trasa=0;
188
   trasa=0;
149
   
189
 
150
   // ... Hlavni smycka ...
190
   // ... Hlavni smycka ...
151
   while(true)
191
   while(true)
152
   {
192
   {
153
      int8 pom;
193
      int8 pom;
154
      int8 n;
194
      int8 n;
155
      
195
 
156
      pom=0;
196
      pom=0;
157
      while(!input(HREF));    // Cekej nez se zacnou posilat pixely z radky
197
      while(!input(HREF));    // Cekej nez se zacnou posilat pixely z radky
158
      set_timer0(0);          // Vynuluj pocitadlo casu
198
      set_timer0(0);          // Vynuluj pocitadlo casu
159
      while(input(HREF))      // Po dobu vysilani radky cekej na hranu W/B
199
      while(input(HREF))      // Po dobu vysilani radky cekej na hranu W/B
160
      {
200
      {
161
// !!!!Dodelat rozpoznani cerne cary napric pro zastaveni
201
// !!!!Dodelat rozpoznani cerne cary napric pro zastaveni
162
         if(!input(PIX))   // Pokud se 3x za sebou precetla CERNA
202
         if(!input(PIX))   // Pokud se 3x za sebou precetla CERNA
163
         if(!input(PIX))
203
         if(!input(PIX))
164
         if(!input(PIX))
204
//         if(!input(PIX))
165
         {
205
         {
166
            pom=get_timer0();    // Precti cas z citace casu hrany
206
            pom=get_timer0();    // Precti cas z citace casu hrany
167
            break;
207
            break;
168
         };
208
         };
169
      };
209
      };
170
      while(input(HREF));      // Pockej na shozeni signalu HREF
210
      while(input(HREF));      // Pockej na shozeni signalu HREF
171
 
211
 
172
      if((pom<CASMAX) && (pom>CASMIN)) cas=pom;  // Orizni konce radku
212
      if((pom<CASMAX) && (pom>CASMIN)) cas=pom;  // Orizni konce radku
173
      // Na konci obrazovaho radku to blbne. Jednak chyba od apertury
213
      // Na konci obrazovaho radku to blbne. Jednak chyba od apertury
174
      // a vubec to nejak na kraji nefunguje.
214
      // a vubec to nejak na kraji nefunguje.
175
 
215
 
176
      set_adc_channel(MODRA);    // Kroutitko na vystredeni predniho kolecka
216
      set_adc_channel(MODRA);    // Kroutitko na vystredeni predniho kolecka
177
      Delay_ms(1);
217
      Delay_ms(1);
178
      offset=read_adc();
218
      offset=read_adc();
179
 
219
 
180
      output_high(SERVO);        // Odvysilani impuzu 1 az 2ms pro servo
220
      output_high(SERVO);        // Odvysilani impuzu 1 az 2ms pro servo
181
      delay_us(1000);
221
      delay_us(1000);
182
      delay_us(offset);
222
      delay_us(offset);
183
      delay_us(offset);
223
      delay_us(offset);
184
      delay_us(cas);
224
      delay_us(cas);
185
      delay_us(cas);
225
      delay_us(cas);
186
      output_low(SERVO);
226
      output_low(SERVO);
187
 
227
 
188
      set_adc_channel(ZELENA);   // Kroutitko pro vykon motoru
228
      set_adc_channel(ZELENA);   // Kroutitko pro vykon motoru
189
      Delay_ms(1);
229
      Delay_ms(1);
190
      rr=read_adc()>>2; //!!! // 0-31
230
      rr=read_adc()>>2; //!!! // 0-31
191
 
231
 
192
disp(cas & 0b11110000);
-
 
193
 
-
 
194
      // Elektronicky diferencial
232
      // Elektronicky diferencial
195
      if(cas<CASAVR) {r1=cas-CASMIN; r2=CASAVR-CASMIN;}; // Normovani vystupni hodnoty radkoveho snimace
233
      if(cas<CASAVR) {r1=cas-CASMIN; r2=CASAVR-CASMIN;}; // Normovani vystupni hodnoty radkoveho snimace
196
      if(cas==CASAVR) {r1=cas-CASMIN; r2=cas-CASMIN;};   // pro rizeni rychlosti motoru
234
      if(cas==CASAVR) {r1=cas-CASMIN; r2=cas-CASMIN;};   // pro rizeni rychlosti motoru
197
      if(cas>CASAVR) {r1=CASAVR-CASMIN; r2=CASMAX-cas;}; // Rozsah 1 az 92
235
      if(cas>CASAVR) {r1=CASAVR-CASMIN; r2=CASMAX-cas;}; // Rozsah 1 az 92
198
 
236
 
199
 
-
 
200
      if (r1>(CASAVR-CASMIN-rr)) r1=(r1<<1)+rr-(CASAVR-CASMIN);     // Neco jako nasobeni
237
      if (r1>(CASAVR-CASMIN-rr)) r1=(r1<<1)+rr-(CASAVR-CASMIN);     // Neco jako nasobeni
201
      if (r2>(CASAVR-CASMIN-rr)) r2=(r2<<1)+rr-(CASAVR-CASMIN);
238
      if (r2>(CASAVR-CASMIN-rr)) r2=(r2<<1)+rr-(CASAVR-CASMIN);
202
 
239
 
203
//      r1<<=1;     // Rychlost je dvojnasobna
240
//      r1<<=1;     // Rychlost je dvojnasobna
204
//      r2<<=1;     // Rozsah 2 az 184
241
//      r2<<=1;     // Rozsah 2 az 184
205
 
242
 
206
      if (stav==jizda)      // Jizda
243
      if (stav==jizda)      // Jizda
207
      {
244
      {
208
         set_pwm1_duty(r1);
245
         set_pwm1_duty(r1);
209
         set_pwm2_duty(r2);
246
         set_pwm2_duty(r2);
210
         trasa++;
247
         trasa++;
211
      }
248
      }
212
      else
249
      else
213
      {
250
      {
214
         set_pwm1_duty(0);       // Zastaveni
251
         set_pwm1_duty(0);       // Zastaveni
215
         set_pwm2_duty(0);
252
         set_pwm2_duty(0);
216
      }
253
      }
217
 
254
 
218
      set_adc_channel(DALKOMER);   // Prepni A/D prevodnik na detektor cihly
255
      set_adc_channel(DALKOMER);   // Prepni A/D prevodnik na detektor cihly
219
      Delay_ms(1);
256
      Delay_ms(1);
220
      for(n=0;n<5;n++)      // Detekce prekazky
257
      for(n=0;n<200;n++)      // Detekce prekazky
221
      {
258
      {
222
         if(read_adc()<128)
259
         if(read_adc()<128)
223
         {
260
         {
224
            if(stav==start)
261
            if(stav==start)
225
            {             
262
            {
226
              disp(0x55);
263
              disp(0x55);
227
              while(read_adc()<128); // Cekej, dokud starter neda ruku pryc
264
              while(read_adc()<128); // Cekej, dokud starter neda ruku pryc
228
              set_pwm1_duty(255);
265
              set_pwm1_duty(255);
229
              set_pwm2_duty(255);
266
              set_pwm2_duty(255);
230
              disp(0xAA);
267
              disp(0xAA);
231
              delay_ms(500);
268
              delay_ms(500);
232
              stav=jizda;
269
              stav=jizda;
233
              break;
270
              break;
234
            };
271
            };
235
            if((stav==jizda)&&(trasa>50)) // musi to alespon 1s jet
272
            if((stav==jizda)&&(trasa>50)) // musi to alespon 1s jet
236
            {
273
            {
237
              set_pwm1_duty(0);
274
              set_pwm1_duty(0);
238
              set_pwm2_duty(0);
275
              set_pwm2_duty(0);
239
              output_high(MOT_L); // zabrzdi
276
              output_high(MOT_L); // zabrzdi
240
              output_high(MOT_R);
277
              output_high(MOT_R);
241
              delay_ms(300); 
278
              delay_ms(300);
242
              output_low(MOT_L); // zastav
279
              output_low(MOT_L); // zastav
243
              output_low(MOT_R);
280
              output_low(MOT_R);
244
              stav=cil;
281
              stav=cil;
245
              while(true);
282
              while(true);
246
            };
283
            };
247
         }
284
         }
248
      }
285
      }
249
 
286
 
-
 
287
      pom=0x80;   
-
 
288
      for(n=CASMAX/8; n<cas; n+=CASMAX/8)
-
 
289
      {
-
 
290
         pom>>=1;
-
 
291
      }
-
 
292
      disp(pom);
-
 
293
      
-
 
294
   output_high(PIN_C0);
-
 
295
   delay_ms(1);
-
 
296
   output_low(PIN_C0);
-
 
297
 
250
   };
298
   };
251
}
299
}