Learning and Intelligent Systems Project, TU Berlin, WS 20/21
Marius Montebaur, Danny Driess, Jung-Su Ha, Marc Toussaint
Media: Final Presentation, Project Report, Project Video
Every subdirectory has its own README.md
file with detailed explanations.
data_generation/
: Scripts for generating training data and download links to datasets.evaluation/
: Contains code that analyzes a trained network's performance in specific scenarios.common/
: Code used for data generation as well as evaluation.mankey/
: Developed from mankey-ros repo. Manipulation based on Keypoints.training/
: Training scripts for different versions of the keypoint detection.inference/
: Code to infer the 3D positions of keypoints from predictions.network/
: Network definitions
third_party/
rai/
: Simulatormrcnn_integrate/
: A fork of the code that was used to train the bounding box (segmentation) algorithm and adapted it to work with the stick.maskrcnn-benchmark/
: A fork of a segmentation algorithm by facebook research. It's not maintained anymore and my fork fixes a few things and adds a Dockerfile.
Unless stated otherwise, the code in this repository was used and tested with Python 3.6 and PyTorch 1.7.1.
After cloning, first make sure all submodules are cloned as well:
git submodule init
git submodule update
# Used by data generation and evaluatoin
pip3 install pybind11 jupyter matplotlib
# Used to train the model. PyTorch is also needed, look below.
pip3 install Pillow pretrainedmodels attrs opencv-python
# Used to visualize and inspect the network's structure
pip3 install torchsummaryX torchviz
Depending on your machine, choose to install pytorch with cuda support or without.
# With cuda support
pip3 install torch==1.7.1+cu102 torchvision==0.8.2+cu102 torchaudio==0.7.2 -f https://download.pytorch.org/whl/torch_stable.html
# Without cuda support
pip3 install torch==1.7.1+cpu torchvision==0.8.2+cpu torchaudio==0.7.2 -f https://download.pytorch.org/whl/torch_stable.html
cd third_party/rai
# Copy default config and disable dependency on pytorch
cp build/config.mk.default config.mk
echo "TORCH = 0" >> config.mk
# Print dependencies the install script will install
make -j1 printUbuntuAll
# Install necessary dependencies
make -j1 installUbuntuAll
# Build rai
make -j $(nproc)
Detailed running instructions for the data generation, the training process and the evaluation are found in their respective directories. Feel free to skip a step, e.g. by not generating training data on your own, but by using the data available for download.
To use the keypoint detection training and inference code, set the python path to include this repository's root:
# From this repo's root
source set_pythonpath.sh
The models that have been used for the evaluation and the generated training data are available for download.
- Training data: Descriptions of the different datasets and links are available listed in
data_generation/README.md
. - Trained Models: Training procedure and download links are in
mankey/README.md
.