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
, Validator
ou 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
, Validator
ou 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_end
et 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_end
et 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_end
et 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 :
- 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.
- 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.
- 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.