深度学习之回归模型-简单线性模型
数据集生成
from sklearn.model_selection import train_test_split
from sklearn import datasets
import matplotlib.pyplot as plt
from tensorflow import keras
X,y = datasets.make_regression(n_samples=10000,noise=0,random_state=8,n_informative=1,n_features=1)
plt.scatter(X,y,c='blue')
plt.show()
data:image/s3,"s3://crabby-images/32da8/32da828759e2f1ea8c49808ed0dd86951bb1f279" alt="image image"
定义线性模型
model = keras.models.Sequential([
keras.layers.Dense(1,input_shape = X_train.shape[1:])]
)
model.summary()
data:image/s3,"s3://crabby-images/edd17/edd1788b0528875596d81a8ca72c22b04eb534a9" alt="image image"
训练模型
model.compile(loss = keras.losses.mean_squared_error,optimizer=keras.optimizers.Adam(),metrics=['mse'])
history = model.fit(X,y,epochs=1000,validation_split=0.25,callbacks=[keras.callbacks.EarlyStopping(patience=3)])
画出损失历史图
# 绘制训练 & 验证的损失值
plt.plot(history.history['loss'])
plt.plot(history.history['val_loss'])
plt.title('Model loss')
plt.ylabel('Loss')
plt.xlabel('Epoch')
plt.legend(['Train', 'Valid'], loc='upper left')
plt.show()
data:image/s3,"s3://crabby-images/a4004/a4004ac23699af2bd44526a302604c7e8a501a4a" alt="image image"
查看模型是否拟合
import numpy as np
weights = model.get_weights()
print(weights)
print(weights[0][0,0])
print(weights[1][0])
w1 = weights[0][0,0]
b1 = weights[1][0]
m_x = np.array([-4,3])
m_y = m_x * w1 + b1
plt.plot(m_x,m_y,color = 'red')
plt.scatter(X,y,c='blue')
plt.show()
data:image/s3,"s3://crabby-images/a549f/a549fb3d3831ede18ca05e412e639513e2065b78" alt="image image"
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。