Vai al contenuto

CoreML Esportazione per i modelli di YOLOv8

L'implementazione di modelli di computer vision su dispositivi Apple come iPhone e Mac richiede un formato che garantisca prestazioni ottimali.

Il formato di esportazione CoreML ti permette di ottimizzare i tuoi Ultralytics YOLOv8 modelli per un rilevamento efficiente degli oggetti nelle applicazioni iOS e macOS. In questa guida ti illustreremo i passi da seguire per convertire i tuoi modelli nel formato CoreML , in modo da rendere più semplice l'utilizzo dei tuoi modelli sui dispositivi Apple.

CoreML

CoreML Panoramica

CoreML è il framework di apprendimento automatico fondamentale di Apple che si basa su Accelerate, BNNS e Metal Performance Shaders. Fornisce un formato di modello di apprendimento automatico che si integra perfettamente nelle applicazioni di iOS e supporta attività come l'analisi delle immagini, l'elaborazione del linguaggio naturale, la conversione audio-testo e l'analisi del suono.

Le applicazioni possono sfruttare Core ML senza dover disporre di una connessione di rete o di chiamate API, perché il framework Core ML funziona utilizzando il calcolo on-device. Ciò significa che l'inferenza del modello può essere eseguita localmente sul dispositivo dell'utente.

Caratteristiche principali dei modelli CoreML

Il framework CoreML di Apple offre funzioni avanzate per l'apprendimento automatico sui dispositivi. Ecco le caratteristiche principali che rendono CoreML un potente strumento per gli sviluppatori:

  • Supporto completo per i modelli: Converte ed esegue modelli da framework popolari come TensorFlow, PyTorch, scikit-learn, XGBoost e LibSVM.

CoreML Modelli supportati

  • Machine Learning on-device: Garantisce la privacy dei dati e un'elaborazione rapida grazie all'esecuzione dei modelli direttamente sul dispositivo dell'utente, eliminando la necessità di connettersi alla rete.

  • Prestazioni e ottimizzazione: Utilizza i motori CPU, GPU e Neural Engine del dispositivo per ottenere prestazioni ottimali con un utilizzo minimo di energia e memoria. Offre strumenti per la compressione e l'ottimizzazione dei modelli mantenendo la precisione.

  • Facilità di integrazione: Fornisce un formato unificato per vari tipi di modelli e un'API di facile utilizzo per una perfetta integrazione nelle applicazioni. Supporta attività specifiche del dominio attraverso framework come Vision e Natural Language.

  • Caratteristiche avanzate: Include funzionalità di formazione sul dispositivo per esperienze personalizzate, previsioni asincrone per esperienze di ML interattive e strumenti di ispezione e validazione dei modelli.

CoreML Opzioni di distribuzione

Prima di esaminare il codice per l'esportazione YOLOv8 modelli al CoreML formato, capiamo dove CoreML Di solito vengono utilizzati modelli.

CoreML offre diverse opzioni di distribuzione per i modelli di apprendimento automatico, tra cui:

  • Distribuzione su dispositivo: Questo metodo integra direttamente i modelli di CoreML nella tua app iOS . È particolarmente vantaggioso per garantire una bassa latenza, una maggiore privacy (poiché i dati rimangono sul dispositivo) e la funzionalità offline. Questo approccio, tuttavia, può essere limitato dalle capacità hardware del dispositivo, soprattutto per i modelli più grandi e complessi. La distribuzione sul dispositivo può essere eseguita in due modi.

    • Modelli incorporati: Questi modelli sono inclusi nel bundle dell'app e sono immediatamente accessibili. Sono ideali per i modelli di piccole dimensioni che non richiedono aggiornamenti frequenti.

    • Modelli scaricati: Questi modelli vengono prelevati da un server quando necessario. Questo approccio è adatto ai modelli più grandi o a quelli che necessitano di aggiornamenti regolari. Contribuisce a ridurre le dimensioni del bundle dell'applicazione.

  • Distribuzione basata sul cloud: i modelli di CoreML sono ospitati su server e accessibili dall'app iOS tramite richieste API. Questa opzione scalabile e flessibile consente di aggiornare facilmente i modelli senza dover rivedere l'app. È ideale per modelli complessi o applicazioni su larga scala che richiedono aggiornamenti regolari. Tuttavia, richiede una connessione a internet e può comportare problemi di latenza e di sicurezza.

Esportare i modelli di YOLOv8 in CoreML

L'esportazione di YOLOv8 in CoreML consente di ottimizzare le prestazioni di apprendimento automatico sul dispositivo all'interno dell'ecosistema Apple, offrendo vantaggi in termini di efficienza, sicurezza e integrazione perfetta con le piattaforme iOS, macOS, watchOS e tvOS.

Installazione

Per installare il pacchetto richiesto, esegui:

Installazione

# Install the required package for YOLOv8
pip install ultralytics

Per istruzioni dettagliate e buone pratiche relative al processo di installazione, consulta la nostra Guida all'installazione diYOLOv8 . Durante l'installazione dei pacchetti necessari per YOLOv8, se dovessi incontrare delle difficoltà, consulta la nostra guida sui problemi comuni per trovare soluzioni e suggerimenti.

Utilizzo

Prima di immergerti nelle istruzioni per l'uso, assicurati di dare un'occhiata alla gamma di modelli diYOLOv8 offerti da Ultralytics. Questo ti aiuterà a scegliere il modello più adatto alle esigenze del tuo progetto.

Utilizzo

from ultralytics import YOLO

# Load the YOLOv8 model
model = YOLO("yolov8n.pt")

# Export the model to CoreML format
model.export(format="coreml")  # creates 'yolov8n.mlpackage'

# Load the exported CoreML model
coreml_model = YOLO("yolov8n.mlpackage")

# Run inference
results = coreml_model("https://ultralytics.com/images/bus.jpg")
# Export a YOLOv8n PyTorch model to CoreML format
yolo export model=yolov8n.pt format=coreml  # creates 'yolov8n.mlpackage''

# Run inference with the exported model
yolo predict model=yolov8n.mlpackage source='https://ultralytics.com/images/bus.jpg'

Per maggiori dettagli sul processo di esportazione, visita la pagina di documentazione diUltralytics sull'esportazione.

Distribuzione dei modelli esportati di YOLOv8 CoreML

Dopo aver esportato con successo i tuoi modelli Ultralytics YOLOv8 in CoreML, la fase successiva e critica consiste nel distribuire questi modelli in modo efficace. Per una guida dettagliata sulla distribuzione dei modelli CoreML in vari ambienti, consulta queste risorse:

  • CoreML Strumenti: Questa guida contiene istruzioni ed esempi per convertire i modelli da TensorFlow, PyTorch e altre librerie in Core ML.

  • ML e Visione: Una raccolta di video completi che coprono vari aspetti dell'uso e dell'implementazione dei modelli di CoreML .

  • Integrare un modello di ML centrale nella tua applicazione: Una guida completa sull'integrazione di un modello di CoreML in un'applicazione di iOS , che illustra i passaggi dalla preparazione del modello all'implementazione nell'applicazione per diverse funzionalità.

Sommario

In questa guida abbiamo spiegato come esportare i modelli Ultralytics YOLOv8 in formato CoreML . Seguendo i passi indicati in questa guida, potrai garantire la massima compatibilità e le massime prestazioni nell'esportazione dei modelli YOLOv8 in CoreML.

Per ulteriori dettagli sull'utilizzo, visita la documentazione ufficiale di CoreML .

Inoltre, se vuoi saperne di più su altri Ultralytics YOLOv8 integrazioni, visita la nostra pagina della guida all'integrazione. Lì troverai molte risorse e approfondimenti preziosi.

DOMANDE FREQUENTI

Come posso esportare i modelli di YOLOv8 nel formato CoreML ?

Per esportare il tuo Ultralytics YOLOv8 modelli in formato CoreML , dovrai innanzitutto assicurarti di avere il ultralytics installato. Puoi installarlo utilizzando:

Installazione

pip install ultralytics

Successivamente, puoi esportare il modello usando i seguenti comandi Python o CLI :

Utilizzo

from ultralytics import YOLO

model = YOLO("yolov8n.pt")
model.export(format="coreml")
yolo export model=yolov8n.pt format=coreml

Per ulteriori dettagli, consulta la sezione Esportazione di modelli YOLOv8 in CoreML della nostra documentazione.

Quali sono i vantaggi dell'utilizzo di CoreML per la distribuzione dei modelli di YOLOv8 ?

CoreML offre numerosi vantaggi per la distribuzione di Ultralytics YOLOv8 sui dispositivi Apple:

  • Elaborazione su dispositivo: Consente l'inferenza locale del modello sui dispositivi, garantendo la privacy dei dati e riducendo al minimo la latenza.
  • Ottimizzazione delle prestazioni: Sfrutta tutto il potenziale di CPU, GPU e Neural Engine del dispositivo, ottimizzando velocità ed efficienza.
  • Facilità di integrazione: Offre un'esperienza di integrazione perfetta con gli ecosistemi Apple, tra cui iOS, macOS, watchOS e tvOS.
  • Versatilità: Supporta un'ampia gamma di attività di apprendimento automatico come l'analisi delle immagini, l'elaborazione audio e l'elaborazione del linguaggio naturale utilizzando il framework CoreML .

Per maggiori dettagli sull'integrazione del tuo modello CoreML in un'app iOS , consulta la guida sull'integrazione di un modello ML principale nella tua app.

Quali sono le opzioni di distribuzione per i modelli di YOLOv8 esportati in CoreML?

Una volta esportato il modello YOLOv8 in formato CoreML , hai a disposizione diverse opzioni di distribuzione:

  1. Distribuzione su dispositivo: Integra direttamente i modelli di CoreML nella tua app per migliorare la privacy e le funzionalità offline. Questo può essere fatto come:

    • Modelli incorporati: Incluso nel bundle dell'app, accessibile immediatamente.
    • Modelli scaricati: Vengono recuperati da un server in base alle necessità, in modo da ridurre le dimensioni del bundle dell'app.
  2. Distribuzione basata sul cloud: Ospita i modelli di CoreML sui server e accedi ad essi tramite richieste API. Questo approccio supporta aggiornamenti più semplici e può gestire modelli più complessi.

Per una guida dettagliata sulla distribuzione dei modelli CoreML , consulta la sezione CoreML Opzioni di distribuzione.

Come fa CoreML a garantire prestazioni ottimizzate per i modelli YOLOv8 ?

CoreML garantisce prestazioni ottimizzate per Ultralytics YOLOv8 utilizzando varie tecniche di ottimizzazione:

  • Accelerazione hardware: Utilizza i motori CPU, GPU e Neural Engine del dispositivo per ottenere calcoli efficienti.
  • Compressione dei modelli: Fornisce strumenti per comprimere i modelli per ridurne l'ingombro senza compromettere l'accuratezza.
  • Inferenza adattiva: Regola l'inferenza in base alle capacità del dispositivo per mantenere un equilibrio tra velocità e prestazioni.

Per ulteriori informazioni sull'ottimizzazione delle prestazioni, visita la documentazione ufficiale di CoreML .

Posso eseguire l'inferenza direttamente con il modello CoreML esportato?

Sì, puoi eseguire l'inferenza direttamente utilizzando il modello esportato di CoreML . Di seguito sono riportati i comandi per Python e CLI:

Esecuzione dell'inferenza

from ultralytics import YOLO

coreml_model = YOLO("yolov8n.mlpackage")
results = coreml_model("https://ultralytics.com/images/bus.jpg")
yolo predict model=yolov8n.mlpackage source='https://ultralytics.com/images/bus.jpg'

Per ulteriori informazioni, consulta la sezione Utilizzo della guida all'esportazione di CoreML .


📅 Created 7 months ago ✏️ Updated 7 days ago

Commenti