🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Keras

Kerasは、TheanoやTensorFlow/CNTK対応のラッパーライブラリです。DeepLearningの数学的部分を短いコードでネットワークとして表現することが可能。DeepLearningの最新手法を迅速に試すことができます。

深層学習

深層学習は、多数のレイヤのニューラルネットワークによる機械学習手法。人工知能研究の一つでディープラーニングとも呼ばれています。コンピューター自体がデータの潜在的な特徴を汲み取り、効率的で的確な判断を実現することができます。

Google Colaboratory

Google Colaboratoryとは、無償のJupyterノートブック環境。教育や研究機関の機械学習の普及のためのGoogleの研究プロジェクトです。PythonやNumpyといった機械学習で要する大方の環境がすでに構築されており、コードの記述・実行、解析の保存・共有などが可能です。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

機械学習

機械学習は、データからパターンを自動的に発見し、そこから知能的な判断を下すためのコンピューターアルゴリズムを指します。人工知能における課題のひとつです。

Q&A

解決済

1回答

2679閲覧

VGG16の回帰モデル転用

pythonista

総合スコア21

Keras

Kerasは、TheanoやTensorFlow/CNTK対応のラッパーライブラリです。DeepLearningの数学的部分を短いコードでネットワークとして表現することが可能。DeepLearningの最新手法を迅速に試すことができます。

深層学習

深層学習は、多数のレイヤのニューラルネットワークによる機械学習手法。人工知能研究の一つでディープラーニングとも呼ばれています。コンピューター自体がデータの潜在的な特徴を汲み取り、効率的で的確な判断を実現することができます。

Google Colaboratory

Google Colaboratoryとは、無償のJupyterノートブック環境。教育や研究機関の機械学習の普及のためのGoogleの研究プロジェクトです。PythonやNumpyといった機械学習で要する大方の環境がすでに構築されており、コードの記述・実行、解析の保存・共有などが可能です。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

機械学習

機械学習は、データからパターンを自動的に発見し、そこから知能的な判断を下すためのコンピューターアルゴリズムを指します。人工知能における課題のひとつです。

0グッド

0クリップ

投稿2019/12/15 13:39

前提・実現したいこと

kerasのVGG16の分類モデルを回帰モデルに転用したい
発生しているエラーメッセージの原因を理解して、エラーメッセージを吐かないようにしたい。

発生している問題・エラーメッセージ

定義したモデルに64×64のRGB画像を学習用として投げ、
input_shape = (256, 256, 3)で以下の定義したモデルに転用したところ

main_model.fit(x=x_train, y=y_train, epochs=10, verbose=2, validation_data=(x_test, y_test))

の入力に

Error when checking target: expected dense_2 to have shape (1,) but got array with shape (2,)

と表示され、学習ができない

該当のソースコード

python3.6

1###レイヤーの定義 2def VGG16_Reg(input_shape): 3 input_layer = Input(shape=input_shape) 4 5 # Block 1 6 conv1_1 = Conv2D(64, (3, 3), name='conv1_1', activation='relu', padding='same')(input_layer) 7 conv1_2 = Conv2D(64, (3, 3), name='conv1_2', activation='relu', padding='same')(conv1_1) 8 bn1 = BatchNormalization(axis=3)(conv1_2) 9 pool1 = MaxPooling2D(pool_size=(2, 2))(bn1) 10 drop1 = Dropout(0.5)(pool1) 11 12 # Block 2 13 conv2_1 = Conv2D(128, (3, 3), name='conv2_1', activation='relu', padding='same')(drop1) 14 conv2_2 = Conv2D(128, (3, 3),name='conv2_2', activation='relu', padding='same')(conv2_1) 15 bn2 = BatchNormalization(axis=3)(conv2_2) 16 pool2 = MaxPooling2D(pool_size=(2, 2))(bn2) 17 drop2 = Dropout(0.5)(pool2) 18 19 # Block 3 20 conv3_1 = Conv2D(256, (3, 3),name='conv3_1', activation='relu', padding='same')(drop2) 21 conv3_2 = Conv2D(256, (3, 3),name='conv3_2', activation='relu', padding='same')(conv3_1) 22 conv3_3 = Conv2D(256, (3, 3),name='conv3_3', activation='relu', padding='same')(conv3_2) 23 conv3_4 = Conv2D(256, (3, 3),name='conv3_4', activation='relu', padding='same')(conv3_3) 24 bn3 = BatchNormalization(axis=3)(conv3_4) 25 pool3 = MaxPooling2D(pool_size=(2, 2))(bn3) 26 drop3 = Dropout(0.5)(pool3) 27 28 # Block 4 29 conv4_1 = Conv2D(512, (3, 3),name='conv4_1', activation='relu', padding='same')(drop3) 30 conv4_2 = Conv2D(512, (3, 3),name='conv4_2', activation='relu', padding='same')(conv4_1) 31 conv4_3 = Conv2D(512, (3, 3),name='conv4_3', activation='relu', padding='same')(conv4_2) 32 conv4_4 = Conv2D(512, (3, 3),name='conv4_4', activation='relu', padding='same')(conv4_3) 33 bn4 = BatchNormalization(axis=3)(conv4_4) 34 pool4 = MaxPooling2D(pool_size=(2, 2))(bn4) 35 drop4 = Dropout(0.5)(pool4) 36 37 # Block 5 38 conv5_1 = Conv2D(512, (3, 3),name='conv5_1', activation='relu', padding='same')(drop4) 39 conv5_2 = Conv2D(512, (3, 3),name='conv5_2', activation='relu', padding='same')(conv5_1) 40 conv5_3 = Conv2D(512, (3, 3),name='conv5_3', activation='relu', padding='same')(conv5_2) 41 conv5_4 = Conv2D(512, (3, 3),name='conv5_4', activation='relu', padding='same')(conv5_3) 42 bn5 = BatchNormalization(axis=3)(conv5_4) 43 pool5 = MaxPooling2D(pool_size=(2, 2))(bn5) 44 drop5 = Dropout(0.5)(pool5) 45 46 x = Flatten()(drop5) 47 x = Dense(4096)(x) 48 x = Dropout(0.5)(x) 49 x = Dense(1)(x) 50 model = Model(inputs=input_layer, outputs=x) 51 model.compile(loss='mean_squared_error', optimizer='rmsprop') 52 return model 53

補足情報

google colabで実行

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

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

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

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

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

guest

回答1

0

ベストアンサー

dense_2が想定しているshapeが(1, )に対して(2, )が入力されているようです.

x = Flatten()(drop5) x = Dense(4096)(x) x = Dropout(0.5)(x) # 追記 print(x.shape) x = Dense(1)(x)

のように追記してshapeを確認して見てください.

投稿2019/12/15 13:57

tetsu316

総合スコア41

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

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

pythonista

2019/12/15 14:16

(?, 4096)というタプルがprintで返却されました。この場合、どのように対処したら良いでしょうか。
tetsu316

2019/12/15 14:24

試してみたところ自分のcolab環境ではできました. x_trainの定義など,前後のコード送ってもらうことは可能ですか?
pythonista

2019/12/15 14:31

ありがとうございます。以下が他の定義になります ``` #画像データの取り込み train_images_list = os.listdir(main_dir +"train_images") ``` ``` ##データ読み込み関数 def images_to_array_CV2(ImageName_list=restricted_train_images_list, Images_directory=main_dir+"train_images/", image_size=64, train_cast="float32", colour_scale=255.0, dense_size=100): import numpy import cv2 import glob from keras.utils import np_utils X = [] Y = [] for index, name in enumerate(ImageName_list): dir = Images_directory + name files = glob.glob(dir) for i, file in enumerate(files): image = cv2.imread(file) image = cv2.resize(image, (image_size, image_size)) data = numpy.asarray(image) X.append(data) Y.append(index) print(name + ": already treated") X = numpy.array(X) Y = numpy.array(Y) # X = X.astype(train_cast) #データサイズ縮小 X = X/colour_scale #色合いを正規化 Y = np_utils.to_categorical(Y, dense_size) #各ラベルを0or1のカテゴリベクトル化(分類タスク用) return [X, Y] ``` ``` #データの整形 x_train = images_to_array_CV2(ImageName_list=restricted_train_images_list, image_size=256)[0] y_train = y_train.head(len(x_train)) x_test = images_to_array_CV2(ImageName_list=train_images_list[31:31+30], image_size=256)[0] y_test = y_train[len(x_test):len(x_test)+30] ```
pythonista

2019/12/15 14:33

def以降は全てreturnまでインデントあります。コピペで貼り付けました。気が回らずに申し訳ありません。 ``` ##データ読み込み関数 def images_to_array_CV2(ImageName_list=restricted_train_images_list, Images_directory=main_dir+"train_images/", image_size=64, train_cast="float32", colour_scale=255.0, dense_size=100): import numpy import cv2 import glob from keras.utils import np_utils X = [] Y = [] for index, name in enumerate(ImageName_list): dir = Images_directory + name files = glob.glob(dir) for i, file in enumerate(files): image = cv2.imread(file) image = cv2.resize(image, (image_size, image_size)) data = numpy.asarray(image) X.append(data) Y.append(index) print(name + ": already treated") X = numpy.array(X) Y = numpy.array(Y) # X = X.astype(train_cast) #データサイズ縮小 X = X/colour_scale #色合いを正規化 Y = np_utils.to_categorical(Y, dense_size) #各ラベルを0or1のカテゴリベクトル化(分類タスク用) return [X, Y] ```
tetsu316

2019/12/15 15:28 編集

``` Y = np_utils.to_categorical(Y, dense_size) #各ラベルを0or1のカテゴリベクトル化(分類タスク用) ``` これですね,分類問題に使われるものです. 今回は回帰タスクに変更したいとのことなのでこの行は消していただいて大丈夫です. ``` #データの整形 x_train = images_to_array_CV2(ImageName_list=restricted_train_images_list, image_size=256)[0] y_train = y_train.head(len(x_train)) x_test = images_to_array_CV2(ImageName_list=train_images_list[31:31+30], image_size=256)[0] y_test = y_train[len(x_test):len(x_test)+30] ``` ここの部分が実行できなかったのですが,以下のように書くと可読性も上がると思います ``` x_train, y_train = images_to_array_CV2(hoge) x_test, y_test = images_to_array_CV2(hoge) ```
tetsu316

2019/12/15 15:29

ラベル(y_train, y_test)が問題だったみたいです
pythonista

2019/12/15 16:39

解決いたしました!!!!!!!!!!! 大変懇切丁寧なアドバイスありがとうございます 本当に助かりました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問