線性回歸練習(xí)

單輸入線性回歸練習(xí)

1.導(dǎo)入需要用的模塊

# import packages and modules
%matplotlib inline
import torch
from IPython import display
from matplotlib import pyplot as plt
import numpy as np
import random

2.初始化參數(shù)

注意:初始化參數(shù)時要初始化為向量继蜡,例如初始化為x = torch.randn(n)就是錯誤的子刮。

#初始化參數(shù)
n = 1000
x = torch.randn(n,1)
w = 3.4
b = 2
y = torch.zeros(n,1)

3.生成數(shù)據(jù)集

注意:生成數(shù)據(jù)集時,后面的隨機(jī)生成的數(shù)字要為和y一樣的隨機(jī)向量,而不能是一個數(shù)字砾层。

#2.生成數(shù)據(jù)集
y = w*x + b + torch.tensor(np.random.normal(0, 0.5, size=y.size()))
print(y[0:10])
print(x.shape,y.shape)
plt.scatter(x.numpy(), y.numpy(),1);

4.初始化參數(shù)

注意:w.requires_grad_(requires_grad=True) 默認(rèn)的requires_grad=False(自動求導(dǎo))

#初始化訓(xùn)練參數(shù) / 讀取數(shù)據(jù)
X = x
w = torch.randn(1)
b = torch.zeros(1)
w.requires_grad_(requires_grad=True)
b.requires_grad_(requires_grad=True)
print(w,b,x_len)

5.分批次讀取數(shù)據(jù)

注意:random.shuffle(indices) 函數(shù)表示打亂列表的循序。
torch.LongTensor(indices[i: min(i + batch_size, num_examples)]) :構(gòu)建多個(1*batch_size) Long類型的張量贱案。

#分批次讀取數(shù)據(jù)
def data_iter(batch_size, features, labels):
    num_examples = len(features)
    indices = list(range(num_examples))
    random.shuffle(indices)  # random read 10 samples 打亂順序函數(shù)
    for i in range(0, num_examples, batch_size):
        j = torch.LongTensor(indices[i: min(i + batch_size, num_examples)]) # the last time may be not enough for a whole batch
        yield  features.index_select(0, j), labels.index_select(0, j)

#前向傳播
def forword(X,w,b):
    w=w.view(len(w),1) # 可以不加肛炮,目的是為了確保w為相對于的矩陣。
    b=b.view(len(b),1)
    return torch.mm(X, w) + b
    
#損失函數(shù)
def squared_loss(y_hat, y): 
    return (y_hat - y.view(y_hat.size())) ** 2 / 2
    
#反向傳播
def sgd(params, lr, batch_size): 
    for param in params:
        param.data -= lr * param.grad / batch_size # ues .data to operate param without gradient track

# super parameters init
lr = 0.03
num_epochs = 5000

net = forword
loss = squared_loss

# training
for epoch in range(num_epochs):  # training repeats num_epochs times
    # in each epoch, all the samples in dataset will be used once
    
    # X is the feature and y is the label of a batch sample
    for X, y in data_iter(batch_size, X, y):
        #print(X.shape,w.shape,b)
        l = loss(net(X, w, b), y).sum()  
        # calculate the gradient of batch sample loss 
        l.backward()  
        # using small batch random gradient descent to iter model parameters
        sgd([w, b], lr, batch_size)  
        # reset parameter gradient
        w.grad.data.zero_()
        b.grad.data.zero_()
    train_l = loss(net(X, w, b), y)
    #print('epoch %d, loss %f' % (epoch + 1, train_l.mean().item()))

print(w,b)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末轰坊,一起剝皮案震驚了整個濱河市铸董,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌肴沫,老刑警劉巖粟害,帶你破解...
    沈念sama閱讀 221,548評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異颤芬,居然都是意外死亡悲幅,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評論 3 399
  • 文/潘曉璐 我一進(jìn)店門站蝠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來汰具,“玉大人,你說我怎么就攤上這事菱魔×衾螅” “怎么了?”我有些...
    開封第一講書人閱讀 167,990評論 0 360
  • 文/不壞的土叔 我叫張陵澜倦,是天一觀的道長峦剔。 經(jīng)常有香客問我官研,道長迷雪,這世上最難降的妖魔是什么板辽? 我笑而不...
    開封第一講書人閱讀 59,618評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮桩卵,結(jié)果婚禮上验靡,老公的妹妹穿的比我還像新娘。我一直安慰自己雏节,他們只是感情好胜嗓,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,618評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著钩乍,像睡著了一般兼蕊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上件蚕,一...
    開封第一講書人閱讀 52,246評論 1 308
  • 那天孙技,我揣著相機(jī)與錄音,去河邊找鬼排作。 笑死牵啦,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的妄痪。 我是一名探鬼主播哈雏,決...
    沈念sama閱讀 40,819評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼衫生!你這毒婦竟也來了裳瘪?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,725評論 0 276
  • 序言:老撾萬榮一對情侶失蹤罪针,失蹤者是張志新(化名)和其女友劉穎彭羹,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體泪酱,經(jīng)...
    沈念sama閱讀 46,268評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡派殷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,356評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了墓阀。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片毡惜。...
    茶點(diǎn)故事閱讀 40,488評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖斯撮,靈堂內(nèi)的尸體忽然破棺而出经伙,到底是詐尸還是另有隱情,我是刑警寧澤勿锅,帶...
    沈念sama閱讀 36,181評論 5 350
  • 正文 年R本政府宣布帕膜,位于F島的核電站,受9級特大地震影響粱甫,放射性物質(zhì)發(fā)生泄漏泳叠。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,862評論 3 333
  • 文/蒙蒙 一茶宵、第九天 我趴在偏房一處隱蔽的房頂上張望危纫。 院中可真熱鬧,春花似錦乌庶、人聲如沸种蝶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,331評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽螃征。三九已至,卻和暖如春透敌,著一層夾襖步出監(jiān)牢的瞬間盯滚,已是汗流浹背踢械。 一陣腳步聲響...
    開封第一講書人閱讀 33,445評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留魄藕,地道東北人内列。 一個月前我還...
    沈念sama閱讀 48,897評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像背率,于是被迫代替她去往敵國和親话瞧。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,500評論 2 359