Maison > développement back-end > Tutoriel Python > Comment extraire les activations de couches spécifiques dans un modèle Keras ?

Comment extraire les activations de couches spécifiques dans un modèle Keras ?

Patricia Arquette
Libérer: 2024-11-30 02:49:14
original
717 Les gens l'ont consulté

How to Extract Activations from Specific Layers in a Keras Model?

Comment obtenir la sortie de chaque couche dans Keras

Lorsque vous travaillez avec des réseaux de neurones profonds (DNN), il est souvent utile d'inspecter les activations de couches individuelles. Cela peut vous aider à comprendre le comportement du modèle et à identifier les problèmes potentiels. Keras, une bibliothèque DNN populaire pour Python, fournit un moyen simple d'y parvenir.

À l'aide de l'interface des couches de modèle

Les modèles Keras sont construits sous la forme d'une séquence de couches, chacune effectuant une opération spécifique sur l'entrée. Pour récupérer la sortie d'une couche particulière, vous pouvez utiliser la syntaxe suivante :

model.layers[index].output
Copier après la connexion

où index est l'index de la couche dont vous souhaitez extraire la sortie. Par exemple, pour obtenir la sortie de la deuxième couche convolutive dans l'extrait de code fourni :

conv_output = model.layers[2].output
Copier après la connexion

Obtenir la sortie de toutes les couches

Pour extraire la sortie de toutes les couches du modèle, vous peut utiliser une compréhension de liste :

outputs = [layer.output for layer in model.layers]
Copier après la connexion

Créer des fonctions d'évaluation

Pour évaluer réellement le sorties des couches, Keras fournit un ensemble de fonctions appelées K.function. Ces fonctions prennent en entrée une liste de tenseurs et renvoient une liste de sorties.

Pour créer une fonction d'évaluation pour chaque sortie de couche, vous pouvez procéder comme suit :

from keras import backend as K

functors = [K.function([inp, K.learning_phase()], [out]) for out in outputs]
Copier après la connexion

où inp est le tenseur d'entrée, K.learning_phase() est un indicateur pour indiquer si le modèle est en mode entraînement ou inférence, et out est la sortie de la couche.

Évaluation Sorties de couche

Maintenant, vous pouvez évaluer les sorties de couche en transmettant les données d'entrée à la fonction d'évaluation correspondante :

test = np.random.random(input_shape)[np.newaxis,...]
layer_outs = [func([test, 1.]) for func in functors]
print layer_outs
Copier après la connexion

N'oubliez pas de définir K.learning_phase() sur 1 si l'un des les couches de votre modèle incluent l'abandon ou la normalisation par lots pour simuler le mode d'entraînement.

Optimisation du processus

Une approche plus efficace pour évaluer les sorties des couches consiste à utiliser une seule fonction qui renvoie la liste des sorties pour toutes les couches :

from keras import backend as K

functor = K.function([inp, K.learning_phase()], outputs)
Copier après la connexion

Cela réduit le transfert de données et la surcharge de calcul associée aux évaluations de fonctions individuelles.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal