Partager via


OneVersusAllTrainer Classe

Définition

Pour IEstimator<TTransformer> l’entraînement d’un classifieur à classes multiples un-contre-tous qui utilise le classifieur binaire spécifié.

public sealed class OneVersusAllTrainer : Microsoft.ML.Trainers.MetaMulticlassTrainer<Microsoft.ML.Data.MulticlassPredictionTransformer<Microsoft.ML.Trainers.OneVersusAllModelParameters>,Microsoft.ML.Trainers.OneVersusAllModelParameters>
type OneVersusAllTrainer = class
    inherit MetaMulticlassTrainer<MulticlassPredictionTransformer<OneVersusAllModelParameters>, OneVersusAllModelParameters>
Public NotInheritable Class OneVersusAllTrainer
Inherits MetaMulticlassTrainer(Of MulticlassPredictionTransformer(Of OneVersusAllModelParameters), OneVersusAllModelParameters)
Héritage

Remarques

Pour créer ce formateur, utilisez OneVersusAll.

Colonnes d’entrée et de sortie

Les données de colonne d’étiquette d’entrée doivent être de type clé et la colonne de caractéristique doit être un vecteur de taille connue de Single.

Ce formateur génère les colonnes suivantes :

Nom de colonne de sortie Type de colonne Description
Score Vecteur de Single Les scores de toutes les classes. Une valeur supérieure signifie une plus forte probabilité d’appartenir à la classe associée. Si l’i-ème élément a la plus grande valeur, l’index de l’étiquette prédite est i. Notez que i est l’index de base zéro.
PredictedLabel type de clé Index de l’étiquette prédite. Si sa valeur est i, l’étiquette réelle est la i-ème catégorie dans le type d’étiquette d’entrée avec une valeur de clé.

Caractéristiques de l’entraîneur

Tâche d’apprentissage automatique Classification multiclasse
La normalisation est-elle nécessaire ? Dépend du classifieur binaire sous-jacent
La mise en cache est-elle requise ? Oui
NuGet requis en plus de Microsoft.ML Aucun
Exportable vers ONNX Oui

Détails de l’algorithme d’apprentissage

Dans une stratégie OVA (un-versus-all), un algorithme de classification binaire est utilisé pour entraîner un classifieur pour chaque classe, ce qui distingue cette classe de toutes les autres classes. La prédiction est ensuite effectuée en exécutant ces classifieurs binaires et en choisissant la prédiction avec le score de confiance le plus élevé. Cet algorithme peut être utilisé avec n’importe quel classifieur binaire dans ML.NET. Quelques classifieurs binaires ont déjà une implémentation pour des problèmes multiclasses, ce qui permet aux utilisateurs de choisir l’un ou l’autre en fonction du contexte. La version OVA d’un classifieur binaire, telle que l’habillage d’un LightGbmBinaryTrainer, peut être différente de LightGbmMulticlassTrainercelle d’un classifieur multiclasse directement. Notez que même si le classifieur indique qu’il n’a pas besoin de mise en cache, OneVersusAll demande toujours la mise en cache, car il effectue plusieurs passes sur le jeu de données. Ce formateur demande la normalisation à partir du pipeline de données si le classifieur indique qu’il en tirerait parti.

Cela peut vous permettre d’exploiter les formateurs qui n’ont pas naturellement une option multiclasse, par exemple, en utilisant la FastTreeBinaryTrainer solution d’un problème multiclasse. Il peut également permettre à ML.NET de résoudre un problème « plus simple », même dans les cas où l’entraîneur dispose d’une option multiclasse, mais son utilisation directe n’est pas pratique en raison, généralement, de contraintes de mémoire. Par exemple, si une régression logistique multiclasse est une méthode plus fondée sur le principe pour résoudre un problème multiclasse, il faut que le formateur stocke beaucoup plus d’état intermédiaire sous la forme d’historique L-BFGS pour toutes les classes simultanément, plutôt que d’un seul par un, comme cela serait nécessaire pour un modèle de classification un-contre-tous.

Consultez la section Voir aussi pour obtenir des liens vers des exemples d’utilisation.

Propriétés

Info

Pour IEstimator<TTransformer> l’entraînement d’un classifieur à classes multiples un-contre-tous qui utilise le classifieur binaire spécifié.

(Hérité de MetaMulticlassTrainer<TTransformer,TModel>)

Méthodes

Fit(IDataView)

Effectue l’apprentissage d’un MulticlassPredictionTransformer<TModel> modèle.

GetOutputSchema(SchemaShape)

Obtient les colonnes de sortie.

(Hérité de MetaMulticlassTrainer<TTransformer,TModel>)

Méthodes d’extension

AppendCacheCheckpoint<TTrans>(IEstimator<TTrans>, IHostEnvironment)

Ajoutez un « point de contrôle de mise en cache » à la chaîne d’estimateur. Cela garantit que les estimateurs en aval seront entraînés par rapport aux données mises en cache. Il est utile d’avoir un point de contrôle de mise en cache avant les formateurs qui prennent plusieurs passes de données.

WithOnFitDelegate<TTransformer>(IEstimator<TTransformer>, Action<TTransformer>)

Étant donné un estimateur, retournez un objet de création de package de restrictions qui appellera un délégué une fois Fit(IDataView) appelé. Il est souvent important qu’un estimateur retourne des informations sur ce qui était adapté, c’est pourquoi la Fit(IDataView) méthode retourne un objet spécifiquement typé, plutôt que simplement un général ITransformer. Toutefois, en même temps, IEstimator<TTransformer> sont souvent formés en pipelines avec de nombreux objets. Nous pouvons donc avoir besoin de créer une chaîne d’estimateurs par EstimatorChain<TLastTransformer> le biais de laquelle l’estimateur pour lequel nous voulons obtenir le transformateur est enterré quelque part dans cette chaîne. Pour ce scénario, nous pouvons par le biais de cette méthode attacher un délégué qui sera appelé une fois l’ajustement appelé.

S’applique à

Voir aussi