*1.作ったロボット [#q79c0cde] #ref(2017b/Member/ryok/Mission2/20171227_180018882.jpg,20%,後ろ) 後ろ。青い部分の下に丸いブロックがある。 #ref(2017b/Member/ryok/Mission2/20171227_180027716.jpg,15%,正面) 正面。センサは右側に。 #ref(2017b/Member/ryok/Mission2/20171227_180036039.jpg,20%,横) 横。ギアの部分で四角い枠を上げ下げする。 4輪でのS字カーブがなかなか上手くいかなかったので、小回りがより効きやすいように、4輪ではなく2輪にした。前方のタイヤ2つと後ろの丸いブロックの3点で床と接する。 センサはロボットの正面右側に付けた。(写真「正面」) また、四角い枠を上げ下げしてコップを運ぶ。(写真「横」「正面」) *2.書いたプログラム [#tc5ff7de] #define THRESHOLD 45 #define HIPOWER 7 //直線用のパワー #define LOWPOWER 2 //カーブのパワー #define set_power_H SetPower(OUT_AC,HIPOWER); //パワー強く #define set_power_L SetPower(OUT_AC,LOWPOWER); //パワー弱く #define go_forward_H set_power_H;OnFwd(OUT_AC); //速く直進 #define go_forward_L set_power_L;OnFwd(OUT_AC); //遅く直進 #define go_left set_power_H;OnFwd(OUT_C);Off(OUT_A); //トレース #define go_right set_power_H;OnFwd(OUT_A);Off(OUT_C); //トレース #define turn_left set_power_L;OnFwd(OUT_C);Off(OUT_A); //左折 #define left_senkai set_power_L;OnFwd(OUT_C);OnRev(OUT_A); //左旋回 #define turn_right set_power_L;OnFwd(OUT_A);Off(OUT_C); //右折 #define right_senkai set_power_L;OnFwd(OUT_A);OnRev(OUT_C); //右旋回 #define Break Off(OUT_AC);Wait(100); //小休憩 #define Cross_right set_power_L;OnFwd(OUT_C);Wait(50); //交差点を直進(ライン右端トレース時) #define Cross_left set_power_L;OnFwd(OUT_A);Wait(50); //交差点を直進(ライン左端トレース時) #define Step 1 //ラインの検知間隔 sub cross_go_forward_right() //交差点直進(ラインの右端をトレース) { int Online=0; // int Cross_count=0; // while(Cross_count < 1) { while(Online < 5) { if(SENSOR_2 < THRESHOLD-5) {right_senkai;PlayTone(523,1);Online++;} else if(SENSOR_2 < THRESHOLD-2){turn_right;Online=0;} else {if(SENSOR_2 < THRESHOLD+2){go_forward_H;} else if(SENSOR_2 < THRESHOLD+5){turn_left;} else {left_senkai;} Online=0; } Wait(Step); } Break; Cross_right; //交差点通過 Cross_count++; } } sub cross_turn_right_right() //交差点右折(ラインの右端をトレース) { int Online=0; // int Cross_count=0; // while(Cross_count < 1) { while(Online < 5) { if(SENSOR_2 < THRESHOLD-5) {right_senkai;PlayTone(523,1);Online++;} else if(SENSOR_2 < THRESHOLD-2){turn_right;Online=0;} else{if(SENSOR_2 < THRESHOLD+2){go_forward_H;} else if(SENSOR_2 < THRESHOLD+2){turn_left;} else{left_senkai;} Online=0; } Wait(Step); } Break; right_senkai;Wait(50);Break;go_forward_L;Wait(45); //交差点右折 Cross_count++; } } sub cross_turn_left_at_R() //Rで交差点左折 { int Online=0; // int Cross_count=0; // while(Cross_count < 1) { while(Online < 2) { if(SENSOR_2 < THRESHOLD-5) {right_senkai;PlayTone(523,1);Online++;} else if(SENSOR_2 < THRESHOLD-2){turn_right;Online=0;} else{if(SENSOR_2 < THRESHOLD+5){go_forward_H;} else if(SENSOR_2 < THRESHOLD+2){turn_left;} else{left_senkai;} Online=0; } Wait(Step); } Break; OnRev(OUT_AC);Wait(20);Off(OUT_AC);left_senkai;Wait(100); //左折 Cross_count++; } } sub cross_go_forward_left() //交差点直進(ラインの左端をトレース)(R~Q間のみ) { int Online=0; int Cross_count=0; while(Cross_count < 1) { while(Online < 5) { if(SENSOR_2 < THRESHOLD-5) {left_senkai;PlayTone(523,1);Online++;} else if(SENSOR_2 < THRESHOLD-2){turn_left;Online=0;} else {if(SENSOR_2 < THRESHOLD+2){go_forward_L;} else if(SENSOR_2 < THRESHOLD+5){turn_right;} else {right_senkai;} Online=0; } Wait(Step); } Break; Cross_left; //交差点通過 Cross_count++; } } sub cross_turn_left_at_Q() //Q左折(左折後センサはラインの右端へ) { int Online=0; int Cross_count=0; while(Cross_count < 1) { while(Online < 5) { if(SENSOR_2 < THRESHOLD-5) {left_senkai;PlayTone(523,1);Online++;} else if(SENSOR_2 < THRESHOLD-2){turn_left;Online=0;} else {if(SENSOR_2 < THRESHOLD+2){go_forward_L;} else if(SENSOR_2 < THRESHOLD+5){turn_right;} else {right_senkai;} Online=0; } Wait(Step); } Break; OnRev(OUT_AC);Wait(20);Off(OUT_AC);left_senkai;Wait(100); //交差点左折 Cross_count++; } } sub cross_turn_left_right() //交差点左折(ラインの右端をトレース)(F左折時のみ) { int Online=0; // int Cross_count=0; // while(Cross_count < 1) { while(Online < 5) { if(SENSOR_2 < THRESHOLD-5) {right_senkai;PlayTone(523,1);Online++;} else if(SENSOR_2 < THRESHOLD-2){turn_right;Online=0;} else{if(SENSOR_2 < THRESHOLD+5){go_forward_H;} else if(SENSOR_2 < THRESHOLD+2){turn_left;} else{left_senkai;} Online=0; } Wait(Step); } Break; OnRev(OUT_AC);Wait(20);left_senkai;Wait(70);Cross_count++; //左折 } } sub s_curve() //S字カーブ { ClearTimer(0); while(FastTimer(0)<1000) //10秒でS字区間通過 { if(SENSOR_2<THRESHOLD-5){right_senkai;} else if(SENSOR_2<THRESHOLD-2){turn_right;} else if(SENSOR_2<THRESHOLD+2){go_forward_H;} else if(SENSOR_2<THRESHOLD+5){turn_left;} else{left_senkai;} } } task main() { SetSensor(SENSOR_2,SENSOR_LIGHT); cross_go_forward_right(); //B通過 cross_turn_right_right(); //C右折 cross_go_forward_right(); //F通過 s_curve(); //S字カーブ cross_turn_right_right(); //E右折 cross_turn_left_at_R(); //R左折 cross_go_forward_left(); //P直進 cross_turn_left_at_Q(); //Q左折(左折後センサはラインの右端へ) cross_go_forward_right(); //S通過 cross_go_forward_right(); //S通過 cross_turn_left_right(); //F左折 cross_turn_right_right(); //C右折 int Online=0; int Cross_count=0; while(Cross_count < 1) { while(Online < 2) { if(SENSOR_2 < THRESHOLD-5) {right_senkai;PlayTone(523,1);Online++;} else if(SENSOR_2 < THRESHOLD-2){turn_right;Online=0;} else {if(SENSOR_2 < THRESHOLD+2){go_forward_H;} else if(SENSOR_2 < THRESHOLD+5){turn_left;} else {left_senkai;} Online=0; } Wait(Step); } Break; OnFwd(OUT_AC);Wait(60);Off(OUT_AC); //Dへ Cross_count++; } } *3.感想 [#s80e56a8] ロボットの構造上センサをロボットの正面右側に付けたので、ラインの右端はスムーズにトレースできたが、左端をトレースする部分ではスムーズにいかないことも多かった。 コースの構造上、右端トレースから左端トレースへ、左端から右端へとセンサの位置を変える必要があり、その部分に大変苦労した。うまくいくように、微調整を繰り返した。 S字カーブはロボットのタイヤを2輪にしたことで、スムーズに解決できた。 交差点の判定などに音をうまく使うことで、より効率的に進めることができたのではと感じた。