Saltar al contenido

Integraci贸n de MLflow para Ultralytics YOLO

Ecosistema MLflow

Introducci贸n

El registro de experimentos es un aspecto crucial de los flujos de trabajo del aprendizaje autom谩tico que permite el seguimiento de diversas m茅tricas, par谩metros y artefactos. Ayuda a mejorar la reproducibilidad del modelo, depurar problemas y mejorar el rendimiento del modelo. Ultralytics YOLO, conocido por sus capacidades de detecci贸n de objetos en tiempo real, ofrece ahora integraci贸n con MLflow, una plataforma de c贸digo abierto para la gesti贸n completa del ciclo de vida del aprendizaje autom谩tico.

Esta p谩gina de documentaci贸n es una gu铆a completa para configurar y utilizar las funciones de registro de MLflow para tu proyecto Ultralytics YOLO .

驴Qu茅 es MLflow?

MLflow es una plataforma de c贸digo abierto desarrollada por Databricks para gestionar el ciclo de vida completo del aprendizaje autom谩tico. Incluye herramientas para hacer un seguimiento de los experimentos, empaquetar el c贸digo en ejecuciones reproducibles, y compartir y desplegar modelos. MLflow est谩 dise帽ado para funcionar con cualquier biblioteca de aprendizaje autom谩tico y lenguaje de programaci贸n.

Caracter铆sticas

  • Registro de m茅tricas: Registra las m茅tricas al final de cada 茅poca y al final del entrenamiento.
  • Registro de par谩metros: Registra todos los par谩metros utilizados en el entrenamiento.
  • Registro de artefactos: Registra los artefactos del modelo, incluidos los pesos y los archivos de configuraci贸n, al final del entrenamiento.

Configuraci贸n y requisitos previos

Aseg煤rate de que MLflow est谩 instalado. Si no lo est谩, inst谩lalo con pip:

pip install mlflow

Aseg煤rate de que el registro MLflow est谩 activado en los ajustes de Ultralytics . Normalmente, esto se controla mediante los ajustes mflow llave. Ver la ajustes para m谩s informaci贸n.

Actualiza la configuraci贸n de Ultralytics MLflow

Dentro del entorno Python , llama a la funci贸n update del m茅todo settings para cambiar tu configuraci贸n:

from ultralytics import settings

# Update a setting
settings.update({"mlflow": True})

# Reset settings to default values
settings.reset()

Si prefieres utilizar la interfaz de l铆nea de comandos, los siguientes comandos te permitir谩n modificar tu configuraci贸n:

# Update a setting
yolo settings runs_dir='/path/to/runs'

# Reset settings to default values
yolo settings reset

C贸mo utilizarlo

Comandos

  1. Establecer un nombre de proyecto: Puedes establecer el nombre del proyecto mediante una variable de entorno:

    export MLFLOW_EXPERIMENT_NAME=<your_experiment_name>
    

O utiliza el project=<project> al entrenar un modelo YOLO , es decir yolo train project=my_project.

  1. Establecer un nombre de ejecuci贸n: De forma similar a establecer un nombre de proyecto, puedes establecer el nombre de ejecuci贸n mediante una variable de entorno:

    export MLFLOW_RUN=<your_run_name>
    

O utiliza el name=<name> al entrenar un modelo YOLO , es decir yolo train project=my_project name=my_name.

  1. Inicia el servidor MLflow local: Para iniciar el seguimiento, utiliza

    mlflow server --backend-store-uri runs/mlflow'
    

Esto iniciar谩 un servidor local en http://127.0.0.1:5000 por defecto y guardar谩 todos los registros de mlflow en el directorio 'runs/mlflow'. Para especificar un URI diferente, establece el par谩metro MLFLOW_TRACKING_URI variable de entorno.

  1. Matar las instancias del servidor MLflow: Para detener todas las instancias de MLflow en ejecuci贸n, ejecuta:

    ps aux | grep 'mlflow' | grep -v 'grep' | awk '{print $2}' | xargs kill -9
    

Registro

Del registro se encarga el on_pretrain_routine_end, on_fit_epoch_endy on_train_end funciones de llamada de retorno. Estas funciones se llaman autom谩ticamente durante las respectivas etapas del proceso de entrenamiento, y se encargan del registro de par谩metros, m茅tricas y artefactos.

Ejemplos

  1. Registro de m茅tricas personalizadas: Puedes a帽adir m茅tricas personalizadas para que se registren modificando la opci贸n trainer.metrics diccionario antes on_fit_epoch_end se llama.

  2. Ver Experimento: Para ver tus registros, navega a tu servidor MLflow (normalmente http://127.0.0.1:5000) y selecciona tu experimento y ejec煤talo. YOLO Experimento MLflow

  3. Ver Carrera: Las Ejecuciones son modelos individuales dentro de un experimento. Haz clic en una Corrida y ver谩s los detalles de la misma, incluidos los artefactos cargados y los pesos de los modelos. YOLO Carrera MLflow

Desactivar MLflow

Para desactivar el registro MLflow:

yolo settings mlflow=False

Conclusi贸n

La integraci贸n del registro de MLflow con Ultralytics YOLO ofrece una forma racionalizada de realizar un seguimiento de tus experimentos de aprendizaje autom谩tico. Te permite supervisar las m茅tricas de rendimiento y gestionar los artefactos de forma eficaz, ayudando as铆 a desarrollar y desplegar modelos s贸lidos. Para m谩s detalles, visita la documentaci贸n oficial de MLflow.



Creado 2023-11-12, Actualizado 2024-05-18
Autores: glenn-jocher (4), Burhan-Q (1)

Comentarios