简单预测Quality的代码

该文展示了如何使用Python的pandas读取数据,scikit-learn进行数据预处理,包括最大最小归一化。然后,利用tensorflow和Keras构建一个简单的神经网络模型,进行训练和验证,最后对测试数据集进行预测并评估模型性能。
摘要由CSDN通过智能技术生成

Question:

Training and testing a neural network on real data

import pandas as pd
from sklearn.model_selection import train_test_split
import tensorflow as tf
from sklearn.preprocessing import MinMaxScaler
from keras.models import Sequential
from keras.layers import Dense

# read_csv the data
data_W = pd.read_csv('./winequality-red.csv',sep=';')[:100]
data_W[:15]
# pre-process the data,max_min normalization 
scale = MinMaxScaler()

train = scale.fit_transform(data_W.values[:,:-1])
test = scale.fit_transform(data_W.values[:,-1].reshape(-1,1))

# split into 50% training dataset and 50% testing dataset  quality is over label, else are our features
X_train, X_test, Y_train, Y_test = train_test_split(train,test,test_size=0.5,random_state=0)

# establish BP model
model = Sequential()
model.add(Dense(30,activation='sigmoid',input_shape=(X_train.shape[1],)))
model.add(Dense(1))
model.compile(optimizer=tf.keras.optimizers.Adam(learning_rate=1e-4), loss='mse')
model.summary()  # 展示模型结构
model.fit(X_train, Y_train, epochs=10, batch_size=1, validation_data=(X_test , Y_test), verbose=2,
shuffle=False)

# make predictions on test set and inverse transform the data
y_pred = model.predict(X_test)
y_pred_inv = scale.inverse_transform(y_pred.reshape(-1, 1))
Y_test_inv = scale.inverse_transform(Y_test)

Y_test_inv[:5],y_pred_inv[:5]
model.evaluate(X_test,Y_test)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值