Visualisez et journalisez des données tabulaires avec W&B Tables. Une W&B Table est une grille de données bidimensionnelle dans laquelle chaque colonne contient un seul type de données. Chaque ligne représente un ou plusieurs points de données journalisés dans un run. W&B Tables prennent en charge les types primitifs et numériques, ainsi que les listes imbriquées, les dictionnaires et les types de médias enrichis. Une W&B Table est un type de données spécialisé dans W&B, journalisé sous forme d’objet artifact. Vous créez et journalisez des objets de type tableau à l’aide du W&B Python SDK. Lorsque vous créez un objet tableau, vous spécifiez les colonnes et les données du tableau, ainsi qu’un mode. Le mode détermine comment le tableau est journalisé et mis à jour pendant vos expériences de machine learning.Documentation Index
Fetch the complete documentation index at: https://wb-21fd5541-john-wbdocs-2044-rename-serverless-products.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
Le mode
INCREMENTAL est pris en charge sur W&B Server v0.70.0 et versions ultérieures.Créer et journaliser un tableau
- Initialisez un nouveau run avec
wandb.init(). - Créez un objet Table avec la classe
wandb.Table. Spécifiez respectivement les colonnes et les données du tableau à l’aide des paramètrescolumnsetdata. Il est recommandé de définir le paramètre facultatiflog_modesur l’un des trois modes suivants :IMMUTABLE(par défaut),MUTABLEouINCREMENTAL. Voir Modes de journalisation des tableaux dans la section suivante pour en savoir plus. - Journalisez le tableau dans W&B avec
run.log().
a et b, et deux lignes de données, ["a1", "b1"] et ["a2", "b2"] :
Modes de journalisation
log_mode de wandb.Table détermine comment un tableau est journalisé et mis à jour pendant vos expériences de ML. Le paramètre log_mode accepte l’un des trois arguments suivants : IMMUTABLE, MUTABLE et INCREMENTAL. Chaque mode a des implications différentes sur la façon dont un tableau est journalisé, sur la manière dont il peut être modifié et sur son rendu dans la W&B App.
Ce qui suit décrit les trois modes de journalisation, leurs principales différences et le cas d’utilisation courant de chacun :
| Mode | Définition | Cas d’utilisation | Avantages |
|---|---|---|---|
IMMUTABLE | Une fois qu’un tableau est journalisé dans W&B, vous ne pouvez plus le modifier. | - Stocker des données tabulaires générées à la fin d’un run pour une analyse ultérieure | - Surcharge minimale lorsqu’il est journalisé à la fin d’un run - Toutes les lignes sont affichées dans l’UI |
MUTABLE | Après avoir journalisé un tableau dans W&B, vous pouvez remplacer le tableau existant par un nouveau. | - Ajouter des colonnes ou des lignes à des tableaux existants - Enrichir les résultats avec de nouvelles informations | - Capturer les modifications apportées à la Table - Toutes les lignes sont affichées dans l’UI |
INCREMENTAL | Ajouter des lots de nouvelles lignes à un tableau tout au long de l’expérience de machine learning. | - Ajouter des lignes aux tableaux par lots - Tâches d’entraînement de longue durée - Traiter de grands Datasets par lots - Surveiller les résultats en cours | - Voir les mises à jour dans l’UI pendant l’entraînement - Possibilité de parcourir les incréments étape par étape |
Mode MUTABLE
MUTABLE met à jour un tableau existant en le remplaçant par un nouveau. Il est utile lorsque vous souhaitez ajouter de nouvelles colonnes et lignes à un tableau existant dans le cadre d’un processus non itératif. Dans l’interface utilisateur, le tableau est affiché avec toutes les lignes et colonnes, y compris celles ajoutées après le journal initial.
En mode
MUTABLE, l’objet tableau est remplacé chaque fois que vous journalisez le tableau. Remplacer un tableau par un nouveau est coûteux en calcul et peut être lent pour les tableaux volumineux.MUTABLE, le journaliser, puis y ajouter de nouvelles colonnes. L’objet tableau est journalisé trois fois : une fois avec les données initiales, une fois avec les scores de confiance et une fois avec les prédictions finales.
L’exemple suivant utilise une fonction fictive
load_eval_data() pour charger les données et une fonction fictive model.predict() pour effectuer des prédictions. Vous devrez les remplacer par vos propres fonctions de chargement des données et de prédiction.INCREMENTAL.
INCREMENTAL mode
Les Workspace de run dans la W&B App sont limités à 100 incréments. Si vous journalisez plus de 100 incréments, seuls les 100 plus récents sont affichés dans le Workspace du run.
INCREMENTAL, le journalise, puis y ajoute de nouvelles lignes. Notez que le tableau est journalisé une fois par étape d’entraînement (step).
L’exemple suivant utilise une fonction fictive
get_training_batch() pour charger les données, une fonction fictive train_model_on_batch() pour entraîner le modèle et une fonction fictive predict_on_batch() pour effectuer des prédictions. Vous devrez les remplacer par vos propres fonctions de chargement des données, d’entraînement et de prédiction.log_mode=MUTABLE). Cependant, la W&B App peut ne pas afficher toutes les lignes du tableau si vous journalisez un grand nombre d’incréments. Si votre objectif est de mettre à jour et de consulter les données de votre tableau pendant l’exécution de votre run, tout en rendant l’ensemble des données disponible pour l’analyse, envisagez d’utiliser deux tableaux : l’un avec le mode de journalisation INCREMENTAL, et l’autre avec le mode de journalisation IMMUTABLE.
L’exemple suivant montre comment combiner les modes de journalisation INCREMENTAL et IMMUTABLE pour y parvenir.
incr_table est journalisé de façon incrémentielle (avec log_mode="INCREMENTAL") pendant l’entraînement. Cela vous permet de journaliser et de consulter les mises à jour du tableau à mesure que de nouvelles données sont traitées. À la fin de l’entraînement, un tableau immuable (final_table) est créé avec toutes les données du tableau incrémentiel. Le tableau immuable est journalisé afin de préserver l’ensemble du jeu de données pour une analyse ultérieure, et il vous permet de voir toutes les lignes dans l’application W&B.
Exemples
Enrichir les résultats d’évaluation avec MUTABLE
Reprendre des runs avec des tableaux INCREMENTAL
Les incréments sont journalisés dans un nouveau tableau si vous désactivez les résumés pour une clé utilisée par le tableau incrémentiel avec
wandb.Run.define_metric("<table_key>", summary="none") ou wandb.Run.define_metric("*", summary="none").