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

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

新規登録して質問してみよう
ただいま回答率
85.35%
機械学習

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

Python

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

Q&A

解決済

1回答

3360閲覧

ValueError: x and y must have same first dimension, but have shapes (200,) and (5,)の解決法

shujiu

総合スコア3

機械学習

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

Python

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

0グッド

0クリップ

投稿2021/05/12 12:35

前提・実現したいこと

Resnet50で転移学習行い、モデル作成しGradcamで特徴領域の抽出を試みています。
学習は完了しましたが下記のようなエラーメッセージが表示されます。
解決法などご教示いただけませんでしょうか。よろしくお願いいたします。

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

C:\Users\orala\Desktop\new>python train3.py Using TensorFlow backend. 2021-05-12 10:57:06.498117: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cudart64_101.dll 2421 39 Found 2421 images belonging to 2 classes. Found 39 images belonging to 2 classes. 2021-05-12 10:57:08.799557: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library nvcuda.dll 2021-05-12 10:57:08.830175: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1555] Found device 0 with properties: pciBusID: 0000:01:00.0 name: NVIDIA GeForce GTX 1660 Ti computeCapability: 7.5 coreClock: 1.59GHz coreCount: 24 deviceMemorySize: 6.00GiB deviceMemoryBandwidth: 268.26GiB/s 2021-05-12 10:57:08.830324: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cudart64_101.dll 2021-05-12 10:57:08.836867: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cublas64_10.dll 2021-05-12 10:57:08.840921: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cufft64_10.dll 2021-05-12 10:57:08.842442: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library curand64_10.dll 2021-05-12 10:57:08.847273: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cusolver64_10.dll 2021-05-12 10:57:08.849772: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cusparse64_10.dll 2021-05-12 10:57:08.858227: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cudnn64_7.dll 2021-05-12 10:57:08.858429: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1697] Adding visible gpu devices: 0 2021-05-12 10:57:08.858718: I tensorflow/core/platform/cpu_feature_guard.cc:142] Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2 2021-05-12 10:57:08.859551: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1555] Found device 0 with properties: pciBusID: 0000:01:00.0 name: NVIDIA GeForce GTX 1660 Ti computeCapability: 7.5 coreClock: 1.59GHz coreCount: 24 deviceMemorySize: 6.00GiB deviceMemoryBandwidth: 268.26GiB/s 2021-05-12 10:57:08.859703: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cudart64_101.dll 2021-05-12 10:57:08.859833: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cublas64_10.dll 2021-05-12 10:57:08.859954: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cufft64_10.dll 2021-05-12 10:57:08.860088: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library curand64_10.dll 2021-05-12 10:57:08.860236: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cusolver64_10.dll 2021-05-12 10:57:08.860386: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cusparse64_10.dll 2021-05-12 10:57:08.860498: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cudnn64_7.dll 2021-05-12 10:57:08.860631: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1697] Adding visible gpu devices: 0 2021-05-12 10:57:09.340333: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1096] Device interconnect StreamExecutor with strength 1 edge matrix: 2021-05-12 10:57:09.340452: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1102] 0 2021-05-12 10:57:09.340708: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1115] 0: N 2021-05-12 10:57:09.340914: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1241] Created TensorFlow device (/job:localhost/replica:0/task:0/device:GPU:0 with 4755 MB memory) -> physical GPU (device: 0, name: NVIDIA GeForce GTX 1660 Ti, pci bus id: 0000:01:00.0, compute capability: 7.5) C:\Users\orala\anaconda3\envs\envtest2\lib\site-packages\keras_applications\resnet50.py:265: UserWarning: The output shape of `ResNet50(include_top=False)` has been changed since Keras 2.2.0. warnings.warn('The output shape of `ResNet50(include_top=False)` ' train3.py:76: UserWarning: Update your `Model` call to the Keras 2 API: `Model(inputs=Tensor("in..., outputs=Tensor("se...)` model = Model(input=ResNet50.input, output=top_model(ResNet50.output)) Epoch 1/200 2021-05-12 10:57:27.358295: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cublas64_10.dll 2021-05-12 10:57:27.650637: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library cudnn64_7.dll 2021-05-12 10:57:28.705641: W tensorflow/stream_executor/gpu/redzone_allocator.cc:312] Internal: Invoking GPU asm compilation is supported on Cuda non-Windows platforms only Relying on driver to perform ptx compilation. This message will be only logged once. 2421/2421 [==============================] - 2049s 846ms/step - loss: 8.0491 - accuracy: 0.8244 - val_loss: 0.0262 - val_accuracy: 0.8718 Epoch 2/200 2421/2421 [==============================] - 2158s 891ms/step - loss: 1.9205 - accuracy: 0.8887 - val_loss: 0.0023 - val_accuracy: 0.8205 Epoch 3/200 2421/2421 [==============================] - 2112s 873ms/step - loss: 0.8607 - accuracy: 0.9081 - val_loss: 0.0530 - val_accuracy: 0.9231 Epoch 4/200 2421/2421 [==============================] - 2128s 879ms/step - loss: 0.2938 - accuracy: 0.9360 - val_loss: 0.1249 - val_accuracy: 0.9231 Epoch 5/200 2421/2421 [==============================] - 2131s 880ms/step - loss: 0.2834 - accuracy: 0.9441 - val_loss: 0.5585 - val_accuracy: 0.9231 {'val_loss': [0.026193205267190933, 0.0023010552395135164, 0.05301950126886368, 0.12488315254449844, 0.5584982633590698], 'val_accuracy': [0.8717948794364929, 0.8205128312110901, 0.9230769276618958, 0.9230769276618958, 0.9230769276618958], 'loss': [8.012906371525457, 1.923668423558113, 0.86216264440948, 0.2938869503103723, 0.277316237373691], 'accuracy': [0.82441044, 0.888705, 0.9080679, 0.9359537, 0.9441456]} Traceback (most recent call last): File "train3.py", line 103, in <module> plt.plot(range(1,epochs+1),acc,'b',label = 'traning accracy') File "C:\Users\orala\anaconda3\envs\envtest2\lib\site-packages\matplotlib\pyplot.py", line 2796, in plot is not None else {}), **kwargs) File "C:\Users\orala\anaconda3\envs\envtest2\lib\site-packages\matplotlib\axes\_axes.py", line 1665, in plot lines = [*self._get_lines(*args, data=data, **kwargs)] File "C:\Users\orala\anaconda3\envs\envtest2\lib\site-packages\matplotlib\axes\_base.py", line 225, in __call__ yield from self._plot_args(this, kwargs) File "C:\Users\orala\anaconda3\envs\envtest2\lib\site-packages\matplotlib\axes\_base.py", line 391, in _plot_args x, y = self._xy_from_xy(x, y) File "C:\Users\orala\anaconda3\envs\envtest2\lib\site-packages\matplotlib\axes\_base.py", line 270, in _xy_from_xy "have shapes {} and {}".format(x.shape, y.shape)) ValueError: x and y must have same first dimension, but have shapes (200,) and (5,)

該当のソースコード

python

1import os 2import random 3import glob 4import matplotlib.pyplot as plt 5from keras.preprocessing.image import ImageDataGenerator 6from keras.applications.resnet50 import ResNet50 7from keras.models import Sequential, Model 8from keras.layers import Input, Flatten, Dense 9from keras import optimizers 10from keras.callbacks import ModelCheckpoint, EarlyStopping 11from keras import backend 12 13 14classes = ['normal','others'] 15nb_classes = len(classes) 16 17#train val dir 18train_dir = './dataset/train' 19val_dir = './dataset/valid' 20model_dir = './saved_model' 21 22#num samples 23train_samples = glob.glob(train_dir + '/*/*.jpg') 24val_samples = glob.glob(val_dir + '/*/*.jpg') 25train_samples = len(train_samples) 26val_samples = len(val_samples) 27print(train_samples) 28print(val_samples) 29 30#img size 31img_w, img_h = 224,224 32 33#keras image data generator 34train_datagen = ImageDataGenerator(rescale = 1.0/255, zoom_range=0.2,horizontal_flip=True) 35val_datagen = ImageDataGenerator(rescale=1.0 / 255) 36 37train_generator = train_datagen.flow_from_directory( 38 train_dir, 39 target_size=(img_w,img_h), 40 color_mode = 'rgb', 41 classes = classes, 42 class_mode = 'categorical', 43 batch_size = 5 44) 45 46val_generator = val_datagen.flow_from_directory( 47 val_dir, 48 target_size=(img_w,img_h), 49 color_mode = 'rgb', 50 classes = classes, 51 class_mode = 'categorical', 52 batch_size = 5 53) 54 55 56#train 57epoch = 200 58history = model.fit_generator( 59 train_generator, 60 steps_per_epoch=train_samples, 61 epochs=epoch, 62 validation_data=val_generator, 63 callbacks=[checkpoint,early_stopping] 64) 65print(history.history) 66 67#plot 68acc = history.history['accuracy'] 69val_acc = history.history['val_accuracy'] 70loss = history.history['loss'] 71val_loss = history.history['val_loss'] 72 73epochs = epoch 74 75plt.figure() 76plt.plot(range(1,epochs+1),acc,'b',label = 'traning accracy') 77plt.plot(range(1,epochs+1),val_acc,'r',label='validation accracy') 78plt.title('Training and validation accuracy') 79plt.legend() 80plt.savefig('result_acc') 81 82 83plt.figure() 84plt.plot(range(1,epochs+1), loss, 'bo', label='Training loss') 85plt.plot(range(1,epochs+1), val_loss, 'ro', label='Validation loss') 86plt.title('Training and validation loss') 87plt.legend() 88plt.savefig('result_loss') 89 90plt.show()

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

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

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

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

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

guest

回答1

0

ベストアンサー

直接のエラーの原因は、EarlyStoppingが機能してepochが5回で終了したため、以下のrange(1,epochs+1)=サイズ200(当初予定のepoch回数)、と、acc=サイズ5(実際のepoch回数)が食い違ったためです。

Python

1epochs = epoch 2 3plt.figure() 4plt.plot(range(1,epochs+1),acc,'b',label = 'traning accracy') 5plt.plot(range(1,epochs+1),val_acc,'r',label='validation accracy')

epochs = len(acc) などとすれば、エラーは発生しないでしょう。
もしくは、以下のように、plotのxパラメータを省略してしまってもよいでしょう。

Python

1plt.plot(acc,'b',label = 'traning accracy') 2plt.plot(val_acc,'r',label='validation accracy')

上記に加え、EarlyStoppingとModelCheckpointが定義されているにも関わらず、コードが書かれていない(そのためデフォルト動作になっている)のが気になります。

また、生Kerasを使うのはトラブルの元ですのでやめましょう。

これらは別の話題になりますので、質問ありましたら新規にお願いします。

投稿2021/05/12 13:19

編集2021/05/12 13:25
toast-uz

総合スコア3266

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

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

shujiu

2021/05/13 14:05

ご返信ありがとうございました。 200、5という数字が何を指すのかが全く理解できていませんでした。 お恥ずかしいことですが、Early stoppingとmodel checkpoint の記載がない点に関しては文字数の関係で一部コードを省略しなければならず、自己判断でこの部分が今回の質問には関係ないと思い込み除外して質問していたというところです。epochs = len(acc)と変更したところ、errorなく動きました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問