Rev 229 | Blame | Last modification | View Log | Download
// **** Objeti cihly vlevo **** LLLL#define L_TOUCH 1 // Cara vlevo#define R_TOUCH 2 // Cata vpravo#define B_TOUCH 3 // Bothint8 n;int8 r1,r2,rr;int8 touch;enum okolo_cihly {pred_carou,na_care,po_care};okolo_cihly ridic; // V jakem jsme stavu objizdeni cihlyint8 vzdalenost;cihla:rr=20;disp(0x99);set_pwm1_duty(0); // zabrzdi levym kolem, prave vpredset_pwm2_duty(150);output_high(MOT_L);output_low(MOT_R);odocounter=get_timer1();while(true) // Na zacatku se vyhni cihle, zatoc co muzes{cas=CASMIN-5; // jeste vic nez hodne do levaset_pwm1_duty(0);set_pwm2_duty(200);output_high(MOT_L); // leve kolo reverzoutput_low(MOT_R); // prave kolo vpredif(get_timer1()>(odocounter+5)) // konec zatacky?{disp(0x66);break;}SetServoQ(cas);delay_ms(18);};//------ Objeti cihly v konstantni vzdalenosti ------touch=0;ridic=pred_carou;cas=CASAVR-CASMIN; // rovneoutput_low(MOT_L); // vpredoutput_low(MOT_R);while(true){if(!input(IRRX)) // hrozi celni srazka s cihlou v prubehu objizdeni{cas=CASMIN;}else{if((vzdalenost!=0)||!input(PROXIMITY)) // Udrzovani konstantni vzdalenosti od cihly{if(cas>(CASMIN+20)) cas-=20;}else{if(cas<(CASMAX-20)) cas+=20;};};// Elektronicky diferencialif(cas<CASAVR) {r1=cas-CASMIN; r2=CASAVR-CASMIN;}; // Normovani vystupni hodnoty radkoveho snimaceif(cas==CASAVR) {r1=cas-CASMIN; r2=cas-CASMIN;}; // pro rizeni rychlosti motoruif(cas>CASAVR) {r1=CASAVR-CASMIN; r2=CASMAX-cas;}; // Rozsah 1 az 92if (r1>(CASAVR-CASMIN-rr)) r1=(r1<<1)+rr-(CASAVR-CASMIN); // Neco jako nasobeniif (r2>(CASAVR-CASMIN-rr)) r2=(r2<<1)+rr-(CASAVR-CASMIN);set_pwm1_duty(r1); // Nastav rychlost motoruset_pwm2_duty(r2);SetServoQ(cas);i2c_start(); // Sonar Pingi2c_write(0xE0);i2c_write(0x0);i2c_write(0x52); // mereni v usi2c_stop();for(n=1;n<=90;n++) // 18ms testovani cary do dalsi korekce serva{set_adc_channel(LMAX);delay_us(100);if(read_adc()<THR) touch|=L_TOUCH;set_adc_channel(RMAX);delay_us(100);if(read_adc()<THR) touch|=R_TOUCH;};i2c_start(); // Odraz ze sonarui2c_write(0xE0);i2c_write(0x3);i2c_stop();i2c_start();i2c_write(0xE1);vzdalenost=i2c_read(0);i2c_stop();if(touch==L_TOUCH) disp(0xC0);if(touch==R_TOUCH) disp(0x03);if((touch==B_TOUCH)&&(ridic==pred_carou)) ridic=na_care;if((ridic==na_care)&&(touch==0)) break;if(ridic==na_care) touch=0;};disp(0xC3);set_pwm1_duty(20);set_pwm2_duty(200);output_high(MOT_L);output_low(MOT_R);delay_us(40);odocounter=get_timer1(); // Poznamenej aktualni stav odometriewhile (true) // Znovu se musime dotknout cary{for(n=1;n<=90;n++) // 18ms testovani cary do dalsi korekce serva{set_adc_channel(LMAX); // Levy UV sensordelay_us(100);if(read_adc()<THR) // Dotkli jsme se levym senzorem{disp(0xE0);cas=CASAVR-CASMIN; // nastavime, ze cara je rovnegoto cara;};set_adc_channel(RMAX); // Pravy UV sensordelay_us(100);if((get_timer1()>=(odocounter+2)) && (read_adc()<THR)) // Pravym senzorem nesmime caru prejet!{disp(0x07);cas=CASMAX; // kdyz prejedem, tak nastavime, ze cara je vpravogoto cara;};}SetServoQ(CASMIN-5); // max. max. doleva L}cara:output_low(MOT_L); // oba motory vpredoutput_low(MOT_R);/*set_pwm1_duty(0); // vypni motoryset_pwm2_duty(0);SetServo(CASAVR-CASMIN); // doprostredset_pwm1_duty(255); // max. vpredset_pwm2_duty(255);output_low(MOT_L);output_low(MOT_R);odocounter=get_timer1(); // Poznamenej aktualni stav odometriewhile(get_timer1()<(odocounter+2)) // Ujed kousek{set_adc_channel(LMAX); // Levy UV sensordelay_us(40);if(read_adc()<THR) {cas=CASMIN; break;}; // Prejeli jsme caru vlevoset_adc_channel(RMAX); // Pravy UV sensordelay_us(40);if(read_adc()<THR) {cas=CASMAX; break;}; // Prejeli jsme caru vpravo};*/