【发布时间】:2019-08-21 10:22:18
【问题描述】:
在 fit 转换方法中编译我的代码时,它显示有关数组形状的错误 " ValueError: 检查输入时出错:预期dense_1_input 的形状为(6,),但得到的数组的形状为(11,)”
import numpy as np
import matplotlib.pyplot as plt
import pandas as pd
dataset = pd.read_csv('Churn_Modelling.csv')
x = dataset.iloc[:, 3:13].values
y = dataset.iloc[:, 13].values
from sklearn.preprocessing import LabelEncoder, OneHotEncoder
labelencoder_x_1 = LabelEncoder()
x[:, 1] = labelencoder_x_1.fit_transform(x[:, 1])
labelencoder_x_2 = LabelEncoder()
x[:, 2] = labelencoder_x_2.fit_transform(x[:, 2])
onehotencoder = OneHotEncoder(categorical_features =[1])
x = onehotencoder.fit_transform(x).toarray()
x =x[:, 1:]
from sklearn.model_selection import train_test_split
x_train, x_test, y_train, y_test = train_test_split(x,y, test_size =0.2, random_state =0)
from sklearn.preprocessing import StandardScaler
sc = StandardScaler()
x_train = sc.fit_transform(x_train)
x_test = sc.transform(x_test)
import keras
from keras.models import Sequential
from keras.layers import Dense
classifier = Sequential()
classifier.add(Dense(output_dim =6, init = 'uniform', activation= 'relu', input_dim= 6))
classifier.add(Dense(output_dim =6, init = 'uniform', activation= 'relu' ))
classifier.add(Dense(output_dim =1, init = 'uniform', activation = 'sigmoid' ))
classifier.compile(optimizer ='adam', loss = 'binary_crossentropy', metrics =['accuracy'])
classifier.fit(x_train, y_train, batch_size = 10, nb_epoch = 100)
y_pred = classifier.predict(x_test)
y_pred = (y_pred > 0.5)
from sklearn.metrics import confusion_matrix
cm = confusion_matrix(y_test, y_pred)
【问题讨论】:
-
您告诉模型输入是 6 维的,而实际上它是 11 维的。修复它。
标签: python numpy tensorflow keras neural-network