Récemment, je courais et j'apprenais le flux tenseur et j'ai obtenu quelques histogrammes que je ne savais pas interpréter. Habituellement, je pense à la hauteur des barres comme à la fréquence (ou fréquence relative / comptes). Cependant, le fait qu'il n'y ait pas de barres comme dans un histogramme habituel et le fait que les choses soient ombrées me confond. il semble également y avoir plusieurs lignes / hauteurs à la fois?
Est-ce que quelqu'un sait comment interpréter les graphiques suivants (et peut-être fournir de bons conseils qui peuvent aider en général à lire les histogrammes dans tensorflow):
Peut-être que d'autres choses intéressantes à discuter sont, si les variables d'origine étaient des vecteurs ou des matrices ou des tenseurs, alors qu'est-ce que le tensorflow montre en fait, comme un histogramme pour chaque coordonnée? De plus, peut-être que faire référence à la façon d'obtenir ces informations pour rendre les gens autonomes serait bien parce que j'ai eu du mal à trouver des choses utiles sur les documents en ce moment. Peut-être quelques exemples de tutoriels, etc.? Peut-être que quelques conseils pour les manipuler seraient bien aussi.
À titre de référence, voici un extrait du code qui a donné ceci:
(X_train, Y_train, X_cv, Y_cv, X_test, Y_test) = data_lib.get_data_from_file(file_name='./f_1d_cos_no_noise_data.npz')
(N_train,D) = X_train.shape
D1 = 24
(N_test,D_out) = Y_test.shape
W1 = tf.Variable( tf.truncated_normal([D,D1], mean=0.0, stddev=std), name='W1') # (D x D1)
S1 = tf.Variable( tf.constant(100.0, shape=[]), name='S1') # (1 x 1)
C1 = tf.Variable( tf.truncated_normal([D1,1], mean=0.0, stddev=0.1), name='C1' ) # (D1 x 1)
W1_hist = tf.histogram_summary("W1", W1)
S1_scalar_summary = tf.scalar_summary("S1", S1)
C1_hist = tf.histogram_summary("C1", C1)
W1_hist = tf.histogram_summary("W1", W1)
. Il dit histogramme, comment puis-je l'appeler autrement? Je ne sais pas pourquoi ils l'appelleraient histogramme alors que c'est autre chose.Réponses:
Actuellement, le nom "histogramme" est impropre. Vous pouvez trouver des preuves de cela dans le README . La signification de l'interface d'histogramme pourrait changer un jour comme ils l'ont dit. Cependant, c'est ce que cela signifie actuellement.
Les graphiques de votre question mélangent différentes exécutions de TensorFlow. Regardez plutôt les graphiques suivants qui affichent une seule exécution:
Tout d'abord, je voudrais dire que les courbes elles-mêmes représentent des centiles . Je vais emprunter la photo d' ici :
ce qui signifie que la courbe étiquetée 93% est le 93e centile, ce qui signifie que 93% des observations étaient inférieures à la valeur ~ 0,130 au pas de temps 1,00k. Le graphique donne donc 3 éléments d'information, le pourcentage d'observations sous une certaine valeur selon une courbe de réflexion à chaque pas de temps du calcul de la formation du réseau neuronal (du moins dans ce cas, c'est ce que signifient les étapes). Cela vous donne une idée de la répartition des valeurs de votre réseau.
Il existe également des valeurs minimales et maximales pour avoir une idée de la plage de valeurs pendant l'entraînement.
Ainsi, l'axe des y vous indique la valeur qui vous intéresse et la courbe vous indique le centile et l'axe des x à l'étape. Donc si vous avez:
la source