summaryrefslogtreecommitdiffstats
path: root/Kod/bilbana/yc4/choose_position.m
diff options
context:
space:
mode:
authorGustav Sörnäs <gusso230@student.liu.se>2019-11-12 13:41:18 +0100
committerGustav Sörnäs <gusso230@student.liu.se>2019-11-12 13:41:18 +0100
commite2172ce2d019b0e80b16d2fa9fa55436a20748a5 (patch)
tree840b161f2a591b50e335b3e157d02e87dc60b942 /Kod/bilbana/yc4/choose_position.m
parent984296b90a2ddcb8bbf913b9ac97d1be2045bfab (diff)
parent8dc7e738c5545d26ff0379e593a2e3980e6737bc (diff)
downloadtfyy51-e2172ce2d019b0e80b16d2fa9fa55436a20748a5.tar.gz
Merge remote-tracking branch 'origin/smart'
Diffstat (limited to 'Kod/bilbana/yc4/choose_position.m')
-rw-r--r--Kod/bilbana/yc4/choose_position.m41
1 files changed, 41 insertions, 0 deletions
diff --git a/Kod/bilbana/yc4/choose_position.m b/Kod/bilbana/yc4/choose_position.m
new file mode 100644
index 0000000..39be6e4
--- /dev/null
+++ b/Kod/bilbana/yc4/choose_position.m
@@ -0,0 +1,41 @@
+function [new_position, seg_plus] = choose_position(position,segment, track)
+%CHOOSE_POSITION Välj vad position ska vara
+% Kör endast vid ny indata. Kollar om indatan är rimlig eller om någon
+% givare missats. Sedan väljs position efter vilken givare det var som
+% passerades. seg_plus anger om och med hur mycket car.segment bör
+% justeras för att kompensera efter missad givare.
+track_len = [0 2.53 3.05 4.73 7.68 8.98 10.93 14.96 17.57;
+ 0 0 0 0 0 0 0 0 0];
+set_pos = [0 2.53 3.05 4.73 7.68 8.98 10.93 14.96 17.57;
+ 0 0 0 0 0 0 0 0 0];
+pos_c = position;
+%% Vilken givare ligger närmast pos_c?
+near = [];
+for i = 1:length(track_len)
+ diff = abs(track_len(track,i)-pos_c);
+ if i == 1
+ near = [i,diff];
+ else
+ if diff < near(2)
+ near = [i,diff];
+ end
+ end
+end
+disp(near);
+%% Beräkning av passerad givare
+if near(1) == segment
+ new_position = set_pos( track, segment);
+ seg_plus = 0;
+ disp('In right segment');
+else
+ if near(2) < 0.7 % Behöver bli smartare. Typ jämföra andra normal miss med denna miss
+ seg_plus = max(0, near(1) - segment)
+ new_position = set_pos( track, segment + seg_plus);
+ else
+ new_position = set_pos( track, segment); % ineff borde kombineras
+ seg_plus = 0;
+ disp('In right segment ich');
+ end
+end
+end
+