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

pytorch如何實現(xiàn)邏輯回歸

 更新時間:2024年02月20日 16:11:59   作者:聽風(fēng)吹等浪起  
這篇文章主要介紹了pytorch如何實現(xiàn)邏輯回歸問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

1. 導(dǎo)入庫

機器學(xué)習(xí)的任務(wù)分為兩大類:分類和回歸

分類是對一堆目標(biāo)進行識別歸類,例如貓狗分類、手寫數(shù)字分類等等

回歸是對某樣事物接下來行為的預(yù)測,例如預(yù)測天氣等等

這次我們要完成的任務(wù)是邏輯回歸,雖然名字叫做回歸,其實是個二元分類的任務(wù)

首先看看我們需要的庫文件

  • torch.nn  是專門為神經(jīng)網(wǎng)絡(luò)設(shè)計的接口
  • matplotlib 用來繪制圖像,幫助可視化任務(wù)
  • torch 定義張量,數(shù)據(jù)的傳輸利用張量來實現(xiàn)
  • optim 優(yōu)化器的包,例如SGD等
  • numpy 數(shù)據(jù)處理的包

2. 定義數(shù)據(jù)集

簡單說明一下任務(wù),想在一個正方形的區(qū)域內(nèi)生成若干點,然后手工設(shè)計label,最后通過神經(jīng)網(wǎng)絡(luò)的訓(xùn)練,畫出決策邊界

假設(shè):正方形的邊長是2,左下角的坐標(biāo)為(0,0),右上角的坐標(biāo)為(2,2)

然后我們手工定義分界線 y = x ,在分界線的上方定義為藍色,下方定義為紅色

2.1 生成數(shù)據(jù)

首先生成數(shù)據(jù)的代碼為

首先通過rand(0-1的均勻分布)生成200個點,并將他們擴大2倍,x1代表橫坐標(biāo),x2代表縱坐標(biāo)

然后定義一下分類,這里簡單介紹一下zip函數(shù)。

zip會將這里的a,b對應(yīng)打包成一對,這樣i對應(yīng)的就是(1,‘a’),i[0] 對應(yīng)的就是1 2 3

 

再回到我們的代碼,因為我們要實現(xiàn)的是二元分類,所以我們定義兩個不同的類型,用pos,neg存起來。

然后我們知道i[1] 代表的是 x2 ,i[0] 代表的是x1 , 所以 x2 - x1 < 0 也就是也就是在直線y=x的下面為pos類型。

否則,為neg類型

最后,我們需要將pos,neg類型的繪制出來。因為pos里面其實是類似于(1,1)這樣的坐標(biāo),因為pos.append(i) 里面的 i 其實是(x1,x2) 的坐標(biāo)形式, 所以我們將pos 里面的第一個元素x1定義為賦值給橫坐標(biāo),第二個元素x2賦值給縱坐標(biāo)

然后通過scatter 繪制離散的點就可以,將pos 繪制成 red 顏色,neg 繪制成 blue 顏色,如圖

 

2.2 設(shè)置label

我們進行的其實是有監(jiān)督學(xué)習(xí),所以需要label

這里需要注意的是,不同于回歸任務(wù),x1不是輸入,x2也不是輸出。應(yīng)該x1,x2都是輸入的元素,也就是特征feature。所以我們應(yīng)該將紅色的點集設(shè)置一個標(biāo)簽,例如 1 ,藍色的點集設(shè)置一個標(biāo)簽,例如 0.

實現(xiàn)代碼如下

很容易理解,訓(xùn)練集x_data 應(yīng)該是所有樣本,也就是pos和neg的所以元素。

而之前介紹了x1,x2都是輸入的特征,那么x_data的shape 應(yīng)該是 [200,2] 的。

而y_data 只有1(pos 紅色)類別,或者 0(neg 藍色)類型,所以y_data 的shape 應(yīng)該是 [200,1] 的。y_data view的原因是變成矩陣的形式而不是向量的形式

這里的意思是,假如坐標(biāo)是(1.5,0.5)那么應(yīng)該落在紅色區(qū)域,那么這個點的標(biāo)簽就是1

3. 搭建網(wǎng)絡(luò)+優(yōu)化器

網(wǎng)絡(luò)的類型很簡單,不再贅述。至于為什么要繼承nn.Module或者super那步是干啥的不用管,基本上都是這樣寫的,記住就行。

需要注意的是我們輸入的特征是(n * 2) ,所以Linear 應(yīng)該是(2,1)

二元分類最后的輸出一般選用sigmoid函數(shù)

這里的損失函數(shù)我們選擇BCE,二元交叉熵損失函數(shù)。

算法為隨機梯度下降

4. 訓(xùn)練

訓(xùn)練的過程也比較簡單,就是將模型的預(yù)測輸出值和真實的label作比較。

然后將梯度歸零,在反向傳播并且更新梯度。

5. 繪制決策邊界

這里模型訓(xùn)練完成后,將w0,w1 ,b取出來,然后繪制出直線

這里要繪制的是w0 * x1+ w1 * x2 + b = 0 ,因為最開始介紹了x1代表橫坐標(biāo)x,x2代表縱坐標(biāo)y。

通過變形可知y = (- w0 * x1 - b ) / w1,結(jié)果如圖

程序輸出的損失為

最后,w0 = 4.1911 , w1 = -4.0290 ,b = 0.0209 ,近似等于y = x,和我們剛開始定義的分界線類似

6. 代碼

import torch.nn as nn
import matplotlib.pyplot as plt
import torch
from torch import optim
import numpy as np
 
torch.manual_seed(1)    # 保證程序隨機生成數(shù)一樣
 
x1 = torch.rand(200) * 2
x2 = torch.rand(200) * 2
data = zip(x1,x2)
pos = []                # 定義類型 1
neg = []                # 定義類型 2
def classification(data):
    for i in data:
        if(i[1] - i[0] < 0):
            pos.append(i)
        else:
            neg.append(i)
classification(data)
pos_x = [i[0] for i in pos]
pos_y = [i[1] for i in pos]
neg_x = [i[0] for i in neg]
neg_y = [i[1] for i in neg]
plt.scatter(pos_x,pos_y,c='r')
plt.scatter(neg_x,neg_y,c='b')
plt.show()
 
x_data = [[i[0],i[1]] for i in pos]
x_data.extend([[i[0],i[1]] for i in neg])
x_data = torch.Tensor(x_data)     # 輸入數(shù)據(jù) feature
 
y_data = [1 for i in range(len(pos))]
y_data.extend([0 for i in range(len(neg))])
y_data = torch.Tensor(y_data).view(-1,1)    # 對應(yīng)的標(biāo)簽
 
 
class LogisticRegressionModel(nn.Module):   # 定義網(wǎng)絡(luò)
    def __init__(self):
        super(LogisticRegressionModel,self).__init__()
        self.linear = nn.Linear(2,1)
        self.sigmoid = nn.Sigmoid()
    def forward(self,x):
        x = self.linear(x)
        x = self.sigmoid(x)
        return x
 
model = LogisticRegressionModel()
criterion = nn.BCELoss()    
optimizer = optim.SGD(model.parameters(),lr =0.01)
 
for epoch in range(10000):
    y_pred = model(x_data)
    loss = criterion(y_pred,y_data)     # 計算損失值
 
    if epoch % 1000 == 0:
        print(epoch,loss.item())     # 打印損失值
 
    optimizer.zero_grad()         # 梯度清零
    loss.backward()                 # 反向傳播
    optimizer.step()                # 梯度更新
 
w = model.linear.weight[0]      # 取出訓(xùn)練完成的結(jié)果
w0 = w[0]
w1 = w[1]
b = model.linear.bias.item()
 
with torch.no_grad():      # 繪制決策邊界,這里不需要計算梯度
    x= torch.arange(0,3).view(-1,1)
    y = (- w0 * x - b) / w1
    plt.plot(x.numpy(),y.numpy())
 
plt.scatter(pos_x,pos_y,c='r')          
plt.scatter(neg_x,neg_y,c='b')
plt.xlim(0,2)
plt.ylim(0,2)
plt.show()

程序結(jié)果

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python使用百度API上傳文件到百度網(wǎng)盤代碼分享

    Python使用百度API上傳文件到百度網(wǎng)盤代碼分享

    這篇文章主要介紹了Python使用百度API上傳文件到百度網(wǎng)盤代碼分享,本文使用了一個第三方庫poster,在文中給出了鏈接,需要的朋友可以參考下
    2014-11-11
  • 一文學(xué)會如何將Python打包后的exe還原成.py

    一文學(xué)會如何將Python打包后的exe還原成.py

    反編譯的第一步就是要將exe文件轉(zhuǎn)換成py文件,下面這篇文章主要給大家介紹了如何通過一文學(xué)會將Python打包后的exe還原成.py的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • python global關(guān)鍵字的用法詳解

    python global關(guān)鍵字的用法詳解

    這篇文章主要介紹了python global關(guān)鍵字的用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • Python基礎(chǔ)篇之字符串的最全常用操作方法匯總

    Python基礎(chǔ)篇之字符串的最全常用操作方法匯總

    我們在學(xué)習(xí)Python語言時會遇到各種各樣的字符串方法處理,下面這篇文章主要給大家介紹了關(guān)于Python基礎(chǔ)篇之字符串的最全常用操作方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-05-05
  • 一篇文章帶你了解python標(biāo)準庫--math模塊

    一篇文章帶你了解python標(biāo)準庫--math模塊

    這篇文章主要介紹了Python的math模塊中的常用數(shù)學(xué)函數(shù)整理,同時對運算符的運算優(yōu)先級作了一個羅列,需要的朋友可以參考下,希望能給你帶來幫助
    2021-08-08
  • python列表:開始、結(jié)束、步長值實例

    python列表:開始、結(jié)束、步長值實例

    這篇文章主要介紹了python列表:開始、結(jié)束、步長值實例,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 保留已有python安裝Anaconda的方法推薦

    保留已有python安裝Anaconda的方法推薦

    在安裝Anaconda之前,有的已經(jīng)安裝過一個Python版本了,但是又不想刪除這個Python版本,該怎么辦呢??這篇文章主要給大家介紹了關(guān)于保留已有python安裝Anaconda的幾種法推薦,需要的朋友可以參考下
    2023-12-12
  • Django中ORM的基本使用教程

    Django中ORM的基本使用教程

    這篇文章主要給大家介紹了關(guān)于Django中ORM基本使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Python通過for循環(huán)理解迭代器和生成器實例詳解

    Python通過for循環(huán)理解迭代器和生成器實例詳解

    這篇文章主要介紹了Python通過for循環(huán)理解迭代器和生成器,結(jié)合實例形式詳細分析了迭代器和生成器的概念、原理、使用方法及相關(guān)操作技巧,需要的朋友可以參考下
    2019-02-02
  • python獲取Pandas列名的幾種方法

    python獲取Pandas列名的幾種方法

    這篇文章主要介紹了python獲取Pandas列名的幾種方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08

最新評論