Integrazione di MLflow per Ultralytics YOLO
Introduzione
La registrazione degli esperimenti è un aspetto cruciale dei flussi di lavoro di machine learning che consente di tracciare vari parametri, metriche e artefatti. Aiuta a migliorare la riproducibilità del modello, a risolvere problemi e a incrementare le prestazioni del modello. Ultralytics YOLO, noto per le sue capacità di object detection in tempo reale, ora offre l'integrazione con MLflow, una piattaforma open source per la gestione completa del ciclo di vita del machine learning.
Questa pagina di documentazione è una guida completa alla configurazione e all'utilizzo delle funzionalità di registrazione di MLflow per il tuo progetto Ultralytics YOLO.
Cos'è MLflow?
MLflow è una piattaforma open source sviluppata da Databricks per gestire il ciclo di vita end-to-end del machine learning. Include strumenti per tracciare esperimenti, impacchettare codice in esecuzioni riproducibili, nonché condividere e distribuire modelli. MLflow è progettato per funzionare con qualsiasi libreria di machine learning e linguaggio di programmazione.
Funzionalità
- Registrazione delle metriche: registra le metriche alla fine di ogni epoca e al termine dell'addestramento.
- Registrazione dei parametri: registra tutti i parametri utilizzati nell'addestramento.
- Registrazione degli artefatti: registra gli artefatti del modello, inclusi pesi e file di configurazione, al termine dell'addestramento.
Configurazione e prerequisiti
Assicurati che MLflow sia installato. In caso contrario, installalo usando pip:
pip install mlflowVerifica che la registrazione MLflow sia abilitata nelle impostazioni di Ultralytics. Solitamente, questa è controllata dalla chiave mlflow nelle impostazioni. Consulta la pagina delle impostazioni per maggiori informazioni.
All'interno dell'ambiente Python, chiama il metodo update sull'oggetto settings per modificare le tue impostazioni:
from ultralytics import settings
# Update a setting
settings.update({"mlflow": True})
# Reset settings to default values
settings.reset()Come utilizzare
Comandi
-
Imposta un nome di progetto: puoi impostare il nome del progetto tramite una variabile d'ambiente:
export MLFLOW_EXPERIMENT_NAME=YOUR_EXPERIMENT_NAMEOppure usa l'argomento
project=<project>durante l'addestramento di un modello YOLO, ad esempioyolo train project=my_project. -
Imposta un nome di esecuzione: in modo simile all'impostazione di un nome di progetto, puoi impostare il nome dell'esecuzione tramite una variabile d'ambiente:
export MLFLOW_RUN=YOUR_RUN_NAMEOppure usa l'argomento
name=<name>durante l'addestramento di un modello YOLO, ad esempioyolo train project=my_project name=my_name. -
Avvia server MLflow locale: per iniziare il tracciamento, usa:
mlflow server --backend-store-uri runs/mlflowQuesto avvierà un server locale su
http://127.0.0.1:5000per impostazione predefinita e salverà tutti i log di mlflow nella directory 'runs/mlflow'. Per puntare le tue esecuzioni di addestramento a un diverso server di tracciamento, esportaMLFLOW_TRACKING_URIprima dell'addestramento:export MLFLOW_TRACKING_URI=http://127.0.0.1:5000 -
Termina istanze del server MLflow: per interrompere tutte le istanze MLflow in esecuzione, esegui:
ps aux | grep 'mlflow' | grep -v 'grep' | awk '{print $2}' | xargs kill -9
Registrazione
The logging is taken care of by the on_pretrain_routine_end, on_fit_epoch_end, and on_train_end callback functions. These functions are automatically called during the respective stages of the training process, and they handle the logging of parameters, metrics, and artifacts.
Esempi
-
Registrazione di metriche personalizzate: puoi aggiungere metriche personalizzate da registrare modificando il dizionario
trainer.metricsprima che venga chiamataon_fit_epoch_end. -
Visualizza esperimento: per visualizzare i tuoi log, naviga sul tuo server MLflow (solitamente
http://127.0.0.1:5000) e seleziona il tuo esperimento ed esecuzione.
-
Visualizza esecuzione: le esecuzioni sono singoli modelli all'interno di un esperimento. Fai clic su un'esecuzione per vedere i dettagli, inclusi gli artefatti caricati e i pesi del modello.

Disabilitazione di MLflow
Per disattivare la registrazione MLflow:
yolo settings mlflow=FalseConclusione
L'integrazione della registrazione MLflow con Ultralytics YOLO offre un modo semplificato per tenere traccia dei tuoi esperimenti di machine learning. Ti permette di monitorare le metriche delle prestazioni e gestire gli artefatti in modo efficace, favorendo così uno sviluppo e una distribuzione robusti dei modelli. Per ulteriori dettagli, visita la documentazione ufficiale di MLflow.
FAQ
Come configuro la registrazione MLflow con Ultralytics YOLO?
Per configurare la registrazione MLflow con Ultralytics YOLO, devi prima assicurarti che MLflow sia installato. Puoi installarlo usando pip:
pip install mlflowSuccessivamente, abilita la registrazione MLflow nelle impostazioni di Ultralytics. Questo può essere controllato usando la chiave mlflow. Per ulteriori informazioni, consulta la guida alle impostazioni.
from ultralytics import settings
# Update a setting
settings.update({"mlflow": True})
# Reset settings to default values
settings.reset()Infine, avvia un server MLflow locale per il tracciamento:
mlflow server --backend-store-uri runs/mlflowQuali metriche e parametri posso registrare usando MLflow con Ultralytics YOLO?
Ultralytics YOLO con MLflow supporta la registrazione di varie metriche, parametri e artefatti durante tutto il processo di addestramento:
- Registrazione delle metriche: traccia le metriche alla fine di ogni epoca e al completamento dell'addestramento.
- Registrazione dei parametri: registra tutti i parametri utilizzati nel processo di addestramento.
- Registrazione degli artefatti: salva gli artefatti del modello come pesi e file di configurazione dopo l'addestramento.
Per informazioni più dettagliate, visita la documentazione sul tracciamento di Ultralytics YOLO.
Posso disabilitare la registrazione MLflow una volta abilitata?
Sì, puoi disabilitare la registrazione MLflow per Ultralytics YOLO aggiornando le impostazioni. Ecco come puoi farlo usando la CLI:
yolo settings mlflow=FalsePer ulteriori personalizzazioni e per ripristinare le impostazioni, fai riferimento alla guida alle impostazioni.
Come posso avviare e interrompere un server MLflow per il tracciamento di Ultralytics YOLO?
Per avviare un server MLflow per tracciare i tuoi esperimenti in Ultralytics YOLO, usa il seguente comando:
mlflow server --backend-store-uri runs/mlflowQuesto comando avvia un server locale su http://127.0.0.1:5000 per impostazione predefinita. Se hai bisogno di interrompere le istanze del server MLflow in esecuzione, usa il seguente comando bash:
ps aux | grep 'mlflow' | grep -v 'grep' | awk '{print $2}' | xargs kill -9Fai riferimento alla sezione comandi per ulteriori opzioni di comando.
Quali sono i vantaggi dell'integrazione di MLflow con Ultralytics YOLO per il tracciamento degli esperimenti?
Integrare MLflow con Ultralytics YOLO offre diversi vantaggi per la gestione dei tuoi esperimenti di machine learning:
- Tracciamento migliorato degli esperimenti: traccia e confronta facilmente diverse esecuzioni e i loro risultati.
- Miglior riproducibilità del modello: assicurati che i tuoi esperimenti siano riproducibili registrando tutti i parametri e gli artefatti.
- Monitoraggio delle prestazioni: visualizza le metriche delle prestazioni nel tempo per prendere decisioni basate sui dati per migliorare i modelli.
- Flusso di lavoro semplificato: automatizza il processo di registrazione per concentrarti maggiormente sullo sviluppo del modello anziché sul tracciamento manuale.
- Sviluppo collaborativo: condividi i risultati degli esperimenti con i membri del team per una migliore collaborazione e condivisione delle conoscenze.
Per uno sguardo approfondito alla configurazione e allo sfruttamento di MLflow con Ultralytics YOLO, esplora la documentazione Integrazione di MLflow per Ultralytics YOLO.