-
Notifications
You must be signed in to change notification settings - Fork 0
/
README
104 lines (77 loc) · 4.17 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
updated by Jan 22, 2018
we run this on ubuntu 16.04 LTS, with lua5.2, argos3.0.0-beta.
#####################################################################################
Brief Introduction
to run this test, you should have these libraries
1. apriltag
2. OpenCV
3. ARGoS or OpenGL
The structure of the code is like this:
argosBlock <----| testbench <----- lua
openglBlock <----|
you can use either argos or opengl to be the GUI, and call testbench functions,
the testbench loads images one by one from camera of data sets, finds tags, and call lua to calculate the pos of the tags.
After calling lua, it stores the result in a array (in testbench.h), so that argos or opengl can see the results.
argos or opengl receive the results, and use them to draw 3D items.
######################################################################################
Folders and Files
There are 5 folders really matters, which are : argosBlock, openglBlock, testbench, lua, data
1. argosBlock contains files to generate argos GUI.
2. openglBlock contains files to generate opengl GUI.
3. Either one you choose, they will call functions in testbench.h and testbench.cpp in
testbench folder.
4. And then testbench functions will run lua script in lua folder and collect results.
In lua folder, additional to lua, there is also a solvepnp folder containing a lua wrap on
opencv's solvepnp function so that opencv can be tested to compare.
5. data contains testing pictures
#####################################################################################
Compile and run
1. ARGoS
Compile:
If you choose ARGoS, go to folder argosBlock/loopFunction, there is a CMakeLists there.
Create a build folder, go inside and run cmake to generate a Makefile, and make, this will
generate a libtestLoopFunction.so, which is needed by argos:
commands:
argosBlock/loopFunction$ mkdir build
argosBlock/loopFunction$ cd build
argosBlock/loopFunction/build$ cmake ..
argosBlock/loopFunction/build$ make
Run:
To run, go back to argosBlock folder, and run argos command :
argosBlock$ argos3 -c fsm_testing.lua
2. OpenGL
Compile:
If you choose OpenGL, go to openglBlock folder, do the same cmake-make thing.
A executable file 'luaBlock' will be generated.
commands:
openglBlock$ mkdir build
openglBlock$ cd build
openglBlock/build$ cd cmake ..
openglBlock/build$ make
Run:
Simply run luaBlock:
openglBlock/build$ ./luaBlock
3. OpenCV
If you want to use solvepnp function in opencv to compare, go to folder lua/solvepnp,
build, cmake and make, generate a libsolvepnp.so in the build folder. It will be used by lua.
###################################################################################
SolveSqu:
The core function (the solveSquare(), who calculate the location and rotation of a tag) is located in
lua/solveSqu/solveSqu.lua
There is also another file called solveSqu_dynamic.lua, which also works. it uses matrix library to dynamically
solve linear equations, while solveSqu.lua uses static formula which is fixed in the code. To switch between these
two, change the require in lua/calcPos.lua Line 2 and 3
###################################################################################
Some flags in the code:
There are some flag to switch between different modes in the code.
1. camera_flag : in testbench/testbench.cpp Line 77, if camera_flag == 1, program will open your camera and use
camera as frame input, otherwise it will use pictures in data folder.
Be careful this camera_flag does not change the camera parameters in opencv(lua/solvepnp),
If you want to use opencv's solvepnp as a compare, make sure you check lua/solvepnp/solvepnp.cpp
Line 14-36 to use the right camera parameters.
2. data set: in data folder there are several data set,
openglBlock/function_opengl.cpp Line 34-38 (opengl) or
argosBlock/loopFunction/testLoopFunction.cpp Line 178-182 (argos) is where to choose data set.
3. In opengl GUI, some keyboard command may be useful, 'p' means pause, 'n' mean step by step and so on. You can
see all the keyboard response in openglBlock/debug_opengl.cpp Line 320 and 432, in function SpecialKeyOperate()
and BoardKeysOperate().