Subversion Repositories svnkaklik

Rev

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

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