Conjunto de dados COCO-Pose

O conjunto de dados COCO-Pose é uma versão especializada do conjunto de dados COCO (Common Objects in Context), projetado para tarefas de estimativa de pose. Ele utiliza as imagens e rótulos do COCO Keypoints 2017 para permitir o treinamento de modelos como o YOLO para tarefas de estimativa de pose.

Estimativa de pose COCO com pontos-chave humanos

Modelos pré-treinados COCO-Pose

Modelotamanho
(pixels)
mAPpose
50-95(e2e)
mAPpose
50(e2e)
Velocidade
CPU ONNX
(ms)
Velocidade
T4 TensorRT10
(ms)
params
(M)
FLOPs
(B)
YOLO26n-pose64057.283.340.3 ± 0.51.8 ± 0.02.97.5
YOLO26s-pose64063.086.685.3 ± 0.92.7 ± 0.010.423.9
YOLO26m-pose64068.889.6218.0 ± 1.55.0 ± 0.121.573.1
YOLO26l-pose64070.490.5275.4 ± 2.46.5 ± 0.125.991.3
YOLO26x-pose64071.691.6565.4 ± 3.012.2 ± 0.257.6201.7

Principais recursos

  • O COCO-Pose baseia-se no conjunto de dados COCO Keypoints 2017, que contém 200 mil imagens rotuladas com pontos-chave para tarefas de estimativa de pose.
  • O conjunto de dados suporta 17 pontos-chave para figuras humanas, facilitando a estimativa detalhada de pose.
  • Como o COCO, ele fornece métricas de avaliação padronizadas, incluindo a Semelhança de Pontos-chave de Objeto (OKS - Object Keypoint Similarity) para tarefas de estimativa de pose, tornando-o adequado para comparar o desempenho dos modelos.

Estrutura do Dataset

O conjunto de dados COCO-Pose é dividido em três subconjuntos:

  1. Train2017: Este subconjunto contém 56.599 imagens do conjunto de dados COCO, anotadas para o treinamento de modelos de estimativa de pose.
  2. Val2017: Este subconjunto possui 2.346 imagens usadas para fins de validação durante o treinamento do modelo.
  3. Test2017: Este subconjunto consiste em imagens usadas para testar e avaliar os modelos treinados. As anotações de verdade fundamental (ground truth) para este subconjunto não estão disponíveis publicamente, e os resultados são enviados para o servidor de avaliação COCO para avaliação de desempenho.

Aplicações

O conjunto de dados COCO-Pose é usado especificamente para treinar e avaliar modelos de deep learning em tarefas de detecção de pontos-chave e estimativa de pose, como o OpenPose. O grande número de imagens anotadas e as métricas de avaliação padronizadas do conjunto de dados o tornam um recurso essencial para pesquisadores e profissionais de visão computacional focados em estimativa de pose.

YAML do Dataset

Um arquivo YAML (Yet Another Markup Language) é usado para definir a configuração do conjunto de dados. Ele contém informações sobre os caminhos do conjunto de dados, classes e outras informações relevantes. No caso do conjunto de dados COCO-Pose, o arquivo coco-pose.yaml é mantido em https://github.com/ultralytics/ultralytics/blob/main/ultralytics/cfg/datasets/coco-pose.yaml.

ultralytics/cfg/datasets/coco-pose.yaml
# Ultralytics 🚀 AGPL-3.0 License - https://ultralytics.com/license

# COCO 2017 Keypoints dataset https://cocodataset.org by Microsoft
# Documentation: https://docs.ultralytics.com/datasets/pose/coco/
# Example usage: yolo train data=coco-pose.yaml
# parent
# ├── ultralytics
# └── datasets
#     └── coco-pose ← downloads here (20.1 GB)

# Train/val/test sets as 1) dir: path/to/imgs, 2) file: path/to/imgs.txt, or 3) list: [path/to/imgs1, path/to/imgs2, ..]
path: coco-pose # dataset root dir
train: train2017.txt # train images (relative to 'path') 56599 images
val: val2017.txt # val images (relative to 'path') 2346 images
test: test-dev2017.txt # 20288 of 40670 images, submit to https://codalab.lisn.upsaclay.fr/competitions/7403

# Keypoints
kpt_shape: [17, 3] # number of keypoints, number of dims (2 for x,y or 3 for x,y,visible)
flip_idx: [0, 2, 1, 4, 3, 6, 5, 8, 7, 10, 9, 12, 11, 14, 13, 16, 15]

# Classes
names:
  0: person

# Keypoint names per class
kpt_names:
  0:
    - nose
    - left_eye
    - right_eye
    - left_ear
    - right_ear
    - left_shoulder
    - right_shoulder
    - left_elbow
    - right_elbow
    - left_wrist
    - right_wrist
    - left_hip
    - right_hip
    - left_knee
    - right_knee
    - left_ankle
    - right_ankle

# Download script/URL (optional)
download: |
  from pathlib import Path

  from ultralytics.utils import ASSETS_URL
  from ultralytics.utils.downloads import download

  # Download labels
  dir = Path(yaml["path"])  # dataset root dir

  urls = [f"{ASSETS_URL}/coco2017labels-pose.zip"]
  download(urls, dir=dir.parent)
  # Download data
  urls = [
      "http://images.cocodataset.org/zips/train2017.zip",  # 19G, 118k images
      "http://images.cocodataset.org/zips/val2017.zip",  # 1G, 5k images
      "http://images.cocodataset.org/zips/test2017.zip",  # 7G, 41k images (optional)
  ]
  download(urls, dir=dir / "images", threads=3)

Utilização

Para treinar um modelo YOLO26n-pose no conjunto de dados COCO-Pose por 100 épocas com um tamanho de imagem de 640, você pode usar os seguintes trechos de código. Para uma lista abrangente de argumentos disponíveis, consulte a página de Treinamento do modelo.

Exemplo de Treino
from ultralytics import YOLO

# Load a model
model = YOLO("yolo26n-pose.pt")  # load a pretrained model (recommended for training)

# Train the model
results = model.train(data="coco-pose.yaml", epochs=100, imgsz=640)

Amostra de Imagens e Anotações

O conjunto de dados COCO-Pose contém um conjunto diversificado de imagens com figuras humanas anotadas com pontos-chave. Aqui estão alguns exemplos de imagens do conjunto de dados, juntamente com suas anotações correspondentes:

Lote de treinamento de mosaico do conjunto de dados de estimativa de pose COCO

  • Imagem em mosaico: Esta imagem demonstra um lote de treino composto por imagens do conjunto de dados em mosaico. A técnica de mosaico é um método utilizado durante o treino que combina várias imagens numa única para aumentar a variedade de objetos e cenas dentro de cada lote de treino. Isto ajuda a melhorar a capacidade do modelo de generalizar para diferentes tamanhos de objetos, proporções e contextos.

O exemplo mostra a variedade e a complexidade das imagens no conjunto de dados COCO-Pose e os benefícios de usar mosaicos durante o processo de treinamento.

Citações e Agradecimentos

Se você usar o conjunto de dados COCO-Pose em seu trabalho de pesquisa ou desenvolvimento, cite o seguinte artigo:

Citação
@misc{lin2015microsoft,
      title={Microsoft COCO: Common Objects in Context},
      author={Tsung-Yi Lin and Michael Maire and Serge Belongie and Lubomir Bourdev and Ross Girshick and James Hays and Pietro Perona and Deva Ramanan and C. Lawrence Zitnick and Piotr Dollár},
      year={2015},
      eprint={1405.0312},
      archivePrefix={arXiv},
      primaryClass={cs.CV}
}

Gostaríamos de agradecer ao Consórcio COCO por criar e manter este recurso valioso para a comunidade de visão computacional. Para obter mais informações sobre o conjunto de dados COCO-Pose e seus criadores, visite o site do conjunto de dados COCO.

FAQ

O que é o conjunto de dados COCO-Pose e como ele é usado com o Ultralytics YOLO para estimativa de pose?

O conjunto de dados COCO-Pose é uma versão especializada do conjunto de dados COCO (Common Objects in Context) projetado para tarefas de estimativa de pose. Ele se baseia nas imagens e anotações do COCO Keypoints 2017, permitindo o treinamento de modelos como o Ultralytics YOLO para estimativa detalhada de pose. Por exemplo, você pode usar o conjunto de dados COCO-Pose para treinar um modelo YOLO26n-pose carregando um modelo pré-treinado e treinando-o com uma configuração YAML. Para exemplos de treinamento, consulte a documentação de Treinamento.

Como posso treinar um modelo YOLO26 no conjunto de dados COCO-Pose?

O treinamento de um modelo YOLO26 no conjunto de dados COCO-Pose pode ser realizado usando Python ou comandos CLI. Por exemplo, para treinar um modelo YOLO26n-pose por 100 épocas com um tamanho de imagem de 640, você pode seguir os passos abaixo:

Exemplo de Treino
from ultralytics import YOLO

# Load a model
model = YOLO("yolo26n-pose.pt")  # load a pretrained model (recommended for training)

# Train the model
results = model.train(data="coco-pose.yaml", epochs=100, imgsz=640)

Para mais detalhes sobre o processo de treinamento e os argumentos disponíveis, verifique a página de treinamento.

Quais são as diferentes métricas fornecidas pelo conjunto de dados COCO-Pose para avaliar o desempenho do modelo?

O conjunto de dados COCO-Pose fornece várias métricas de avaliação padronizadas para tarefas de estimativa de pose, semelhantes ao conjunto de dados COCO original. As principais métricas incluem a Semelhança de Pontos-chave de Objeto (OKS), que avalia a precisão dos pontos-chave previstos em relação às anotações de verdade fundamental. Essas métricas permitem comparações de desempenho detalhadas entre diferentes modelos. Por exemplo, os modelos pré-treinados do COCO-Pose, como YOLO26n-pose, YOLO26s-pose e outros, possuem métricas de desempenho específicas listadas na documentação, como mAPpose50-95 e mAPpose50.

Como o conjunto de dados COCO-Pose é estruturado e dividido?

O conjunto de dados COCO-Pose é dividido em três subconjuntos:

  1. Train2017: Contém 56.599 imagens COCO, anotadas para o treinamento de modelos de estimativa de pose.
  2. Val2017: 2.346 imagens para fins de validação durante o treinamento do modelo.
  3. Test2017: Imagens usadas para testar e avaliar modelos treinados. As anotações de verdade fundamental para este subconjunto não estão publicamente disponíveis; os resultados são enviados para o servidor de avaliação COCO para avaliação de desempenho.

Esses subconjuntos ajudam a organizar as fases de treinamento, validação e teste de forma eficaz. Para detalhes de configuração, explore o arquivo coco-pose.yaml disponível no GitHub.

Quais são as principais características e aplicações do conjunto de dados COCO-Pose?

O conjunto de dados COCO-Pose amplia as anotações do COCO Keypoints 2017 para incluir 17 pontos-chave para figuras humanas, permitindo uma estimativa detalhada de pose. Métricas de avaliação padronizadas (por exemplo, OKS) facilitam comparações entre diferentes modelos. As aplicações do conjunto de dados COCO-Pose abrangem vários domínios, como análise esportiva, saúde e interação humano-computador, sempre que for necessária uma estimativa detalhada da pose de figuras humanas. Para uso prático, aproveitar modelos pré-treinados como os fornecidos na documentação (por exemplo, YOLO26n-pose) pode agilizar significativamente o processo (Principais Características).

Se você usar o conjunto de dados COCO-Pose em seu trabalho de pesquisa ou desenvolvimento, cite o artigo com a seguinte entrada BibTeX.

Comentários