Skip to content

Rappels

Rappels

Ultralytics supporte les callbacks comme points d'entrée dans les étapes stratégiques des modes train, val, export et predict. Chaque callback accepte un Trainer, Validatorou Predictor en fonction du type d'opération. Toutes les propriétés de ces objets peuvent être trouvées dans la section Référence de la documentation.



Regarder : Mastering Ultralytics YOLO : Rappels

Exemples

Renvoi d'informations supplémentaires avec la prédiction

Dans cet exemple, nous voulons renvoyer l'image originale avec chaque objet résultat. Voici comment procéder

from ultralytics import YOLO


def on_predict_batch_end(predictor):
    """Handle prediction batch end by combining results with corresponding frames; modifies predictor results."""
    _, image, _, _ = predictor.batch

    # Ensure that image is a list
    image = image if isinstance(image, list) else [image]

    # Combine the prediction results with the corresponding frames
    predictor.results = zip(predictor.results, image)


# Create a YOLO model instance
model = YOLO("yolo11n.pt")

# Add the custom callback to the model
model.add_callback("on_predict_batch_end", on_predict_batch_end)

# Iterate through the results and frames
for result, frame in model.predict():  # or model.track()
    pass

Tous les rappels

Voici tous les rappels pris en charge. Voir le code source des callbacks pour plus de détails.

Rappels du formateur

Rappel Description
on_pretrain_routine_start Déclenché au début de la routine de pré-entraînement
on_pretrain_routine_end Déclenché à la fin de la routine de pré-entraînement
on_train_start Déclenché au début de la formation
on_train_epoch_start Déclenché au début de chaque période d'apprentissage
on_train_batch_start Déclenché au début de chaque lot de formation
optimizer_step Déclenché pendant l'étape de l'optimiseur
on_before_zero_grad Déclenché avant la mise à zéro des gradients
on_train_batch_end Déclenché à la fin de chaque lot de formation
on_train_epoch_end Déclenché à la fin de chaque période d'apprentissage
on_fit_epoch_end Déclenché à la fin de chaque période d'ajustement
on_model_save Déclenché lorsque le modèle est sauvegardé
on_train_end Déclenché à la fin du processus de formation
on_params_update Déclenché lors de la mise à jour des paramètres du modèle
teardown Déclenché lorsque le processus de formation est en cours de nettoyage

Rappels du validateur

Rappel Description
on_val_start Déclenché au début de la validation
on_val_batch_start Déclenché au début de chaque lot de validation
on_val_batch_end Déclenché à la fin de chaque lot de validation
on_val_end Déclenché à la fin de la validation

Rappels de prédicteurs

Rappel Description
on_predict_start Déclenché lorsque le processus de prédiction commence
on_predict_batch_start Déclenché au début de chaque lot de prédiction
on_predict_postprocess_end Déclenché à la fin du post-traitement de la prédiction
on_predict_batch_end Déclenché à la fin de chaque lot de prédictions
on_predict_end Déclenché à la fin du processus de prédiction

Rappels de l'exportateur

Rappel Description
on_export_start Déclenché au début du processus d'exportation
on_export_end Déclenché à la fin du processus d'exportation

FAQ

Que sont les rappels Ultralytics et comment puis-je les utiliser ?

Ultralytics rappels sont des points d'entrée spécialisés déclenchés lors d'étapes clés des opérations du modèle telles que l'entraînement, la validation, l'exportation et la prédiction. Ces rappels permettent d'obtenir des fonctionnalités personnalisées à des moments précis du processus, ce qui permet d'améliorer et de modifier le flux de travail. Chaque rappel accepte un Trainer, Validatorou Predictor en fonction du type d'opération. Pour connaître les propriétés détaillées de ces objets, reportez-vous à la section Section de référence.

Pour utiliser un rappel, vous pouvez définir une fonction et l'ajouter au modèle à l'aide de la fonction add_callback méthode. Voici un exemple de retour d'informations supplémentaires lors de la prédiction :

from ultralytics import YOLO


def on_predict_batch_end(predictor):
    """Handle prediction batch end by combining results with corresponding frames; modifies predictor results."""
    _, image, _, _ = predictor.batch
    image = image if isinstance(image, list) else [image]
    predictor.results = zip(predictor.results, image)


model = YOLO("yolo11n.pt")
model.add_callback("on_predict_batch_end", on_predict_batch_end)
for result, frame in model.predict():
    pass

Comment puis-je personnaliser la routine d'entraînement de Ultralytics à l'aide de rappels ?

Pour personnaliser votre routine de formation Ultralytics à l'aide de rappels, vous pouvez injecter votre logique à des étapes spécifiques du processus de formation. Ultralytics YOLO fournit une variété de rappels de formation tels que on_train_start, on_train_endet on_train_batch_end. Ils vous permettent d'ajouter des mesures, des traitements ou des enregistrements personnalisés.

Here's an example of how to freeze BatchNorm statistics when freezing layers with callbacks:

from ultralytics import YOLO


# Add a callback to put the frozen layers in eval mode to prevent BN values from changing
def put_in_eval_mode(trainer):
    n_layers = trainer.args.freeze
    if not isinstance(n_layers, int):
        return

    for i, (name, module) in enumerate(trainer.model.named_modules()):
        if name.endswith("bn") and int(name.split(".")[1]) < n_layers:
            module.eval()
            module.track_running_stats = False


model = YOLO("yolo11n.pt")
model.add_callback("on_train_epoch_start", put_in_eval_mode)
model.train(data="coco.yaml", epochs=10)

Reportez-vous au Guide de la formation pour plus de détails sur la manière d'utiliser efficacement les rappels de formation.

Pourquoi utiliser des callbacks lors de la validation dans Ultralytics YOLO ?

Utilisation callbacks lors de la validation dans Ultralytics YOLO peuvent améliorer l'évaluation du modèle en permettant un traitement personnalisé, la journalisation ou le calcul de métriques. Les rappels tels que on_val_start, on_val_batch_endet on_val_end fournissent des points d'entrée pour injecter une logique personnalisée, garantissant des processus de validation détaillés et complets.

For instance, you might want to plot all the validation batches, instead of just the first 3. Here's how you can do that:

import inspect

from ultralytics import YOLO


def plot_samples(validator):
    frame = inspect.currentframe().f_back.f_back
    v = frame.f_locals
    validator.plot_val_samples(v["batch"], v["batch_i"])
    validator.plot_predictions(v["batch"], v["preds"], v["batch_i"])


model = YOLO("yolo11n.pt")
model.add_callback("on_val_batch_end", plot_samples)
model.val(data="coco.yaml")

Consultez le Guide de validation pour en savoir plus sur l'intégration des rappels dans votre processus de validation.

Comment puis-je attacher un callback personnalisé pour le mode prédiction dans Ultralytics YOLO ?

Pour attacher un rappel personnalisé à la fonction mode de prédiction dans Ultralytics YOLO , vous définissez une fonction de rappel et l'enregistrez dans le processus de prédiction. Les fonctions de rappel de prédiction les plus courantes sont les suivantes on_predict_start, on_predict_batch_endet on_predict_end. Ils permettent de modifier les résultats de la prédiction et d'intégrer des fonctionnalités supplémentaires telles que l'enregistrement des données ou la transformation des résultats.

Here is an example where a custom callback is used to save predictions based on whether an object of a particular class is present:

from ultralytics import YOLO

model = YOLO("yolo11n.pt")

class_id = 2


def save_on_object(predictor):
    r = predictor.results[0]
    if class_id in r.boxes.cls:
        predictor.args.save = True
    else:
        predictor.args.save = False


model.add_callback("on_predict_postprocess_end", save_on_object)
results = model("pedestrians.mp4", stream=True, save=True)

for results in results:
    pass

Pour une utilisation plus complète, consultez le Guide de prédiction qui contient des instructions détaillées et des options de personnalisation supplémentaires.

Quels sont les exemples pratiques d'utilisation de callbacks dans Ultralytics YOLO ?

Ultralytics YOLO prend en charge diverses implémentations pratiques de rappels pour améliorer et personnaliser différentes phases telles que l'entraînement, la validation et la prédiction. Voici quelques exemples pratiques :

  1. Enregistrement de mesures personnalisées: Enregistrez des mesures supplémentaires à différents stades, par exemple à la fin des périodes d'apprentissage ou de validation.
  2. Augmentation des données: Mise en œuvre de transformations ou d'augmentations personnalisées des données au cours des lots de prédiction ou d'entraînement.
  3. Résultats intermédiaires: Enregistrez les résultats intermédiaires, tels que les prédictions ou les cadres, en vue d'une analyse ou d'une visualisation plus poussée.

Exemple : Combinaison de trames avec les résultats de la prédiction pendant la prédiction à l'aide de on_predict_batch_end:

from ultralytics import YOLO


def on_predict_batch_end(predictor):
    """Combine prediction results with frames."""
    _, image, _, _ = predictor.batch
    image = image if isinstance(image, list) else [image]
    predictor.results = zip(predictor.results, image)


model = YOLO("yolo11n.pt")
model.add_callback("on_predict_batch_end", on_predict_batch_end)
for result, frame in model.predict():
    pass

Consultez la référence complète sur les rappels pour découvrir d'autres options et exemples.

📅C réé il y a 1 an ✏️ Mis à jour il y a 16 jours

Commentaires