summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorlonkaars <loek@pipeframe.xyz>2022-06-05 16:36:42 +0200
committerlonkaars <loek@pipeframe.xyz>2022-06-05 16:36:42 +0200
commit028bbb5d8ad414e9244c21467602648fba463b97 (patch)
tree5f8ae0142c5062eb860580d6a5a53fb921568d13
parentfa6af27248ec1fcbfdec433ea16154b7bdae045f (diff)
parentbc283424c699effcfa84816c609ca7f00ed5259a (diff)
Merge branch 'master' of https://github.com/HoodieJeansJordans/wall-e2
-rw-r--r--.vscode/settings.json4
-rw-r--r--robot/mode_maze.c141
-rw-r--r--robot/mode_maze.h4
3 files changed, 148 insertions, 1 deletions
diff --git a/.vscode/settings.json b/.vscode/settings.json
index 565c3cf..1d75503 100644
--- a/.vscode/settings.json
+++ b/.vscode/settings.json
@@ -6,5 +6,9 @@
"args": [ "-defterm", "-no-start", "-mingw64", "-shell", "sh", "-here" ],
"icon": "terminal-bash"
}
+ },
+ "files.associations": {
+ "limits": "c",
+ "orangutan_shim.h": "c"
}
}
diff --git a/robot/mode_maze.c b/robot/mode_maze.c
index 6ae62be..9570706 100644
--- a/robot/mode_maze.c
+++ b/robot/mode_maze.c
@@ -1,3 +1,142 @@
#include "mode_maze.h"
+#include "orangutan_shim.h"
+void full_rotation(){
+ set_motors(0,0);
+ delay_ms(500);
+ set_motors(60,-60);
+ delay_ms(540);
+ set_motors(0,0);
+ position = read_line(sensors,IR_EMITTERS_ON);
+ delay_ms(500);
+
-void w2_mode_maze() {}
+}
+
+void half_rotation_left(){
+ set_motors(0,0);
+ set_motors(50,50);
+ delay_ms(150);
+ set_motors(-30,30);
+ delay_ms(600);
+ set_motors(0,0);
+ position = read_line(sensors,IR_EMITTERS_ON);
+ delay_ms(500);
+
+}
+void half_rotation_right(){
+ set_motors(0,0);
+ set_motors(50,50);
+ delay_ms(150);
+ set_motors(30,-30);
+ delay_ms(600);
+ set_motors(0,0);
+ set_motors(50,50);
+ delay_ms(150);
+ position = read_line(sensors,IR_EMITTERS_ON);
+ delay_ms(500);
+}
+void crossway_detection(){
+ half_rotation_left();
+}
+void intersection_detection(){
+ half_rotation_left();
+}
+void w2_mode_maze() {
+ while(1)
+ {
+ // Get the position of the line. Note that we *must* provide
+ // the "sensors" argument to read_line() here, even though we
+ // are not interested in the individual sensor readings.
+ position = read_line(sensors,IR_EMITTERS_ON);
+
+ // The "proportional" term should be 0 when we are on the line.
+ int proportional = ((int)position) - 2000;
+
+ // Compute the derivative (change) and integral (sum) of the
+ // position.
+ int derivative = proportional - last_proportional;
+ integral += proportional;
+
+ // Remember the last position.
+ last_proportional = proportional;
+
+ // Compute the difference between the two motor power settings,
+ // m1 - m2. If this is a positive number the robot will turn
+ // to the right. If it is a negative number, the robot will
+ // turn to the left, and the magnitude of the number determines
+ // the sharpness of the turn.
+ int power_difference = proportional/20 + integral/10000 + derivative*3/2;
+
+ // Compute the actual motor settings. We never set either motor
+ // to a negative value.
+
+ const int max = 60;
+ if(power_difference > max)
+ power_difference = max;
+ if(power_difference < -max)
+ power_difference = -max;
+
+ if(sensors[0] < 100 && sensors[1] <100 && sensors[2] < 100 && sensors[3] < 100 && sensors[4] < 100){
+ // grid detectie
+ /*set_motors(0,0);
+ delay_ms(450);
+ set_motors(50,50);
+ delay_ms(180);
+ if ( sensors[2] >= 100 || sensors[3] >= 100 || sensors[1] >= 100 || sensors[0] >= 100 || sensors[4] >= 100)
+ {
+ set_motors(0,0);
+ delay_ms(15000);
+ set_motors(50,50);
+ delay_ms(180);
+ if (sensors[2] >= 100 || sensors[3] >= 100 || sensors[1] >= 100 || sensors[0] >= 100 || sensors[4] >= 100 )
+ {
+ set_motors(0,0);
+ delay_ms(1500);
+ set_motors(50,50);
+ delay_ms(180);
+ if (sensors[2] >= 100 || sensors[3] >= 100 || sensors[1] >= 100 || sensors[0] >= 100 || sensors[4] >= 100)
+ {
+ print("GRID!");
+ set_motors(0,0);
+ delay_ms(10000);
+
+ }
+ }
+
+ }
+ else if(sensors[0] < 100 && sensors[1] <100 && sensors[2] < 100 && sensors[3] < 100 && sensors[4] < 100){*/
+ full_rotation();
+ //}
+
+ }
+ else if(sensors[0] >= 500 && sensors[1] >= 250 && sensors[2] >= 500 && sensors[3] >= 250 &&sensors[4] >= 500){
+ crossway_detection();
+ }
+ //else if(sensors[0] >= 500 && sensors[2] < 50 &&sensors[4] >= 500){
+ //intersection_detection();
+ //}
+ else if (sensors[0] >= 500 && sensors[1] >= 200 && sensors[4] < 100){
+ half_rotation_left();
+ }
+ //else if(sensors[4] >= 500 && sensors[3] >= 200 && sensors[0] < 100){
+ //half_rotation_right();
+ //}
+ else{
+ if(power_difference < 0 && (sensors[2] > 100 || sensors[3] > 100 || sensors[1] > 100) )
+ set_motors(max+power_difference, max);
+ else if( power_difference > 0 && ( sensors[2] > 100 || sensors[3] > 100 || sensors[1] > 100) )
+ set_motors(max, max-power_difference);
+
+ }
+
+ }
+
+ // This part of the code is never reached. A robot should
+ // never reach the end of its program, or unpredictable behavior
+ // will result as random code starts getting executed. If you
+ // really want to stop all actions at some point, set your motors
+ // to 0,0 and run the following command to loop forever:
+ //
+ // while(1);
+}
+}
diff --git a/robot/mode_maze.h b/robot/mode_maze.h
index e7490b9..6d481c1 100644
--- a/robot/mode_maze.h
+++ b/robot/mode_maze.h
@@ -7,4 +7,8 @@
*
* finds route out of maze
*/
+unsigned int sensors[5]; // an array to hold sensor values
+unsigned int position;
+unsigned int last_proportional=0;
+long integral=0;
void w2_mode_maze();