Subversion Repositories svnkaklik

Rev

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

Rev 176 Rev 179
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
// kroutitka
5
// kroutitka
6
#define  CERVENA  3  // AN3/RA3
6
#define  CERVENA  3  // AN3/RA3
7
#define  CERNA    2  // AN2/RA2
7
#define  CERNA    2  // AN2/RA2
8
#define  ZELENA   1  // AN1/RA0
8
#define  ZELENA   1  // AN1/RA0
9
#define  MODRA    0  // AN0/RA1
9
#define  MODRA    0  // AN0/RA1
10
 
10
 
11
// I/O
11
// I/O
12
#define LED    PIN_C0      // LED signalizujici start programu
12
#define LED    PIN_C0      // LED signalizujici start programu
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
 
18
 
19
#define DATA   PIN_B2
19
#define DATA   PIN_B2      // K modulu LEDbar data
20
#define CP     PIN_B1
20
#define CP     PIN_B1      // K modulu LEDbar hodiny
21
 
21
 
-
 
22
#define CASMIN 6           // Rozsah radku snimace
-
 
23
#define CASMAX 192
-
 
24
#define CASAVR ((CASMAX+CASMIN) / 2)
-
 
25
 
-
 
26
// Zobrazeni jednoho byte na modulu LEDbar
22
void disp(int8 x)
27
void disp(int8 x)
23
{
28
{
24
   int n;
29
   int n;
25
 
30
 
26
   x=~x;
31
   x=~x;
27
   for(n=0;n<=7;n++)
32
   for(n=0;n<=7;n++)
28
   {
33
   {
29
      if (x & 1 == 1) output_high(DATA); else output_low(DATA);
34
      if (x & 1 == 1) output_high(DATA); else output_low(DATA);
30
      output_high(CP);
35
      output_high(CP);
31
      x>>=1;
36
      x>>=1;
32
      output_low(CP);
37
      output_low(CP);
33
   }
38
   }
34
}
39
}
35
 
40
 
-
 
41
// Blikani LEDbarem ve stilu Night Rider
36
void NightRider(int x)
42
void NightRider(int x)
37
{
43
{
38
   int n,i,j;
44
   int n,i,j;
39
 
45
 
40
   for(j=0;j<x;j++)
46
   for(j=0;j<x;j++)
41
   {
47
   {
42
      i=0x01;
48
      i=0x01;
43
      for(n=0;n<7;n++)
49
      for(n=0;n<7;n++)
44
      {
50
      {
45
         disp(i);
51
         disp(i);
46
         rotate_left(&i, 1);
52
         rotate_left(&i, 1);
47
         delay_ms(100);
53
         delay_ms(100);
48
      }
54
      }
49
      for(n=0;n<7;n++)
55
      for(n=0;n<7;n++)
50
      {
56
      {
51
         disp(i);
57
         disp(i);
52
         rotate_right(&i, 1);
58
         rotate_right(&i, 1);
53
         delay_ms(100);
59
         delay_ms(100);
54
      }
60
      }
55
   }
61
   }
56
   disp(i);
62
   disp(i);
57
   delay_ms(100);
63
   delay_ms(100);
58
   i=0;
64
   i=0;
59
   disp(i);
65
   disp(i);
60
}
66
}
61
 
67
 
62
void main()
68
void main()
63
{
69
{
64
   int8 cas;      // Cas hrany bila/cerna v radce
70
   int8 cas;      // Cas hrany bila/cerna v radce
65
   int8 offset;   // Promena pro ulozeni ovsetu
71
   int8 offset;   // Promena pro ulozeni ovsetu
66
   int8 rr;       // Promenna na ulozeni Rozumne rychlost
72
   int8 rr;       // Promenna na ulozeni Rozumne rychlost
67
   int8 r1;       // Rychlost motoru 1
73
   int8 r1;       // Rychlost motoru 1
68
   int8 r2;       // Rychlost motoru 2
74
   int8 r2;       // Rychlost motoru 2
69
 
75
 
70
   int16 ble;     // Prodleva do rozjezdu
76
   int16 ble;     // Prodleva do rozjezdu
71
 
77
 
72
   setup_adc_ports(ALL_ANALOG);              // Zapnuti A/D prevodniku pro cteni kroutitek
78
   setup_adc_ports(ALL_ANALOG);              // Zapnuti A/D prevodniku pro cteni kroutitek
73
   setup_adc(ADC_CLOCK_INTERNAL);
79
   setup_adc(ADC_CLOCK_INTERNAL);
74
   setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);  // Casovac pro mereni casu hrany W/B v radce
80
   setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);  // Casovac pro mereni casu hrany W/B v radce
75
   setup_timer_1(T1_DISABLED);
81
   setup_timer_1(T1_DISABLED);
76
   setup_timer_2(T2_DIV_BY_16,255,1);        // Casovac PWM motoru
82
   setup_timer_2(T2_DIV_BY_16,255,1);        // Casovac PWM motoru
77
   setup_ccp1(CCP_PWM); // RC1               // PWM pro motory
83
   setup_ccp1(CCP_PWM); // RC1               // PWM pro motory
78
   setup_ccp2(CCP_PWM); // RC2
84
   setup_ccp2(CCP_PWM); // RC2
79
   setup_comparator(NC_NC_NC_NC);
85
   setup_comparator(NC_NC_NC_NC);
80
   setup_vref(FALSE);
86
   setup_vref(FALSE);
81
 
87
 
82
   set_tris_c(0b11111000);     // Nastaveni vstup/vystup pro branu C, protoze se nedela automaticky
88
   set_tris_c(0b11111000);     // Nastaveni vstup/vystup pro branu C, protoze se nedela automaticky
83
 
89
 
84
   set_pwm1_duty(0);   // Zastav motory
90
   set_pwm1_duty(0);   // Zastav motory
85
   set_pwm2_duty(0);
91
   set_pwm2_duty(0);
86
   output_low(MOT_L);
92
   output_low(MOT_L);
87
   output_low(MOT_R);
93
   output_low(MOT_R);
88
 
94
 
89
   NightRider(1);    // Aby se poznalo, ze byl RESET
95
   NightRider(1);    // Aby se poznalo, ze byl RESET
90
                     // Musi se pockat, nez se rozjede kamera, nez se do ni zacnou posilat prikazy
96
                     // Musi se pockat, nez se rozjede kamera, nez se do ni zacnou posilat prikazy
91
 
97
 
92
   //... Nastaveni kamery ...
98
   //... Nastaveni kamery ...
93
   i2c_start();      // Soft RESET kamery
99
   i2c_start();      // Soft RESET kamery
94
   i2c_write(0xC0);        // Pro single slave musi mit vsechny zapisy adresu C0h
100
   i2c_write(0xC0);        // Pro single slave musi mit vsechny zapisy adresu C0h
95
   i2c_write(0x12);        // Adresa registru COMH
101
   i2c_write(0x12);        // Adresa registru COMH
96
   i2c_write(0x80 | 0x24); // Zapis ridiciho slova
102
   i2c_write(0x80 | 0x24); // Zapis ridiciho slova
97
   i2c_stop();
103
   i2c_stop();
98
 
104
 
99
   i2c_start();      // BW
105
   i2c_start();      // BW
100
   i2c_write(0xC0);
106
   i2c_write(0xC0);
101
   i2c_write(0x28);
107
   i2c_write(0x28);
102
   i2c_write(0b01000001);
108
   i2c_write(0b01000001);
103
   i2c_stop();
109
   i2c_stop();
104
 
110
 
105
/*
111
/*
106
   i2c_start();      // Contrast
112
   i2c_start();      // Contrast
107
   i2c_write(0xC0);
113
   i2c_write(0xC0);
108
   i2c_write(0x05);
114
   i2c_write(0x05);
109
   i2c_write(0xA0);  // 48h
115
   i2c_write(0xA0);  // 48h
110
   i2c_stop();
116
   i2c_stop();
111
*/
117
*/
112
   i2c_start();      // Brightness
118
   i2c_start();      // Brightness
113
   i2c_write(0xC0);
119
   i2c_write(0xC0);
114
   i2c_write(0x06);
120
   i2c_write(0x06);
115
   i2c_write(0x90);  // 80h
121
   i2c_write(0x9A);  // 80h
116
   i2c_stop();
122
   i2c_stop();
117
 
123
 
118
/*
124
/*
119
   i2c_start();      // Band Filter
125
   i2c_start();      // Band Filter
120
   i2c_write(0xC0);
126
   i2c_write(0xC0);
121
   i2c_write(0x2D);
127
   i2c_write(0x2D);
122
   i2c_write(0x04 | 0x03);
128
   i2c_write(0x04 | 0x03);
123
   i2c_stop();
129
   i2c_stop();
124
*/
130
*/
125
   i2c_start();      // VSTRT
131
   i2c_start();      // VSTRT
126
   i2c_write(0xC0);
132
   i2c_write(0xC0);
127
   i2c_write(0x19);
133
   i2c_write(0x19);
128
   i2c_write(45);
134
   i2c_write(45);
129
   i2c_stop();
135
   i2c_stop();
130
 
136
 
131
   i2c_start();      // VEND
137
   i2c_start();      // VEND
132
   i2c_write(0xC0);
138
   i2c_write(0xC0);
133
   i2c_write(0x1A);
139
   i2c_write(0x1A);
134
   i2c_write(45);
140
   i2c_write(45);
135
   i2c_stop();
141
   i2c_stop();
136
 
142
 
137
   NightRider(1);    // Aby se poznalo, ze byl RESET
143
   NightRider(1);    // Musi se dat cas kamere na AGC a AEC
138
 
144
 
139
   cas=128;  // Inicializace promenych, aby neslo servo za roh a aby se to rozjelo jeste dneska
145
   cas=128;  // Inicializace promenych, aby neslo servo za roh a aby se to rozjelo jeste dneska
140
   ble=0;
146
   ble=0;
141
 
147
 
142
/*
-
 
143
while(true)
-
 
144
{
-
 
145
disp(ble);
-
 
146
   i2c_start();      
-
 
147
   i2c_write(0xC0);
-
 
148
   i2c_write(0x06);
-
 
149
   i2c_write(ble); 
-
 
150
   i2c_stop();
-
 
151
delay_ms(1000);
-
 
152
ble+=0x10;
-
 
153
};
-
 
154
*/
-
 
155
 
-
 
156
   // ... Hlavni smycka ...
148
   // ... Hlavni smycka ...
157
   while(true)
149
   while(true)
158
   {
150
   {
-
 
151
      int8 pom;
-
 
152
 
-
 
153
      pom=0;
159
      while(!input(HREF));    // Cekej nez se zacnou posilat pixely z radky
154
      while(!input(HREF));    // Cekej nez se zacnou posilat pixely z radky
160
      set_timer0(0);          // Vynuluj pocitadlo casu
155
      set_timer0(0);          // Vynuluj pocitadlo casu
161
      while(input(HREF))      // Po dobu vysilani radky cekej na hranu W/B
156
      while(input(HREF))      // Po dobu vysilani radky cekej na hranu W/B
162
      {
157
      {
163
// Dodelat rozpoznani cerne cary napric pro zastaveni
158
// !!!!Dodelat rozpoznani cerne cary napric pro zastaveni
164
// Pockat na shozeni signalu HREF
-
 
165
         if(!input(PIX))   // Pokud se dvakrat za sebou precetla CERNA
159
         if(!input(PIX))   // Pokud se 3x za sebou precetla CERNA
166
         if(!input(PIX))
160
         if(!input(PIX))
167
         if(!input(PIX))
161
         if(!input(PIX))
168
         {
162
         {
169
            int8 pom;
-
 
170
 
-
 
171
            pom=get_timer0();    // Precti cas z citace casu hrany
163
            pom=get_timer0();    // Precti cas z citace casu hrany
172
//            cas=255-cas;         // Vlevo je vpravo
-
 
173
            if(pom<0b11000000) cas=pom;
-
 
174
            break;
164
            break;
175
         };
165
         };
176
      };
166
      };
-
 
167
      while(input(HREF));      // Pockej na shozeni signalu HREF
-
 
168
 
-
 
169
      if((pom<CASMAX) && (pom>CASMIN)) cas=pom;  // Orizni konce radku
-
 
170
      // Na konci obrazovaho radku to blbne. Jednak chyba od apertury
-
 
171
      // a vubec to nejak na kraji nefunguje.
177
 
172
 
178
      set_adc_channel(MODRA);    // Kroutitko na vystredeni predniho kolecka
173
      set_adc_channel(MODRA);    // Kroutitko na vystredeni predniho kolecka
179
      Delay_ms(1);
174
      Delay_ms(1);
180
      offset=read_adc();
175
      offset=read_adc();
181
 
176
 
182
      output_high(SERVO);        // Odvysilani impuzu 1 az 2ms pro servo
177
      output_high(SERVO);        // Odvysilani impuzu 1 az 2ms pro servo
183
      delay_us(1000);
178
      delay_us(1000);
184
      delay_us(offset);
179
      delay_us(offset);
185
      delay_us(offset);
180
      delay_us(offset);
186
      delay_us(cas);
181
      delay_us(cas);
187
      delay_us(cas);
182
      delay_us(cas);
188
      output_low(SERVO);
183
      output_low(SERVO);
189
 
184
 
190
      ble++;                     // Casovac pro odlozeni rozjezdu po zapnuti napajeni
185
      ble++;                     // Casovac pro odlozeni rozjezdu po zapnuti napajeni
191
      set_adc_channel(ZELENA);   // Kroutitka pro vykon motoru (!!! to bude chtit jeste predelat !!!)
186
      set_adc_channel(ZELENA);   // Kroutitko pro vykon motoru
192
      Delay_ms(1);
187
      Delay_ms(1);
193
      offset=read_adc();
-
 
194
      set_adc_channel(CERNA);
-
 
195
      Delay_ms(1);
-
 
196
      rr=read_adc();
188
      rr=read_adc()>>2; //!!! // 0-31
197
 
189
 
198
disp(cas);
190
disp(cas & 0b11110000);
-
 
191
      
-
 
192
      // Elektronicky diferencial
-
 
193
      if(cas<CASAVR) {r1=cas-CASMIN; r2=CASAVR-CASMIN;}; // Normovani vystupni hodnoty radkoveho snimace 
-
 
194
      if(cas==CASAVR) {r1=cas-CASMIN; r2=cas-CASMIN;};   // pro rizeni rychlosti motoru
-
 
195
      if(cas>CASAVR) {r1=CASAVR-CASMIN; r2=CASMAX-cas;}; // Rozsah 1 az 92
-
 
196
      
-
 
197
      
-
 
198
      if (r1>(CASAVR-CASMIN-rr)) r1=(r1<<1)+rr-(CASAVR-CASMIN);     // Neco jako nasobeni
-
 
199
      if (r2>(CASAVR-CASMIN-rr)) r2=(r2<<1)+rr-(CASAVR-CASMIN);    
199
 
200
 
200
      r1=cas>>1;                 // Elektronicky diferencial
201
//      r1<<=1;     // Rychlost je dvojnasobna
201
      r2=255-offset-(cas>>1);
202
//      r2<<=1;     // Rozsah 2 az 184
202
 
203
 
203
      if (ble==99)               // Rozjezd na Rozumnou rychlost
-
 
204
      {
-
 
205
         set_pwm1_duty(rr);
-
 
206
         set_pwm2_duty(rr);
-
 
207
      };
-
 
208
      if ((ble>100)&&(ble<60000))      // Jizda
204
      if ((ble>100)&&(ble<60000))      // Jizda
209
      {
205
      {
210
         if (r1<=rr) set_pwm1_duty(r1);
206
         set_pwm1_duty(r1);
211
         if (r2<=rr) set_pwm2_duty(r2);
207
         set_pwm2_duty(r2);
212
      }
208
      }
213
      else
209
      else
214
      {
210
      {
-
 
211
//!!!!!!!!!!!!!!!!!! Tenhle kod pred zavodem zrusit !!!!!!!!!!!!!!!!!!!!!!!!!!!!      
215
         set_pwm1_duty(0);       // Zastaveni
212
         set_pwm1_duty(0);       // Zastaveni
216
         set_pwm2_duty(0);
213
         set_pwm2_duty(0);
217
      }
214
      }
218
   };
215
   };
219
}
216
}