欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

pytorch動態(tài)神經(jīng)網(wǎng)絡(luò)(擬合)實現(xiàn)

 更新時間:2021年03月24日 08:39:53   作者:子玹  
這篇文章主要介紹了pytorch動態(tài)神經(jīng)網(wǎng)絡(luò)(擬合)實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

(1)首先要建立數(shù)據(jù)集

import torch  #引用torch模塊
import matplotlib.pyplot as plt #引用畫圖模塊
x=torch.unsqueeze(torch.linspace(-1,1,100),dim=1)#產(chǎn)生(-1,1)的100個點橫坐標(biāo),dim表示維度,表示在這里增加第二維
y=x.pow(2)+0.2*torch.rand(x,size())
#0.2*torch.rand(x,size())是為了產(chǎn)生噪點使數(shù)據(jù)更加真實

(2)建立神經(jīng)網(wǎng)絡(luò)

import torch
imoort torch.nn.functional as F #激勵函數(shù)在這個模塊里
class Net (torch.nn.Module): #Net要繼承torch中Module 
(1)首先有定義(建立)神經(jīng)網(wǎng)絡(luò)層
def __init__(self,n_feature,n_hidden,n_output):
#__init__表示初始化數(shù)據(jù)
  super(Net,self).__init__()#Net的對象self轉(zhuǎn)換為類nn.module的對象,然后在用nn.Module的方法使用__init__初始化。
self.hidden=torch.nn.Linear(n_feature,n_hidden)
#建立隱藏層線性輸出
self.predict=torch.nn.Linear(n_hidden,n_output)
#建立輸出層線性輸出

(2)建立層與層之間的關(guān)系

def forward (self,x):
# 這同時也是 Module 中的 forward 功能
x=F.relu(self,hidden(x))
#使用激勵函數(shù)把數(shù)據(jù)激活
return x #輸出數(shù)據(jù)
net=Net(n_feature=1,n_hidden=10,n_output=1)
#一個隱藏層有10節(jié)點,輸出層有1節(jié)點,輸出數(shù)數(shù)據(jù)為一個

(3)訓(xùn)練網(wǎng)絡(luò)

optimizer=torch.optim.SGD(net.parameter().lr=0.2)#傳入 net 的所有參數(shù), lr代表學(xué)習(xí)率,optimizer是訓(xùn)練工具
loss_func=torch.nn.MSELoss()#預(yù)測值和真實值的誤差計算公式 (均方差)
for t in range(100):
prediction = net(x) # 喂給 net 訓(xùn)練數(shù)據(jù) x, 輸出預(yù)測值
  loss = loss_func(prediction, y)  # 計算兩者的誤差
  optimizer.zero_grad() # 清空上一步的殘余更新參數(shù)值
  loss.backward()    # 誤差反向傳播, 計算參數(shù)更新值
  optimizer.step()    # 將參數(shù)更新值施加到 net 的 parameters 上

(四)可視化訓(xùn)練

import matplotlib.pyplot as plt
plt.ion() # 畫圖
plt.show()
for t in range(200):
  ...
  loss.backward()
  optimizer.step() 
  # 接著上面來
  if t % 5 == 0:
    # plot and show learning process
    plt.cla()
    plt.scatter(x.data.numpy(), y.data.numpy())
    plt.plot(x.data.numpy(), prediction.data.numpy(), 'r-', lw=5)
    plt.text(0.5, 0, 'Loss=%.4f' % loss.data.numpy(), fontdict={'size': 20, 'color': 'red'})
    plt.pause(0.1)

會得到如下圖像:

整體代碼如下:

import torch
import matplotlib.pyplot as plt
x=torch.unsqueeze(torch.linspace(-2,2,100),dim=1)
y=x.pow(2)+0.2*torch.rand(x.size())
import torch
import torch.nn.functional as F
class Net(torch.nn.Module):
  def __init__(self,n_feature,n_hidden,n_output):
    super(Net,self).__init__()
    self.hidden=torch.nn.Linear(n_feature,n_hidden)
    self.predict=torch.nn.Linear(n_hidden,n_output)
  def forward(self,x):
    x=F.relu(self.hidden(x))
    x=self.predict(x)
    return x
net=Net(n_feature=1,n_hidden=10,n_output=1)
optimizer=torch.optim.SGD(net.parameters(),lr=0.3)
loss_func=torch.nn.MSELoss()
plt.ion() 
plt.show()
for t in range(100):
  prediction=net(x)
  loss=loss_func(prediction,y)
  optimizer.zero_grad() 
  loss.backward()    
  optimizer.step()
  if t % 5 == 0:
 
    plt.cla()
    plt.scatter(x.data.numpy(), y.data.numpy())
    plt.plot(x.data.numpy(), prediction.data.numpy(), 'r-', lw=5)
    plt.text(0.5, 0, 'Loss=%.4f' % loss.data.numpy(), fontdict={'size': 20, 'color': 'red'})
    plt.pause(0.1)

【參考文獻】https://mofanpy.com/tutorials/machine-learning/torch/regression/

到此這篇關(guān)于pytorch動態(tài)神經(jīng)網(wǎng)絡(luò)(擬合)實現(xiàn)的文章就介紹到這了,更多相關(guān)pytorch動態(tài)神經(jīng)網(wǎng)絡(luò)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python文件夾分區(qū)的實現(xiàn)方法實例

    python文件夾分區(qū)的實現(xiàn)方法實例

    這篇文章主要給大家介紹了關(guān)于python文件夾分區(qū)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Facebook開源一站式服務(wù)python時序利器Kats詳解

    Facebook開源一站式服務(wù)python時序利器Kats詳解

    這篇文章主要為答案及介紹了Facebook開源一站式服務(wù)python時序利器Kats的功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-11-11
  • django中path函數(shù)使用詳解

    django中path函數(shù)使用詳解

    django.urls.path是Django中用于定義URL映射規(guī)則的函數(shù)之一,本文主要介紹了django中path函數(shù)使用,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • python圖像處理入門(一)

    python圖像處理入門(一)

    這篇文章主要介紹了python圖像處理入門,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Python如何給你的程序做性能測試

    Python如何給你的程序做性能測試

    這篇文章主要介紹了Python如何給你的程序做性能測試,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • 使用pyqt5 tablewidget 單元格設(shè)置正則表達式

    使用pyqt5 tablewidget 單元格設(shè)置正則表達式

    今天小編就為大家分享一篇使用pyqt5 tablewidget 單元格設(shè)置正則表達式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • python基礎(chǔ)之并發(fā)編程(三)

    python基礎(chǔ)之并發(fā)編程(三)

    這篇文章主要介紹了詳解python的并發(fā)編程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • python中g(shù)lobal用法實例分析

    python中g(shù)lobal用法實例分析

    這篇文章主要介紹了python中g(shù)lobal用法,較為詳細(xì)的分析了global的功能并實例演示了相應(yīng)的使用技巧,需要的朋友可以參考下
    2015-04-04
  • Python3.6.2調(diào)用ffmpeg的方法

    Python3.6.2調(diào)用ffmpeg的方法

    今天小編就為大家分享一篇Python3.6.2調(diào)用ffmpeg的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Python連接Redis庫常見操作全面詳解

    Python連接Redis庫常見操作全面詳解

    本文將介紹如何在Python中進行Redis操作,包括連接Redis、數(shù)據(jù)存儲、數(shù)據(jù)檢索和其他常見操作,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11

最新評論