|
|
1 d0 c9 N0 V/ V$ b3 J( d( }- #include <Arduino.h>
: F4 O/ _" I9 {+ s* d2 i5 R2 w: ] - #include <MeAuriga.h>
, Y) r- N: O1 U# [4 y6 f - #include "MeLineFollowerArray.h"
' q( S3 H) w( a0 ?5 ]
- ] N. Y# w- C- MeEncoderOnBoard Encoder_1(SLOT1);
8 R- c$ T+ P5 a - MeEncoderOnBoard Encoder_2(SLOT2);
8 y" Q3 z! O( h/ ? - MeLightSensor lightsensor_1(12);
% r+ G* v4 \( E7 e" E - MeLightSensor lightsensor_2(11);
, P# @& _7 M( l. s' d, s5 h - MeBuzzer buzzer;( u4 H( [( D, K1 d) N
- MeLineFollowerArray linefollower(PORT_6);
* R' T Z- R+ E% q0 S7 ~
' i: t0 D- ?) m% D- #define Error1 12 k9 M+ ~$ p# D6 U" ^
- #define Error2 25 O) R4 w- w# f) l
- #define Error3 3
1 j6 R& x% j: Z% S; r4 [; `1 D - $ U' W1 D5 M) U
- #define Kp 15. z& v& ~) E: e4 E. Z' v3 b. f
- #define Ki 0.15
$ \4 q. R& R+ ~ - #define Kd 0.03
$ ~( u1 \8 C% p1 C5 e7 H
: \6 B8 q) C* z: v K& t: |- uint8_t sData;
: t# d6 z$ t; _8 d - uint8_t D1;. K& k& y: B! `0 |& G4 M0 g
- uint8_t D2;
8 f* w$ V! G3 q d - uint8_t D3;
) i3 O1 z5 s" u x - uint8_t D4;/ e1 J5 }7 E( z' d! u7 U7 x
- uint8_t D5;
+ b# W% m, R- C - uint8_t D6;
" M+ @. R; d: y, l4 {9 c* B - 3 U. Z- M& o4 x1 I
- float previous_error = 0;
- B$ y+ F i! j2 C) u( d& y - float integral = 0;
t$ `/ ] P6 b - float derivative = 0;1 A2 q/ s0 w4 N$ q/ m
- int Speed = 160;% e' H' ?; i# D1 S& c$ Z u
- float output;
( b7 `9 W/ D0 Y9 x% A
8 o8 h6 L+ D* f2 `# d( |- byte Left;6 B8 [9 {! J/ J. e2 P
, f& M' z9 R b# o$ }4 j8 }& @& }- void setup() : {5 h! t; j8 B) g1 }6 J/ {% J2 b
- {* U3 K0 u% y' x2 U& ]
- //Set PWM 8KHz
4 b+ S4 t( Q3 Q I' T5 n, e - TCCR1A = _BV(WGM10);
* p' W$ {, Z4 p+ S - TCCR1B = _BV(CS11) | _BV(WGM12);. E5 F- m5 R- J9 p7 y
- TCCR2A = _BV(WGM21) | _BV(WGM20);% Z: T2 ^, {* E7 K1 |0 a! Z
- TCCR2B = _BV(CS21);
# B: t- W1 W& X7 \ - Serial.begin(9600);
. R+ a* {) c" _& h& V1 f - buzzer.setpin(45);
- |' R/ s0 h, g) V# h2 A - }
s1 X1 y/ y |! n! h) u b
. R& a; C( M N7 x- Z2 T6 b0 E- void loop()
; ~8 c) ?% w+ I& O6 Q - {
4 a$ s8 K: m3 e/ u - while(!((lightsensor_1.read()) < (10)));
& ^! K' M5 Y% A, e+ | - buzzer.tone(1047, 500);
U1 E: X" I2 @! F0 l - delay(500);- T& C: x" k$ b: X4 u* k
- do- |$ M" p c1 M- E0 _+ B. q$ `
- {& H& M3 S/ D* T8 G4 x( s4 G6 y
- int Err = getErr();
3 N2 |* l. T) P4 ~ - if(D1 == 1); A! e+ M4 p. x
- {
" u2 n' s5 z/ e5 T5 T* N - Left = 1;
^& c! a" Y/ z. P$ ?1 [# r- o - }
5 |% L& [+ ^6 d/ w - if(D6 == 1)
9 _, T& t* v9 m7 ]; Z3 X( a - {
) }0 G8 P p: R - Left = 0;! K) y, m2 U( w# l9 M
- }" _9 F4 A# r" Q
- if(Err == 99)
j) c; {/ y. i# R9 Y4 { - {
" N* Z! h |! h. G9 j i - if(Left == 1)3 [% y' B/ x: y
- {
) d8 i2 f7 [) @+ ` - Speed -= 5;
m7 o. i' x" b" W8 w# k3 C - moto(0,Speed);& |, ]* q- r% d, O9 d6 g
- do
! A; p* a2 ?3 Z, _& x& { - {
( D' c( D" F) a - Err = getErr();
+ ]0 M& Z" O3 O# m( I7 f& y5 D - }while((D1+D6) == 0);
! m* \" b) v; W V - }
+ M, U! h4 @3 j& D - else3 f0 q# R, a; h: }" h: U
- {
# J+ q' f! u$ R2 Z, D - Speed -= 5;2 s! C! `8 i, q$ m) `
- moto(Speed,0);
* z: g: r/ K8 e! H, W% [4 S* u# M6 b - do; J, G% V# i& K2 H" J+ r1 a+ \
- {6 R" K/ E/ t& ]; z% O
- Err = getErr();/ u N1 y2 c3 o8 Z; l
- }while((D1+D6) == 0);$ W5 k' F0 c1 t: n$ ]- R
- }8 y. ?: h; ]8 G
- }8 S4 A, J2 l$ H5 D6 G& E
- else' d$ T p+ B) N$ }2 ~
- {# j: h! r2 ^8 M0 F& o8 H) S2 M
- if((Speed < 160) & (Err < 2)) Speed+=1;
& U' `+ h: K/ K* m# \, ~ - if((Speed > 100) & (Err > 2)) Speed-=2; / W0 ~" [) h6 {% \
- integral = integral + Err;
. d( e. m. h& m - derivative = Err - previous_error;
4 b5 J+ z. Y [3 |5 e3 E+ y - output = Kp*Err + Ki*integral + Kd*derivative;
" c: q; i& J" m - moto(int(Speed-output),int(Speed+output));
+ f- M3 S5 S8 n' o" N - previous_error = Err;6 |6 E/ t! ~! E S
- }
# H! h% C' m; z' u2 K - }while(!((lightsensor_2.read()) < (10)));- E6 s' q) b q. H1 f( b# ^* P0 T* h
- moto(0,0);3 v" D9 h+ {8 i( ]( v9 a7 d
- delay(500);
5 A7 p0 F1 y, u& o, o/ x - buzzer.tone(262, 500);, Y. @3 h, I/ c2 k
- }$ q4 O5 X4 d" J5 K5 v, H
- 6 w8 _( x/ E; a& Y
- int getErr()
, s) f& W s$ Y" Q; @5 d2 `$ a - { * X6 H1 t* m- X1 b! ?) s" N) O
- sData = linefollower.getValue();" _! z9 E/ r* w- u/ f
- D1 = ~(sData>>0)&1;
$ H- R" ?( V( Q: T9 d/ M/ U( R- i8 q - D2 = ~(sData>>1)&1;- m( l- Z! m Z4 X* D+ A# g0 Y
- D3 = ~(sData>>2)&1;1 d* I5 l& }1 k, e( d9 M
- D4 = ~(sData>>3)&1;" ?$ C- R) Q5 S) Q' `! ?& a- X0 B0 j
- D5 = ~(sData>>4)&1;5 s2 J9 G$ Z# n2 G& j
- D6 = ~(sData>>5)&1;
9 }$ c }% K3 ~1 E2 e - int downD = D1+D2+D3+D4+D5+D6;; U" ~% j- V, W" |5 E
- int upD = D1*(Error3)+D2*(Error2)+D3*(Error1)+D4*(-Error1)+D5*(-Error2)+D6*(-Error3);% V, ^: H: f6 H7 G# q
- if(downD == 0)
4 \, |: l3 v% h. Z- Y5 g - {# ` }7 M2 b" \7 u
- return 99;- w& | p9 @% }' |
- }
J- G; g& [7 U; L* H4 L - else
) ^* ~1 x4 s2 ~* A - {
. r$ r4 s2 _9 ^9 M0 m - return upD/downD;
4 o/ W8 o- t6 `9 Y* s - }
, \4 w: g- F+ Y7 } - }3 a+ [! h# n4 a, X
- 1 m' Q: N4 m# x' ]/ f4 t- A7 t
- void moto(int Speed_L,int Speed_R)
8 j' K: E- L7 j6 `: | - {
. p3 ~4 S8 t0 m - Encoder_2.setMotorPwm(Speed_L);
% e: o- d# @ |1 M7 p! f - Encoder_1.setMotorPwm(-Speed_R);$ m' @' k4 a, }/ P
- }
複製代碼 $ }9 E" p7 C0 w
MeLineFollowerArray.cpp
+ Y% N: T& B- Z0 @' z2 R- #include "MeLineFollowerArray.h"8 o X- b- H" ?" k# ^
- ; g m: E Z9 g' `+ Q
- #ifdef ME_PORT_DEFINED
3 [6 e- O! a" Q8 Z a$ w. P - MeLineFollowerArray::MeLineFollowerArray(void) : MePort(0)
" n; d0 n1 ^! z# O: h0 G/ C4 c - {
7 Z6 a$ W' `& `8 M - 4 X' l1 U' Y D4 ~ O& g+ J
- }
% Y3 ^7 N* |9 n4 m6 N - MeLineFollowerArray::MeLineFollowerArray(uint8_t port) : MePort(port). |7 g8 X9 j' c
- {
- u% k1 I, @" c - _DataPin = mePort[port].s2;
) a, U; Y. _$ V7 h - pinMode(_DataPin, OUTPUT);
* j6 \; w3 t: M" _ - digitalWrite(_DataPin, HIGH);
- {, B$ N0 i: [" U - }7 m+ z& D2 [ q8 X
- #else // ME_PORT_DEFINED
/ ~( _0 T# C' @& B# | - MeLineFollowerArray::MeLineFollowerArray(uint8_t pin)% _9 L" C7 P5 P
- {
+ o0 P' T+ k0 H4 ?$ o8 | - _DataPin = pin;
+ ~/ L( \# ?" y - pinMode(_DataPin, OUTPUT);
- ^+ L5 T7 C( W - digitalWrite(_DataPin, HIGH);
* Y$ B: S5 s* ]- w' j2 m. | - }7 j9 Y& e( d1 X" ^
- #endif // ME_PORT_DEFINED, J! w; d$ F2 b0 q3 D/ l
- 2 y) @( t" q- V# N$ m9 f. T' y
- ) h! h e3 H, v7 S% C1 \/ n
- void MeLineFollowerArray::setpin(uint8_t pin)
% L- z) N) Y' l; ^ - {- h6 q! I2 A2 K/ f7 ^) J
- _DataPin = pin;, k$ O4 R4 x$ h
- pinMode(_DataPin, OUTPUT);
* F" I) O9 C7 W4 J8 J$ t+ r - digitalWrite(_DataPin, HIGH);* g& y6 r; N" r5 P
3 ~ p7 E$ r- g2 W8 M- #ifdef ME_PORT_DEFINED1 i# o7 P7 m9 Q5 a
- s2 = pin;
- W4 |, b( E z }1 n - #endif2 T0 S( F6 z+ L' V
- }# n6 m# X/ G% Z k" {
- ' k4 P% J. ]! ?; Z+ r' k! y5 U2 {2 l. G
- uint8_t MeLineFollowerArray::getValue()1 S. {% s5 Z' h; N* d2 `
- {
+ P6 ?/ z4 G3 i6 F' w - uint32_t LOW_level_read_time;
5 Q4 [( U2 x9 {9 v: h! Z( f, A - uint32_t HIGH_level_read_time;
" a% P; M8 x. I5 D; s2 ] - uint32_t time_out_flag;7 ~3 E' L8 d1 y& u
- uint8_t Sensor_Data[3];9 y, c. D6 c( r, Q2 ~
- static uint8_t old_data = 0xff;* D$ U8 `# g- r& p; p6 j
1 t/ k( V1 g8 ~- pinMode(_DataPin, OUTPUT);
e4 d! h( z1 m8 ]; N5 o - digitalWrite(_DataPin, LOW);
# a4 T, f8 {3 i. K+ K! N9 s# W - delayMicroseconds(980);6 @) f7 B6 s6 M5 g* ^& G, n
- digitalWrite(_DataPin, HIGH);
7 J4 [: f7 v2 `4 C" h, `) V- Q
* P( D( W6 f2 \7 {- pinMode(_DataPin, INPUT_PULLUP);- `8 v- w7 W* F% d2 c% N; D$ Z
- delayMicroseconds(10);
$ ^/ N1 t, O6 C7 x3 a+ ] - 3 S2 O6 A9 h4 B% C$ G4 N0 w
- time_out_flag = millis();3 p& V# p2 t, I2 q! D: `' l! O
- while(digitalRead(_DataPin) == 1 && ((millis() - time_out_flag) < MeLineFollowerArray_Communication_Time_Out) );
/ j) ^, ]& p8 k5 |% V* Q
/ V, f0 }$ R" x$ Y- LOW_level_read_time = micros();
( B& Z. g; O! }6 E' S - if((millis() - time_out_flag) >= MeLineFollowerArray_Communication_Time_Out) //time out
" C1 ]0 m. ^- o, G6 q - {
1 q+ ], m9 [3 M' }2 |" W - return 0xff;
5 h8 V8 U" @) P/ C6 D. {1 r1 } - }
+ ~' W! `( U! k0 r3 W; ?" Y - : w" j. g/ C3 S) A! G2 W. Z
- while(digitalRead(_DataPin) == 0 && ((millis() - time_out_flag) < MeLineFollowerArray_Communication_Time_Out) );
, y) c8 F9 [4 f$ _9 O
9 T4 s1 J H; I) P8 Q+ B; K- HIGH_level_read_time = micros();
: t% n/ M7 X4 G8 L% |6 i: h" ?. s8 D - LOW_level_read_time = micros() - LOW_level_read_time; //read 100us LOW level
! P5 N: ?; ^/ e; p% b - 5 O: }/ e& a+ D
- if((millis() - time_out_flag) >= MeLineFollowerArray_Communication_Time_Out) //time out
" g v* `5 E$ \7 Q. F - {
( N+ u5 a6 B8 j( R) z9 D - return 0xff;
1 [. l& \; G, g5 w; S2 f - }( q" F* }4 H5 Z2 `9 w) d; Z- x" ^
- : E8 w0 X1 w' Z9 j3 @
- if( (LOW_level_read_time < 90) && (LOW_level_read_time > 110))4 x6 J( T+ i. \' |% r1 z& b. c9 b
- {
2 q2 h- o, K7 O6 e! E - return 0xff;
, L3 R6 X5 u3 g7 d8 r - }* \2 V2 X& Q, k4 R/ h2 |
- 8 [. q+ J. W6 V! l$ c& I! M
- while(digitalRead(_DataPin) == 1 && ((millis() - time_out_flag) < MeLineFollowerArray_Communication_Time_Out) );
z @, ^4 H" F% u* L - LOW_level_read_time = micros();
& r* f. ~) B# U5 B0 } - HIGH_level_read_time = micros() - HIGH_level_read_time; //read 50us HIGH level: V J: q' \ ]
- 4 P: B# p6 v. [, P9 m
- if((millis() - time_out_flag) >= MeLineFollowerArray_Communication_Time_Out) //time out: l# L) {% s+ f7 O
- {0 }& K. g! X% n5 y& N
- return 0xff;
8 ?0 S2 \$ k( S0 ] - }& o7 u7 y1 b8 F, d5 T1 e# M
- + R1 D, d* b5 M8 ?! Q8 b
- if( (HIGH_level_read_time < 5) && (HIGH_level_read_time > 55))9 t& D; {0 ]0 n- D1 O
- {
' h# e9 ~: c" T; B: t" E* Z# y% \ - return 0xff;
, @* c1 ] v; T* l: I - }/ a+ c& D$ E! Z' |4 O3 _
- 0 j1 [, p# V# a" j5 `, z# F% B
- for(uint8_t k=0; k<3; k++)8 Z; Z V A; ^
- {3 O) y6 H! f- W, S# k
- Sensor_Data[k] = 0x00;' C2 N/ `4 z% R5 E4 a
- 1 o6 k. l0 m6 G% Z( f& p: C
- for(uint8_t i=0;i<8;i++)
1 {' [" I4 R: v- c - {
$ ~& p" o$ }; G: V9 Y7 l @ - while(digitalRead(_DataPin) == 0 && ((millis() - time_out_flag) < MeLineFollowerArray_Communication_Time_Out) ); //read 50us LOW level" z/ W1 }1 v( O ?
- HIGH_level_read_time = micros();3 F+ v p1 ]- |/ _1 z2 K$ ^
- LOW_level_read_time = micros() - LOW_level_read_time;
; r0 H. l8 K w- G
. J: M! l9 Q" H: {: z- if( (LOW_level_read_time < 5) && (LOW_level_read_time > 55) )7 J8 @5 \, _" @! W7 y
- {! \4 R: B3 P! c4 u4 ~3 X
- return 0xff;
, y6 @* g! b, s" {* N, ^ - }: T1 Y! g# V! I5 u3 |$ P8 Y
" v4 k/ Q& n, g: N8 Z! Y0 S- while(digitalRead(_DataPin) == 1 && ((millis() - time_out_flag) < MeLineFollowerArray_Communication_Time_Out) );0 u% O" M( C" ?* S3 z, ~9 g
- LOW_level_read_time = micros();- w* k) T1 G, ~ Y/ c5 g+ R" [
- HIGH_level_read_time = micros() - HIGH_level_read_time; //read HIGH level
' o3 t0 m& I% s
( Y# O$ n5 [/ n/ q e( ~- if(HIGH_level_read_time > 50 && HIGH_level_read_time < 100) //bit 1
! v1 N: |& i- U - {. j5 T' ^9 L$ p' m
- Sensor_Data[k] |= (0x80 >> i);' o7 Y9 `/ _7 i: s* S% x) V7 F
- }
+ K1 H! E2 d7 M9 H - else if(HIGH_level_read_time >= 100)
" m; Y2 t! }- r: ] - {
+ b! N' n9 j7 t - return 0xff;# ~3 n6 t$ i, W2 V* J3 [
- }
8 k- b: g1 O9 y, m( p% I C n- L - % @ J5 o9 _! a& u+ C
- if((millis() - time_out_flag) >= MeLineFollowerArray_Communication_Time_Out)8 M7 Y; n* t) g7 G+ V
- {
! S! ?# g- H& T, d% l - return 0xff;
* a9 a5 R0 N2 n! \ - }
* q, Y" y; _" }4 A/ N - }
; |3 q% L+ m+ j - }7 ]" n7 W5 b% J: K) X# ? w
7 F3 ~& d( L) C$ C6 }- while(digitalRead(_DataPin) == 0 && ((millis() - time_out_flag) < MeLineFollowerArray_Communication_Time_Out) ); //read 50us LOW level
0 s+ w! x* C/ n! M. U* N( J - HIGH_level_read_time = micros();
3 f* @: \/ e) ]1 \+ @. P - LOW_level_read_time = micros() - LOW_level_read_time;1 C a0 v) x7 e, L0 H. y0 D
" W( ?$ e2 Y; H1 x- if( (LOW_level_read_time < 5) && (LOW_level_read_time > 55) )# L/ V7 Z9 M& w8 ]
- {; l3 C& [5 u1 H
- return 0xff;
0 M5 i1 I! a8 B' Q, h; G5 y; b$ z - }# L% F% Z. d. ~* B& Q- q$ f9 D
- 8 l5 N( W. P1 f
- pinMode(_DataPin, OUTPUT);
* V2 {- E+ k' T9 u9 |) P - digitalWrite(_DataPin, HIGH);
5 n! y* h1 d2 b+ T2 Y4 \
' t) F3 P6 V. j; C/ F) U; l5 L- if( (Sensor_Data[2] == (uint8_t)(Sensor_Data[1] - Sensor_Data[0])) && (Sensor_Data[1] == (uint8_t)(~(uint8_t)Sensor_Data[0])))- {6 M, {- k, ?, t, i; k( o
- {- a, W! |$ J1 b2 L9 Q3 ]6 W! A* G
- old_data = Sensor_Data[0];
6 c2 q1 F# O `% O f4 N/ ~# l - return Sensor_Data[0];
% q+ v, f! m9 {" p5 z/ ~6 v - }
( C( S. M/ S( B+ F. P) B* Z! x' ]) B - else; W; d. P6 K& \. ]9 }
- {6 E9 t. l6 r& z$ |8 J5 n
- return old_data;4 l3 c& Q! y6 a( l: K
- }2 ?/ i! B% i5 q, U) H2 E
- }
2 X" C. B6 @+ ^ v6 k9 o
複製代碼 % E, i/ W- X4 S' M3 G
MeLineFollowerArray.h
MeLineFollowerArray.h
(731 Bytes, 下載次數: 10, 售價: 100 個銅錢)
) f: B# p# Y* \0 X" _2 U
# k( s! |# ^) U! p) w9 A3 i |
|