#include "main.h"// NEPOUZIVAT PINY B6 A B7, JSOU VYHRAZENY PRO SERIOVOU KOMUNIKACI// BAUD RATE = 9600// univerzalni LED diody#define LED1 PIN_A4#define LED2 PIN_A5// piezo pipak#DEFINE SOUND_HI PIN_B4#DEFINE SOUND_LO PIN_B5// radkovy senzor#define SDIN PIN_D4 // seriovy vstup#define SDOUT input(PIN_B2) // seriovy vystup#define SCLK PIN_D5 // takt// pro komunikaci s OLSA, prvni se posila LSBint1 main_reset[8]={1,1,0,1,1,0,0,0}; // hlavni reset 0x1Bint1 set_mode_rg[8]={1,1,1,1,1,0,1,0}; // zapis do MODE registru 0x5Fint1 clear_mode_rg[8]={0,0,0,0,0,0,0,0}; // nulovani MODE registru 0x00int1 left_offset[8]={0,0,0,0,0,0,1,0}; // offset leveho segmentu senzoru 0x40int1 mid_offset[8]={0,1,0,0,0,0,1,0}; // offset prostredniho segmentu senzoru 0x42int1 right_offset[8]={0,0,1,0,0,0,1,0}; // offset praveho segmentu senzoru 0x44int1 offset[8]={1,0,0,0,0,0,0,1}; // minus jedna - pouzit pro vsechny segmenty 0x81int1 left_gain[8]={1,0,0,0,0,0,1,0}; // zisk leveho segmentu 0x41int1 mid_gain[8]={1,1,0,0,0,0,1,0}; // zisk leveho segmentu 0x43int1 right_gain[8]={1,0,1,0,0,0,1,0}; // zisk leveho segmentu 0x45int1 gain[8]={1,0,1,0,0,0,0,0}; // zisk = 5 - pouzit pro vsechny segmenty 0x5int1 start_int[8]={0,0,0,1,0,0,0,0}; // zacatek integrace 0x08int1 stop_int[8]={0,0,0,0,1,0,0,0}; // konec integrace 0x10int1 readout[8]={0,1,0,0,0,0,0,0}; // cteni senzoru 0x02int8 olsa_lseg[51]={0}; // leva cast radky (pixely 0 - 50)int8 olsa_rseg[51]={0}; // prava cast radky (pixely 51 - 101)int8 *line_lp=&olsa_lseg; // ukazatel na levou cast radkyint8 *line_rp=&olsa_rseg; // ukazatel na pravou cast radkyint8 pixel; // dec hodnota jednoho pixeluint8 rpx; // pocet prectenych pixeluint8 rbit;//naraznik#define BUMPL input(PIN_D6)#define BUMPR input(PIN_D7)//nouzove senzory#define LINEL 0#define LINER 1#define TRESHOLD 200 // rozhodovaci uroven (zmereno 0 - cerna, 255 cerna)int8 line_l;int8 line_r;int1 line_position;// motory#define LMF PIN_D0#define LMB PIN_D1#define RMF PIN_D2#define RMB PIN_D3int8 lm_speed;int8 rm_speed;//PODPROGRAMY//SENZORY//OLSA01Avoid olsa_pulses(int count) // vytvori impulzy pro ridici logiku{int8 ct;for(ct=0;ct<=count;ct++){delay_us(1); // doba pro ustalenioutput_high(SCLK);delay_us(1); // doba pro ustalenioutput_low(SCLK);}}void olsa_pulse() // vytvori jeden impulz{delay_us(1); // doba pro ustalenioutput_high(SCLK);delay_us(1); // doba pro ustalenioutput_low(SCLK);}void olsa_send(int1 info[8]) // USART komunikace s modulem OLSA01A - poslani zpravy{int8 ip; // ukazatel na pole s informaciint1 i; // pomocna promenna pro nastaveni 0 nebo 1 na SDINoutput_low(SDIN); // start bitolsa_pulse();for(ip=0;ip<8;ip++) // predani informace - 8 bit, LSB prvni > MSB posledni{i=info[ip]; // ziskani hodnoty z poleif(i==1) // vyhodnoceni obsahu informace - nastav 1{output_high(SDIN);}else // vyhodnoceni obsahu informace - nastav 0{output_low(SDIN);}olsa_pulse();}output_high(SDIN); // stop bitolsa_pulse();}void olsa_reset() // hlavni RESET - provadi se po zapnuti{output_low(SDIN);output_low(SCLK);olsa_pulses(30); // reset radkoveho senzoruoutput_high(SDIN);olsa_pulses(10); // start bit - synchronizaceolsa_send(main_reset);olsa_pulses(5);olsa_send(set_mode_rg);olsa_send(clear_mode_rg);}void olsa_setup() // kompletni nastaveni, provadi se po resetu{olsa_send(left_offset); // nastaveni leveho segmentu (offset a zisk)olsa_send(offset);olsa_send(left_gain);olsa_send(gain);olsa_send(mid_offset); // nastaveni prostredniho segmentu (offset a zisk)olsa_send(offset);olsa_send(mid_gain);olsa_send(gain);olsa_send(right_offset); // nastaveni praveho segmentu (offset a zisk)olsa_send(offset);olsa_send(right_gain);olsa_send(gain);}void olsa_integration() // snimani pixelu{olsa_send(start_int); // zacatek integrace senzoruolsa_pulses(22);olsa_send(stop_int); // konec integrace senzoruolsa_pulses(5);}int1 bity[8] = { 0, 1, 1, 1, 0, 0, 1, 0 };int8 bajt;void bit_to_bajt(){int i;bajt = 0;for (i = 0; i < 8; i++)bajt |= bity[i] << i;printf("bajt: %x\n", bajt);}void olsa_bit_save() // ukladani jednotlivych bitu pixelu{t_bit_save:if(SDOUT==0) // zacatek prenosu{do // prijimej zpravy{//program pro prijemrbit++; // zapocita precteni bitu 0 - 7}while(rbit==7);goto e_bit_save; // skoc na konec prenosu}else // posli impulz a cekej na prenos{olsa_pulse();goto t_bit_save; // skoci na zacatek prenosu, pokud SDOUT == 1}e_bit_save:olsa_pulse(); // posle impulz pro generovani stop bitu}void olsa_convert(){}void olsa_byte_save() // zapis pixelu do pole{if(rpx<=51) // leva polovina radky{olsa_lseg[line_lp]=pixel; // zapis do poleline_lp++;}else // prava polovina radky{olsa_rseg[line_rp]=pixel; // zapis od poleline_rp++;}}void olsa_evaluate() // vyhodnoceni polohy{}void olsa_read() // precist senzor{rpx=0; // cteny pixel = 0line_lp=0; // ukazatel na levou cast radky = 0line_rp=0; // ukazatel na pravou cast radky = 0olsa_send(readout); // prikaz pro cteni ze senzorudo{olsa_bit_save(); // precte a ulozi bityolsa_convert(); // prevede bity do jednoho bytuolsa_byte_save(); // zapise byte do polerpx++;}while(rpx==101);olsa_evaluate(); // zjisti pozici cary}//ZACHRANNE SENZORYvoid read_blue_sensors() // cteni nouzovych senzoru{set_adc_channel(LINEL); // cti levy nouzovy senzordelay_us(10);line_l=read_adc();set_adc_channel(LINER); // cti pravy nouzovy senzordelay_us(10);line_r=read_adc();}//PIPAKvoid beep(int16 period,int16 length){int16 bp; //promenna pro nastaveni delkyfor(bp=length;bp>0;bp--){output_high(SOUND_HI);output_low(SOUND_LO);delay_us(period);output_high(SOUND_LO);output_low(SOUND_HI);delay_us(period);}}//MOTORYvoid l_motor_fwd(int8 speedl) // levy motor dopredu{output_high(LMF);output_low(LMB);set_pwm2_duty(speedl);}void l_motor_bwd(int8 speedl) // levy motor dozadu{output_high(LMB);output_low(LMF);set_pwm2_duty(speedl);}void r_motor_fwd(int8 speedr) // pravy motor dopredu{output_high(RMF);output_low(RMB);set_pwm1_duty(speedr);}void r_motor_bwd(int8 speedr) // pravy motor dozadu{output_high(RMB);output_low(RMF);set_pwm1_duty(speedr);}void l_motor_off() // levy motor vypnut{output_low(LMF);output_low(LMB);set_pwm2_duty(0);}void r_motor_off() // pravy motor vypnut{output_low(RMF);output_low(RMB);set_pwm1_duty(0);}void motor_test() // test motoru{int8 i;beep(100,200);printf("TEST MOTORU\r\n");delay_ms(1000);printf("LEVY MOTOR DOPREDU\r\n");for(i=0;i<255;i++){l_motor_fwd(i);printf("RYCHLOST: %u\r\n",i);delay_ms(5);}for(i=255;i>0;i--){l_motor_fwd(i);printf("RYCHLOST: %u\r\n",i);delay_ms(5);}printf("LEVY MOTOR DOZADU\r\n");for(i=0;i<255;i++){l_motor_bwd(i);printf("RYCHLOST: %u\r\n",i);delay_ms(5);}for(i=255;i>0;i--){l_motor_bwd(i);printf("RYCHLOST: %u\r\n",i);delay_ms(5);}printf("PRAVY MOTOR DOPREDU\r\n");for(i=0;i<255;i++){r_motor_fwd(i);printf("RYCHLOST: %u\r\n",i);delay_ms(5);}for(i=255;i>0;i--){r_motor_fwd(i);printf("RYCHLOST: %u\r\n",i);delay_ms(5);}printf("PRAVY MOTOR DOZADU\r\n");for(i=0;i<255;i++){r_motor_bwd(i);printf("RYCHLOST: %u\r\n",i);delay_ms(5);}for(i=255;i>0;i--){r_motor_bwd(i);printf("RYCHLOST: %u\r\n",i);delay_ms(5);}printf("KONEC TESTU MOTORU\r\n");}void diagnostika() // diagnostika - vypis senzoru s moznosti prepnuti na test motoru{read_blue_sensors();printf("LEVA: %u \t",line_l);delay_ms(10);printf("PRAVA: %u \t",line_r);delay_ms(10);printf("L_NARAZ: %u \t",BUMPL);delay_ms(10);printf("P_NARAZ: %u \r\n",BUMPR);delay_ms(10);if(BUMPL&&BUMPR) // po zmacknuti stran narazniku spusti test motoru{motor_test();}}// HLAVNI SMYCKAvoid main(){printf("POWER ON \r\n");// NASTAVENI > provede se pouze pri zapnutisetup_adc_ports(sAN0-sAN1-sAN2);setup_adc(ADC_CLOCK_INTERNAL); // interni hodniny pro AD prevodniksetup_spi(SPI_SS_DISABLED);setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);setup_timer_1(T1_DISABLED);setup_timer_2(T2_DIV_BY_16,255,1); // casovac pro PWMsetup_ccp1(CCP_PWM); // povoli PWM na pinu RC2setup_ccp2(CCP_PWM); // povolĂ PWM na pinu RC1setup_comparator(NC_NC_NC_NC);setup_vref(FALSE);l_motor_off(); // vypne levy motorr_motor_off(); // vypne pravy motorolsa_reset(); // reset logiky radkoveho senzoruolsa_setup(); // nastaveni segmentu radkoveho senzoru (offset a zisk)output_high(LED1); // zhasne LED1output_high(LED2); // zhasne LED2beep(500,200); // pipni pri startuprintf("OK! \r\n");delay_ms(500);printf("VYBRAT MOD... \r\n");while(true){diagnostika();}}