tf.keras实现线性回归和多层感知器

线性回归实现

相关库引用

import tensorflow as tf
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
%matplotlib inline

加载数据

data = pd.read_csv("E:/datasets/dataset/Income1.csv") # 获取数据
x = data.Education
y = data.Income
data

输出散点图,看看数据的分布情况

plt.scatter(data.Education, data.Income) # 打印散点图

定义模型

model = tf.keras.Sequential() # 建立一个层叠模型
model.add(tf.keras.layers.Dense(1, input_shape = (1, ))) # 添加一个层,1个单元,输入大小用元组
model.summary() # 查看模型的参数信息


这里总共有2个参数,即 \(y = ax + b\)\(a\)\(b\)
tf.keras.layers.Dense()参数列表中还有激活函数,这个后面介绍

模型编译

model.compile(
    optimizer = 'adam', # adam优化器
    loss = 'mse'        # 均方根误差
)

训练模型

history = model.fit(x, y, epochs = 10000) # 训练10000次

预测

model.predict(pd.Series([20]))

多层感知器实现

加载数据

data = pd.read_csv("E:/datasets/dataset/Advertising.csv") # 获取数据
x = data.iloc[:, 1:-1]
y = data.iloc[:, -1]
data

输出散点图,看看数据的分布情况

plt.scatter(data.TV, data.sales) # 打印散点图

定义模型

model = tf.keras.Sequential() # 建立一个层叠模型
model.add(tf.keras.layers.Dense(10, input_shape = (3, ), activation = 'relu')) # 添加一个层,10个节点
model.add(tf.keras.layers.Dense(1))
model.summary()


这里总共有51个参数,即:
第一层:\(y = a_1*x_1 + a_2*x_2 + a_3*x_3 + b\)\(a_1,a_2,a_3\)\(b\),总共10个节点,因此有40个参数
第二层:\(y = \sum_{i = 1}^{10}w_i*x_i + b\)\(w_i\)\(b\),总共有11个参数

模型编译

model.compile(
    optimizer = 'adam', # adam优化器
    loss = 'mse'        # 均方根误差
)

训练模型

history = model.fit(x, y, epochs = 1000) # 训练1000次

预测

test = data.iloc[:10, 1:-1]
model.predict(test)

posted @ 2021-01-16 22:41  pbc的成长之路  阅读(297)  评论(0编辑  收藏  举报