|
--- |
|
title: Demo Space |
|
emoji: 🤗 |
|
colorFrom: yellow |
|
colorTo: orange |
|
sdk: gradio |
|
app_file: app.py |
|
pinned: false |
|
--- |
|
|
|
|
|
# YOLOv8-TO |
|
Code for the article "From Density to Geometry: YOLOv8 Instance Segmentation for Reverse Engineering of Optimized Structures" |
|
|
|
## Table of Contents |
|
- [Overview](#overview) |
|
- [Reference](#reference) |
|
- [Installation](#installation) |
|
- [Prerequisites](#prerequisites) |
|
- [Installing](#installing) |
|
- [Datasets](#datasets) |
|
- [Training](#training) |
|
- [Inference](#inference) |
|
|
|
## Overview |
|
Brief description of what the project does and the problem it solves. Include a link or reference to the original article that inspired or is associated with this implementation. |
|
|
|
## Demo |
|
Try it at: |
|
|
|
## Reference |
|
This code aims to reproduce the results presented in the research article: |
|
|
|
```bibtex |
|
@misc{rochefortbeaudoin2024density, |
|
title={From Density to Geometry: YOLOv8 Instance Segmentation for Reverse Engineering of Optimized Structures}, |
|
author={Thomas Rochefort-Beaudoin and Aurelian Vadean and Sofiane Achiche and Niels Aage}, |
|
year={2024}, |
|
eprint={2404.18763}, |
|
archivePrefix={arXiv}, |
|
primaryClass={cs.CV} |
|
} |
|
``` |
|
## Installation |
|
|
|
### Prerequisites |
|
This package comes with a fork of the ultralytics package in the yolov8-to directory. The fork is necessary to add the functionality of the design variables regression. |
|
|
|
### Installing |
|
|
|
```bash |
|
git clone https://github.com/COSIM-Lab/YOLOv8-TO.git |
|
cd YOLOv8-TO |
|
pip install -e . |
|
``` |
|
## Datasets |
|
Links to the dataset on HuggingFace: |
|
- [YOLOv8-TO_Data](https://huggingface.co/datasets/tomrb/yolov8to_data) |
|
|
|
The Huggingface dataset contains the following datasets (see paper for details): |
|
- MMC |
|
- MMC-random |
|
- SIMP |
|
- SIMP_5% |
|
- OOD |
|
|
|
|
|
If you want to use one of the linked datasets, please unzip it inside of the datasets folder. Training labels are provided for the MMC and MMC-random data. To train on the data, please update the data.yaml file with the correct path to the dataset. |
|
```yaml |
|
path: # dataset root dir |
|
``` |
|
|
|
|
|
## Training |
|
|
|
To train the model, make sure the train dataset is setup according to the above section and according to the documentation from ultralytics: |
|
https://docs.ultralytics.com/datasets/ |
|
|
|
Refer to the notebook `YOLOv8_TO.ipynb` for an example of how to train the model. |
|
|
|
## Inference |
|
Refer to the notebook `YOLOv8_TO.ipynb` for an example of how to perform inference with the trained model. |