CoreML Exportation pour les modèles YOLO11
Le déploiement de modèles de vision par ordinateur sur des appareils Apple tels que les iPhones et les Macs nécessite un format qui garantisse des performances sans faille.
Le format d'exportation CoreML vous permet d'optimiser vos modèles pour une détection efficace des objets dans les applications et macOS. Ultralytics YOLO11 modèles pour une détection efficace des objets dans les applications iOS et macOS. Dans ce guide, nous vous expliquons les étapes de la conversion de vos modèles au format CoreML , ce qui permet à vos modèles d'être plus performants sur les appareils Apple.
CoreML
CoreML est le cadre fondamental d'apprentissage automatique d'Apple qui s'appuie sur Accelerate, BNNS et Metal Performance Shaders. Il fournit un format de modèle d'apprentissage automatique qui s'intègre de manière transparente dans les applications iOS et prend en charge des tâches telles que l'analyse d'images, le traitement du langage naturel, la conversion audio/texte et l'analyse sonore.
Les applications peuvent tirer parti de Core ML sans avoir besoin d'une connexion réseau ou d'appels API, car le cadre Core ML utilise l'informatique sur l'appareil. Cela signifie que l'inférence du modèle peut être effectuée localement sur l'appareil de l'utilisateur.
Principales caractéristiques des modèles CoreML
Le framework CoreML d'Apple offre des fonctionnalités robustes pour l'apprentissage automatique sur l'appareil. Voici les principales caractéristiques qui font de CoreML un outil puissant pour les développeurs :
- Prise en charge complète des modèles: Convertit et exécute des modèles à partir de cadres populaires tels que TensorFlow, PyTorchscikit-learn, XGBoost et LibSVM.
-
Apprentissage automatique sur l'appareil: Garantit la confidentialité des données et un traitement rapide en exécutant les modèles directement sur l'appareil de l'utilisateur, ce qui élimine la nécessité d'une connectivité réseau.
-
Performance et optimisation: Utilise les moteurs CPU, GPU et Neural Engine de l'appareil pour des performances optimales avec une consommation d'énergie et une utilisation de la mémoire minimales. Offre des outils pour la compression et l'optimisation des modèles tout en maintenant la précision.
-
Facilité d'intégration: Fournit un format unifié pour différents types de modèles et une API conviviale pour une intégration transparente dans les applications. Prend en charge les tâches spécifiques à un domaine grâce à des frameworks tels que Vision et Natural Language.
-
Fonctionnalités avancées: Comprend des capacités de formation sur l'appareil pour des expériences personnalisées, des prédictions asynchrones pour des expériences interactives de ML, et des outils d'inspection et de validation de modèles.
CoreML Options de déploiement
Avant d'examiner le code permettant d'exporter les modèles YOLO11 vers le format CoreML , il convient de comprendre où les modèles CoreML sont généralement utilisés.
CoreML offre diverses options de déploiement pour les modèles d'apprentissage automatique, notamment :
-
Déploiement sur l'appareil: Cette méthode intègre directement les modèles CoreML dans votre application iOS . Elle est particulièrement avantageuse pour garantir une faible latence, une meilleure confidentialité (puisque les données restent sur l'appareil) et une fonctionnalité hors ligne. Cette approche peut toutefois être limitée par les capacités matérielles de l'appareil, en particulier pour les modèles plus grands et plus complexes. Le déploiement sur l'appareil peut être exécuté de deux manières.
-
Modèles intégrés: Ces modèles sont inclus dans le paquet d'applications et sont immédiatement accessibles. Ils sont idéaux pour les petits modèles qui ne nécessitent pas de mises à jour fréquentes.
-
Modèles téléchargés: Ces modèles sont récupérés sur un serveur en fonction des besoins. Cette approche convient aux modèles de grande taille ou à ceux qui nécessitent des mises à jour régulières. Elle permet de réduire la taille du paquet d'applications.
-
-
Déploiement dans le nuage: les modèles CoreML sont hébergés sur des serveurs et l'application iOS y accède par le biais de requêtes API. Cette option évolutive et flexible permet de mettre facilement à jour les modèles sans avoir à réviser l'application. Elle est idéale pour les modèles complexes ou les applications à grande échelle nécessitant des mises à jour régulières. Cependant, elle nécessite une connexion internet et peut poser des problèmes de latence et de sécurité.
Exportation des modèles YOLO11 vers CoreML
L'exportation de YOLO11 vers CoreML permet d'optimiser les performances d'apprentissage automatique sur appareil au sein de l'écosystème d'Apple, offrant des avantages en termes d'efficacité, de sécurité et d'intégration transparente avec iOS, macOS, watchOS et les plateformes tvOS.
Installation
Pour installer le paquetage requis, exécutez :
Pour des instructions détaillées et les meilleures pratiques liées au processus d'installation, consultez notre guide d'installationYOLO11 . Lors de l'installation des paquets requis pour YOLO11, si vous rencontrez des difficultés, consultez notre guide des problèmes courants pour obtenir des solutions et des conseils.
Utilisation
Avant de vous plonger dans les instructions d'utilisation, n'oubliez pas de consulter la gamme de modèlesYOLO11 proposée par Ultralytics. Cela vous aidera à choisir le modèle le plus approprié aux exigences de votre projet.
Utilisation
from ultralytics import YOLO
# Load the YOLO11 model
model = YOLO("yolo11n.pt")
# Export the model to CoreML format
model.export(format="coreml") # creates 'yolo11n.mlpackage'
# Load the exported CoreML model
coreml_model = YOLO("yolo11n.mlpackage")
# Run inference
results = coreml_model("https://ultralytics.com/images/bus.jpg")
Pour plus de détails sur le processus d'exportation, consultez la page de documentationUltralytics sur l'exportation.
Déploiement des modèles exportés YOLO11 CoreML
Après avoir exporté avec succès vos modèles Ultralytics YOLO11 vers CoreML, la phase critique suivante consiste à déployer ces modèles de manière efficace. Pour obtenir des conseils détaillés sur le déploiement des modèles CoreML dans divers environnements, consultez les ressources suivantes :
-
CoreML Outils: Ce guide comprend des instructions et des exemples pour convertir les modèles de TensorFlow, PyTorch, et d'autres bibliothèques vers Core ML.
-
ML et Vision: Une collection de vidéos complètes qui couvrent divers aspects de l'utilisation et de la mise en œuvre des modèles CoreML .
-
Intégrer un modèle ML de base dans votre application: Un guide complet sur l'intégration d'un modèle CoreML dans une application iOS , détaillant les étapes depuis la préparation du modèle jusqu'à sa mise en œuvre dans l'application pour diverses fonctionnalités.
Résumé
Dans ce guide, nous avons vu comment exporter les modèles Ultralytics YOLO11 vers le format CoreML . En suivant les étapes décrites dans ce guide, vous pouvez garantir une compatibilité et des performances maximales lors de l'exportation de modèles YOLO11 vers CoreML.
Pour plus de détails sur l'utilisation, consultez la documentation officielle deCoreML .
Par ailleurs, si vous souhaitez en savoir plus sur d'autres intégrations de Ultralytics YOLO11 , visitez notre page de guide d'intégration. Vous y trouverez de nombreuses ressources et informations précieuses.
FAQ
Comment exporter les modèles YOLO11 au format CoreML ?
Pour exporter votre Ultralytics YOLO11 au format CoreML , vous devez d'abord vous assurer que vous disposez de l'information suivante ultralytics
installé. Vous pouvez l'installer en utilisant :
Vous pouvez ensuite exporter le modèle à l'aide des commandes Python ou CLI :
Utilisation
Pour plus de détails, consultez la section Exportation des modèles YOLO11 vers CoreML de notre documentation.
Quels sont les avantages de l'utilisation de CoreML pour le déploiement des modèles YOLO11 ?
CoreML offre de nombreux avantages pour le déploiement de Ultralytics YOLO11 sur les appareils Apple :
- Traitement sur l'appareil: Permet l'inférence de modèles locaux sur les appareils, garantissant la confidentialité des données et minimisant la latence.
- Optimisation des performances: Exploite tout le potentiel des moteurs CPU, GPU et Neural Engine de l'appareil, en optimisant à la fois la vitesse et l'efficacité.
- Facilité d'intégration: Offre une expérience d'intégration transparente avec les écosystèmes d'Apple, notamment iOS, macOS, watchOS et tvOS.
- Polyvalence: Prise en charge d'un large éventail de tâches d'apprentissage automatique telles que l'analyse d'images, le traitement audio et le traitement du langage naturel à l'aide du cadre CoreML .
Pour plus de détails sur l'intégration de votre modèle CoreML dans une application iOS , consultez le guide sur l'intégration d'un modèle ML de base dans votre application.
Quelles sont les options de déploiement pour les modèles YOLO11 exportés vers CoreML?
Une fois que vous avez exporté votre modèle YOLO11 au format CoreML , vous disposez de plusieurs options de déploiement :
-
Déploiement sur l'appareil: Intégrez directement les modèles CoreML dans votre application pour améliorer la confidentialité et la fonctionnalité hors ligne. Cela peut se faire de la manière suivante :
- Modèles intégrés: Inclus dans l'app bundle, accessible immédiatement.
- Modèles téléchargés: Les modèles sont téléchargés à partir d'un serveur en fonction des besoins, ce qui permet de réduire la taille du paquet d'applications.
-
Déploiement dans le nuage: Héberger les modèles CoreML sur des serveurs et y accéder via des requêtes API. Cette approche facilite les mises à jour et permet de gérer des modèles plus complexes.
Pour des conseils détaillés sur le déploiement des modèles CoreML , voir CoreML Deployment Options.
Comment CoreML garantit-il des performances optimales pour les modèles YOLO11 ?
CoreML garantit des performances optimales pour les modèles en utilisant diverses techniques d'optimisation. Ultralytics YOLO11 en utilisant diverses techniques d'optimisation :
- Accélération matérielle: Utilise le site CPU, GPU, et le moteur neuronal de l'appareil pour des calculs efficaces.
- Compression de modèles: Fournit des outils pour compresser les modèles afin de réduire leur encombrement sans compromettre la précision.
- Inférence adaptative: Ajuste l'inférence en fonction des capacités de l'appareil afin de maintenir un équilibre entre vitesse et performance.
Pour plus d'informations sur l'optimisation des performances, consultez la documentation officielle deCoreML .
Puis-je effectuer une inférence directement avec le modèle exporté CoreML ?
Oui, vous pouvez exécuter l'inférence directement en utilisant le modèle exporté CoreML . Vous trouverez ci-dessous les commandes pour Python et CLI:
Inférence en cours d'exécution
Pour plus d'informations, reportez-vous Ă la section Utilisation du guide d'exportation CoreML .