1 Star 0 Fork 0

程序员Eric / my_keras_learn

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
regression.py 1.13 KB
一键复制 编辑 原始数据 按行查看 历史
程序员Eric 提交于 2021-04-16 00:41 . update
from keras.models import Sequential
from keras.layers import Dense
import numpy as np
np.random.seed(1337)
import matplotlib.pyplot as plt
X = np.linspace(-1,1,200)
# np.random.shuffle(X)
Y = 0.5 * X + 2 + np.random.normal(0, 0.05, (200, ))
# plot data
# plt.scatter(X,Y)
# plt.show()
X_train, Y_train = X[:160], Y[:160]
X_test, Y_test = X[160:], Y[160:]
### build a neural network from the 1st layer to the last layer
model = Sequential()
# 定义第一层
model.add(Dense(units=1, input_dim=1))
### choose loss function and optimizing method
# mse: mean squared error 均方误差
# sgd: 随机梯度下降
model.compile(loss='mse', optimizer='sgd')
# training
print('Training --------')
for step in range(301):
cost = model.train_on_batch(X_train, Y_train)
if step % 100 == 0:
print('train cost', cost)
# testing
print('\nTesting -----------')
cost = model.evaluate(X_test, Y_test, batch_size = 40)
print('test cost: ', cost)
W,b = model.layers[0].get_weights()
print("Weights=", W, '\nbiases=',b)
# plotting the prediction
Y_pred = model.predict(X_test)
plt.scatter(X_test, Y_test)
plt.plot(X_test, Y_pred)
plt.show()
1
https://gitee.com/cecurio/my_keras_learn.git
git@gitee.com:cecurio/my_keras_learn.git
cecurio
my_keras_learn
my_keras_learn
master

搜索帮助