forked from cvat-ai/cvat
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Documentation: Annotation skeletons (cvat-ai#7197)
- Loading branch information
Showing
14 changed files
with
221 additions
and
115 deletions.
There are no files selected for viewing
16 changes: 0 additions & 16 deletions
16
site/content/en/docs/manual/advanced/annotation-with-skeletons/_index.md
This file was deleted.
Oops, something went wrong.
59 changes: 0 additions & 59 deletions
59
...tent/en/docs/manual/advanced/annotation-with-skeletons/creating-the-skeleton.md
This file was deleted.
Oops, something went wrong.
39 changes: 0 additions & 39 deletions
39
...ntent/en/docs/manual/advanced/annotation-with-skeletons/editing-the-skeleton.md
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,220 @@ | ||
--- | ||
title: 'Annotation with skeletons' | ||
linkTitle: 'Annotation with skeletons' | ||
weight: 12 | ||
description: 'Guide to annotating tasks using Skeletons' | ||
--- | ||
|
||
In this guide, we delve into the efficient process of annotating complex | ||
structures through the implementation of **Skeleton** annotations. | ||
|
||
**Skeletons** serve as annotation templates | ||
for annotating complex objects with a consistent structure, | ||
such as human pose estimation or facial landmarks. | ||
|
||
A **Skeleton** is composed of numerous points (also referred to as elements), | ||
which may be connected by edges. Each point functions as an individual object, | ||
possessing unique attributes and properties like color, occlusion, and visibility. | ||
|
||
**Skeletons** can be [**exported**](/docs/manual/advanced/formats/) | ||
in two formats: [**CVAT for image**](/docs/manual/advanced/formats/format-cvat/#cvat-for-videos-export) | ||
and [**COCO Keypoints**](/docs/manual/advanced/formats/coco-keypoints/). | ||
|
||
> **Note**: that skeletons' labels cannot be imported in a label-less project by importing a dataset. | ||
> You need to define the labels manually before the import. | ||
See: | ||
|
||
- [Adding Skeleton manually](#adding-skeleton-manually) | ||
- [Skeleton Configurator](#skeleton-configurator) | ||
- [Configuring Skeleton points](#configuring-skeleton-points) | ||
- [Adding Skeleton labels manually](#adding-skeleton-labels-manually) | ||
- [Adding Skeleton labels from the model](#adding-skeleton-labels-from-the-model) | ||
- [Annotation with Skeletons](#annotation-with-skeletons) | ||
- [Automatic annotation with Skeletons](#automatic-annotation-with-skeletons) | ||
- [Editing skeletons on the canvas](#editing-skeletons-on-the-canvas) | ||
- [Editing skeletons on the sidebar](#editing-skeletons-on-the-sidebar) | ||
|
||
## Adding Skeleton manually | ||
|
||
To start annotating using skeletons, you need to set up a **Skeleton** task | ||
in **Configurator**: | ||
|
||
To open **Configurator**, when [creating a task](/docs/manual/basics/create_an_annotation_task/), | ||
click on the **Setup skeleton** button if you want to set up the skeleton manually, | ||
or [**From model**](/docs/manual/advanced/skeletons/#adding-skeleton-labels-from-the-model) | ||
if you want to add skeleton labels from a model. | ||
|
||
data:image/s3,"s3://crabby-images/5481a/5481a25f7c8976a984bb9f285e3ceddb9ac62349" alt="" | ||
|
||
### Skeleton Configurator | ||
|
||
The skeleton **Configurator** is a tool to build | ||
skeletons for annotation. It has the following fields: | ||
|
||
data:image/s3,"s3://crabby-images/beb52/beb523cd90ba4869f29e87648a8900361f7286e8" alt="" | ||
|
||
<!--lint disable maximum-line-length--> | ||
|
||
| Number | Name | Description | | ||
| ------ | --------------------------- | ------------------------------------------------------------------------------------------------------------------------------------- | | ||
| **1** | **Upload background image** | (Optional) Use it to upload a background image, to draw a skeleton on top of it. | | ||
| **2** | **Add point** | Use it to add Skeleton points to the **Drawing area** (**8**). | | ||
| **3** | **Click and drag** | Use it to move points across the **Drawing area** (**8**). | | ||
| **4** | **Add edge** | Use it to add edge on the **Drawing area** (**8**) to connect the points (**2**). | | ||
| **5** | **Remove point** | Use it to remove points. Click on **Remove point** and then on any point (**2**) on the **Drawing area** (**8**) to delete the point. | | ||
| **6** | **Download skeleton** | Use it to download created skeleton in .SVG format. | | ||
| **7** | **Upload skeleton** | Use it to upload skeleton in .SVG format. | | ||
| **8** | **Drawing area** | Use it as a canvas to draw a skeleton. | | ||
|
||
<!--lint enable maximum-line-length--> | ||
|
||
### Configuring Skeleton points | ||
|
||
You can name labels, set attributes, | ||
and change the color of each point of the skeleton. | ||
|
||
To do this, right-click on the skeleton point and select **Configure**: | ||
|
||
data:image/s3,"s3://crabby-images/ef285/ef285265523bd9160e13cf8d9c60b4f75f0cda9f" alt="" | ||
|
||
In the opened menu, you can change the point setting. It is similar to | ||
[adding labels and attributes of the regular task](docs/manual/basics/create_an_annotation_task/#create-a-task): | ||
|
||
data:image/s3,"s3://crabby-images/11a66/11a6640eb6555ddd16d2a4617a10f2eb267535e5" alt="" | ||
|
||
A **Skeleton** point can only exist within its parent **Skeleton**. | ||
|
||
> **Note** that you cannot change the skeleton configuration for an existing task/project. | ||
> You can copy/insert skeleton configuration from the **Raw** tab of the label configurator. | ||
### Adding Skeleton labels manually | ||
|
||
To create the **Skeleton** task, do the following: | ||
|
||
1. Open **Configurator**. | ||
2. (Optional) Upload background image. | ||
3. In the Label name field, enter the name of the label. | ||
4. (Optional) [**Add attribute**](/docs/manual/basics/create_an_annotation_task/#add-an-attribute) | ||
<br>**Note**: you can add attributes exclusively to each point, | ||
for more information, see [**Configuring Skeleton points**](#configuring-skeleton-points) | ||
5. Use **Add point** to add points to the **Drawing area**. | ||
6. Use **Add edge** to add edges between points. | ||
7. Upload files. | ||
8. Click: | ||
- **Submit & Open** to create and open the task. | ||
- **Submit & Continue** to submit the configuration and start creating a new task. | ||
|
||
## Adding Skeleton labels from the model | ||
|
||
To add points from the model, and annotate do the following: | ||
|
||
1. Open **Basic configurator**. | ||
2. On the **Constructor** tab, click **From model**. | ||
3. From the **Select a model to pick labels** select the | ||
`Human pose estimation` model or others if available. | ||
4. Click on the model's labels, you want to use. | ||
<br>Selected labels will become gray. | ||
|
||
data:image/s3,"s3://crabby-images/7eccf/7eccf9cfaf0823a317c3ed04758a3e1feec1c2fe" alt="" | ||
|
||
5. (Optional) If you want to adjust labels, within the | ||
label, click the **Update** attributes icon. | ||
<br>The [**Skeleton configurator**](/docs/manual/advanced/skeletons/#skeleton-configurator) | ||
will open, where you can [**configure the skeleton**](/docs/manual/advanced/skeletons/#configuring-skeleton-points). | ||
<br>**Note**: Labels cannot be adjusted after the task/project is created. | ||
6. Click **Done**. The labels, that you selected, | ||
will appear in the labels window. | ||
7. Upload data. | ||
8. Click: | ||
- **Submit & Open** to create and open the task. | ||
- **Submit & Continue** to submit the configuration and start creating a new task. | ||
|
||
## Annotation with Skeletons | ||
|
||
To annotate with **Skeleton**, do the following | ||
|
||
1. Open job. | ||
2. On the tools panel select **Draw new skeleton**. | ||
3. Select **Track** or **Shape** to annotate. | ||
without tracking. | ||
|
||
data:image/s3,"s3://crabby-images/fd758/fd758991db2cf4772581c054a196def3881e6e5e" alt="" | ||
|
||
4. Draw a skeleton on the image. | ||
|
||
data:image/s3,"s3://crabby-images/4ce83/4ce83241115f1b66cc93bc19b41a70d01c28ff27" alt="" | ||
|
||
## Automatic annotation with Skeletons | ||
|
||
To automatically annotate with **Skeleton**, do the following | ||
|
||
1. Open the job and on the tools panel select **AI Tools** > **Detectors** | ||
2. From the drop-down list select the model. | ||
You will see a list of points to match and | ||
the name of the skeleton on the top of the list. | ||
|
||
data:image/s3,"s3://crabby-images/d7792/d77920b2d62a88360a2506cd5819cb00a1272cee" alt="" | ||
|
||
3. (Optional) By clicking on the **Bin** icon, you can | ||
remove any mapped item: | ||
- A skeleton together with all points. | ||
- Certain points from two mapped skeletons. | ||
4. Click **Annotate**. | ||
|
||
## Editing skeletons on the canvas | ||
|
||
A drawn skeleton is encompassed within a bounding box, | ||
it allows you to manipulate the skeleton as a regular bounding box, | ||
enabling actions such as dragging, resizing, or rotating: | ||
|
||
data:image/s3,"s3://crabby-images/2fae3/2fae393cc20218fb2747f50b62b0beef44f7f1f5" alt="" | ||
|
||
Upon repositioning a point, the bounding box adjusts automatically, | ||
without affecting other points: | ||
|
||
data:image/s3,"s3://crabby-images/5fcd1/5fcd12c93f1204a184bf214b56d0d6b265afbb76" alt="" | ||
|
||
Additionally, **Shortcuts** are applicable | ||
to both the skeleton as a whole and its elements: | ||
|
||
- To use a shortcut to the entire skeleton, hover over | ||
the bounding box and push the shortcut keyboard key. | ||
This action is applicable for shortcuts like the lock, occluded, | ||
pinned, keyframe, and outside for skeleton tracks. | ||
- To use a shortcut to a specific skeleton point, hover over the | ||
point and push the shortcut keyboard key. | ||
The same list of shortcuts is available, with the addition of outside, | ||
which is also applicable to individual skeleton shape elements. | ||
|
||
## Editing skeletons on the sidebar | ||
|
||
In CVAT, the sidebar offers an alternative method for setting | ||
up skeleton properties and attributes. | ||
|
||
This approach is similar to that used for other | ||
object types supported by CVAT, but with a few specific alterations: | ||
|
||
An additional collapsible section is provided for | ||
users to view a comprehensive list of skeleton parts. | ||
|
||
<div style="display: flex; align-items: flex-start;"> | ||
<img src="/images/image-skeleton-track-sidebar.jpg" width="300px" /> | ||
<img src="/images/image-skeleton-shape-sidebar.jpg" width="300px" /> | ||
</div> | ||
|
||
Skeleton points can have properties like **Outside**, **Occluded**, and **Hidden**. | ||
|
||
data:image/s3,"s3://crabby-images/53cff/53cffa95ad15b5d478dcb33dbae5b1bb49a13028" alt="" | ||
|
||
Both **Outside** and **Hidden** make a skeleton point invisible. | ||
|
||
- **Outside** property is part of annotations. | ||
Use it when part of the object is out of frame borders. | ||
|
||
- **Hidden** makes a point hidden only for the annotator's | ||
convenience, this property will not be saved between different sessions. | ||
|
||
- **Occluded** keeps the point visible on the frame and usually | ||
means that the point is still on a frame, just hidden behind another object. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified
BIN
-58.8 KB
(27%)
site/content/en/images/image-skeleton-configurator-overview.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.