Run.config comme entrées du job, mais le SDK Launch fournit une fonction pour contrôler certaines clés de la configuration du run ou pour spécifier des fichiers JSON ou YAML comme entrées.
Les fonctions du SDK Launch nécessitent
wandb-core. Voir le fichier wandb-core README pour plus d’informations.Reconfigurer l’objet Run
Run renvoyé par wandb.init dans un job peut, par défaut, être reconfiguré. Le SDK Launch permet de personnaliser les parties de l’objet Run.config qui peuvent être reconfigurées au lancement du job.
launch.manage_wandb_config configure le job pour qu’il accepte des valeurs d’entrée pour l’objet Run.config. Les options facultatives include et exclude prennent des préfixes de chemin au sein de l’objet de configuration imbriqué. Cela peut être utile si, par exemple, un job utilise une bibliothèque dont vous ne souhaitez pas exposer les options aux utilisateurs finaux.
Si des préfixes include sont fournis, seuls les chemins de la configuration qui correspondent à un préfixe include accepteront des valeurs d’entrée. Si des préfixes exclude sont fournis, les chemins correspondant à la liste exclude seront exclus des valeurs d’entrée. Si un chemin correspond à la fois à un préfixe include et à un préfixe exclude, le préfixe exclude sera prioritaire.
Dans l’exemple précédent, le chemin ["trainer.private"] exclura la clé private de l’objet trainer, et le chemin ["trainer"] exclura toutes les clés qui ne se trouvent pas sous l’objet trainer.
Utilisez un
. précédé d’un caractère d’échappement \ pour exclure les clés dont le nom contient un ..Par exemple, r"trainer\.private" exclut la clé trainer.private plutôt que la clé private sous l’objet trainer.Notez que le préfixe r ci-dessus désigne une chaîne brute.trainer.
Accéder aux entrées de configuration du run
Run.config. Le Run renvoyé par wandb.init dans le code du job aura automatiquement les valeurs des inputs définies. Utilisez
Reconfigurer un fichier
Sweeps on Launch ne prend pas en charge l’utilisation d’entrées du fichier de configuration comme paramètres de balayage. Les paramètres de balayage doivent être contrôlés via l’objet
Run.config.launch.manage_config_file peut être utilisée pour ajouter un fichier de configuration comme entrée du job Launch, ce qui vous permet de modifier les valeurs qu’il contient au moment de lancer le job.
Par défaut, aucune entrée de configuration du run n’est capturée lorsque launch.manage_config_file est utilisé. L’appel à launch.manage_wandb_config remplace ce comportement.
Prenez l’exemple suivant :
config.yaml situé dans le même répertoire :
launch.manage_config_file ajoute le fichier config.yaml comme entrée du job, ce qui le rend reconfigurable lors d’un lancement depuis la CLI ou l’UI de W&B.
Les arguments nommés include et exclude peuvent être utilisés pour filtrer les clés d’entrée acceptées du fichier de configuration, de la même manière que launch.manage_wandb_config.
Accéder aux valeurs d’entrée du fichier de configuration
launch.manage_config_file est appelé dans un run créé par Launch, launch met à jour le contenu du fichier de configuration avec les valeurs d’entrée. Le fichier de configuration mis à jour est disponible dans l’environnement du job.
Personnaliser l’interface du volet de lancement d’un job
launch.manage_wandb_config ou launch.manage_config_file. Le schéma peut être soit un dict Python au format JSON Schema, soit une classe de modèle Pydantic.
- Schéma JSON
- Modèle Pydantic
L’exemple suivant montre un schéma avec les propriétés suivantes :De manière générale, les attributs JSON Schema suivants sont pris en charge :
seed, un entiertrainer, un dictionnaire avec certaines clés spécifiées :trainer.learning_rate, un flottant qui doit être supérieur à zérotrainer.batch_size, un entier qui doit être égal à 16, 64 ou 256trainer.dataset, une chaîne qui doit être soitcifar10, soitcifar100
| Attribut | Requis | Notes |
|---|---|---|
type | Oui | Doit être l’un de number, integer, string ou object |
title | Non | Remplace le nom d’affichage de la propriété |
description | Non | Fournit le texte d’aide de la propriété |
enum | Non | Crée une liste déroulante au lieu d’un champ de texte libre |
minimum | Non | Autorisé uniquement si type vaut number ou integer |
maximum | Non | Autorisé uniquement si type vaut number ou integer |
exclusiveMinimum | Non | Autorisé uniquement si type vaut number ou integer |
exclusiveMaximum | Non | Autorisé uniquement si type vaut number ou integer |
properties | Non | Si type vaut object, sert à définir des configurations imbriquées |
