TensorFlow--线性模型简单示例

首先得到原始数据x_data ,y_data

然后构建自己的线性模型 y = k*x_data+b

定义二次代价函数loss

定义一个使用梯度下降法训练的优化器optimizer

这里只有k,b是未知的,用梯度下降法来寻求使得 loss最小化的k,b

进行200次迭代,最后得到使得loss 较小的k,b作为线性模型的预测


#-*-coding:utf-8-*-
import tensorflow as tf
import numpy as np

#用numpy 生成100个随机点
x_data = np.random.rand(100)
y_data = 0.1*x_data + 0.2

#定义一个线性模型:
b = tf.Variable(0.)
k = tf.Variable(0.)
y = k*x_data + b

#定义二次代价函数
loss = tf.reduce_mean(tf.square(y_data - y))
#定义用梯度下降法来进行训练的优化器:
optimizer = tf.train.GradientDescentOptimizer(0.2)
#使用优化器来最小化代价函数
train = optimizer.minimize(loss)

#初始化变量:
init = tf.global_variables_initializer()
with tf.Session() as sess:
    sess.run(init)
    for _ in range(201):
        sess.run(train)
        print(_,sess.run([loss,k,b]))

运行结果:







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值