
Link to this sectionYOLOv5 con Comet#
Esta guía cubre cómo usar YOLOv5 con Comet, una potente herramienta para realizar el seguimiento, la comparación y la optimización de experimentos de aprendizaje automático.
Link to this sectionAcerca de Comet#
Comet desarrolla herramientas que ayudan a científicos de datos, ingenieros y líderes de equipo a acelerar y optimizar modelos de aprendizaje automático y aprendizaje profundo.
Realiza el seguimiento y visualiza las métricas del modelo en tiempo real, guarda tus hiperparámetros, conjuntos de datos y puntos de control (checkpoints) del modelo, y visualiza las predicciones de tu modelo con Comet Custom Panels! ¡Comet se asegura de que nunca pierdas el rastro de tu trabajo y facilita compartir resultados y colaborar en equipos de todos los tamaños!
Link to this sectionIntroducción#
Link to this sectionInstala Comet#
pip install comet_mlLink to this sectionConfigura las credenciales de Comet#
Existen dos formas de configurar Comet con YOLOv5.
Puedes configurar tus credenciales a través de variables de entorno:
Variables de entorno
export COMET_API_KEY=YOUR_API_KEY
export COMET_PROJECT_NAME=YOUR_COMET_PROJECT_NAME # This will default to 'yolov5'O bien, crea un archivo .comet.config en tu directorio de trabajo y configura tus credenciales allí:
Archivo de configuración de Comet
[comet]
api_key=YOUR_API_KEY
project_name=YOUR_COMET_PROJECT_NAME # This will default to 'yolov5'Link to this sectionEjecuta el script de entrenamiento#
# Train YOLOv5s on COCO128 for 5 epochs
python train.py --img 640 --batch 16 --epochs 5 --data coco128.yaml --weights yolov5s.pt¡Eso es todo! Comet registrará automáticamente tus hiperparámetros, argumentos de línea de comandos, y métricas de entrenamiento y validación. Puedes visualizar y analizar tus ejecuciones en la interfaz de usuario (UI) de Comet.

Link to this section¡Prueba un ejemplo!#
Echa un vistazo a un ejemplo de una ejecución completada aquí.
O mejor aún, pruébalo tú mismo en este Colab Notebook:
Link to this sectionRegistro automático#
De forma predeterminada, Comet registrará los siguientes elementos:
Link to this sectionMétricas#
- Pérdida de caja (Box Loss), pérdida de objeto (Object Loss), pérdida de clasificación (Classification Loss) para el entrenamiento y los datos de validación
- Métricas mAP_0.5, mAP_0.5:0.95 para los datos de validación
- Precisión y exhaustividad (Recall) para los datos de validación
Link to this sectionParámetros#
- Hiperparámetros del modelo
- Todos los parámetros pasados a través de las opciones de línea de comandos
Link to this sectionVisualizaciones#
- Matriz de confusión de las predicciones del modelo sobre los datos de validación
- Gráficos de las curvas PR y F1 para todas las clases
- Correlograma de las etiquetas de clase
Link to this sectionConfigura el registro de Comet#
Comet puede configurarse para registrar datos adicionales, ya sea a través de flags de línea de comandos pasados al script de entrenamiento o mediante variables de entorno:
export COMET_MODE=online # Set whether to run Comet in 'online' or 'offline' mode. Defaults to online
export COMET_MODEL_NAME="yolov5" # Set the name for the saved model. Defaults to yolov5
export COMET_LOG_CONFUSION_MATRIX=false # Set to disable logging a Comet Confusion Matrix. Defaults to true
export COMET_MAX_IMAGE_UPLOADS=30 # Controls how many total image predictions to log to Comet. Defaults to 100.
export COMET_LOG_PER_CLASS_METRICS=true # Set to log evaluation metrics for each detected class at the end of training. Defaults to false
export COMET_DEFAULT_CHECKPOINT_FILENAME="last.pt" # Set this if you would like to resume training from a different checkpoint. Defaults to 'last.pt'
export COMET_LOG_BATCH_LEVEL_METRICS=true # Set this if you would like to log training metrics at the batch level. Defaults to false.
export COMET_LOG_PREDICTIONS=true # Set this to false to disable logging model predictionsLink to this sectionRegistro de puntos de control (checkpoints) con Comet#
El registro de modelos en Comet está deshabilitado por defecto. Para habilitarlo, pasa el argumento save-period al script de entrenamiento. Esto guardará los puntos de control registrados en Comet basándose en el valor de intervalo proporcionado por save-period:
python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--save-period 1Link to this sectionRegistro de predicciones del modelo#
Por defecto, las predicciones del modelo (imágenes, etiquetas de verdad terreno y cajas delimitadoras) se registrarán en Comet.
Puedes controlar la frecuencia de las predicciones registradas y las imágenes asociadas pasando el argumento de línea de comandos bbox_interval. Las predicciones pueden visualizarse usando el panel personalizado de Detección de objetos de Comet. Esta frecuencia corresponde a cada enésimo lote (batch) de datos por época. En el ejemplo a continuación, registramos cada segundo lote de datos por cada época.
Nota: El cargador de datos de validación de YOLOv5 usará por defecto un tamaño de lote de 32, por lo que tendrás que ajustar la frecuencia de registro en consecuencia.
Aquí tienes un ejemplo de proyecto usando el Panel
python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--bbox_interval 2Link to this sectionControl del número de imágenes de predicción registradas en Comet#
Al registrar predicciones desde YOLOv5, Comet registrará las imágenes asociadas con cada conjunto de predicciones. Por defecto, se registra un máximo de 100 imágenes de validación. Puedes aumentar o disminuir este número usando la variable de entorno COMET_MAX_IMAGE_UPLOADS:
env COMET_MAX_IMAGE_UPLOADS=200 python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--bbox_interval 1Link to this sectionRegistro de métricas a nivel de clase#
Usa la variable de entorno COMET_LOG_PER_CLASS_METRICS para registrar mAP, precisión, exhaustividad (recall) y f1 para cada clase:
env COMET_LOG_PER_CLASS_METRICS=true python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.ptLink to this sectionCarga de un conjunto de datos en Comet Artifacts#
Si deseas almacenar tus datos usando Comet Artifacts, puedes hacerlo usando el flag upload_dataset.
El conjunto de datos debe estar organizado tal como se describe en la documentación de YOLOv5. El archivo yaml de configuración del conjunto de datos debe seguir el mismo formato que el del archivo coco128.yaml.
python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--upload_datasetPuedes encontrar el conjunto de datos cargado en la pestaña Artifacts en tu espacio de trabajo de Comet:

Puedes previsualizar los datos directamente en la interfaz de usuario de Comet:

Los artefactos tienen versiones y también admiten la adición de metadatos sobre el conjunto de datos. Comet registrará automáticamente los metadatos de tu archivo yaml de conjunto de datos:

Link to this sectionUso de un Artifact guardado#
Si deseas usar un conjunto de datos de Comet Artifacts, configura la variable path en tu archivo yaml de conjunto de datos para que apunte a la siguiente URL del recurso Artifact:
# Contents of artifact.yaml file
path: "comet://WORKSPACE_NAME/ARTIFACT_NAME:ARTIFACT_VERSION_OR_ALIAS"Luego, pasa este archivo a tu script de entrenamiento de la siguiente manera:
python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data artifact.yaml \
--weights yolov5s.ptLos artefactos también te permiten rastrear el linaje de los datos a medida que fluyen a través de tu flujo de trabajo de experimentación. Aquí puedes ver un gráfico que te muestra todos los experimentos que han utilizado tu conjunto de datos cargado:

Link to this sectionReanudación de una ejecución de entrenamiento#
Si tu ejecución de entrenamiento se interrumpe por cualquier motivo, p. ej., una conexión a internet interrumpida, puedes reanudar la ejecución usando el flag resume y la ruta de ejecución (Run Path) de Comet.
La ruta de ejecución tiene el siguiente formato comet://WORKSPACE_NAME/PROJECT_NAME/EXPERIMENT_ID.
Esto restaurará la ejecución al estado previo a la interrupción, lo que incluye restaurar el modelo desde un punto de control, restaurar todos los hiperparámetros y argumentos de entrenamiento, y descargar los Artifacts del conjunto de datos de Comet si se utilizaron en la ejecución original. La ejecución reanudada continuará registrando en el experimento existente en la interfaz de usuario de Comet:
python train.py \
--resume "comet://YOUR_RUN_PATH"Link to this sectionBúsqueda de hiperparámetros con el optimizador de Comet#
YOLOv5 también está integrado con el Optimizador de Comet, lo que hace que sea sencillo visualizar barridos (sweeps) de hiperparámetros en la interfaz de usuario de Comet.
Link to this sectionConfiguración de un barrido del optimizador#
Para configurar el optimizador de Comet, tendrás que crear un archivo JSON con la información sobre el barrido. Se ha proporcionado un archivo de ejemplo en utils/loggers/comet/optimizer_config.json:
python utils/loggers/comet/hpo.py \
--comet_optimizer_config "utils/loggers/comet/optimizer_config.json"El script hpo.py acepta los mismos argumentos que train.py. Si deseas pasar argumentos adicionales a tu barrido, simplemente añádelos después del script:
python utils/loggers/comet/hpo.py \
--comet_optimizer_config "utils/loggers/comet/optimizer_config.json" \
--save-period 1 \
--bbox_interval 1Link to this sectionVisualización de resultados#
Comet ofrece varias formas de visualizar los resultados de tu barrido. Echa un vistazo a un proyecto con un barrido completado aquí.
