Final project for "3D Scanning and Motion Capture" class in SS2022 at Technical University of Munich.
Install Eigen (Version 3.4).
Install OpenCV Library (Visual Studio 2019 VC16).
-
Data
-
demo_material
-
images
-
masks
-
-
-
Libs
-
src
-
CMakeLists.txt
-
README.adoc
You can use Data to store images, masks, and calibration files of models you want to carve. The subfolder demo_material contains all inputs and outputs used to generate the model as described in section 4.
If you have never worked with OpenCV or Eigen you can follow the instructions below and install these libraries in the Libs directory.
This directory contains the implementation of this project.
-
Download
CMake(3.9.1 or newer) -
Install
CMakein your preferred directory. -
Add
CMaketoPATHvariable.
Download and extract Eigen (see Eigen - Getting started).
-
Navigate to the directory where you wish to install
OpenCV(eg.{directory}/AR_Voxel_Project/Libs) -
create new file
installOCV.shwith the following content:#!/bin/bash -e # taken from: https://docs.opencv.org/3.4/d3/d52/tutorial_windows_install.html myRepo=$(pwd) CMAKE_GENERATOR_OPTIONS=-G"Visual Studio 17 2022" #CMAKE_GENERATOR_OPTIONS=-G"Visual Studio 16 2019" #CMAKE_GENERATOR_OPTIONS=-G"Visual Studio 15 2017 Win64" #CMAKE_GENERATOR_OPTIONS=(-G"Visual Studio 16 2019" -A x64) # CMake 3.14+ is required if [ ! -d "$myRepo/opencv" ]; then echo "cloning opencv" git clone https://github.com/opencv/opencv.git else cd opencv git pull --rebase cd .. fi if [ ! -d "$myRepo/opencv_contrib" ]; then echo "cloning opencv_contrib" git clone https://github.com/opencv/opencv_contrib.git else cd opencv_contrib git pull --rebase cd .. fi RepoSource=opencv mkdir -p build_opencv pushd build_opencv CMAKE_OPTIONS=(-DBUILD_PERF_TESTS:BOOL=OFF -DBUILD_TESTS:BOOL=OFF -DBUILD_DOCS:BOOL=OFF -DWITH_CUDA:BOOL=OFF -DBUILD_EXAMPLES:BOOL=OFF -DINSTALL_CREATE_DISTRIB=ON) set -x cmake "${CMAKE_GENERATOR_OPTIONS[@]}" "${CMAKE_OPTIONS[@]}" -DOPENCV_EXTRA_MODULES_PATH="$myRepo"/opencv_contrib/modules -DCMAKE_INSTALL_PREFIX="$myRepo/install/$RepoSource" "$myRepo/$RepoSource" echo "************************* $Source_DIR -->debug" cmake --build . --config debug echo "************************* $Source_DIR -->release" cmake --build . --config release cmake --build . --target install --config release cmake --build . --target install --config debug popd
-
Adjust the
CMAKE_GENERATOR_OPTIONSaccording to your Visual Studio version. -
In git command line enter the following command:
./installOCV.sh
This script will generate the required installation of
Open CVin the current directory (eg.{directory}/AR_Voxel_Project/Libs/install/opencv). -
Keep in mind that this will take some time.
-
Add
{directory}\Libs\install\opencv\binto PATH. -
For further information please check the official OpenCV website.
After installing both libraries, your repository should look like this.
-
Data
-
demo_material
-
images
-
masks
-
-
-
Libs
-
Eigen3
-
opencv
-
install
-
opencv
-
-
opencv_contrib
-
-
src
-
CMakeLists.txt
-
README.adoc
Now you are ready to generate the project using CMake. If you followed the instructions above, CMake should already have found the installation directories of Eigen and OpenCV. Make sure that Eigen3_DIR and OpenCV_DIR are set correctly.
After compiling the project, you are ready to carve your first model.
The following example gives visualize the carved model of our demo object. If you want to reproduce our results, you can use this dataset. For comparison we also provide details about the configuration and the expected output meshes.
$ ./voxel_project.exe -c=1This command will generate a new subdirectory out containing the file BoardImage.jpg. This ChArUco Board can be used to calibrate your individual camera and later on carve your own models.
$ ./voxel_project.exe -c=2Perform camera calibration on previously taken images or take images using a connected camera and perform calibration on those.
After initial calibration, the user can interactively choose to exclude specific images by ID (e.g. outliers). For this, reprojection errors are provided for individual images, as well as the overall error.
The final data is saved to a .yml file that can be specified using -calibration
| Flag | Default | Description |
|---|---|---|
-live=true/false |
true |
Whether the images used for calibration should be taken live using a connected camera. If false, a folder with images for calibration has to be provided to -images. |
-cam_id=<cam_id> |
0 |
The camera to use when performing live calibration. 0 should be the system’s default device. |
-images="<images-dir>" |
Ignored if live==true NonOptional if live==false |
Directory of the input images to be used for calibration e.g. |
-calibration="<calibration-file>" |
out/cameracalibration.yml |
Output file for the camera calibration data. |
$ ./voxel_project.exe -c=5 -images="<images-dir>" -masks="<masks-dir>" -calibration="<cameracalibartion.yml-dir>" -carve=<carving-method> -x=<x-dim> -y=<y-dim> -z=<z-dim> -size=<voxel-size> -scale=<model-scale> -dx=<x-offset> -dy=<y-offset> -dz=<z-offset> -color=<color-method> -model_debug=<model_debug-method> -postprocessing=<postprocessing-method> -intermediateMesh=<intermediateMesh-generation> -outFile=<out_file_path>This command will generate a new file out/mesh.off containing the mesh generated by carving your specified inputs. To understand more about the flags please refer to the table below.
| Flag | Default | Description |
|---|---|---|
-images="<images-dir>" |
NonOptional |
Directory of the input images e.g. |
-masks="<masks-dir>" |
NonOptional |
Directory of the masks e.g. |
-calibration="<cameracalibartion.yml-dir>" |
NonOptional |
Directory of the masks e.g. |
-carve=<carving-method> |
1 |
|
-x=<x-dim> |
100 |
Number of voxels in x direction. |
-y=<y-dim> |
100 |
Number of voxels in y direction. |
-z=<z-dim> |
100 |
Number of voxels in z direction. |
-size=<voxel-size> |
0.0028 |
Side length of a voxel. |
-scale=<model-scale> |
1.0 |
Scale factor for the output model. |
-dx=<x-offset> |
0.0 |
Move output model in x direction (unscaled). |
-dx=<y-offset> |
0.0 |
Move output model in y direction (unscaled). |
-dx=<z-offset> |
0.0 |
Move output model in z direction (unscaled). |
-color=<color-method> |
0 |
|
-model_debug=<model_debug-method> |
false |
|
-postprocessing=<postprocessing-method> |
true |
|
-intermediateMesh=<intermediateMesh-generation> |
false |
|
-outFile=<out_file_path> |
./out/mesh.off |
Filepath the generated mesh will be written to. Should end with |
$ ./voxel_project.exe -c=6 -images="<images-dir>" -masks="<masks-dir>" -calibration="<cameracalibartion.yml-dir>"This command will execute the provided benchmarking cases on the specified data. For each case a mesh file will be generated in out/bench. Additionally, the bash will print a table containing information about the test cases and execution times (see table below).
For more information about the flags please refer to the table above.
| Column | Description |
|---|---|
Name |
Short description of the testcase
|
Model size |
Model dimensions (x, y, z direction) and voxel size |
Carving time |
Time needed to execute carving process (in milliseconds) |
Coloring time |
Time needed to execute coloring process (in milliseconds) |
Postprocessing time |
Time needed for postprocessing (in milliseconds) |
Marching cubes time |
Time needed to transform model into |
Overall time |
Time needed for complete reconstruction process (including output file writing and variable initializations, excluding image loading) (in milliseconds) |
TODO

