Chilitags are a C++ cross-platform software library for the detection and identification of 2D fiducial markers. Their purpose is to be printed and placed on objects from the real world, to form the basis or Augmented Reality (AR) applications. Using a camera, the position of the tagged objects can be acquired by a computer and used to virtually display information on them.
Chilitags were developed internally for projects of the CHILI lab (Computer-Human Interaction in Learning and Instruction, formerly CRAFT), such as Metroscope or TapaCarp. There are already many alternatives (e.g. ARToolKit, or reacTIVision, among many others), but we decided to release Chilitags anyway, as there seemed to be a demand for it.
The following videos show real applications of Chilitags for research in tangible learning or paper-based interfaces.
The features of Chilitags come from their original use:
-
Illumination tolerance: Chilitags were developed for use in projector/camera systems, which required the detection to be robust to the illumination constraints of the projector.
-
Precision: Chilitags were used in applications to teach geometry, which required the detection to be as precise as possible to match the requirement on the quality of work of the students.
-
Reliability: Chilitags were used for long experiments in ecologically valid conditions, which required to build systems stable even in various, uncontrolled settings.
Chilitags can be recognized even from low resolution images (markers as narrow as 20 pixels are recognized). However, they are very sensitive to occlusions: if a border is occluded, the tag will not be detected.
The Chilitags demonstration video gives a worst case scenario for the sample code running in real time on a single thread of an Intel Core i7-620m, with a camera set for 960x720x30fps, in an unevenly lit, large scene.
This release of Chilitags consists of three components:
-
the library itself,
-
detector
, the sample program illustrating how to use the library and used to generate the demonstration video. -
creator
, a utility to generate markers,
Chilitags have been developed on Linux (Ubuntu 64 bits), and are known to run on Windows and MacOS X.
Chilitags rely on OpenCV 2. They have has been recently tested with OpenCV 2.3 and 2.4 on Ubuntu (64 bits) 12.10 and 13.04. The documentation on how to install OpenCV can be found for various platforms and IDE.
CMake can be used to generate configuration files of the most popular IDE's of the main platforms. A CMakeLists file is provided in the release. Please refer to online documentation on how to use CMake.
For example on Ubuntu, the software can be compiled via makefile with the following commands:
sudo apt-get install libopencv-dev cmake
to install the OpenCV libraries and cmake
mkdir build && cd build
to create the build
folder where the compilation output will be placed
cmake ..
to generate the makefile
make
to compile detector
and creator
in the build
folder.
sudo make install
to install the library system-wide (see CMake
options to install in another prefix).
./detector
to start the sample program with default parameters for the camera.
Once the software is up and running, the markers can be generated using the
creator
executable. We also generated sets of
markers with various settings.
The README
file accompanying creator
gives important guidelines on how to
design and print chilitags. It also explains the usage of creator
.
The main design principles for tags are summarized below:
The documentation regarding the usage of chilitags
is provided under the form
of the sample code detector
. Please refer to its README
file and comments in
its source code.
Chilitags is released under the LGPL3.
In short, it means that you can do more or less what you want with Chilitags, as long as you publish the modifications you make to Chilitags under the same terms (but you don't have to share the sources of the rest of your software).
You should also credit the authors.
We especially appreciate a reference in your paper, should you use Chilitags for a research project. Let us make that easy for you:
- Chilitags: Robust Fiducial Markers for Augmented Reality. Q. Bonnard, G.
Zufferey, A. Mazzei, S. Cuendet, N. Li, P. Dillenbourg. CHILI, EPFL,
Switzerland.
http://chili.epfl.ch/
. 2013.
@misc{chilitags,
title = {Chilitags: Robust Fiducial Markers for Augmented Reality.},
author={Bonnard, Quentin and Zufferey, Guillaume and Mazzei, Andrea and Cuendet, S\'{e}bastien and Li, Nan and Dillenbourg, Pierre},
publisher={CHILI, EPFL, Switzerland},
url={http://chili.epfl.ch/software},
year={2013}
}
Should you require a different licence, please contact CHILI.
This release intends to be minimal, with only the core functionality of Chilitags: given an image, identify which tag is where. Additional features (tracking, calibration, 3D positions, etc.) may come in further releases. The current release is especially adapted to developers who want to embed marker detection in their C++ application. A TUIO server for chilitags allows the use of chilitags with other, independent applications.
Despite the efforts done to extract this release from "research code", Chilitags can easily be improved on the software engineering level. Documentation have been created only for this release, and can probably be augmented. Contributions are very welcome.
Chilitags have been extensively used in the past years, but proper tests are a
more recent addition. To run automated testes, you need to activate them in the
CMake configuration (option WITH_TESTS
). The test data is in a separate
repository. The easiest is
to clone it in a directory at the same level as your local copy of Chilitags, or
you will also need to update the path in the CMakeLists.txt
. Then you can run
the test suite using CMake's test target.
Example on Unix
git clone [email protected]:chili-epfl/chilitags
git clone [email protected]:chili-epfl/chilitags-testdata.git
cd chilitags
mkdir build
cd build
cmake ..
make
make test