summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Kod/bilbana/yc4/main.m60
-rw-r--r--Kod/scripts/test_givare.m38
2 files changed, 66 insertions, 32 deletions
diff --git a/Kod/bilbana/yc4/main.m b/Kod/bilbana/yc4/main.m
index e2f223e..221caea 100644
--- a/Kod/bilbana/yc4/main.m
+++ b/Kod/bilbana/yc4/main.m
@@ -106,7 +106,6 @@ while 1
%% CHECK LAP AND CHECKPOINT (CAR 1)
if car1.running == true
-
%% CALC POSITION (CAR 1)
if car1.lap > 1
last_seg_times1 = car1.seg_times(car1.lap - 1, 1:9);
@@ -170,48 +169,45 @@ while 1
end
%{
- TODO 1 -> 2
-
- %% CHECK LAP AND CHECKPOINT (CAR 1)
- if car1.running == true
-
- %% CALC POSITION (CAR 1)
- if car1.lap ~= 0
- if car1.lap > 1
- last_seg_times1 = car1.seg_times(car1.lap - 1, 1:9);
- aprox_v = get_aprox_v(car1.segment, last_seg_times1);
- car1.position = get_position(aprox_v, car1.position, delta_t);
+ %% CHECK LAP AND CHECKPOINT (CAR 2)
+ if car2.running == true
+ %% CALC POSITION (CAR 2)
+ if car2.lap ~= 0
+ if car2.lap > 1
+ last_seg_times1 = car2.seg_times(car2.lap - 1, 1:9);
+ aprox_v = get_aprox_v(car2.segment, last_seg_times2); %TODO ??
+ car2.position = get_position(aprox_v, car2.position, delta_t);
end
end
- if car1.new_check_point == true
+ if car2.new_check_point == true
% beep;
- if car1.lap ~= 0
- car1.seg_times(car1.lap, car1.segment) = toc(car1.seg_tic);
+ if car2.lap ~= 0
+ car2.seg_times(car2.lap, car2.segment) = toc(car2.seg_tic);
end
- car1.segment = car1.segment + 1;
- car1.seg_tic = tic;
- car1.position = car1.seg_len(car1.segment);
+ car2.segment = car2.segment + 1;
+ car2.seg_tic = tic;
+ car2.position = car2.seg_len(car2.segment);
end
- if car1.new_lap == true
- if car1.lap == 0
+ if car2.new_lap == true
+ if car2.lap == 0
% dont save time for first lap
- car1.segment = 1;
- car1.lap = car1.lap + 1;
- car1.seg_tic = tic;
- car1.lap_tic = tic;
+ car2.segment = 1;
+ car2.lap = car2.lap + 1;
+ car2.seg_tic = tic;
+ car2.lap_tic = tic;
continue;
end
beep;
- car1.seg_times(car1.lap, car1.segment) = toc(car1.seg_tic);
- car1.seg_tic = tic;
- car1.lap_times(car1.lap) = toc(car1.lap_tic);
- car1.lap_tic = tic;
- car1.position = 0;
+ car2.seg_times(car2.lap, car2.segment) = toc(car2.seg_tic);
+ car2.seg_tic = tic;
+ car2.lap_times(car2.lap) = toc(car2.lap_tic);
+ car2.lap_tic = tic;
+ car2.position = 0;
- display_data = {display_data, put_text(100, 32, 'L', strjoin({num2str(car1.lap), get_time_as_string(round(car1.lap_times(car1.lap) * 1000))}, ' '))};
+ display_data = {display_data, put_text(100, 32, 'L', strjoin({num2str(car2.lap), get_time_as_string(round(car2.lap_times(car2.lap) * 1000))}, ' '))};
- car1.segment = 1;
- car1.lap = car1.lap + 1;
+ car2.segment = 1;
+ car2.lap = car2.lap + 1;
end
end
%}
diff --git a/Kod/scripts/test_givare.m b/Kod/scripts/test_givare.m
new file mode 100644
index 0000000..204d501
--- /dev/null
+++ b/Kod/scripts/test_givare.m
@@ -0,0 +1,38 @@
+disp('Startar bilbanan. Avsluta med q.')
+hf=figure('position',[0 0 eps eps],'menubar','none');
+
+initialize_counters(1)
+initialize_counters(2)
+
+start_race(1)
+start_race(2)
+
+config_IOs
+
+car1 = struct;
+car2 = struct;
+
+while 1
+ %% PRE-LOOP
+ if strcmp(get(hf,'currentcharacter'),'q')
+ close(hf)
+ break
+ end
+
+ figure(hf)
+ drawnow
+
+ %% READ
+ [car1.new_lap, car1.new_check_point, car1.time] = get_car_position(1);
+ [car2.new_lap, car2.new_check_point, car2.time] = get_car_position(2);
+
+ if car1.new_lap == true || car1.new_check_point == true || car2.new_lap == true || car2.new_check_point == true
+ beep;
+ end
+
+ pause(0.1)
+end
+
+%%
+terminate(1)
+terminate(2) \ No newline at end of file