2 Autonomous car architecture
5 [CMake] is used for project build.
21 Macros that affects output binary may be used with the cmake commands as
24 cmake -DPLANNER=LaValle1998 ../
28 The list of available macros with values:
30 - `LaValle198` - RRT framework.
31 - `Kuwata2008` - RRT with changing cost and steering to goal.
32 - `Karaman2011` - RRT* framework.
33 - `TMAX` - Specify the upper time bound in seconds.
35 - `nn1` - Nearest neighbour basic DFS procedure.
37 - `nv1` - Near vertices basic DFS procedure.
39 - `sa1` - Basic sample procedure.
41 - `st1` - Steer directly to goal.
42 - `st2` - Steer with maximum turning radius and direction in mind.
43 - `st3` - Reeds and Shepp steer procedure.
44 - `st4` - Very basic closed-loop simulator.
46 - `co1` - Euclidean distance cost.
47 - `co2` - Reeds and Shepp distance.
49 - `co3` - Cumulative cost based on Euclidean distance.
50 - `co4` - Cumulative cost based on Reeds and Shepp distance.
52 To disable *OpenMP*, add `-DCMAKE_DISABLE_FIND_PACKAGE_OpenMP=TRUE` to `cmake`
53 command or to `build.sh` script.
55 [CMake]: https://cmake.org/
58 The scenarios may be run and plot by the following example command from root:
60 SC=lpar && cat $SC.json | ./build/go_car_go > traj.json &&
61 python plot.py $SC.json traj.json
65 The `go_car_go` program expects json formatted on std input. The output is json
66 formatted to std output.
68 - Street width min.: 2.75 (sometimes 2.5m).
70 ## Small cars (size 01)
71 - Norm: `ČSN 73 6056 s účinností od 1.8. 1988`.
72 - Perpendicular: 2.25 x 4.5m
73 - Parallel: 2.0 x 5,5m
75 ## Large cars (size 02)
76 - Perpendicular: 2.4 x 5.30m
77 - Parallel: 2.2 x 6.5m
79 ## Parallel parking example (large cars)
82 "init": [1.1, 6.5, 1.5707963267948966],
83 "goal": [-1.1, 14.37, 1.5707963267948966],
137 ## Perpendicular parking example
140 "init": [1.1, 6.5, 1.5707963267948966],
141 "goal": [-0.37, 14.2, 3.141592653589793],
196 for i in {0..19}; do $( bash test.sh )&& mv log log_$i; done
197 L=l; WHAT=par; for i in {0..19}; do mv log_${i}/*${L}${WHAT}* ${WHAT}/${L}${WHAT}_${i}.json; done
198 L=r; WHAT=par; for i in {0..19}; do mv log_${i}/*${L}${WHAT}* ${WHAT}/${L}${WHAT}_${i}.json; done
199 L=l; WHAT=per; for i in {0..19}; do mv log_${i}/*${L}${WHAT}* ${WHAT}/${L}${WHAT}_${i}.json; done
200 L=r; WHAT=per; for i in {0..19}; do mv log_${i}/*${L}${WHAT}* ${WHAT}/${L}${WHAT}_${i}.json; done
204 while ! timeout 2 ./bin/Kuwata2008st3co1 < lpar.json > traj.json; do
207 python plot.py lpar.json t.json &