學習筆記TF055:TensorFlow神經網路簡單實現一元二次函數

来源:http://www.cnblogs.com/libinggen/archive/2017/11/03/7777101.html
-Advertisement-
Play Games

TensorFlow運行方式。載入數據、定義超參數,構建網路,訓練模型,評估模型、預測。 構造一個滿足一元二次函數y=ax^2+b原始數據,構建最簡單神經網路,包含輸入層、隱藏層、輸出層。TensorFlow學習隱藏層、輸出層weights、biases。觀察訓練次數增加,損失值變化。 生成、載入數 ...


TensorFlow運行方式。載入數據、定義超參數,構建網路,訓練模型,評估模型、預測。

構造一個滿足一元二次函數y=ax^2+b原始數據,構建最簡單神經網路,包含輸入層、隱藏層、輸出層。TensorFlow學習隱藏層、輸出層weights、biases。觀察訓練次數增加,損失值變化。

生成、載入數據。方程y=x^2-0.5。構造滿足方程的x、y。加入不滿足方程雜訊點。

import tensor flow as tf
import bumpy as np
# 構造滿中一元二次方程的函數
x_data = np.linspace(-1,1,300)[:,np.newaxis] # 構建起300個點,分佈在-1到1區間,用np生成等差數列,300個點的一維數組轉換為300x1的二維數組
noise = np.random.normal(0, 0.05, x_data.shape) # 加入雜訊點,與x_data維度一致,擬合均值0、方差0.05正態分佈
y_data = np.square(x_data) - 0.5 + noise # y = x^2 - 0.5 + 雜訊

定義x、y占位符作輸入神經網路變數。

xs = tf.placeholder(tf.float32, [None, 1])
ys = tf.placeholder(tf.float32, [None, 1])

構建網路模型。

構建一個隱藏層,一個輸出層。輸入參數4個變數,輸入數據、輸入數據維度、輸出數據維度、激活函數。每層向量化處理(y = weights*x +biases),激活函數非線性化處理,輸出數據。定義隱藏層、輸出層:

def add_layer(inputs, in_size, out_size, activation_function=None):
# 構建權重:in_size*out_size 大小的矩陣
weights = tf.Variable(tf.random_normal([in_size, out_size]))
# 構建偏置:1 * out_size矩陣
biases = tf.Variable(tf.zeros([1, out_size]) + 0.1)
# 矩陣相乘
Wx_plus_b = tf.matmul(inputs, weights) + biases
if activation_function is None:
outputs = Wx_plus_b
else:
outputs = activation_function(Wx_plus_b)
return outputs #得到輸出數據
# 構建隱藏層,假設隱藏層有10個神經元
h1 = add_layer(xs, 1, 20, activation_function=tf.nn.relu)
# 構建輸出層,假設輸出層和輸入層一樣,有1個神經元
prediction = add_layer(h1, 20, 1, activation_function=None)

構建損失函數,計算輸出層預測值、真實值間誤差。二者差的平方求和再取平均。梯度下降法,以0.1效率最小化損失。

loss = tf.reduce_mean(tf.reduce_sum(tf.square(ys - prediction), reduction_indices=[1]))
train_step = tf.train.GradientDescentOptimizer(0.1).minimize(loss)

訓練模型。訓練1000次,每50次輸出訓練損失值。

init = tf.global_variables_initializer() # 初始化所有變數
sess = tf.Session()
sess.run(init)

for i in range(1000): # 訓練1000次
sess.run(train_step, feed_dict = (xs: x_data, ys: y_data)
if i % 50 == 0: #每50次列印出一次損失值
print(sets.run(loss, feed_dict={xs: x_data, ys: y_data}))

訓練權重值,模型擬合y = x^2-0.5的繫數1和-0.5。損失值越來越小,訓練參數越來越逼近目標結果。評估模型,學習繫數weights、biase前向傳播後和真值y = x^2-0.5結果繫數比較,根據相近程度計算準確率。

超參數設定。hyper-parameters,機器學習模型框架參數。手動設定、不斷試錯。

學習率(learning rate),設置越大,訓練時間越短,速度越快。設置越小,訓練準確度越高。可變學習率,訓練過程記錄最桂準確率,連續n輪(epoch)沒達到最佳準確率,認為準確率不再提高,停止訓練,early stopping,no_improvement-in-n規則。學習率減半,再滿足時再減半。逐漸接近最優解,學習率越小,準確度越高。

mini-batch大小。每批大小決定權重更新規則。整批樣本梯度全部計算完,才求平均值,更新權重。批次越大訓練速度越快,利用矩陣、線性代數庫加速,權重更新頻率低。批次越小,訓練速度越慢。結合機器硬體性能與數據集大小設定。

正則項繫數(regularization parameter,λ)。憑經驗。複雜網路出現明顯過擬合(訓練數據準確率高,測試數據準確率下降)。一開始設0,確定好學習率,再給λ設值,根據準確率精細調整。

參考資料:
《TensorFlow技術解析與實戰》

歡迎推薦上海機器學習工作機會,我的微信:qingxingfengzi


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

-Advertisement-
Play Games
更多相關文章
  • 如果想把命令E:\zpic作為提供下載的目錄,那麼在cmd里cd到該目錄下,並執行命令:python -m SimpleHTTPServer 預設的埠號是8000, 伺服器根目錄就是運行python命令的工作目錄 如果提示錯誤:No module named SimpleHTTPServer 則試 ...
  • 最近公司安排做CCFA的一些東西,有一項就是做一個網頁播放攝像頭的實時監控。網上百度了很久,很多都是直接用vlc插件實現,但是目前主流瀏覽器都已經不支持vlc插件了,搞了很久也沒成功。 網上大多是這麼實現的: <object type='application/x-vlc-plugin' id='v ...
  • GO可以說是近幾年最熱門的新興語言之一了, 一般人看到 分散式 和 大數據 就會想到GO, 這個系列的文章會通過研究golang的源代碼來分析內部的實現原理, 和CoreCLR不同的是, golang的源代碼已經被很多人研究過了, 我將會著重研究他們未提到過的部分. 另一點和CoreCLR不同的是, ...
  • 其實在最前面的某一篇博文里,是絕對提過編碼的,有ASCII,有UTF-8,有GB2312等等,這些我絕對說過的。 url編碼 首先,Http協議中參數的傳輸是"key=value"這種鍵值對形式的,如果要傳多個參數就需要用“&”符號對鍵值對進行分割。如"?key1=value1&key2=value ...
  • 格式化輸出信息: %s 代表string字元串 %d 有符號整數(十進位),幫助檢驗數字類型 %f 浮點數字(用小數點符號) 1)%s 實例: 執行結果: 2.再從整型轉換成字元串 執行結果: 執行結果: format 另一種方式也行 執行結果: ...
  • Java 9 在 9 月 21 日 正式發佈 ,同時 Oracle 宣佈將 Java 新版本的 發佈周期調整為每半年一次。目前,Java 新版本的開發也已正式進入軌道。就已公開的消息來看,下一個版本的 Java 預計會在 2018 年 3 月發佈,版本號將會是 18.3 ,已經規劃加入的特性包括 J ...
  • 這是我自己早前聽課時整理的java基礎全套知識,使用於初學者,也可以適用於中級的程式員,我做成了chm文檔的類型,你們可以下載 筆記是比較系統全面,可以抵得上市場上90%的學習資料。討厭那些隨便亂寫的資料還有拿出來賣錢的人!在這裡我免費的分享出來供大家使用! 在這個平臺真的可以學習到不少的東西!有很 ...
  • IOC
    IOC ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...