溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何使用TensorFlow神經(jīng)網(wǎng)絡(luò)構(gòu)造線性回歸模型

發(fā)布時(shí)間:2021-11-04 09:08:50 來(lái)源:億速云 閱讀:240 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下如何使用TensorFlow神經(jīng)網(wǎng)絡(luò)構(gòu)造線性回歸模型,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

先制作一些數(shù)據(jù):

import numpy as np
import tensorflow as tf
import matplotlib.pyplot as plt
# 隨機(jī)生成1000個(gè)點(diǎn),圍繞在y=0.1x+0.3的直線周圍
num_points = 1000
vectors_set = []
for i in range(num_points):
    x1 = np.random.normal(0.0, 0.55)
    # np.random.normal(mean,stdev,size)給出均值為mean,標(biāo)準(zhǔn)差為stdev的高斯隨機(jī)數(shù)(場(chǎng)),當(dāng)size賦值時(shí),如:size=100,表示返回100個(gè)高斯隨機(jī)數(shù)。
    y1 = x1 * 0.1 + 0.3 + np.random.normal(0.0, 0.03)
    # 后面加的高斯分布為人為噪聲
    vectors_set.append([x1, y1])
# 生成一些樣本
x_data = [v[0] for v in vectors_set]
y_data = [v[1] for v in vectors_set]
plt.scatter(x_data, y_data, c='r')
plt.show()
# 構(gòu)造1維的w矩陣,取值是隨機(jī)初始化權(quán)重參數(shù)為[-1, 1]之間的隨機(jī)數(shù)
w = tf.Variable(tf.random_uniform([1], -1.0, 1.0), name='w')
# 構(gòu)造1維的b矩陣,初始化為0
b = tf.Variable(tf.zeros([1]), name='b')
# 建立回歸公式,經(jīng)過(guò)計(jì)算得出估計(jì)值y
y = w * x_data +b

# 定義loss函數(shù),估計(jì)值y和實(shí)際值y_data之間的均方誤差作為損失
loss = tf.reduce_mean(tf.square(y - y_data), name='loss')
# 采用梯度下降法來(lái)優(yōu)化參數(shù),學(xué)習(xí)率為0.5
optimizer = tf.train.GradientDescentOptimizer(0.5)
# train相當(dāng)于一個(gè)優(yōu)化器,訓(xùn)練的過(guò)程就是最小化loss
train = optimizer.minimize(loss, name='train')
sess = tf.Session()
# 全局變量的初始化
init = tf.global_variables_initializer()
sess.run(init)
# 打印初始化的w和b
print('w = ', sess.run(w), 'b = ', sess.run(b), 'loss = ', sess.run(loss))
# 訓(xùn)練迭代20次
for step in range(20):
    sess.run(train)
    # 打印訓(xùn)練好的w和b
    print('w = ', sess.run(w), 'b = ', sess.run(b), 'loss = ', sess.run(loss))

代碼運(yùn)行一下,下面這個(gè)圖就是上面代碼剛剛構(gòu)造的數(shù)據(jù)點(diǎn):

如何使用TensorFlow神經(jīng)網(wǎng)絡(luò)構(gòu)造線性回歸模型

有了數(shù)據(jù)之后,接下來(lái)構(gòu)造線性回歸模型,去學(xué)習(xí)出來(lái)這個(gè)數(shù)據(jù)符合什么樣的w和b,訓(xùn)練完后看下得到的w和b是不是接近構(gòu)造數(shù)據(jù)時(shí)的w和b,最后一次結(jié)果是w = [ 0.10149562] b = [ 0.29976717] loss = 0.000948041的,也就是這個(gè)線性回歸模型學(xué)習(xí)到了數(shù)據(jù)的分布規(guī)則。也可以看出隨著訓(xùn)練次數(shù)的迭代,loss值也越來(lái)越小,也就是模型越來(lái)越好,將訓(xùn)練出來(lái)的w和b構(gòu)造成圖中藍(lán)色的線,這條線就是當(dāng)前最能擬合數(shù)據(jù)的直線了。運(yùn)行結(jié)果如圖所示:

如何使用TensorFlow神經(jīng)網(wǎng)絡(luò)構(gòu)造線性回歸模型 

如何使用TensorFlow神經(jīng)網(wǎng)絡(luò)構(gòu)造線性回歸模型

以上是“如何使用TensorFlow神經(jīng)網(wǎng)絡(luò)構(gòu)造線性回歸模型”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI