diff options
61 files changed, 1043 insertions, 261 deletions
diff --git a/Dokument/Kartläggning-bilbana/Mätningar-bilbana.csv b/Dokument/Kartläggning-bilbana/Mätningar-bilbana.csv new file mode 100644 index 0000000..09f08e5 --- /dev/null +++ b/Dokument/Kartläggning-bilbana/Mätningar-bilbana.csv @@ -0,0 +1,80 @@ +Bana 1;Bitar;Segment;Subsegment;Längd;Svängighet;Lutning;Maxspänning;;;Bana 2;Bitar;Segment;Subsegment;Längd;Svängighet;Lutning;Maxspänning;;Bana 2;Segment;Längd;;; +;Start;1;1;300;0;;?;;;;Start;1;1;300;0;;?;;;1;2525;;; +;Hel;;2;350;;;;;;;Hel;;2;350;;;;;;2;525;;; +;Hel;;3;350;;;;;;;Hel;;3;350;;;;;;3;1865;;; +;Hel;;4;350;;;;;;;Hel;;4;350;;;;;;4;2680;;; +;Hel;;5;350;;;;;;;Hel;;5;350;;;;;;5;1240;;; +;Hel;;6;350;;;;;;;Hel;;6;350;;;;;;6;1810;;; +;Hel;;7;350;;;;;;;Hel;;7;350;;;;;;7;4030;;; +;Innan seg;;8;125;;;;;;;Innan seg;;8;125;;;;;;8;3085;;; +;Efter seg;2;1;225;;;;;;;Efter seg;2;1;225;;;;;;9;2190;;;19 950 +;Innan seg;;2;300;;;;;;;Innan seg;;2;300;;;;;;;;;; +;Efter seg;3;1;50;;;;;;;Efter seg;3;1;50;;;;;Bana 1;Segment;Längd;;; +;Inner;;2;200;225;;;;;;Ytter;;2;250;225;;;;;1;2525;;; +;Inner;;3;200;;;;;;;Ytter;;3;250;;;;;;2;525;;; +;Inner;;4;200;;;;;;;Ytter;;4;250;;;;;;3;1675;;;19 560 +;Inner;;5;200;;;;;;;Ytter;;5;250;;;;;;4;2920;;; +;Inner;;6;200;;;;;;;Ytter;;6;250;;;;;;5;1200;;; +;Hel;;7;350;;;;;;;Hel;;7;350;;;;;;6;2010;;; +;Ytter + Innan seg;;8;275;-45;;;;;;Inner + Innan seg;;8;215;-45;;;;;7;3830;;; +;Efter seg;4;1;325;;;;;;;Efter seg;4;1;325;;;;;;8;2885;;; +;Hel;;2;350;;;;;;;Hel;;2;350;;;;;;9;1990;;; +;Halv;;3;175;;;;;;;Halv;;3;175;;;;;;;;;; +;Halv;;4;175;;;;;;;Halv;;4;175;;;;;;;;;; +;Ytter;;5;250;-90;;;;;;Inner;;5;200;-90;;;;;;;;; +;Ytter;;6;250;;;;;;;Inner;;6;200;;;;;;;;;; +;Kort;;7;90;;;;;;;Kort;;7;90;;;;;;;;;; +;Bro;;8;235;;;;;;;Bro;;8;235;;;;;;;;;; +;Hel;;9;350;;;;;;;Hel;;9;350;;;;;;;;;; +;Ytter;;10;250;-135;;;;;;Inner;;10;200;-135;;;;;;;;; +;Ytter;;11;250;;;;;;;Inner;;11;200;;;;;;;;;; +;Ytter;;12;250;;;;;;;Inner;;12;200;;;;;;;;;; +;Inner;5;1;200;90;;;;;;Ytter;5;1;250;90;;;;;;;;; +;Inner;;2;200;;;;;;;Ytter;;2;250;;;;;;;;;; +;Ytter;;3;250;-90;;;;;;Inner;;3;200;-90;;;;;;;;; +;Ytter;;4;250;;;;;;;Inner;;4;200;;;;;;;;;; +;Inner;;5;400;45;;;;;;Ytter;;5;500;45;;;;;;;;; +;Ytter;6;1;250;-225;;;;;;Inner;6;1;200;-225;;;;;;;;; +;Ytter;;2;250;;;;;;;Inner;;2;200;;;;;;;;;; +;Ytter;;3;250;;;;;;;Inner;;3;200;;;;;;;;;; +;Ytter;;4;250;;;;;;;Inner;;4;200;;;;;;;;;; +;Ytter;;5;250;;;;;;;Inner;;5;200;;;;;;;;;; +;Hel;;6;350;;;;;;;Hel;;6;350;;;;;;;;;; +;Hel;;7;350;;;;;;;Hel;;7;350;;;;;;;;;; +;Inner;7;1;200;45;;;;;;Ytter;7;1;250;45;;;;;;;;; +;Kort;;2;90;;;;;;;Kort;;2;90;;;;;;;;;; +;Ytter;;3;250;-90;;;;;;Inner;;3;200;-90;;;;;;;;; +;Ytter;;4;250;;;;;;;Inner;;4;200;;;;;;;;;; +;Hel;;5;350;;;;;;;Hel;;5;350;;;;;;;;;; +;Inner;;6;200;45;;;;;;Ytter;;6;250;45;;;;;;;;; +;Bro;;7;235;;;;;;;Bro;;7;235;;;;;;;;;; +;Bro;;8;235;;;;;;;Bro;;8;235;;;;;;;;;; +;Ytter;;9;250;-45;;;;;;Inner;;9;200;-45;;;;;;;;; +;Hel;;10;350;;;;;;;Hel;;10;350;;;;;;;;;; +;Halv;;11;175;;;;;;;Halv;;11;175;;;;;;;;;; +;Inner;;12;200;135;;;;;;Ytter;;12;250;135;;;;;;;;; +;Inner;;13;200;;;;;;;Ytter;;13;250;;;;;;;;;; +;Inner;;14;200;;;;;;;Ytter;;14;250;;;;;;;;;; +;Halv;;15;175;;;;;;;Halv;;15;175;;;;;;;;;; +;Inner;;16;200;90;;;;;;Ytter;;16;250;90;;;;;;;;; +;Inner;;1;200;;;;;;;Ytter;;17;250;;;;;;;;;; +;Ytter;8;2;250;-45;;;;;;Inner;8;1;200;-45;;;;;;;;; +;Inner;;3;200;45;;;;;;Ytter;;2;250;45;;;;;;;;; +;Halv;;4;175;;;;;;;Halv;;3;175;;;;;;;;;; +;Inner;;5;200;90;;;;;;Ytter;;4;250;90;;;;;;;;; +;Inner;;6;200;;;;;;;Ytter;;5;250;;;;;;;;;; +;Bro;;7;235;;;;;;;Bro;;6;235;;;;;;;;;; +;Hel;;8;350;;;;;;;Hel;;7;350;;;;;;;;;; +;Inner;;9;200;90;;;;;;Ytter;;8;250;90;;;;;;;;; +;Inner;;10;200;;;;;;;Ytter;;9;250;;;;;;;;;; +;Hel;;11;350;;;;;;;Hel;;10;350;;;;;;;;;; +;Halv;;12;175;;;;;;;Halv;;11;175;;;;;;;;;; +;Hel;;13;350;;;;;;;Hel;;12;350;;;;;;;;;; +;Inner;9;1;200;90;;;;;;Ytter;9;1;250;90;;;;;;;;; +;Inner;;2;200;90;;;;;;Ytter;;2;250;90;;;;;;;;; +;Hel;;3;350;;;;;;;Hel;;3;350;;;;;;;;;; +;Hel;;4;350;;;;;;;Hel;;4;350;;;;;;;;;; +;Halv;;5;175;;;;;;;Halv;;5;175;;;;;;;;;; +;Inner;;6;200;90;;;;;;Ytter;;6;250;90;;;;;;;;; +;Inner;;7;200;;;;;;;Ytter;;7;250;;;;;;;;;; +;Målbit;;8;315;;;;;;;Målbit;;8;315;;;;;;;;;; diff --git a/Dokument/Teknisk Dokumentation/spÃ¥na pÃ¥ governor.txt b/Dokument/Teknisk Dokumentation/spÃ¥na pÃ¥ governor.txt new file mode 100644 index 0000000..e8cb78b --- /dev/null +++ b/Dokument/Teknisk Dokumentation/spÃ¥na pÃ¥ governor.txt @@ -0,0 +1,17 @@ +Funktionen ska utifrÃ¥n köregenskaper för bil, vald referenstid och, om gemensam mÃ¥lgÃ¥ng aktiverad, skillnad i bilarnas placering och se till att rätt gaspÃ¥drag skickas till banan. + +Vi utgÃ¥r ifrÃ¥n de redan skrivna bankartorna (bana1.mat och bana2.mat) och multiplicerar dess spänningsvärde med en car_constant. Programmet kommer sedan ihÃ¥g hur lÃ¥ng tid varje segment tagit för olika car_constant och gör en modell över hur hög den bör vara för att nÃ¥ en viss segmentstid. gov_set väljer sedan segmentstider utifrÃ¥n vald referenstid (och om gemensam mÃ¥lgÃ¥ng aktiverad car_diff). + +gov_mem +Sparar car_constant och tid frÃ¥n varje segment. + +gov_calc +gör en modell över hur lÃ¥ng tid ett segment tar relativt sin car_constant. + +gov_set +Väljer en tid för varje segment utifrÃ¥n referenstid, car_diff (om gemensam mÃ¥lgÃ¥ng aktiverad) + +Almänna komentarer: +Kan behövas nÃ¥n form av ingÃ¥ngshastighet till varje segment sÃ¥ att segmentstidens samband med car_constant tydligare kan ses. Beroende pÃ¥ hur snabbt bilen accelererar kan detta vara helt onödigt. +Hur ska kallibrerigsvarven hanteras? Antagligen behövs specialkod för första varvet sÃ¥ att bilen inte behöver köra jättelÃ¥ngsamt hela varvet. Kanse gÃ¥r det att gissa pÃ¥ en lite högre car_constant efter bara nÃ¥t varv. +Tänker att övre gräns ej behöver sättas om bankartorna är korrekt gjorda.
\ No newline at end of file diff --git a/Kod/bilbana/Graph/graphs_test.m b/Kod/bilbana/Graph/graphs_test.m index 3a2a2e5..955aeee 100644 --- a/Kod/bilbana/Graph/graphs_test.m +++ b/Kod/bilbana/Graph/graphs_test.m @@ -1,11 +1,19 @@ +%{ %% Data needed -car1.seg_times = [3.9,1.1,2.2,1.8,1.4,3.9,1.5,3.4,1.4; - 4.2,1.1,2.2,1.8,1.4,3.4,1.5,3.4,1.4; - 3.2,1.1,2.2,1.8,1.4,3.2,1.5,3.4,1.4; - 4.0,1.4,2.2,1.8,1.4,3.4,1.5,3.4,1.4; - 4.0,1.1,2.2,1.8,1.4,3.6,1.5,3.4,1.4; - 4.1,1.1,2.2,1.8,1.4,3.8,1.5,3.4,1.4]; +A = [3.9,1.1,2.2,1.8,1.4,3.9,1.5,3.4,1.4; + 4.2,1.1,2.2,1.8,1.4,3.4,1.5,3.4,1.4; + 3.2,1.1,2.2,1.8,1.4,3.2,1.5,3.4,1.4; + 4.0,1.1,2.2,1.8,1.4,3.6,1.5,3.4,1.4; + 4.1,1.1,2.2,1.8,1.4,3.8, 0, 0, 0]; +B = [3.9,1.1,2.2,1.8,1.4,3.9, 0, 0, 0]; +C = [3.9,1.1,2.2,1.8,1.4,3.9,1.5,3.1,1.0; + 4.1,1.1,2.2,1.8,1.4,3.4, 0, 0, 0]; +car1.seg_times = C; car1.lap_times = [14.1,13.8,14.15,13.9,14.1,14]; ref_lap_time = 14; %% Actual test -graphs(car1.lap_times,ref_lap_time,car1.seg_times,1)
\ No newline at end of file +graphs(car1.lap_times,ref_lap_time,car1.seg_times,5) +%} +position = 2.54; +segment = 2; +detect_missed(position,segment,1)
\ No newline at end of file diff --git a/Kod/bilbana/Graph/lap_time_graph.m b/Kod/bilbana/Graph/lap_time_graph.m index 8d54c6a..c21a0c5 100644 --- a/Kod/bilbana/Graph/lap_time_graph.m +++ b/Kod/bilbana/Graph/lap_time_graph.m @@ -40,13 +40,13 @@ hold off %% Standardavvkielse sigma = std(lap_times); sigma = round(sigma, 2); -sig_str = string(sigma); +sig_str = num2str(sigma); %% Text xlabel('Varv'); ylabel('Tid [s]'); -Tit = join(['Varvtider bana',string(track)]); +Tit = ['Varvtider bana ' num2str(track)]; title(Tit); -txt = join(['Standardavvikelse:',sig_str, 's/varv']); +txt = ['Standardavvikelse: ' sig_str ' s/varv']; annotation('textbox',[.1 0.5 .5 .05],'String',txt,'EdgeColor','none') end diff --git a/Kod/bilbana/Graph/segment_time_graph.m b/Kod/bilbana/Graph/segment_time_graph.m index 602938b..c32281a 100644 --- a/Kod/bilbana/Graph/segment_time_graph.m +++ b/Kod/bilbana/Graph/segment_time_graph.m @@ -1,15 +1,40 @@ -function [] = segment_time_graph(seg_time, track) -%SEGMENT_TIME_GRAPH Snittid för varje segment. -seg_time_size = size(seg_time); -avr_seg_time = mean(seg_time(1:(seg_time_size(1) - 1), 1:(seg_time_size(2)))); -subplot(20, 1, 13:20); +function [] = segment_time_graph(seg_times, track) +%SEGMENT_TIME_GRAPH Stapeldiagram med snittid för varje segment. + %{ + Utgår ifrån en r*k matris (seg_times). I den finns segmenttider lagrade + enligt rad ~ varv och kollonn ~ segment. Funktionen summerar alla + kollonner och delar summan med antalet kolloner som inte har värdet 0. + Sedan ritas ett stapeldiagram där varje stapel motsvarar en kollon i + den nyligen beräknade 1*k matrisen. + %} +seg_time_size = size(seg_times); +divide_by_n = ones(1,seg_time_size(2)); +%% Summera seg_time om seg_time ~= 0 +for r = 1:seg_time_size(1) + if r == 1 + avr_seg_time(1,1:seg_time_size(2)) = seg_times(1,1:seg_time_size(2)); + else + for c = 1:seg_time_size(2) + x = seg_times(r,c); + if x ~= 0 + avr_seg_time(c) = avr_seg_time(c) + seg_times(r,c); + divide_by_n(c) = divide_by_n(c) + 1; + end + end + end +end +%% Ta medel av summan +for c =1:seg_time_size(2) + avr_seg_time(c) = avr_seg_time(c)/divide_by_n(c); +end +%% Rita +subplot(20, 1, 13:20); Plot = bar(avr_seg_time); -%Plot.Marker = 'o'; Plot.FaceColor = 'k'; xlabel('Segment'); ylabel('Tid [s]'); -tit = join(['Medeltid/segment bana',string(track)]); +tit = ['Medeltid/segment bana ' num2str(track)]; title(tit); end diff --git a/Kod/bilbana/files/Bana1.mat b/Kod/bilbana/files/Bana1.mat Binary files differnew file mode 100644 index 0000000..d83861f --- /dev/null +++ b/Kod/bilbana/files/Bana1.mat diff --git a/Kod/bilbana/files/Bana1.txt b/Kod/bilbana/files/Bana1.txt new file mode 100644 index 0000000..120c696 --- /dev/null +++ b/Kod/bilbana/files/Bana1.txt @@ -0,0 +1,81 @@ +total segment sub_segment v len +0 1 1 35 300 +30 1 2 40 350 +65 1 3 40 350 +100 1 4 50 350 +135 1 5 50 350 +170 1 6 40 350 +205 1 7 35 350 +240 1 8 30 125 +253 2 1 25 225 +275 2 2 25 300 +305 3 1 30 50 +310 3 2 30 200 +330 3 3 30 200 +350 3 4 30 200 +370 3 5 30 200 +390 3 6 30 200 +410 3 7 30 350 +445 3 8 30 275 +473 4 1 30 325 +505 4 2 30 350 +540 4 3 30 175 +558 4 4 30 175 +575 4 5 30 250 +600 4 6 30 250 +625 4 7 30 90 +634 4 8 30 235 +658 4 9 30 350 +693 4 10 30 250 +718 4 11 30 250 +743 4 12 30 250 +768 5 1 50 200 +788 5 2 50 200 +808 5 3 50 250 +833 5 4 50 250 +858 5 5 50 400 +898 6 1 50 250 +923 6 2 50 250 +948 6 3 50 250 +973 6 4 50 250 +998 6 5 50 250 +1023 6 6 50 350 +1058 6 7 50 350 +1093 7 1 40 200 +1113 7 2 40 90 +1122 7 3 40 250 +1147 7 4 40 250 +1172 7 5 40 350 +1207 7 6 40 200 +1227 7 7 40 235 +1250 7 8 40 235 +1274 7 9 40 250 +1299 7 10 40 350 +1334 7 11 50 175 +1351 7 12 50 200 +1371 7 13 50 200 +1391 7 14 50 200 +1411 7 15 50 175 +1429 7 16 50 200 +1449 7 17 50 200 +1469 8 1 50 250 +1494 8 2 60 200 +1514 8 3 60 175 +1531 8 4 60 200 +1551 8 5 50 200 +1571 8 6 50 235 +1595 8 7 50 350 +1630 8 8 50 200 +1650 8 9 50 200 +1670 8 10 50 350 +1705 8 11 50 175 +1722 8 12 50 350 +1757 9 1 35 200 +1777 9 2 35 200 +1797 9 3 35 350 +1832 9 4 35 350 +1867 9 5 35 175 +1885 9 6 35 200 +1905 9 7 35 200 +1925 9 8 35 315 +1960 9 9 35
\ No newline at end of file diff --git a/Kod/bilbana/files/Bana2.mat b/Kod/bilbana/files/Bana2.mat Binary files differnew file mode 100644 index 0000000..622fc18 --- /dev/null +++ b/Kod/bilbana/files/Bana2.mat diff --git a/Kod/bilbana/files/Bana2.txt b/Kod/bilbana/files/Bana2.txt new file mode 100644 index 0000000..bb89c52 --- /dev/null +++ b/Kod/bilbana/files/Bana2.txt @@ -0,0 +1,81 @@ +total segment sub_segment v len +0 1 1 35 300 +30 1 2 40 350 +65 1 3 40 350 +100 1 4 50 350 +135 1 5 50 350 +170 1 6 40 350 +205 1 7 35 350 +240 1 8 30 125 +253 2 1 25 225 +275 2 2 25 300 +305 3 1 30 50 +310 3 2 30 200 +335 3 3 30 200 +360 3 4 30 200 +385 3 5 30 200 +410 3 6 30 200 +435 3 7 30 350 +470 3 8 30 275 +492 4 1 30 325 +524 4 2 30 350 +559 4 3 30 175 +578 4 4 30 175 +594 4 5 30 250 +614 4 6 30 250 +634 4 7 30 90 +643 4 8 30 235 +667 4 9 30 350 +702 4 10 30 250 +722 4 11 30 250 +742 4 12 30 250 +762 5 1 50 200 +787 5 2 50 200 +812 5 3 50 250 +832 5 4 50 250 +852 5 5 50 400 +902 6 1 50 250 +922 6 2 50 250 +942 6 3 50 250 +962 6 4 50 250 +982 6 5 50 250 +1002 6 6 50 350 +1037 6 7 50 350 +1072 7 1 40 200 +1097 7 2 40 90 +1101 7 3 40 250 +1126 7 4 40 250 +1146 7 5 40 350 +1181 7 6 40 200 +1206 7 7 40 235 +1229 7 8 40 235 +1253 7 9 40 250 +1273 7 10 40 350 +1308 7 11 50 175 +1325 7 12 50 200 +1350 7 13 50 200 +1375 7 14 50 200 +1400 7 15 50 175 +1418 7 16 50 200 +1443 7 17 50 200 +1468 8 1 50 250 +1488 8 2 60 200 +1513 8 3 60 175 +1530 8 4 60 200 +1556 8 5 50 200 +1580 8 6 50 235 +1604 8 7 50 350 +1639 8 8 50 200 +1664 8 9 50 200 +1689 8 10 50 350 +1724 8 11 50 175 +1741 8 12 50 350 +1776 9 1 35 200 +1801 9 2 35 200 +1826 9 3 35 350 +1861 9 4 35 350 +1896 9 5 35 175 +1916 9 6 35 200 +1939 9 7 35 200 +1964 9 8 35 315 +1995 9 9 35
\ No newline at end of file diff --git a/Kod/bilbana/files/file_test.m b/Kod/bilbana/files/file_test.m new file mode 100644 index 0000000..1370e7d --- /dev/null +++ b/Kod/bilbana/files/file_test.m @@ -0,0 +1,3 @@ +Bana1 +car_position = 9.74; +get_new_v(car_position, Bana1)
\ No newline at end of file diff --git a/Kod/bilbana/yc4/choose_position.m b/Kod/bilbana/yc4/choose_position.m new file mode 100644 index 0000000..d6db2ca --- /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 2.53 3.05 4.92 7.60 8.84 10.65 14.68 17.76]; +set_pos = [0 2.53 3.05 4.73 7.68 8.98 10.93 14.96 17.57; + 0 2.53 3.05 4.92 7.60 8.84 10.65 14.68 17.76]; +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 + diff --git a/Kod/bilbana/yc4/detect_missed.m b/Kod/bilbana/yc4/detect_missed.m new file mode 100644 index 0000000..fb80d1c --- /dev/null +++ b/Kod/bilbana/yc4/detect_missed.m @@ -0,0 +1,9 @@ +function [out] = detect_missed( position, segment, track) +%DETECT_MISSED Retunerar true om position ligger utanför nuvarande segment +% +track_len = [2.53 3.05 4.73 7.68 8.98 10.93 14.96 17.57 19.60; + 2.53 3.05 4.92 7.60 8.84 10.65 14.68 17.76 19.95]; +a = track_len(track, segment); +out = a <= position; +end + diff --git a/Kod/bilbana/yc4/display/clear_display.m b/Kod/bilbana/yc4/display/clear_display.m index 32fdac1..45f1680 100644 --- a/Kod/bilbana/yc4/display/clear_display.m +++ b/Kod/bilbana/yc4/display/clear_display.m @@ -1,3 +1,3 @@ function pkg = clear_display() - pkg = get_package('DL', []) +pkg = get_package('DL', []); end diff --git a/Kod/bilbana/yc4/display/continue_line.m b/Kod/bilbana/yc4/display/continue_line.m index 9734201..99b4074 100644 --- a/Kod/bilbana/yc4/display/continue_line.m +++ b/Kod/bilbana/yc4/display/continue_line.m @@ -1,5 +1,4 @@ function pkg = continue_line(x2, y2) - arg = [get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('GW', arg) +arg = [get_bytes(x2), get_bytes(y2)]; +pkg = get_package('GW', arg) end diff --git a/Kod/bilbana/yc4/display/define_flashing_area.m b/Kod/bilbana/yc4/display/define_flashing_area.m index 11d6cf3..3e581ea 100644 --- a/Kod/bilbana/yc4/display/define_flashing_area.m +++ b/Kod/bilbana/yc4/display/define_flashing_area.m @@ -1,5 +1,4 @@ function pkg = define_flashing_area(x1, y1, x2, y2) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('QI', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +pkg = get_package('QI', arg); end diff --git a/Kod/bilbana/yc4/display/define_flashing_area_with_pattern.m b/Kod/bilbana/yc4/display/define_flashing_area_with_pattern.m index eb13e90..c5c190f 100644 --- a/Kod/bilbana/yc4/display/define_flashing_area_with_pattern.m +++ b/Kod/bilbana/yc4/display/define_flashing_area_with_pattern.m @@ -1,5 +1,4 @@ function pkg = define_flashing_area_with_pattern(x1, y1, x2, y2, n1) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2), n1]; - - pkg = get_package('QM', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2), n1]; +pkg = get_package('QM', arg); end diff --git a/Kod/bilbana/yc4/display/define_touch_key.m b/Kod/bilbana/yc4/display/define_touch_key.m index 14ee5ee..69ed130 100644 --- a/Kod/bilbana/yc4/display/define_touch_key.m +++ b/Kod/bilbana/yc4/display/define_touch_key.m @@ -1,7 +1,7 @@ function pkg = define_touch_key(x1, y1, x2, y2, down_code, up_code, just, text) - arg_location = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - arg_text = double(strjoin({just; text}, '')); - arg_null = 0; +arg_location = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +arg_text = double(strjoin({just; text}, '')); +arg_null = 0; - pkg = get_package('AT', [arg_location, down_code, up_code, arg_text, arg_null]); +pkg = get_package('AT', [arg_location, down_code, up_code, arg_text, arg_null]); end diff --git a/Kod/bilbana/yc4/display/define_touch_switch.m b/Kod/bilbana/yc4/display/define_touch_switch.m index 47d3cd9..e45f512 100644 --- a/Kod/bilbana/yc4/display/define_touch_switch.m +++ b/Kod/bilbana/yc4/display/define_touch_switch.m @@ -1,7 +1,7 @@ -function pkg = define_touch_key(x1, y1, x2, y2, down_code, up_code, just, text) - arg_location = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - arg_text = double(strjoin({just; text}, '')); - arg_null = 0; +function pkg = define_touch_switch(x1, y1, x2, y2, down_code, up_code, just, text) +arg_location = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +arg_text = double(strjoin({just; text}, '')); +arg_null = 0; - pkg = get_package('AK', [arg_location, down_code, up_code, arg_text, arg_null]); +pkg = get_package('AK', [arg_location, down_code, up_code, arg_text, arg_null]); end diff --git a/Kod/bilbana/yc4/display/delete_area.m b/Kod/bilbana/yc4/display/delete_area.m index 44953b7..576638e 100644 --- a/Kod/bilbana/yc4/display/delete_area.m +++ b/Kod/bilbana/yc4/display/delete_area.m @@ -1,5 +1,4 @@ function pkg = delete_area(x1, y1, x2, y2) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('RL', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +pkg = get_package('RL', arg); end diff --git a/Kod/bilbana/yc4/display/draw_box.m b/Kod/bilbana/yc4/display/draw_box.m index b9eb5be..7ac4b70 100644 --- a/Kod/bilbana/yc4/display/draw_box.m +++ b/Kod/bilbana/yc4/display/draw_box.m @@ -1,5 +1,4 @@ function pkg = draw_box(x1, y1, x2, y2, n1) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2), n1]; - - pkg = get_package('RO', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2), n1]; +pkg = get_package('RO', arg); end diff --git a/Kod/bilbana/yc4/display/draw_frame.m b/Kod/bilbana/yc4/display/draw_frame.m index 7b97adb..1a6ce3b 100644 --- a/Kod/bilbana/yc4/display/draw_frame.m +++ b/Kod/bilbana/yc4/display/draw_frame.m @@ -1,5 +1,4 @@ function pkg = draw_frame(x1, y1, x2, y2, n1) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('RR', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +pkg = get_package('RR', arg); end diff --git a/Kod/bilbana/yc4/display/draw_frame_box.m b/Kod/bilbana/yc4/display/draw_frame_box.m index 9b57c7c..f2a247e 100644 --- a/Kod/bilbana/yc4/display/draw_frame_box.m +++ b/Kod/bilbana/yc4/display/draw_frame_box.m @@ -1,5 +1,4 @@ function pkg = draw_frame_box(x1, y1, x2, y2, n1) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2), n1]; - - pkg = get_package('RT', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2), n1]; +pkg = get_package('RT', arg); end diff --git a/Kod/bilbana/yc4/display/draw_point.m b/Kod/bilbana/yc4/display/draw_point.m index b81d8cb..34ba683 100644 --- a/Kod/bilbana/yc4/display/draw_point.m +++ b/Kod/bilbana/yc4/display/draw_point.m @@ -1,5 +1,4 @@ function pkg = draw_point(x1, y1) - arg = [get_bytes(x1), get_bytes(y2)]; - - pkg = get_package('GP', arg); +arg = [get_bytes(x1), get_bytes(y1)]; +pkg = get_package('GP', arg); end diff --git a/Kod/bilbana/yc4/display/draw_rectangle.m b/Kod/bilbana/yc4/display/draw_rectangle.m index 9e92cad..3edff7c 100644 --- a/Kod/bilbana/yc4/display/draw_rectangle.m +++ b/Kod/bilbana/yc4/display/draw_rectangle.m @@ -1,5 +1,4 @@ function pkg = draw_rectangle(x1, y1, x2, y2) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('GR', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +pkg = get_package('GR', arg); end diff --git a/Kod/bilbana/yc4/display/draw_single_line.m b/Kod/bilbana/yc4/display/draw_single_line.m index ca13293..c1da8ab 100644 --- a/Kod/bilbana/yc4/display/draw_single_line.m +++ b/Kod/bilbana/yc4/display/draw_single_line.m @@ -1,4 +1,4 @@ function pkg = draw_single_line(x1, y1, x2, y2) - arg = [mod(x1, 255), fix(x1 / 255), y1, 0, mod(x2, 255), fix(x2 / 255), y2, 0]; - pkg = get_package('GD', arg); +arg = [mod(x1, 255), fix(x1 / 255), y1, 0, mod(x2, 255), fix(x2 / 255), y2, 0]; +pkg = get_package('GD', arg); end diff --git a/Kod/bilbana/yc4/display/fill_area.m b/Kod/bilbana/yc4/display/fill_area.m index 4d64463..ae53551 100644 --- a/Kod/bilbana/yc4/display/fill_area.m +++ b/Kod/bilbana/yc4/display/fill_area.m @@ -1,5 +1,4 @@ function pkg = fill_area(x1, y1, x2, y2) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('RS', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +pkg = get_package('RS', arg); end diff --git a/Kod/bilbana/yc4/display/fill_area_with_pattern.m b/Kod/bilbana/yc4/display/fill_area_with_pattern.m index 4815f5b..a461444 100644 --- a/Kod/bilbana/yc4/display/fill_area_with_pattern.m +++ b/Kod/bilbana/yc4/display/fill_area_with_pattern.m @@ -1,5 +1,4 @@ function pkg = fill_area_with_pattern(x1, y1, x2, y2, n1) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2), n1]; - - pkg = get_package('RM', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2), n1]; +pkg = get_package('RM', arg); end diff --git a/Kod/bilbana/yc4/display/fill_display.m b/Kod/bilbana/yc4/display/fill_display.m index e5fc1d2..55699b2 100644 --- a/Kod/bilbana/yc4/display/fill_display.m +++ b/Kod/bilbana/yc4/display/fill_display.m @@ -1,3 +1,3 @@ function pkg = fill_display() - pkg = get_package('DS', []); +pkg = get_package('DS', []); end diff --git a/Kod/bilbana/yc4/display/get_bytes.m b/Kod/bilbana/yc4/display/get_bytes.m index 76efc9c..9482008 100644 --- a/Kod/bilbana/yc4/display/get_bytes.m +++ b/Kod/bilbana/yc4/display/get_bytes.m @@ -1,3 +1,3 @@ -function bytes = get_bytes(num): - bytes = [mod(num, 256), num ./ 256]; +function bytes = get_bytes(num) +bytes = [mod(num, 256), fix(num / 256)]; end diff --git a/Kod/bilbana/yc4/display/get_num.m b/Kod/bilbana/yc4/display/get_num.m new file mode 100644 index 0000000..8ff62f7 --- /dev/null +++ b/Kod/bilbana/yc4/display/get_num.m @@ -0,0 +1,3 @@ +function num = get_num(bytes) +num = bytes(1) + bytes(2) * 256; +end diff --git a/Kod/bilbana/yc4/display/get_package.m b/Kod/bilbana/yc4/display/get_package.m index 7c3a01e..d2e8a26 100644 --- a/Kod/bilbana/yc4/display/get_package.m +++ b/Kod/bilbana/yc4/display/get_package.m @@ -1,10 +1,4 @@ -function [pkg] = get_package(code, args) - DC1 = 17; - ESC = 27; - - data = [ESC, double(code), args]; - len = length(data); - initStr = [DC1, len, data]; - bcc = mod(sum(initStr), 256); - pkg = [initStr, bcc]; +function pkg = get_package(code, args) +ESC = 27; +pkg = [ESC, double(code), args]; end diff --git a/Kod/bilbana/yc4/display/get_response.m b/Kod/bilbana/yc4/display/get_response.m new file mode 100644 index 0000000..0c77a00 --- /dev/null +++ b/Kod/bilbana/yc4/display/get_response.m @@ -0,0 +1,56 @@ +function [ack, start_code, responses] = get_response(display_data) +% GET RESPONSE +% In-depth explanation +% [flag, display_data] = matlabclient(2) + +ack = false; +start_code = ''; +responses = []; + +if isempty(display_data) + return +end +bcc = display_data(length(display_data)); + + +pointer = 1; + +if display_data(pointer) == 6 + ack = true; +else + return +end + +if pointer > length(display_data) + return +end + +pointer = pointer + 1; +if display_data(1) == 17 + start_code = 'DC1'; +elseif display_data(1) == 18 + start_code = 'DC2'; +end + +pointer = pointer + 1; +% total length + +data = struct; +while pointer < length(display_data) - 1 % last value is bcc + pointer = pointer + 1; + if display_data(pointer) ~= 27 + % TODO: no ESC? + end + pointer = pointer + 1; + data.id = char(display_data(pointer)); + + pointer = pointer + 1; + data.length = display_data(pointer); + if data.id == 'A' + pointer = pointer + 1; + data.data = display_data(pointer); + else + pointer = pointer + data.length; + end + responses = [responses, data]; +end diff --git a/Kod/bilbana/yc4/display/get_smallpackage.m b/Kod/bilbana/yc4/display/get_smallpackage.m new file mode 100644 index 0000000..be386bc --- /dev/null +++ b/Kod/bilbana/yc4/display/get_smallpackage.m @@ -0,0 +1,8 @@ +function pkg = get_smallpackage(data) +DC1 = 17; + +len = length(data); +initStr = [DC1, len, data]; +bcc = mod(sum(initStr), 256); +pkg = [initStr, bcc]; +end diff --git a/Kod/bilbana/yc4/display/invert_area.m b/Kod/bilbana/yc4/display/invert_area.m index 39db3c2..081d65c 100644 --- a/Kod/bilbana/yc4/display/invert_area.m +++ b/Kod/bilbana/yc4/display/invert_area.m @@ -1,5 +1,4 @@ function pkg = invert_area(x1, y1, x2, y2) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('RI', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +pkg = get_package('RI', arg); end diff --git a/Kod/bilbana/yc4/display/invert_display.m b/Kod/bilbana/yc4/display/invert_display.m index ab2ddad..c661167 100644 --- a/Kod/bilbana/yc4/display/invert_display.m +++ b/Kod/bilbana/yc4/display/invert_display.m @@ -1,3 +1,3 @@ function pkg = invert_display() - pkg = get_package('DI', []); +pkg = get_package('DI', []); end diff --git a/Kod/bilbana/yc4/display/put_text.m b/Kod/bilbana/yc4/display/put_text.m index 22871e3..8455c83 100644 --- a/Kod/bilbana/yc4/display/put_text.m +++ b/Kod/bilbana/yc4/display/put_text.m @@ -1,9 +1,7 @@ function [pkg] = put_text(x, y, justification, text) - code = strjoin({'Z', justification}, ''); +arg1 = [mod(x, 256), x ./ 256, mod(y, 256), y ./ 256]; +arg2 = text; +arg3 = 0; - arg1 = [mod(x, 256), x ./ 256, mod(y, 256), y ./ 256]; - arg2 = text; - arg3 = 0; - - pkg = get_package(code, [arg1 double(arg2) arg3]); +pkg = get_package(strjoin({'Z', justification}, ''), [arg1 double(arg2) arg3]); end diff --git a/Kod/bilbana/yc4/display/remove_flashing_area.m b/Kod/bilbana/yc4/display/remove_flashing_area.m index 701402b..4efa5be 100644 --- a/Kod/bilbana/yc4/display/remove_flashing_area.m +++ b/Kod/bilbana/yc4/display/remove_flashing_area.m @@ -1,5 +1,4 @@ function pkg = remove_flashing_area(x1, y1, x2, y2) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('QL', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +pkg = get_package('QL', arg); end diff --git a/Kod/bilbana/yc4/display/restore_display_from_clipboard.m b/Kod/bilbana/yc4/display/restore_display_from_clipboard.m index 9542851..44c6150 100644 --- a/Kod/bilbana/yc4/display/restore_display_from_clipboard.m +++ b/Kod/bilbana/yc4/display/restore_display_from_clipboard.m @@ -1,3 +1,3 @@ function pkg = restore_display_from_clipboard() - pkg = get_package('CR', []); +pkg = get_package('CR', []); end diff --git a/Kod/bilbana/yc4/display/restore_display_from_clipboard_to_point.m b/Kod/bilbana/yc4/display/restore_display_from_clipboard_to_point.m index 2c9e1aa..e10d019 100644 --- a/Kod/bilbana/yc4/display/restore_display_from_clipboard_to_point.m +++ b/Kod/bilbana/yc4/display/restore_display_from_clipboard_to_point.m @@ -1,5 +1,4 @@ function pkg = restore_display_from_clipboard_to_point(x1, y1) - arg = [get_bytes(x1), get_bytes(y1)]; - - pkg = get_package('CK', arg); +arg = [get_bytes(x1), get_bytes(y1)]; +pkg = get_package('CK', arg); end diff --git a/Kod/bilbana/yc4/display/save_area_to_clipboard.m b/Kod/bilbana/yc4/display/save_area_to_clipboard.m index 8098b06..4d12459 100644 --- a/Kod/bilbana/yc4/display/save_area_to_clipboard.m +++ b/Kod/bilbana/yc4/display/save_area_to_clipboard.m @@ -1,5 +1,4 @@ function pkg = save_area_to_clipboard(x1, y1, x2, y2) - arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; - - pkg = get_package('CS', arg); +arg = [get_bytes(x1), get_bytes(y1), get_bytes(x2), get_bytes(y2)]; +pkg = get_package('CS', arg); end diff --git a/Kod/bilbana/yc4/display/save_display_to_clipboard.m b/Kod/bilbana/yc4/display/save_display_to_clipboard.m index f8cd0bd..404831f 100644 --- a/Kod/bilbana/yc4/display/save_display_to_clipboard.m +++ b/Kod/bilbana/yc4/display/save_display_to_clipboard.m @@ -1,3 +1,3 @@ function pkg = save_display_to_clipboard() - pkg = get_package('CB', []); +pkg = get_package('CB', []); end diff --git a/Kod/bilbana/yc4/display/send_data_to_display.m b/Kod/bilbana/yc4/display/send_data_to_display.m deleted file mode 100644 index c5d70c7..0000000 --- a/Kod/bilbana/yc4/display/send_data_to_display.m +++ /dev/null @@ -1,27 +0,0 @@ -function [] = send_data_to_display() -%SEND_DATA_TO_DISPLAY sends available data to display if last send was -% more than 0.5 seconds ago. - persistent last_send; - global display_data; - - if isempty(display_data) - return - end - % disp(last_send); - % disp(clock); - if isempty(last_send) % first send - %% SEND DATA - % disp('sending data'); - % disp(display_data) - matlabclient(1, display_data{1}); - last_send = clock; - display_data(1) = []; - elseif (etime(clock, last_send) >= 0.5) - %% SEND DATA - % disp('sending data'); - % disp(display_data) - matlabclient(1, display_data{1}); - last_send = clock; - display_data(1) = []; - end -end diff --git a/Kod/bilbana/yc4/display/set_display_visible.m b/Kod/bilbana/yc4/display/set_display_visible.m index 12fa3b3..58cd1a4 100644 --- a/Kod/bilbana/yc4/display/set_display_visible.m +++ b/Kod/bilbana/yc4/display/set_display_visible.m @@ -1,7 +1,7 @@ function pkg = set_display_visible(visible) - if visible == true - pkg = get_package('DE', []); - else - pkg = get_package('DA', []); - end +if visible == true + pkg = get_package('DE', []); +else + pkg = get_package('DA', []); +end end diff --git a/Kod/bilbana/yc4/display/set_drawing_mode.m b/Kod/bilbana/yc4/display/set_drawing_mode.m index c8ecf07..1164ebc 100644 --- a/Kod/bilbana/yc4/display/set_drawing_mode.m +++ b/Kod/bilbana/yc4/display/set_drawing_mode.m @@ -1,5 +1,6 @@ function pkg = set_drawing_mode(n1) - arg = [n1]; - - pkg = get_package('GV', arg); +% 1 = set +% 2 = delete (erase) +% 3 = invert (on -> off, off -> on for every pixel thats drawn over) +pkg = get_package('GV', [n1]); end diff --git a/Kod/bilbana/yc4/display/set_flashing_time.m b/Kod/bilbana/yc4/display/set_flashing_time.m index e4f056d..3d11420 100644 --- a/Kod/bilbana/yc4/display/set_flashing_time.m +++ b/Kod/bilbana/yc4/display/set_flashing_time.m @@ -1,3 +1,3 @@ function pkg = set_flashing_time(n1) - pkg = get_package('QZ', [n1]); +pkg = get_package('QZ', [n1]); end diff --git a/Kod/bilbana/yc4/display/set_line_pattern.m b/Kod/bilbana/yc4/display/set_line_pattern.m new file mode 100644 index 0000000..c836c80 --- /dev/null +++ b/Kod/bilbana/yc4/display/set_line_pattern.m @@ -0,0 +1,3 @@ +function pkg = set_line_pattern(n1) +pkg = get_package('GM', n1); +end diff --git a/Kod/bilbana/yc4/display/set_pattern.m b/Kod/bilbana/yc4/display/set_pattern.m index 5ec583e..5962ebc 100644 --- a/Kod/bilbana/yc4/display/set_pattern.m +++ b/Kod/bilbana/yc4/display/set_pattern.m @@ -1,5 +1,3 @@ function pkg = set_pattern(n1) - arg = [n1]; - - pkg = get_package('GM', n1); +pkg = get_package('GM', n1); end diff --git a/Kod/bilbana/yc4/display/set_point_size.m b/Kod/bilbana/yc4/display/set_point_size.m index 750b172..17615a1 100644 --- a/Kod/bilbana/yc4/display/set_point_size.m +++ b/Kod/bilbana/yc4/display/set_point_size.m @@ -1,5 +1,4 @@ function pkg = set_point_size(n1, n2) - arg = [n1 n2]; - - pkg = get_package('GZ', arg); +arg = [n1, n2]; +pkg = get_package('GZ', arg); end diff --git a/Kod/bilbana/yc4/display/set_text_flashing.m b/Kod/bilbana/yc4/display/set_text_flashing.m new file mode 100644 index 0000000..00f683e --- /dev/null +++ b/Kod/bilbana/yc4/display/set_text_flashing.m @@ -0,0 +1,7 @@ +function pkg = set_text_flashing(n1) +%SET_TEXT_FLASHING Summary of this function goes here +% Detailed explanation goes here + +pkg = get_package('ZB', [n1]); +end + diff --git a/Kod/bilbana/yc4/display/set_text_font.m b/Kod/bilbana/yc4/display/set_text_font.m index 768d16b..1aed263 100644 --- a/Kod/bilbana/yc4/display/set_text_font.m +++ b/Kod/bilbana/yc4/display/set_text_font.m @@ -1,3 +1,3 @@ function pkg = set_text_font(font_num) - pkg = get_package('ZF', [font_num]) +pkg = get_package('ZF', [font_num]); end diff --git a/Kod/bilbana/yc4/display/set_touch_sound_response.m b/Kod/bilbana/yc4/display/set_touch_sound_response.m index 851eaf2..cb14d83 100644 --- a/Kod/bilbana/yc4/display/set_touch_sound_response.m +++ b/Kod/bilbana/yc4/display/set_touch_sound_response.m @@ -1,7 +1,7 @@ function pkg = set_touch_sound_response(state) - if state == true - pkg = get_package('AS', [1]); - else - pkg = get_package('AS', [0]); - end +if state == true + pkg = get_package('AS', [1]); +else + pkg = get_package('AS', [0]); +end end diff --git a/Kod/bilbana/yc4/do_car.m b/Kod/bilbana/yc4/do_car.m new file mode 100644 index 0000000..f822395 --- /dev/null +++ b/Kod/bilbana/yc4/do_car.m @@ -0,0 +1,132 @@ +function [car, stop, display_data] = do_car(car, t, display_data) +%DO_CAR Ger nya värden till struct car, avgör om koden ska stoppas samt hämtar displaydata. +%{ +Input/Output: +car - En struct med data för en viss bil + car.num - Vilken bil det är (1 eller 2) + car.running - Om bilen körs eller inte + car.automatic - Om bilen körs automatiskt eller inte + car.segment - Bilens nuvarande segment + car.lap - Bilens nuvarande varv + car.lap_times - Bilens sparade varvtider (1 x n matris) + car.seg_times - Bilens sparade segmentstier (n x m matris) + car.position - Bilens nuvarande placering på banan i meter från + start/mål + car.seg_len - Banans längd från start till givarna (1 x 9 matris) + car.map - Tabell med hastighetskoefficienter för alla positioner (.mat + fil) + car.miss_probability - Sannorlikheten för artificiellt introducerade + missade givare +t - Längden (s) på nuvarande programcykel +display_data - Buffer med den data som ska skickas till displayen vid nästa + anrop +stop - Huruvida koden ska stoppas eller inte +%} +stop = false; +if car.running == true + [car.new_lap, car.new_check_point, car.time] = get_car_position(car.num); + if car.new_check_point == true && rand < car.miss_probability && car.lap >= 4 + disp('Hoppar �ver givare'); + car.new_check_point = false; + beep; + end +end + +%% CHECK LAP AND CHECKPOINT +if car.running == true + if car.lap ~= 0 + if toc(car.seg_tic) > 9.0 + set_car_speed(1, 0); + set_car_speed(2, 0); + %disp(strjoin({'AvÃ¥kning bil', num2str(car.num)})); + disp('J = Ja, N = Nej') + car.response = input('Vill du fortsätta? [N] ', 's'); + if car.response == 'J' + car.seg_tic = tic; + else + stop = true; + return; + end + end + end + %% CALC POSITION + if car.lap > 1 + % car.last_seg_times = car.seg_times(car.lap - 1, 1:9); + aprox_v = get_aprox_v(car.segment + detect_missed(car.position, car.segment, car.num), car.lap, car.seg_times, car.num); + car.position = get_position(aprox_v, car.position, t); + if detect_missed( car.position, car.segment, car.num) + disp('Miss?'); + + %disp(toc(car.miss_time)); + %if car.miss_time == 0 + % car.miss_time = tic; + %end + end + end + if car.new_check_point == true + if car.new_lap == false % choose_position krachar vid nytt varv (seg 10) + if car.lap ~= 0 + car.seg_times(car.lap, car.segment) = toc(car.seg_tic); + end + car.segment = car.segment + 1; + car.seg_tic = tic; + if car.lap > 2 % S�kerhetsmarginal (B�r vara 1?) + disp(car); + [new_position, seg_plus] = ... + choose_position(car.position, car.segment, car.num); + if seg_plus ~= 0 && car.segment == 1 + disp('Hoppar �ver missad givare 1/2'); + else + car.position = new_position; + car.segment = car.segment + seg_plus; + end + %car.miss_time = uint64(0); + else + car.position = car.seg_len(car.segment); + %car.miss_time = uint64(0); + end + end + end + if car.new_lap == true + car.new_lap = false; + beep; + if car.lap == 0 + % dont save time for first lap + car.segment = 1; + car.lap = car.lap + 1; + car.seg_tic = tic; + car.lap_tic = tic; + else + % beep; + car.seg_times(car.lap, car.segment) = toc(car.seg_tic); + car.seg_tic = tic; + car.lap_times(car.lap) = toc(car.lap_tic); + car.lap_tic = tic; + car.position = 0; + + display_data = [display_data, put_text(100, 16 + (16 * car.num), 'L', strjoin({num2str(car.lap), get_time_as_string(round(car.lap_times(car.lap) * 1000))}, ' '))]; + + car.segment = 1; + car.lap = car.lap + 1; + end + end +end + +%% CALCULATE +if car.running == true && car.automatic == true + car.car_constant = get_car_constant(car.num); + car.v = get_new_v(car.position, car.map); + car.track_u_constant = get_track_u_constant(); + car.u = get_new_u(car.v, car.car_constant, car.track_u_constant); +end + +%% CONTROLLER +if car.running == true && car.automatic == false + % set_car_speed(car.num, mult * ((max - get_manual_speed(car.num)) / div)); +end + +%% EXECUTE +if car.running == true && car.automatic == true + set_car_speed(car.num, car.u); +end +end diff --git a/Kod/bilbana/yc4/get_aprox_v.m b/Kod/bilbana/yc4/get_aprox_v.m new file mode 100644 index 0000000..1867565 --- /dev/null +++ b/Kod/bilbana/yc4/get_aprox_v.m @@ -0,0 +1,32 @@ +function [v] = get_aprox_v(cur_seg, lap, seg_times, track) +%GET_APROX_V Tillf�llig? Beh�vs f�r att testa get_position. Ger +%medelhastigheten f�r nuvarande segment p� f�rra varvet. +%{ +cur_seg: Nuvarande segment +last_seg_times: 1x9 vektor med f�rra varvets segmenttider +%} +seg_len1 = [2.53 0.53 1.68 2.92 1.2 2.01 3.83 2.89 1.99]; +seg_len2 = [2.53 0.53 1.87 2.68 1.24 1.81 4.03 3.09 2.19]; + +% seg_len = []; + +if track == 1 + seg_len = seg_len1; +else + seg_len = seg_len2; +end + +if cur_seg > 9 + cur_seg = cur_seg - 9; +end + +while lap > 0 + lap = lap - 1; + if seg_times(lap, cur_seg) ~= 0 + v = seg_len(cur_seg) / seg_times(lap, cur_seg); + return + end +end +disp('bara nollor?'); + +end diff --git a/Kod/bilbana/yc4/get_car_constant.m b/Kod/bilbana/yc4/get_car_constant.m index eb3bd22..e5e9801 100644 --- a/Kod/bilbana/yc4/get_car_constant.m +++ b/Kod/bilbana/yc4/get_car_constant.m @@ -13,9 +13,9 @@ precision. switch(in_pos) case 1 - car_constant = 1; + car_constant = 0.95; case 2 - car_constant = 1.2; + car_constant = 1.2; end end diff --git a/Kod/bilbana/yc4/get_new_v.m b/Kod/bilbana/yc4/get_new_v.m index 26bf175..e722326 100644 --- a/Kod/bilbana/yc4/get_new_v.m +++ b/Kod/bilbana/yc4/get_new_v.m @@ -1,21 +1,21 @@ -function [ new_v ] = get_new_v( old_v, speed_constant, target_diff, car_position_diff, agressiveness ) +function [ new_v ] = get_new_v( position, list) %GET_NEW_V Hastigheten som bilen ska få nästa cykel. %{ -Tar förra cykelns hastighet (old_ v) och lägger till eller drar -av beroende på hur långt ifrån målet bilarna ligger (target_diff) och, -om gemensam målgång är aktiverad, hur långt ifrån varandra bilarna är -(car_position_diff). Beror också på agressiveness; högre agressiveness ger -större skillnad mellan new_v och old_v medan ett lågt värde gör att new_v -inte ändras särskilt mycket. new_v används sedan för att sätta new_u. -Högre new_v ger högre new_u och lägre new_v ger lägre_u. +Utgår ifrån position och ger motsvarande hårdkodade värde på v för +nuvarande sub_segment. %} +position = position*100; %temp input för position -%{ -GET_NEW_V: -new_v: Den hastighet som bilen ska få nästa cykel. -%} -v = [35, 25, 30, 30, 40, 50, 40, 50, 35]; -new_v = v(old_v); -end +for i = 1:length(list) + + if list(i,1) > position + new_v = list((i-1),4); + break + elseif i == length(list) + new_v = list(80,4); + break + end +end + diff --git a/Kod/bilbana/yc4/get_position.m b/Kod/bilbana/yc4/get_position.m index 9f70347..72fa866 100644 --- a/Kod/bilbana/yc4/get_position.m +++ b/Kod/bilbana/yc4/get_position.m @@ -1,6 +1,13 @@ -function [ output_args ] = get_position( v_prev_cycle, prev_p, delta_t ) -%UNTITLED Summary of this function goes here -% Detailed explanation goes here - +function [ position ] = get_position( aprox_v, prev_p, delta_t) +%GET_POSITION: Uppskattar position utifrån förra positionen och hastigheten +%{ +Använder s = v*t för att beräkna skillnaden i strecka sedan förra cykeln. +v är just nu medelhastigheten för nuvarande segment förra cykeln. +dt är just nu samma tic toc som checkar att cykeln inte var mer än 0.1 s. +%} +v = aprox_v; +dt = delta_t; +dp = v*dt; +position = prev_p + dp; end diff --git a/Kod/bilbana/yc4/main.m b/Kod/bilbana/yc4/main.m index 3bdf697..109d8b4 100644 --- a/Kod/bilbana/yc4/main.m +++ b/Kod/bilbana/yc4/main.m @@ -5,39 +5,94 @@ cd display/ClientServerApp/Release !startServer cd ../../.. -global display_data; -display_data = {}; -display_data = {display_data clear_display()}; -pause(1); +display = struct; +display.data = [clear_display()]; +display.out = 0; +display.shm = 0; +display.shm_interp = struct; +display.shm_interp.ack = 0; +display.shm_interp.start_code = ''; +display.shm_interp.data = []; +display.last_send = tic; +display.last_request = tic; +display.send_interval = 0.5; disp('Startar bilbanan. Avsluta med q.') -hf=figure('position',[0 0 eps eps],'menubar','none'); +hf=figure('position', [0 0 eps eps], 'menubar', 'none'); initialize_counters(1) initialize_counters(2) config_IOs +load('bilbana\files\Bana1.mat') +load('bilbana\files\Bana2.mat') + start_race(1) start_race(2) car1 = struct; +car1.num = 1; +car1.running = false; +car1.automatic = true; car1.segment = 1; car1.lap = 0; car1.lap_times = []; car1.seg_times = []; +car1.last_seg_times = []; +car1.position = 0; +car1.seg_len = [0.0 2.53 3.05 4.73 7.68 8.98 10.93 14.69 17.57]; +car1.map = Bana1; +car1.approximation = []; +car1.miss_probability = 0.0; car2 = struct; +car2.num = 2; +car2.running = false; +car2.automatic = true; car2.segment = 1; car2.lap = 0; car2.lap_times = []; car2.seg_times = []; +car2.last_seg_times = []; +car2.position = 0; +car2.seg_len = [0.0 2.53 3.05 4.92 7.60 8.84 10.65 14.68 17.76]; +car2.map = Bana2; +car2.miss_probability = 0.0; + +t = 0; +highToc = 0; + +%% ASK ACTIVE CARS +disp('J = Ja (automatiskt), M = Ja (manuellt), N = Nej'); + +car1.response = input('Vill du köra bil 1? [N] ', 's'); +if car1.response == 'J' + car1.running = true; + car1.automatic = true; +elseif car1.response == 'M' + car1.running = true; + car1.automatic = false; +else + car1.running = false; +end + + +car2.response = input('Vill du köra bil 2? [N] ', 's'); +if car2.response == 'J' + car2.running = true; + car2.automatic = true; +elseif car2.response == 'M' + car2.running = true; + car2.automatic = false; +else + car2.running = false; +end -tocs = []; %% MAIN LOOP while 1 - tic; + readTime = tic; %% PRE-LOOP if strcmp(get(hf,'currentcharacter'),'q') close(hf) @@ -47,102 +102,64 @@ while 1 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); - - %% CHECK LAP AND CHECKPOINT (CAR 1) - if car1.new_check_point == true - % beep; - if car1.lap ~= 0 - car1.seg_times(car1.lap, car1.segment) = toc(car1.seg_tic); - end - car1.segment = car1.segment + 1; - car1.seg_tic = tic; - end - if car1.new_lap == true - if car1.lap == 0 - % dont save time for first lap - car1.segment = 1; - car1.lap = car1.lap + 1; - car1.seg_tic = tic; - car1.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, car1.stop, display.data] = do_car(car1, t, display.data); + [car2, car2.stop, display.data] = do_car(car2, t, display.data); - display_data = {display_data, put_text(100, 32, 'L', strjoin({num2str(car1.lap), get_time_as_string(round(car1.lap_times(car1.lap) * 1000))}, ' '))}; - - car1.segment = 1; - car1.lap = car1.lap + 1; - - car1.seg_times(car1.lap, 1) = 0; - end + if car1.stop == true + disp('stopped by car 1'); + break; + end + if car2.stop == true + disp('stopped by car 2'); + break; + end - %% CHECK LAP AND CHECKPOINT (CAR 2) - if car2.new_check_point == true - % beep; - if car2.lap ~= 0 - car2.seg_times(car2.lap, car2.segment) = toc(car2.seg_tic); - end - car2.segment = car2.segment + 1; - car2.seg_tic = tic; - end - if car2.new_lap == true - if car2.lap == 0 - % dont save time for first lap - car2.segment = 1; - car2.lap = car2.lap + 1; - car2.seg_tic = tic; - car2.lap_tic = tic; - disp('continuing'); - continue; + %% END OF LOOP + while 1 %Whileloop med paus som k�rs till pausen �verskridit 0.07 sekunder + % DISPLAY + display.send_delay = tic; + if toc(display.last_send) > display.send_interval + % queue control signal + if car1.running && car1.automatic + display.data = [display.data, put_text(20, 16 + (16 * 1), 'L', num2str(car1.u))]; + end + if car2.running && car2.automatic + display.data = [display.data, put_text(20, 16 + (16 * 2), 'L', num2str(car2.u))]; + end + + % send all queued data + if ~isempty(display.data) + [display.out] = matlabclient(1, get_smallpackage(display.data)); + display.data = []; + end + display.last_send = tic; + + % read internal mem from last send + [display.out, display.shm] = matlabclient(2); + [display.shm_interp.ack, display.shm_interp.start_code, display.shm_interp.data] = get_response(display.shm); + + % request internal mem + matlabclient(1, hex2dec(['12'; '01'; '53'; '66'])); end - beep; - - 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; - - display_data = {display_data, put_text(100, 48, 'L', strjoin({num2str(car2.lap), get_time_as_string(round(car2.lap_times(car2.lap) * 1000))}, ' '))}; + % disp(strjoin({'display took additional ', num2str(toc(display.send_delay))})); + % ACTUAL END OF LOOP + t = toc(readTime); - car2.segment = 1; - car2.lap = car2.lap + 1; - - car2.seg_times(car2.lap, 1) = 0; + if t > 0.07 + if t > highToc + highToc = t; %Om det nya v�rdet p� pausen �r h�gre �n den tidigare h�gsta s� sparas det som den h�gsta + end + if t > 0.1 + % beep; + end + break; + end + pause(0.001); end - - %% CALCULATE (CAR 1) - car1.car_constant = get_car_constant(1); - car1.v = get_new_v(car1.segment); - car1.track_u_constant = get_track_u_constant(); - car1.u = get_new_u(car1.v, car1.car_constant, car1.track_u_constant); - - %% CALCULATE (CAR 2) - car2.car_constant = get_car_constant(2); - car2.v = get_new_v(car2.segment); - car2.track_u_constant = get_track_u_constant(); - car2.u = get_new_u(car2.v, car2.car_constant, car2.track_u_constant); - - %% EXECUTE - set_car_speed(1, car1.u); - set_car_speed(2, car2.u); - - %% DISPLAY - - %% END OF LOOP - pause(0.1) - tocs(end + 1) = toc; - send_data_to_display(); end %% END OF PROGRAM -disp(tocs); +disp(highToc); disp(car1); disp(car2); @@ -153,5 +170,11 @@ matlabclient(3); %% DISPLAY GRAPHS -graphs(car1.lap_times, 13, car1.seg_times, 1); -graphs(car2.lap_times, 13, car2.seg_times, 2);
\ No newline at end of file +if car1.running == true + graphs(car1.lap_times, 13, car1.seg_times, 1); +end + + +if car2.running == true + graphs(car2.lap_times, 13, car2.seg_times, 2); +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 diff --git a/Motesprotokoll/2019-09-23.tex~Fixa datum b/Motesprotokoll/2019-09-23.tex~Fixa datum new file mode 100644 index 0000000..28a8714 --- /dev/null +++ b/Motesprotokoll/2019-09-23.tex~Fixa datum @@ -0,0 +1,60 @@ +\documentclass[11pt,a4paper]{article} +\usepackage{geometry} % gör texten lite bredare eftersom vanlig latex är för smal för a4 +\usepackage{url} + +% minska storleken på rubriker och underrubriker +\usepackage{titlesec} +\titleformat{\section} + {\normalfont\Large\bfseries}{\thesection}{1em}{} + +\titleformat{\subsection} + {\normalfont\normalsize\bfseries}{\thesubsection}{1em}{}[\vspace{-0.4em}] +\usepackage[]{parskip} + +% undvik helst subsubsections + +%% FÖRKLARINGAR AV KOMMANDON OCH DYL. +% \\ skapar en radbrytning +% \\[1em] skapar en radbrytning med "1em" extra utrymme mellan rader +% (1 em är ganska stor) +% \textbf{Skapar text i fetstil} +% \begin{itemize} och \end{itemize} skapar en s.k. list-enviornment (list-miljö) +% Inuti itemize skriver man \item för att skapa en ny punkt, annars är det bara att skriva +% \section*{Titel} och \subsection*{Understitel} skapar nya sektioner och undersektioner +% Asterisken ser till att det inte dyker upp ett nummer bredvid namnet. +% I övrigt är det bara att skriva text där man vill ha den + +\begin{document} +\pagenumbering{gobble} % räkna inte (och skriv inte heller ut) sidnumrering + \begin{center} + \textbf{\Large TFYY51 - Yc4} \\[0.2em] + Mötesprotokoll för 23 September 2019 + \end{center} + \vspace{1em} + \textbf{Närvarande:} Gustav (ordf), David (sek), Alexander (lokal), Mattias, Albin \\[0.5em] + \textbf{Frånvarande:} \\[0.5em] % som exempel + \textbf{Övriga närvarande:} + + \section*{Föregående protokoll} + \vspace{1em} + + \section*{Dagordning} + \subsection*{Stämma av projektplan} + Inte direkt några invändningar. Projektplanen ser bra ut helt enkelt + \subsection*{Gör mailgrupp} + Mattias skapar en gemensam mailgrupp; \url{team_YC4@liu.onmicrosoft.com}, så att vi kan ha mailkontakt med varandra på ett smidigt och funktionellt sätt. + Dessutom kan Eriks information nå ut till hela gruppen skulle han ha något viktigt att säga. + \subsection*{Mer detaljrik tidsplan} + Vi räknar ut att vi vill snitta på 10 timmar/pers/vecka. Färre timmar, ungefär hälften av snittet, kan läggas ned på arbetet de veckor som kräver förberedelse inför diverse + prov eller redovisningar + \subsection*{Gör mötesprotkollmall} + Mallen är strukturerad på det sätt vi vill ha det. Mallen skrivs in i \LaTeX\ och läggs upp i gitLab + \subsection*{Formell gruppbestämmelse} + Utökat gruppkontrakt, med bestämmelse om struktur och ordning i gruppen. Bland annat mötesordning och rullians på roller inför möten + + \section*{Övrigt} + \vspace{1em} + + \section*{Nästa möte} + Nästa mötes hålls Tisdag 1 Oktober 2019 13:15. Lokalbokare kommer då vara Mattias. +\end{document}
\ No newline at end of file diff --git a/Motesprotokoll/2019-09-23.tex~master b/Motesprotokoll/2019-09-23.tex~master new file mode 100644 index 0000000..28a8714 --- /dev/null +++ b/Motesprotokoll/2019-09-23.tex~master @@ -0,0 +1,60 @@ +\documentclass[11pt,a4paper]{article} +\usepackage{geometry} % gör texten lite bredare eftersom vanlig latex är för smal för a4 +\usepackage{url} + +% minska storleken på rubriker och underrubriker +\usepackage{titlesec} +\titleformat{\section} + {\normalfont\Large\bfseries}{\thesection}{1em}{} + +\titleformat{\subsection} + {\normalfont\normalsize\bfseries}{\thesubsection}{1em}{}[\vspace{-0.4em}] +\usepackage[]{parskip} + +% undvik helst subsubsections + +%% FÖRKLARINGAR AV KOMMANDON OCH DYL. +% \\ skapar en radbrytning +% \\[1em] skapar en radbrytning med "1em" extra utrymme mellan rader +% (1 em är ganska stor) +% \textbf{Skapar text i fetstil} +% \begin{itemize} och \end{itemize} skapar en s.k. list-enviornment (list-miljö) +% Inuti itemize skriver man \item för att skapa en ny punkt, annars är det bara att skriva +% \section*{Titel} och \subsection*{Understitel} skapar nya sektioner och undersektioner +% Asterisken ser till att det inte dyker upp ett nummer bredvid namnet. +% I övrigt är det bara att skriva text där man vill ha den + +\begin{document} +\pagenumbering{gobble} % räkna inte (och skriv inte heller ut) sidnumrering + \begin{center} + \textbf{\Large TFYY51 - Yc4} \\[0.2em] + Mötesprotokoll för 23 September 2019 + \end{center} + \vspace{1em} + \textbf{Närvarande:} Gustav (ordf), David (sek), Alexander (lokal), Mattias, Albin \\[0.5em] + \textbf{Frånvarande:} \\[0.5em] % som exempel + \textbf{Övriga närvarande:} + + \section*{Föregående protokoll} + \vspace{1em} + + \section*{Dagordning} + \subsection*{Stämma av projektplan} + Inte direkt några invändningar. Projektplanen ser bra ut helt enkelt + \subsection*{Gör mailgrupp} + Mattias skapar en gemensam mailgrupp; \url{team_YC4@liu.onmicrosoft.com}, så att vi kan ha mailkontakt med varandra på ett smidigt och funktionellt sätt. + Dessutom kan Eriks information nå ut till hela gruppen skulle han ha något viktigt att säga. + \subsection*{Mer detaljrik tidsplan} + Vi räknar ut att vi vill snitta på 10 timmar/pers/vecka. Färre timmar, ungefär hälften av snittet, kan läggas ned på arbetet de veckor som kräver förberedelse inför diverse + prov eller redovisningar + \subsection*{Gör mötesprotkollmall} + Mallen är strukturerad på det sätt vi vill ha det. Mallen skrivs in i \LaTeX\ och läggs upp i gitLab + \subsection*{Formell gruppbestämmelse} + Utökat gruppkontrakt, med bestämmelse om struktur och ordning i gruppen. Bland annat mötesordning och rullians på roller inför möten + + \section*{Övrigt} + \vspace{1em} + + \section*{Nästa möte} + Nästa mötes hålls Tisdag 1 Oktober 2019 13:15. Lokalbokare kommer då vara Mattias. +\end{document}
\ No newline at end of file diff --git a/Motesprotokoll/23-09-2019.tex b/Motesprotokoll/23-09-2019.tex new file mode 100644 index 0000000..28a8714 --- /dev/null +++ b/Motesprotokoll/23-09-2019.tex @@ -0,0 +1,60 @@ +\documentclass[11pt,a4paper]{article} +\usepackage{geometry} % gör texten lite bredare eftersom vanlig latex är för smal för a4 +\usepackage{url} + +% minska storleken på rubriker och underrubriker +\usepackage{titlesec} +\titleformat{\section} + {\normalfont\Large\bfseries}{\thesection}{1em}{} + +\titleformat{\subsection} + {\normalfont\normalsize\bfseries}{\thesubsection}{1em}{}[\vspace{-0.4em}] +\usepackage[]{parskip} + +% undvik helst subsubsections + +%% FÖRKLARINGAR AV KOMMANDON OCH DYL. +% \\ skapar en radbrytning +% \\[1em] skapar en radbrytning med "1em" extra utrymme mellan rader +% (1 em är ganska stor) +% \textbf{Skapar text i fetstil} +% \begin{itemize} och \end{itemize} skapar en s.k. list-enviornment (list-miljö) +% Inuti itemize skriver man \item för att skapa en ny punkt, annars är det bara att skriva +% \section*{Titel} och \subsection*{Understitel} skapar nya sektioner och undersektioner +% Asterisken ser till att det inte dyker upp ett nummer bredvid namnet. +% I övrigt är det bara att skriva text där man vill ha den + +\begin{document} +\pagenumbering{gobble} % räkna inte (och skriv inte heller ut) sidnumrering + \begin{center} + \textbf{\Large TFYY51 - Yc4} \\[0.2em] + Mötesprotokoll för 23 September 2019 + \end{center} + \vspace{1em} + \textbf{Närvarande:} Gustav (ordf), David (sek), Alexander (lokal), Mattias, Albin \\[0.5em] + \textbf{Frånvarande:} \\[0.5em] % som exempel + \textbf{Övriga närvarande:} + + \section*{Föregående protokoll} + \vspace{1em} + + \section*{Dagordning} + \subsection*{Stämma av projektplan} + Inte direkt några invändningar. Projektplanen ser bra ut helt enkelt + \subsection*{Gör mailgrupp} + Mattias skapar en gemensam mailgrupp; \url{team_YC4@liu.onmicrosoft.com}, så att vi kan ha mailkontakt med varandra på ett smidigt och funktionellt sätt. + Dessutom kan Eriks information nå ut till hela gruppen skulle han ha något viktigt att säga. + \subsection*{Mer detaljrik tidsplan} + Vi räknar ut att vi vill snitta på 10 timmar/pers/vecka. Färre timmar, ungefär hälften av snittet, kan läggas ned på arbetet de veckor som kräver förberedelse inför diverse + prov eller redovisningar + \subsection*{Gör mötesprotkollmall} + Mallen är strukturerad på det sätt vi vill ha det. Mallen skrivs in i \LaTeX\ och läggs upp i gitLab + \subsection*{Formell gruppbestämmelse} + Utökat gruppkontrakt, med bestämmelse om struktur och ordning i gruppen. Bland annat mötesordning och rullians på roller inför möten + + \section*{Övrigt} + \vspace{1em} + + \section*{Nästa möte} + Nästa mötes hålls Tisdag 1 Oktober 2019 13:15. Lokalbokare kommer då vara Mattias. +\end{document}
\ No newline at end of file |
