The AAFR is a framework for virtually reassembling broken objects. Click here to check out the project page for more details
It was developed within the RePAIR european project but the reconstruction works also for other broken objects. We tested it on the breaking bad dataset and on the brick from the TU-Wien dataset.
Receiving as input the point cloud of each broken part of the object (initially we start with two, but it will be extended to multiple, the work is already in progress)).
The pipeline consists of several steps:
- it creates two graphs from each pointcloud (one for the whole point cloud, one for the borders), then it computes corner penalties to detect points belonging to breaking curves (edges in 3D data).
- following these breaking curves, the pointcloud is segmented into regions.
- each possible pair of regions (excluding super small regions) is registered and the registration is evaluated. The best registration is selected and applied to the pointcloud.
We do not have yet a clean environment, but we have a requirements.txt
file which can be installed using pip
:
pip install -r requirements.txt
The registration part can be achieved using different modules. Although at the publication time we used mostly ICP, currently the code uses TEASER++ to register segmented regions, because is more robust to the initial position.
So you need to install and link teaser, check the getting started section or directly the instructions for the python bindings here.
ICP can be used, but the test_icp.py
file should be slightly modified (should return a panda dataframe with results (see teaser.py
), not only an array). Hopefully this will be done soon, but using TEASER++ is recommended to get the best results.
If you really want to use ICP change the pipeline_parameters
in configs/assemble_cfg.py
and set registration_module
to icp
and check the test_module/icp.py
file (you need to finish the implementation)
In the configs/assemble_cfg.py
you should have
pipeline_parameters = {
'processing_module' : "standard",
'registration_module' : "icp",
'evaluation_metrics' : ["rms"]
}
The rest of the code uses libraries which are located in this (sub)folder (so make sure the root path is included).
It was tested using python 3.9.0
on Ubuntu 20.04
.
The code does many computations, so we created a couple of scripts to be able to run it quickly without complications.
These are based on the breaking bad dataset because this is available and easier to use.
The data collection process from the RePAIR project is yet to be finished and the data will be released when ready, so at the moment it is not possible to make experiments with these objects.
However, the code can be easily modified to work with different kind of data (it uses pointcloud, but resampling a mesh in a pointcloud is easy and you find an example in the prepare_challenge.py
script if needed).
If there are issues or you need help, please do open an issue and ask.
If you want to use it on your own data, check the data preparation section.
If you want to assemble fragments (you have prepared data), check the assembling fragment section.
If you have no idea, check the demo file for a quick run (everything is prepared).
If you already have the pointclouds of the broken objects in some random position, you can skip this part.
If you want to test with two pointclouds which are initially aligned, you can run the preparation script (please change the path )
We prepared an example based on the breaking bad dataset, please change the /path_to_breaking_bad_dataset/
to the real path on your local computer.
Then run:
python prepare_challenge.py --cfg configs/prepare_cfg.yaml
This is prepared for the breaking bad dataset, so it assumes the data has subfolder (category, fracture_id, objects_files) and re-creates this structures in the output folder. If you have different structure, change the prepare challenge code (for example lines 65 and 66 of prepare_challenge.py
extract category and fracture_id from the path)
The script reads the configuration from configs/prepare_cfg.yaml
(check the file for more info), it reads the data (either .obj
mesh or .ply
pointcloud) and resample it.
It contains a list of the broken objects (this works for a list of data)
It has r
and t
vectors which are the angles and units for rotation and translation.
Everything will be prepared and saved in the output folder (which is by default data
in the root folder where you run the code).
You can check there that everything worked (it will create subfolders and write there the resampled pointclouds with some rotation and translation as a challenge).
Assuming the data is ready, we can run the script to assemble the data. It works on a loop, so it will reconstruct all the folders. We created a script for the assembly, which can be run as:
python assemble_fragments.py --cfg assemble_cfg
This will assemble all the broken objects and create a lot (maybe too much? The call to the saving functions (detached from the computational one for ease of use) are easy to disable, check the code in assemble_fragments.py
and look for fr_ass.save_
)
The results will be in the output folder (check the name, line 19 of configs/assembly_cfg.py
file) and will contain segmented data (colored) registered data and a copy of the pointcloud (and also colored borders) so you should be able to easily visualize all intermediate steps (if you have no idea, use Meshlab to visualize .ply
files)
Why before a .yaml
file and now a .py
file as config (with different syntax)?
They were created at different times, and the .py
file is very useful to create nested folders. They are relatively easy to use so it should be possible to understand both, sorry for the change`.
There is a demo run prepared. Check the demo file for more info.
The repo contains a lot of experiments, which will be organized with time. Use the scripts mentioned above for a guaranteed execution and use the rest of the code at your own risk.
If you encounter an issue due to modules compiled with different versions of numpy, most likely you are using numpy 2.0 and the code was done using a previous version. Thanks to @ronaldpan who opened and solved the issue #6 we know a quick workaround is to downgrade to numpy==1.26.4
.
The code is related to the paper accepted in the 2023 3DVR CVPR Workshop and published as conference proceedings at the 27th IEEE International Conference on Pattern Recognition, Kolkata, India, 2024.
To cite the paper:
@misc{alagrami2023reassembling,
title={Reassembling Broken Objects using Breaking Curves},
author={Ali Alagrami and Luca Palmieri and Sinem Aslan and Marcello Pelillo and Sebastiano Vascon},
year={2023},
eprint={2306.02782},
archivePrefix={arXiv},
primaryClass={cs.CV}
}
This work is part of a project that has received funding from the European Union's Horizon 2020 research and innovation programme under grant agreement No.964854.
🔥 Shootout to @LucHayward for help in improving performance on the segmentation part: turns out, changing a list to a set when iterating over it for long time yielded a ~100x speed up!
The code is released under the Creative Commons Zero v1.0 Universal License. For more details, refer to the license itself.
The project page is available here
This page was built using the Academic Project Page Template.
You are free to borrow the of this website, we just ask that you link back to this page in the footer.
This website is licensed under a Creative
Commons Attribution-ShareAlike 4.0 International License.
Shootout to Eliahu Horwitz for the template. Thanks a lot.