質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

535閲覧

tensorflowでの内積を用いた形状変換について。

wildgeece96

総合スコア8

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2017/12/11 07:35

tensorflowでtf.matmul関数を用いた形状変換をしたいのですが、NumPyのようにブロードキャストが適用されず、どうしたらいいのかよくわかりません。

コードはcifar-10での畳み込み層に2つ前の層から合流するものを作るのですが、
その合流する際にフィルターの数が変わっている部分があり、そこの調整を行うために
tf.matmul関数を使って形状変換を試みました。

num_filters = 16 num_filters = 32 h_pool9 = tf.placeholder(dtype=tf.float32, shape=[None, 12, 12, num_filters1]) W_extra = tf.Variable(tf.truncated_normal([num_filters1, num_filters2], stddev=0.05, dtype=dtype2), name='change_weights') b_extra = tf.Variable(tf.constant(0.1, shape=[num_filters2]), name='change_biases') h_pool9_for_11 = tf.matmul(h_pool9, W_extra) + b_extra

これを実行しようとするとエラーが生じます。

ValueError: Shape must be rank 2 but is rank 4 for 'MatMul_9' (op: 'MatMul') with input shapes: [?,12,12,16], [16,32].

最終的にh_pool9_for_11で求めたい形状は[?, 12, 12, 32]です。
これを行うためにはどうしたらいいのでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

tf.matmulは引数2つがともに2次元であることを要求しています。
行列積ですから。

どのようなことを実現したいのかが少々わかりません。

  1. 畳み込みによってピクセル数を削減をしたい
  2. reshapeして次元を変えたい
  3. その他

どのようなものでしょう。

それともtf.multiplyがお探しの関数ですか?
https://www.tensorflow.org/versions/r0.12/api_docs/python/math_ops/arithmetic_operators#multiply


python

1import tensorflow as tf 2import numpy as np 3with tf.Session() as sess: 4 x = tf.Variable([1, 2, 3]) 5 y = tf.Variable([[[1, 2, 3], [4, 5, 6]]]) 6 sess.run(tf.global_variables_initializer()) 7 print('x.shape\n', x.shape) 8 print('y.shape\n', y.shape) 9 print('x*y\n', sess.run(tf.multiply(x, y))) 10''' 11x.shape 12 (3,) 13y.shape 14 (1, 2, 3) 15x*y 16 [[[ 1 4 9] 17 [ 4 10 18]]] 18'''

投稿2017/12/11 09:15

編集2017/12/11 09:20
mkgrei

総合スコア8560

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

wildgeece96

2017/12/11 12:19

これはcifar-10をResNetを用いて分類を行おうとしたときのコードの一部を抜き出してその場で実行できるようにしたものです。 h_pool9というのが第9層で畳み込みを行った後、プーリング層を通したもので、ここでのフィルターの数が16枚でした。 その後、フィルターの枚数を倍の32枚にした層が第10層から始まり、11層で9層での出力を合流させたくてフィルター数が合致しないためその次元数を調整するために何かしらの処理を施したかったのです。 僕が参照した論文(日本語訳されたものがあったのでそのリンクを貼り付けておきます)ではそのとき重み行列wをかけることでそれを行う趣旨のものが書かれていたため(僕の読み違いであったらすみません)、とりあえず`tf.matmul`関数を使ってその次元調整を行おうと考えた次第です。実際、NumPyで同様のコードを実行するとうまくいったのでTensorFlowでも行えるかと思っていたのですがこのようなエラーが出た次第です。 https://qiita.com/ikeyasu/items/ea9ced2b8e0fcb3da2be
wildgeece96

2017/12/11 12:20

サンプルコードを読んでみると、畳込みでそれを実現しているのを見つけたので、とりあえずそれでやってみます。
mkgrei

2017/12/11 12:38

その場合、 W_extra = tf.Variable(tf.truncated_normal([1, 1, num_filters1, num_filters2], stddev=0.05, dtype=dtype2), name='change_weights') ではうまくいきませんか?
mkgrei

2017/12/11 12:41

1x1 Convでもうまく行くみたいですね。
wildgeece96

2017/12/11 12:41

うまくいきました! とりあえずモデル作成段階ではエラーは吐き出されなかったです!! ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問