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

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

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

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

機械学習

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

Python

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

Q&A

1回答

1545閲覧

メモリが足りないです

shosinnshadesu

総合スコア93

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

機械学習

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

Python

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

0グッド

0クリップ

投稿2021/11/01 03:52

編集2021/11/01 22:55

python

1import tensorflow as tf 2import numpy as np 3import matplotlib.pyplot as plt 4import pandas as pd 5import glob 6from sklearn.preprocessing import LabelEncoder 7from sklearn.model_selection import train_test_split 8 9 10x_train, x_valid, y_train, y_valid = np.load("/content/drive/MyDrive/chest x-ray/dataset 3/Xy_data.npy", allow_pickle=True) 11 12x_train = np.array(x_train) / 255.0 13x_valid = np.array(x_valid) / 255.0 14y_train = np.array(y_train) 15y_valid = np.array(y_valid) 16 17Xy_data = (x_train, x_valid, y_train, y_valid) 18np.save("/content/drive/MyDrive/image/Xy_data0.npy", Xy_data)

google colab proを使っています。特にエラーコードはなくセッションがクラッシュしましたと言われて再起動します。

上のコードを実行すると、np.save("/content/drive/MyDrive/image/Xy_data0.npy", Xy_data) の部分でセッションがクラッシュしてしまいます。
どのようにすればクラッシュせずに実行できますか?
自分はデータがメモリを消費するため、一回一回データを変えた後にセーブさせようとしています。
また、np.save("/content/drive/MyDrive/image/Xy_data0.npy", Xy_data)のコードを実行せずにモデルを作るコード下のような

python

1model = tf.keras.models.Sequential([ 2 tf.keras.layers.Flatten(input_shape=(1024, 1024, 1)), 3 tf.keras.layers.Dense(64, activation='relu'), 4 tf.keras.layers.Dropout(0.2), 5 tf.keras.layers.Dense(2, activation='softmax') 6]) 7model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy']) 8model.fit(x_train, y_train, epochs=10)

を実行しても同じようにセッションがクラッシュしてしまいます。

画像のサイズが1024x1024なのですが大きすぎるでしょうか?

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

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

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

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

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

jbpb0

2021/11/01 06:38

> セッションがクラッシュ Pythonは、どのようにして実行してるのですか? 「クラッシュ」とは、具体的に何が起きるのですか? エラーメッセージとか、表示されないのでしょうか?
Zuishin

2021/11/01 23:00

> 画像のサイズが1024x1024なのですが大きすぎるでしょうか? その程度の大きさでクラッシュするようなものはリリースしないでしょう。 保存時に異常終了するのがはっきりしているのであれば、真っ先に書き込み権限を疑ってください。numpy を使わず同じパスで空のファイルが作れるかどうかを確かめてみたらどうでしょうか。
bsdfan

2021/11/02 00:24 編集

x_train, x_valid, y_train, y_validのshapeはどうなっていますか? numpy.save()はひとつのarrayを保存するためのものなので、複数のarrayをtupleにしてわたすと、中でひとつのarrayに変換しようとしているかもしれません。shapeがそろっていないとエラーになりそうです。(それでクラッシュするとは思えないですが) → 試してみたところwarningは出ますがエラーにはなりませんでした。 numpy.save()でこういう使い方は、あまりしないと思います。
jbpb0

2021/11/02 00:40

エラーが出る行のすぐ上に下記を追加して実行したら、それぞれ何て表示されますでしょうか? print(x_train.shape) print(x_valid.shape) print(y_train.shape) print(y_valid.shape) print(x_train.dtype) print(x_valid.dtype) print(y_train.dtype) print(y_valid.dtype)
jbpb0

2021/11/02 04:34

> 画像のサイズが1024x1024なのですが大きすぎるでしょうか? 枚数によります 質問に掲載されてるコードでは、全部のデータを読み込んで処理するので、画像枚数が多いとメモリーが不足するでしょうね > どのようにすればクラッシュせずに実行できますか? 画像枚数が多すぎることが原因ならですが、 https://www.scsk.jp/product/oss/tec_guide/tensorflow_keras/1_tensorflow_keras2_3.html https://developers.wonderpla.net/entry/2017/10/24/110000 とかに書かれてる方法では、データを全部読み込まず、必要な分だけ読み込んで処理するので、バッチサイズを小さくすれば使うメモリーが減ります
guest

回答1

0

メモリが足りないのですか?

投稿2021/11/01 06:03

qqfsdfsafd

総合スコア599

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問