This repository includes codes that can be used to work with the augmented reality library, ArUco. A few programs in the repository, including the codes to create the markers and to calibrate the cameras, are copies of the examples included with the OpenCV libraries with minor changes, which are added so that everything is in one place.
- Installing OpenCV
- Generating Markers
- Detecting the Markers
- Camera Calibration
- Pose Estimation
- Draw a Cube
You can install the standalone ArUco library by downloading the source files which can be found in the above website and building and installing them. But it is highly recommended to install ArUco library packed in OpenCV library. The instruction below are for installing OpenCV with ArUco library.
You can install OpenCV using the master branch of their repository, OR using the submodules added to this repository. Building and installing OpenCV with the provided submodules guarantees that the other codes on this repository works without issues. So it is recommended to install from the submodules.
sudo apt-get install build-essential
sudo apt-get install cmake git libgtk2.0-dev pkg-config libavcodec-dev libavformat-dev libswscale-dev
sudo apt-get install python-dev python-numpy libtbb2 libtbb-dev libjpeg-dev libpng-dev libtiff-dev libjasper-dev libdc1394-22-dev
git submodule update --init
cd libraries/opencv
mkdir build && cd build
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr/local -DOPENCV_EXTRA_MODULES_PATH=../../opencv_contrib/modules ..
make -j4 # if you have more/less cores on your computer, substitute 4 with the number of cores
# use command "nproc" to find the number fo cores
sudo make install
sudo apt-get install build-essential
sudo apt-get install cmake git libgtk2.0-dev pkg-config libavcodec-dev libavformat-dev libswscale-dev
sudo apt-get install python-dev python-numpy libtbb2 libtbb-dev libjpeg-dev libpng-dev libtiff-dev libjasper-dev libdc1394-22-dev
git clone https://github.com/opencv/opencv.git
git clone https://github.com/opencv/opencv_contrib.git
# if you need a specific version, you should checkout to that version on
# both repositories before executing the below commands
mkdir build && cd build
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr/local -DOPENCV_EXTRA_MODULES_PATH=../../opencv_contrib/modules ..
make -j4 # if you have more cores on your computer, substitute 4 with the number of cores
# use command "nproc" to find the number fo cores
sudo make install
To detect the markers using a camera, first you need to print the markers. The ArUco library comes with few functions to generate the markers, and they are copied to this repository for the ease of finding them.
cd create_markers
mkdir build && cd build
cmake ../
make
# create a single marker
# for details about the parameters, run just ./generate_marker
./generate_marker --b=1 -d=16 --id=108 --ms=400 --si marker.jpg
# create a marker board
# for details about the parameters, run just ./generate_board
./generate_board --bb=1 -h=2 -w=4 -l=200 -s=100 -d=16 --si board.jpg
Marker should look like this:
Board looks like this:
First, print the generated markers. Connect a camera to the computer and run below lines:
cd detect_markers
mkdir build && cd build
cmake ../
make
./detect_markers
All the detected markers would be drawn on the image.
To accurately detect markers or to get accurate pose data, a camera calibration needs to be performed.
Run below lines to perform the camera calibration:
cd camera_calibration
mkdir build && cd build
cmake ../
make
# below command is accurate only if you used the same parameters when you generated the markers
# if you changed any of them, change below arguments accordingly
./camera_calibration -d=16 -dp=../detector_params.yml -h=2 -w=4 -l=<side length of a single marker (in meters)> -s=<separation between two consecutive markers in the grid (in meters)> ../../calibration_params.yml
Then points the camera at the marker at different orientations and at different angles and save those images by pressing key C
.
These instructions should appear on the screen.
Around 30 images should be good enough.
To estimate the translation and the rotation of the ArUco marker, run below code:
cd pose_estimation
# measure the length of the marker you plan to measure with a ruler
# open src/main.cpp and update the variable 'actual_marker_length' with
# the measured value (in meters)
mkdir build && cd build
cmake ../
make
./pose_estimation
Below image shows the output of this code.
The distances shown in the left top corner are in meters with axes as same as thos defined in OpenCV model, i.e., x
-axis increases from left to right of the image, y
-axis increases from top to bottom of the image, and the z
-axis points outwards the camera, with the origin on the top left corner of the image.
The axes drawn on the markers represents the orientation of the marker with the Red-Green-Blue axes order.
To estimate pose and draw a cube over the ArUco marker, run below code:
cd draw_cube
# measure the length of the marker you plan to measure with a ruler
# open src/main.cpp and update the variable 'actual_marker_length' with
# the measured value (in meters)
mkdir build && cd build
cmake ../
make
./draw_cube
Below image shows the output of this code.