亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

pytorch使用Variable實現(xiàn)線性回歸

 更新時間:2021年04月09日 14:23:09   作者:東城青年  
這篇文章主要為大家詳細介紹了pytorch使用Variable實現(xiàn)線性回歸,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了pytorch使用Variable實現(xiàn)線性回歸的具體代碼,供大家參考,具體內(nèi)容如下

一、手動計算梯度實現(xiàn)線性回歸

#導入相關(guān)包
import torch as t
import matplotlib.pyplot as plt
 
#構(gòu)造數(shù)據(jù)
def get_fake_data(batch_size = 8):
 #設(shè)置隨機種子數(shù),這樣每次生成的隨機數(shù)都是一樣的
 t.manual_seed(10)
 #產(chǎn)生隨機數(shù)據(jù):y = 2*x+3,加上了一些噪聲
 x = t.rand(batch_size,1) * 20
 #randn生成期望為0方差為1的正態(tài)分布隨機數(shù)
 y = x * 2 + (1 + t.randn(batch_size,1)) * 3 
 return x,y
 
#查看生成數(shù)據(jù)的分布
x,y = get_fake_data()
plt.scatter(x.squeeze().numpy(),y.squeeze().numpy())
 
#線性回歸
 
#隨機初始化參數(shù)
w = t.rand(1,1)
b = t.zeros(1,1)
#學習率
lr = 0.001 
 
for i in range(10000):
 x,y = get_fake_data()
 
 #forward:計算loss
 y_pred = x.mm(w) + b.expand_as(y)
 
 #均方誤差作為損失函數(shù)
 loss = 0.5 * (y_pred - y)**2 
 loss = loss.sum()
 
 #backward:手動計算梯度
 dloss = 1
 dy_pred = dloss * (y_pred - y)
 dw = x.t().mm(dy_pred)
 db = dy_pred.sum()
 
 #更新參數(shù)
 w.sub_(lr * dw)
 b.sub_(lr * db)
 
 if i%1000 == 0:
 #畫圖
 plt.scatter(x.squeeze().numpy(),y.squeeze().numpy())
 
 x1 = t.arange(0,20).float().view(-1,1)
 y1 = x1.mm(w) + b.expand_as(x1)
 plt.plot(x1.numpy(),y1.numpy()) #predicted
 plt.show()
 #plt.pause(0.5)
 print(w.squeeze(),b.squeeze())

顯示的最后一張圖如下所示:

二、自動梯度 計算梯度實現(xiàn)線性回歸

#導入相關(guān)包
import torch as t
from torch.autograd import Variable as V
import matplotlib.pyplot as plt
 
#構(gòu)造數(shù)據(jù)
def get_fake_data(batch_size=8):
 t.manual_seed(10) #設(shè)置隨機數(shù)種子
 x = t.rand(batch_size,1) * 20
 y = 2 * x +(1 + t.randn(batch_size,1)) * 3
 return x,y
 
#查看產(chǎn)生的x,y的分布是什么樣的
x,y = get_fake_data()
plt.scatter(x.squeeze().numpy(),y.squeeze().numpy())
 
#線性回歸
 
#初始化隨機參數(shù)
w = V(t.rand(1,1),requires_grad=True)
b = V(t.rand(1,1),requires_grad=True)
lr = 0.001
for i in range(8000):
 x,y = get_fake_data()
 x,y = V(x),V(y)
 y_pred = x * w + b
 loss = 0.5 * (y_pred-y)**2
 loss = loss.sum()
 
 #自動計算梯度
 loss.backward()
 #更新參數(shù)
 w.data.sub_(lr * w.grad.data)
 b.data.sub_(lr * b.grad.data)
 
 #梯度清零,不清零梯度會累加的
 w.grad.data.zero_()
 b.grad.data.zero_()
 
 if i%1000==0:
 #predicted
 x = t.arange(0,20).float().view(-1,1)
 y = x.mm(w.data) + b.data.expand_as(x)
 plt.plot(x.numpy(),y.numpy())
 
 #true data
 x2,y2 = get_fake_data()
 plt.scatter(x2.numpy(),y2.numpy())
 plt.show()
print(w.data[0],b.data[0])

顯示的最后一張圖如下所示:

用autograd實現(xiàn)的線性回歸最大的不同點就在于利用autograd不需要手動計算梯度,可以自動微分。這一點不單是在深度在學習中,在許多機器學習的問題中都很有用。另外,需要注意的是每次反向傳播之前要記得先把梯度清零,因為autograd求得的梯度是自動累加的。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python如何實現(xiàn)向上取整

    python如何實現(xiàn)向上取整

    這篇文章主要介紹了python如何實現(xiàn)向上取整問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • python如何生成隨機n位數(shù)字與字母組合(創(chuàng)建隨機)

    python如何生成隨機n位數(shù)字與字母組合(創(chuàng)建隨機)

    這篇文章主要介紹了python如何生成隨機n位數(shù)字與字母組合(創(chuàng)建隨機),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • python中繞過反爬蟲的方法總結(jié)

    python中繞過反爬蟲的方法總結(jié)

    在本篇文章里小編給大家整理的是一篇關(guān)于python中繞過反爬蟲的方法總結(jié)內(nèi)容,需要的朋友們可以參考下。
    2020-11-11
  • Python的線程之線程同步

    Python的線程之線程同步

    這篇文章主要為大家介紹了Python線程同步,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Python?ORM框架之SQLAlchemy?的基礎(chǔ)用法

    Python?ORM框架之SQLAlchemy?的基礎(chǔ)用法

    這篇文章主要介紹了Python?ORM框架之SQLAlchemy?的基礎(chǔ)用法,ORM全稱?Object?Relational?Mapping對象關(guān)系映射,更多詳細內(nèi)容需要的小伙伴課題參考下面文章介紹。希望對你的學習有所幫助
    2022-03-03
  • python用字符組成圖像代碼實例

    python用字符組成圖像代碼實例

    大家好,本篇文章主要講的是python用字符組成圖像代碼實例,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • Python的Flask框架中集成CKeditor富文本編輯器的教程

    Python的Flask框架中集成CKeditor富文本編輯器的教程

    在用Flask搭建網(wǎng)站時的后臺文章編輯器可以使用CKeditor,CKeditor所支持的文本樣式較多且開源,這里我們就來看一下Python的Flask框架中集成CKeditor富文本編輯器的教程
    2016-06-06
  • Python實現(xiàn)隨機游走的詳細解釋

    Python實現(xiàn)隨機游走的詳細解釋

    這篇文章主要介紹了Python實現(xiàn)隨機游走的詳細解釋,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • Pycharm連接遠程服務(wù)器過程圖解

    Pycharm連接遠程服務(wù)器過程圖解

    這篇文章主要介紹了Pycharm連接遠程服務(wù)器過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • 簡單了解python元組tuple相關(guān)原理

    簡單了解python元組tuple相關(guān)原理

    這篇文章主要介紹了簡單了解python元組tuple相關(guān)原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12

最新評論