機器學習系列-tensorflow-03-線性回歸Linear Regression

来源:https://www.cnblogs.com/brightyuxl/archive/2018/10/30/9880411.html
-Advertisement-
Play Games

利用tensorflow實現數據的線性回歸 導入相關庫 import tensorflow as tf import numpy import matplotlib.pyplot as plt rng = numpy.random 參數設置 learning_rate = 0.01 training ...


利用tensorflow實現數據的線性回歸

導入相關庫

import tensorflow as tf
import numpy
import matplotlib.pyplot as plt
rng = numpy.random

參數設置

learning_rate = 0.01
training_epochs = 1000
display_step = 50

訓練數據

train_X = numpy.asarray([3.3,4.4,5.5,6.71,6.93,4.168,9.779,6.182,7.59,2.167,
                     7.042,10.791,5.313,7.997,5.654,9.27,3.1])
train_Y = numpy.asarray([1.7,2.76,2.09,3.19,1.694,1.573,3.366,2.596,2.53,1.221,
                     2.827,3.465,1.65,2.904,2.42,2.94,1.3])
n_samples = train_X.shape[0]

tf圖輸入

X = tf.placeholder("float")
Y = tf.placeholder("float")

設置權重和偏置

W = tf.Variable(rng.randn(), name="weight")
b = tf.Variable(rng.randn(), name="bias")

構建線性模型

pred = tf.add(tf.multiply(X, W), b)

均方誤差

cost = tf.reduce_sum(tf.pow(pred-Y, 2))/(2*n_samples)

梯度下降

optimizer = tf.train.GradientDescentOptimizer(learning_rate).minimize(cost)

初始化變數

init = tf.global_variables_initializer()

開始訓練

with tf.Session() as sess:
    sess.run(init)
    # 適合所有訓練數據
    for epoch in range(training_epochs):
        for (x, y) in zip(train_X, train_Y):
            sess.run(optimizer, feed_dict={X: x, Y: y})
        # 顯示每個紀元步驟的日誌
        if (epoch+1) % display_step == 0:
            c = sess.run(cost, feed_dict={X: train_X, Y:train_Y})
            print("Epoch:", '%04d' % (epoch+1), "cost=", "{:.9f}".format(c), \
                "W=", sess.run(W), "b=", sess.run(b))
    print("Optimization Finished!") 
    training_cost = sess.run(cost, feed_dict={X: train_X, Y: train_Y})
    print("Training cost=", training_cost, "W=", sess.run(W), "b=", sess.run(b), '\n')
    # 畫圖顯示
    plt.plot(train_X, train_Y, 'ro', label='Original data')
    plt.plot(train_X, sess.run(W) * train_X + sess.run(b), label='Fitted line')
    plt.legend()
    plt.show()

結果展示

Epoch: 0050 cost= 0.183995649 W= 0.43250677 b= -0.5143978
Epoch: 0100 cost= 0.171630666 W= 0.42162812 b= -0.43613702
Epoch: 0150 cost= 0.160693780 W= 0.41139638 b= -0.36253116
Epoch: 0200 cost= 0.151019916 W= 0.40177315 b= -0.2933027
Epoch: 0250 cost= 0.142463341 W= 0.39272234 b= -0.22819161
Epoch: 0300 cost= 0.134895071 W= 0.3842099 b= -0.16695316
Epoch: 0350 cost= 0.128200993 W= 0.37620357 b= -0.10935676
Epoch: 0400 cost= 0.122280121 W= 0.36867347 b= -0.055185713
Epoch: 0450 cost= 0.117043234 W= 0.36159125 b= -0.004236537
Epoch: 0500 cost= 0.112411365 W= 0.3549302 b= 0.04368245
Epoch: 0550 cost= 0.108314596 W= 0.34866524 b= 0.08875148
Epoch: 0600 cost= 0.104691163 W= 0.34277305 b= 0.13114017
Epoch: 0650 cost= 0.101486407 W= 0.33723122 b= 0.17100765
Epoch: 0700 cost= 0.098651998 W= 0.33201888 b= 0.20850417
Epoch: 0750 cost= 0.096145160 W= 0.32711673 b= 0.24377018
Epoch: 0800 cost= 0.093927994 W= 0.32250607 b= 0.27693948
Epoch: 0850 cost= 0.091967128 W= 0.31816947 b= 0.308136
Epoch: 0900 cost= 0.090232961 W= 0.31409115 b= 0.33747625
Epoch: 0950 cost= 0.088699281 W= 0.31025505 b= 0.36507198
Epoch: 1000 cost= 0.087342896 W= 0.30664718 b= 0.39102668
Optimization Finished!
Training cost= 0.087342896 W= 0.30664718 b= 0.39102668


參考:
Author: Aymeric Damien
Project: https://github.com/aymericdamien/TensorFlow-Examples/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如果代碼風格相對而言不是那麼的pythonic,或許很少碰到這類錯誤。當然並不是不鼓勵使用一些python語言的技巧。如果遇到這這種類型的錯誤,說明我們對python中變數引用相關部分有不當的認識和理解。而這又是對理解python相關概念比較重要的。這也是本文寫作的原因。 本文為理解閉包相關概念的做 ...
  • //輸出一段utf-8編碼的html $this->show('<p>歡迎使用 <b>ThinkPHP</b>!</p>','utf-8'); 字元串替換$br=str_replace("/>", "/><br />", $con); php把文本框回車轉換成html換行 $aa=@ereg_rep ...
  • 前言 在上文 "《一份針對於新手的多線程實踐》" 留下了一個問題: 這隻是多線程其中的一個用法,相信看到這裡的朋友應該多它的理解更進一步了。 再給大家留個閱後練習,場景也是類似的: 在 Redis 或者其他存儲介質中存放有上千萬的手機號碼數據,每個號碼都是唯一的,需要在最快的時間內把這些號碼全部都遍 ...
  • 有幸得到一本第四版的,雖然以前看過第三版的,總覺得翻譯不佳,而且看起來比較難懂,尤其是輸入輸出系統的時候完全找不到感覺,幾個流就把我弄得雲里霧裡。25號得到第四版,從開始看到現在看到初始化與清理,感覺條理相當的清晰,內容理解的也比以前深入了 ,但是還是有些地方需要反覆閱讀才能理解的透徹,可能是行文比 ...
  • 1 public class Sort { 2 public static void main(String[] args) { 3 int[] arr = { 9, 54, 5, 47, 61, 2, 4, 32, 25 }; 4 selectSort(arr); 5 print(arr); 6 ... ...
  • 多線程 繞過mutex的保護 mutex,能夠解決線程安全的問題,但它不是萬能的。下麵的例子雖然使用了mutex,但是惡意註入了一個外部函數,導致把被mutex保護的雙向鏈表,讓一個外部的指針指向了,結果就可以通過這個外部的指針操作被保護的雙向鏈表,也就繞過了metex的保護。 例子: c++ in ...
  • JDBC 筆記 作者:晨鐘暮鼓c個人微信公眾號:程式猿的月光寶盒 對應pdf版:https://download.csdn.net/download/qq_22430159/10754554 沒有積分的可關註公眾號後臺回覆[JDBC] Day1 JDBC概述+JDBC完成CRUD+DAO設計 1.J ...
  • 1. 函數進階 動態接收位置參數 之前寫的函數都是固定參數的,假設有個函數需要的參數由幾十個,一個個寫在形參的位置會非常麻煩,因此我們要考慮使用動態參數,使用動態參數時需要在參數前加 ,表示接收多個參數: 從上面的例子我們可以看出,動態參數可以接收任意個參數,在形參中作為一個元組的形式傳遞過來;但是 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...