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

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

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

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

Q&A

解決済

1回答

51874閲覧

データ前処理の次元拡大によるMemoryError対処

ringok

総合スコア7

Python 3.x

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

0グッド

0クリップ

投稿2019/08/15 06:37

編集2019/08/15 07:03

前提・実現したいこと

データの前処理での次元拡大によるMemoryError対処法について
入力における特徴量を減らす以外での解決策を探しています。
大変未熟者ですがご教授願います。

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

numpy.core._exceptions.MemoryError: Unable to allocate array with shape (31934, 356727) and data type object

該当のソース

Python 3.7.3

Pandasでデータを読み込んだ後、
dataset.shape->(445909, 79)
とし、このデータ内のカテゴリカル変数のみをOneHotEncordingでDummy変数化を行いました。
その後、元データと連結し
After_dummy_dataset.shape->(445909, 31935)

dataをtrain,testに分割
dataset_train, dataset_test, attack_train, attack_test = train_test_split(dataset, attack, train_size = 0.6, test_size = 0.4, shuffle = True)
test,trainそれぞれに対し、正規化
from sklearn import preprocessing
mm = preprocessing.MinMaxScaler()
dataset_train = mm.fit_transform(dataset_train)
dataset_test = mm.fit_transform(dataset_test)

当たり前ですが、次元数が多すぎることから、実装でMemoryErrorを起こします。
入力における特徴量を減らす以外での解決策を探しています。
###補足
データセット内の欠損値はないです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

疎行列型配列(scipy.sparse.csr_matrix)で取り扱えばメモリに載せること自体は可能です。

どのようにダミー変数に変換したのかはわかりませんが、sklearn.preprocessing.OneHotEncoderを使えはデフォルトで疎行列型配列に変換されます。

sklearn.preprocessing.OneHotEncoder — scikit-learn 0.21.3 documentation

注意点としては、

  • 連結のときにnumpy配列に変換しようとして失敗しているのかもしれません。このあたりもどうやっているのかはわかりませんが、sklearn.compose.ColumnTransformerなどを活用してください(設定次第で結果を疎行列型配列にできます)。
  • MinMaxScalerは必ずnumpy配列を返すので、この目的には使えません。実数型変数だけに適用するならありですが。最終的に疎行列型配列に変換されるように(あと途中でダミー変数の部分がnumpy配列にならないように)transformerを組む必要があります。

そもそも論としては、そんなにでかいダミー変数の配列にしたところでまともな分析はできないと思うので、やり方を変えた方が良いと思います。

投稿2019/08/15 07:01

編集2019/08/15 07:19
hayataka2049

総合スコア30933

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問