COCO
Overview
This converter allows to import images with annotations in COCO format. COCO format has all annotations in one .json file.
"Auto Import" app supports the following COCO annotation types: instances, keypoints, captions.

Enterprise users have access to "Import as links" option, which supports import of this format with annotations. This option might be beneficial in many cases, as it allows data import to Supervisely platform without re-uploading, maintaining a single source and speeding up import process.
To step up import speed even further you can compress all annotation files (.json's) into an archive and import it together with the images. (Note: This method is format-dependent and may not apply to all formats.)
Format description
Supported image formats: .jpg, .jpeg, .mpo, .bmp, .png, .webp, .tiff, .tif, .jfif, .avif, .heic, and .heif
With annotations: yes
Supported annotation file extension: .json.
Grouped by: any structure (will be uploaded as a single dataset)\
Default option: Import images and annotations together
Use this option if you have images and annotations in COCO format and you want to upload them together to Supervisely.
We prepared sample datasets in COCO format for you to try the import process:
- instances: download ⬇️ 
- keypoints: download ⬇️ 
Recommended directory structure:
    📦project name
     ┗ 📂dataset
        ┣ 📂annotations
        ┃  ┗ 📜instances.json
        ┗ 📂images
           ┣ 🖼️0001.png
           ┣ 🖼️0002.png
           ┣ 🖼️0003.png
           ┣ 🖼️0004.png
           ┗ 🖼️0005.pngAdvanced option: how to speed up the import process
🏋️♂️ Use this option if you have a large dataset already uploaded to Supervisely and you don't want to upload images again (for example, you have a dataset with images and you want to upload annotations only).
All you need to do is upload the JSON file with annotations in COCO format. The application will match the annotations with the images by their names and upload the annotations to the existing dataset.
Key points:
- Press - + Import databutton inside the dataset: you need to run the import process from the dataset that contains the images.
- Image names: the application will match the annotations with the images by their names. So, make sure that the names of the images in the dataset match the names of the images in the COCO annotations file. 
- Impact on existing annotations: new annotations will be merged with the existing ones. If you want to keep the original annotations, clone the dataset before importing new annotations. 
COCO Annotation
COCO format is a complex format that can contain multiple types of annotations. Supervisely import supports only instances, keypoints, and captions. The COCO dataset is formatted in .json and is a dictionary of keys info, licenses, images, annotations, and categories (in most cases).
- info- contains high-level information about the dataset
- licenses- contains a list of image licenses that apply to images in the dataset.
- images- contains the complete list of images in your dataset. Note that image ids need to be unique among other images.
- annotations- contains a list of every individual object annotation from every image in the dataset.
- categories- contains a list of categories (e.g. dog, boat) and each of those belongs to a supercategory (e.g. animal, vehicle). The original COCO dataset contains 90 categories. You can use the existing COCO categories or create an entirely new list of your own. Each category ID must be unique among the rest of the categories.
Instances
Regions of interest indicated by these annotations are specified by segmentations, which are usually a list of polygon vertices around the object, but can also be a run-length-encoded (RLE) bit mask. Typically, RLE is used for groups of objects (like a large stack of books).
Example annotation for instances for one image in COCO format:
Keypoints
Annotations for keypoints are just like in Object Detection (Segmentation) above, except a number of keypoints is specified in sets of 3, (x, y, v).
- x and y indicate pixel positions in the image. 
- v indicates visibility — v=0: not labeled (in which case x=y=0), v=1: labeled but not visible (behind an object for example), and v=2: labeled and visible. Only keypoints with v=2 will be uploaded to the project. 
Example of the annotation file with keypoints:
Captions
Image caption annotations are pretty simple. There are no categories in this .json file, just annotations with caption descriptions.
Useful links
Last updated
