-
Notifications
You must be signed in to change notification settings - Fork 137
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support YOLO Ultralytics segmentation #1114
Comments
Hi @hugo082, sorry for the late response, sure, we are always open to add more features. Please feel free to create the PR. This will be helpful to be consistent to YOLO-Ultralytics. |
Using the script general_json2yolo.py, you can convert the RLE mask with holes to the YOLO segmentation format. The RLE mask is converted to a parent polygon and a child polygon using
The RLE mask. The converted YOLO segmentation format. To run the script, put the COCO JSON file coco_train.json into Edit use_segments and use_keypoints in the script.
To convert the COCO bbox format to YOLO bbox format.
To convert the COCO segmentation format to YOLO segmentation format.
To convert the COCO keypoints format to YOLO keypoints format.
This script originates from Ultralytics JSON2YOLO repository. |
was a PR ever made out of this ? It would be useful to have conversion from |
Hi, you can find it implemented in our fork: https://github.com/cvat-ai/datumaro/blob/7b388295769d5198b7475906a6e4eb2d83235063/src/datumaro/plugins/data_formats/yolo/exporter.py#L380 |
Hi,
It would be nice to have support for YOLO Ultralytics segmentation format. Currently when we export a mask via CVAT and YOLO 1.1 format, which use datumaro under the hood, the masks are ignored.
The segmentation format is pretty similar to the bbox one (with more points) and I identified the code responsible of the convertion.
I can take time to propose a PR, do you think it is possible to merge only the export part?
I already develop some code to convert Label studio brush labels to YOLO segmentation, and it seems we can access the bitwise 2d mask from
datumaro.annotation.Mask
so the code should stay pretty similar to the following:The text was updated successfully, but these errors were encountered: