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

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

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

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

Python

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

Q&A

0回答

1036閲覧

データ数、バッチサイズとバッチループが一致しない場合の処理

tfulcrum

総合スコア43

Keras

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

Python

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

0グッド

0クリップ

投稿2021/08/24 07:33

画像を回帰、ミニバッチで機械学習させようとしています。
ざっくり該当箇所を抜くと、下記のコードです。

filenames = numpy.array(os.listdir('data/')) batch_size = 38 DIR = './data' file_num = len([name for name in os.listdir(DIR) if os.path.isfile(os.path.join(DIR, name))]) n_batch_loop = int(file_num / batch_size) epochs = 50 for e in range(epochs): print('Epoch', e) indices = numpy.repeat(range(n_batch_loop), batch_size) numpy.random.shuffle(indices) checkpoint = ModelCheckpoint( filepath=os.path.join(MODEL_DIR, "model-{epoch:02d}.h5"), monitor = "accuracy", save_best_only=True, save_freq="epoch", verbose=1) for i_batch_loop in range(n_batch_loop): filenames_temp = filenames[indices == i_batch_loop] x, y = load_data('data/', filenames_temp, img_width, img_height) model.fit(x, y, epochs=1, batch_size=batch_size, callbacks=[checkpoint])

問題は、元の教師データの画像数が固定であり、画像数と、batch_sizeとbatch_loopの積と一致しないと動かない、事にあります。
このままでは使い勝手が悪いのと、元の教師データの数が因数分解できないと稼働しない状態です。
そこで、上記のfilenamesとindicesの差分を取ってindicesと結合してやればいいのかと下記コードも試してみましたが、うまくいきません。
どうしたら、良いでしょうか?
当方、始めたばかりで、あまりよくわかっていませんが、宜しくお願いします。

def list_difference(filenames, indices): result = filenames.copy() for value in indices: if value in result: result.remove(value) return result if len(filenames) != len(indices): result = list_difference(filenames, indices) indices = numpy.hstack(indices, result)

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

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

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

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

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

meg_

2021/08/24 11:47

> うまくいきません。 具体的にはどういうことでしょうか?
tfulcrum

2021/08/24 20:53

このコードですと下記エラーが返されます。 indices = numpy.hstack(indices, result) File "<__array_function__ internals>", line 4, in hstack TypeError: _vhstack_dispatcher() takes 1 positional argument but 2 were given numpy.stackにしてみたり、或いは他で調べて別の記載をするのですが、 結局、元のデータ数と、バッチ数とイテレーション数の積の差分を、 indices(バッチ数とイテレーション数の積)に結合する方法が見つかりません。 宜しくお願いします。
meg_

2021/08/25 00:38

上記エラーはnumpy.hstackの引数の書き方が良くないと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問