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

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

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

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

深層学習

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

機械学習

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

Python

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

Q&A

解決済

1回答

3012閲覧

保存したkerasのモデルをロードして実行するとエラーに...。

python_2019

総合スコア68

Keras

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

深層学習

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

機械学習

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

Python

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

0グッド

0クリップ

投稿2019/08/23 08:10

〇学習済のkerasのモデルをロードして、実行すると、以下のようなエラーが出ます。
同じようなpgmの、SVMではエラーは出ないのですが、なぜでしょうか?
モデルの作成、学習、評価、モデル保存、ロードは正常に稼働しました。
ロードしたモデルの実行でエラーになります。

ご指導、よろしくお願いいたします。


AttributeError Traceback (most recent call last)
<ipython-input-263-b992f4e997c5> in <module>
1 # 新たに予測する
----> 2 result = loaded_model.score(x_test_new , y_test_new)
3 print(result)
AttributeError: 'Sequential' object has no attribute 'score'


〇入力に使ったデータです。
iris_data.xlsx
イメージ説明

〇以下、実際のPGMとエラーです。(エラーは上記と同じです)

from pandas import Series,DataFrame
import pandas as pd

◆エクセルの入力ファイル名、シート名を指定
df = pd.read_excel('iris_data.xlsx',sheet_name='target')

◆データをコピーする。
df_X = df.copy()
df_Y = df.copy()

◆取得したExcelデータから属性データのみを取り出す
df_X = df_X.drop('Target',axis=1)

◆取得したExcelデータから目的変数のみを取り出す
drop_idx = ['sepal length (cm)', 'sepal width (cm)','petal length (cm)','petal width (cm)']
df_Y = df_Y.drop(drop_idx,axis=1)

◆訓練データと評価用データに分割
from sklearn.model_selection import train_test_split as split
x_train, x_test, y_train, y_test = split(df_X,df_Y,train_size=0.8,test_size=0.2)

import tensorflow as tf
import keras
from keras.layers import Dense,Activation

◆ニュートラルネットワークで使用するモデル作成
model = keras.models.Sequential()
model.add(Dense(units=32,input_dim=4))
model.add(Activation('relu'))
model.add(Dense(units=3))
model.add(Activation('softmax'))
model.compile(loss='sparse_categorical_crossentropy',optimizer='sgd',metrics=['accuracy'])

◆学習の実行
model.fit(x_train,y_train,epochs=100)

◆評価の実行
score = model.evaluate(x_test, y_test,batch_size = 1)
print(score[1])
30/30 [==============================] - 0s 399us/step
0.5666666666666667

◆モデルを保存する
import pickle
filename = 'finalized_model_keras_1.sav'
pickle.dump(model, open(filename, 'wb'))

◆保存したモデルをロードする
loaded_model = pickle.load(open(filename, 'rb'))

◆新たに予測するデータ
x_train, x_test_new, y_train, y_test_new = split(df_X,df_Y,train_size=0.8,test_size=0.2)

◆新たに予測する(実行)
result = loaded_model.score(x_test_new , y_test_new)
print(result)

以下、エラー---------------------------------------------------------------------------

AttributeError Traceback (most recent call last)
<ipython-input-263-b992f4e997c5> in <module>
1 # 新たに予測する
----> 2 result = loaded_model.score(x_test_new , y_test_new)
3 print(result)

AttributeError: 'Sequential' object has no attribute 'score'


以上です。

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

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

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

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

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

guest

回答1

0

ベストアンサー

同じようなpgmの、SVMではエラーは出ないのですが、なぜでしょうか?

loaded_model.score(x_test_new , y_test_new)

keras の Sequential モデルオブジェクトに score という関数は存在しません。
sklearn の SVM と似たような使い方ができても、ライブラリによって、関数の名前などは異なります。
Keras の場合は loaded_model.evaluate を使えばよいと思います。

Keras の使い方は Keras のドキュメントを読んで、それに従いプログラムを作成してください。

Sequentialモデルのガイド - Keras Documentation

投稿2019/08/23 08:35

編集2019/08/23 08:44
tiitoi

総合スコア21956

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

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

python_2019

2019/08/23 09:14

ご回答ありがとうございます。 ご指示の通り実行しましたら、エラーがなくなりました。 また、ドキュメントもお教えいただきありがとうございます。 追加で質問させてください。 print結果出力で、2つの数値が出力されていますが、これはどう理解すればよいでしょうか? [0.2647995948791504, 1.0] 正確度としては、どちらか1つかと想像しておりますが、「1.0」がそうでしょうか? ご指導よろしくお願いいたします。 # 新たに予測する result = loaded_model.evaluate(x_test_new , y_test_new) print(result) 30/30 [==============================] - 0s 7ms/step [0.2647995948791504, 1.0]
tiitoi

2019/08/23 09:18

1つ目の値は損失関数の値、2つ目の値は正答率です。 今回正答率が 1.0 となっているので、100%全問正解したと解釈できます。
python_2019

2019/08/23 09:27

ご回答ありがとうございました。 理解できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問