|
# Handcrafted solution example for the S23DR competition |
|
|
|
This repo provides an example of a simple algorithm to reconstruct wireframe and submit to S23DR competition. |
|
|
|
|
|
The repo consistst of the following parts: |
|
|
|
- `script.py` - the main file, which is run by the competition space. It should produce `submission.parquet` as the result of the run. |
|
- `hoho.py` - the file for parsing the dataset at the inference time. Do NOT change it. |
|
- `handcrafted_solution.py` - contains the actual implementation of the algorithm |
|
- other `*.py` files - helper i/o and visualization utilities |
|
- `packages/` - the directory to put python wheels for the custom packages you want to install and use. |
|
|
|
## Solution description |
|
|
|
The solution is simple. |
|
|
|
1. Using provided (but noisy) semantic segmentation called `gestalt`, it takes the centroids of the vertex classes - `apex` and `eave_end_point` and projects them to 3D using provided (also noisy) monocular depth. |
|
2. The vertices are connected using the same segmentation, by checking for edges classes to be present - `['eave', 'ridge', 'rake', 'valley']`. |
|
3. All the "per-image" vertex predictions are merged in 3D space if their distance is less than threshold. |
|
4. All vertices, which have zero connections, are removed. |
|
|
|
|
|
## Example on the training set |
|
|
|
See in [notebooks/example_on_training.ipynb](notebooks/example_on_training.ipynb) |
|
|
|
--- |
|
license: apache-2.0 |
|
--- |
|
|
|
|