91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

深度學習框架pytorch入門與實踐

工程師鄧生 ? 來源:未知 ? 作者:劉芹 ? 2023-08-17 16:03 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

深度學習框架pytorch入門與實踐

深度學習是機器學習中的一個分支,它使用多層神經(jīng)網(wǎng)絡(luò)對大量數(shù)據(jù)進行學習,以實現(xiàn)人工智能的目標。在實現(xiàn)深度學習的過程中,選擇一個適用的開發(fā)框架是非常關(guān)鍵的。PyTorch是一個開源的深度學習框架,在深度學習領(lǐng)域得到了廣泛應(yīng)用。本文將介紹PyTorch框架的基本知識、核心概念以及如何在實踐中使用PyTorch框架。

一、PyTorch框架概述

PyTorch是一個Facebook開源項目,是一個動態(tài)計算圖的深度學習框架。與靜態(tài)計算圖的TensorFlow不同,PyTorch使用動態(tài)圖的方式,這樣就可以在計算圖中進行變量、條件、循環(huán)等計算,這使得PyTorch框架更加靈活、直觀。

PyTorch的優(yōu)點在于它是Python優(yōu)秀的科學計算庫Numpy的擴展,這使得PyTorch非常容易上手,尤其是對于已經(jīng)熟悉Python編程、數(shù)據(jù)科學和機器學習的人來說非常有利。

二、PyTorch框架核心概念

1. 張量

張量是PyTorch框架中最基本的數(shù)據(jù)類型,與Numpy中的數(shù)組類似。張量可以是標量(僅包含一個數(shù)字)、向量(包含一個一維數(shù)組)、矩陣(包含一個二維數(shù)組)或其他更高維數(shù)組。在PyTorch中可以使用torch.Tensor類創(chuàng)建張量。

import torch

# 創(chuàng)建一個標量張量,即只包含一個數(shù)字
a = torch.tensor(2.8)
print(a)

# 創(chuàng)建一個向量張量
b = torch.tensor([2, 8, 4])
print(b)

# 創(chuàng)建一個矩陣張量
c = torch.tensor([[2, 8, 4], [3, 1, 5]])
print(c)

2. 變量

變量是PyTorch框架中的另一個重要概念,它包含了張量及其導數(shù)(梯度)。變量的主要作用就是記錄所有的計算過程。當我們使用PyTorch框架構(gòu)建神經(jīng)網(wǎng)絡(luò)時,就可以使用變量來記錄每一層的計算結(jié)果,從而實現(xiàn)反向傳播算法。

import torch

# 創(chuàng)建一個可導的變量
a = torch.autograd.Variable(torch.tensor([2.]), requires_grad=True)
b = torch.autograd.Variable(torch.tensor([3.]), requires_grad=True)

# 進行計算
c = 5 * a + b
d = c.mean()

# 計算導數(shù)
d.backward()
print(a.grad) # 輸出 5

3. 模型

在PyTorch框架中,一個模型通常由一個或多個層組成,每一層都包含了一些可訓練的權(quán)重和偏差,它們會被不斷地更新以優(yōu)化模型的預測性能。在PyTorch中可以使用torch.nn.Module類來定義一個模型。

import torch.nn as nn

# 定義一個簡單的模型
class Net(nn.Module):
def __init__(self):
super(Net, self).__init__()
self.fc1 = nn.Linear(2, 10)
self.fc2 = nn.Linear(10, 1)

def forward(self, x):
x = self.fc1(x)
x = nn.ReLU()(x)
x = self.fc2(x)
return x

4. 優(yōu)化器

優(yōu)化器是訓練神經(jīng)網(wǎng)絡(luò)時至關(guān)重要的組件,它可以針對模型的誤差,自動地調(diào)整模型的參數(shù)以達到預期的訓練效果。在PyTorch中可以使用各種優(yōu)化器,如SGD、Adam等來優(yōu)化模型。

import torch.optim as optim

# 實例化一個優(yōu)化器對象
optimizer = optim.SGD(net.parameters(), lr=0.01, momentum=0.9)

# 在訓練循環(huán)中使用優(yōu)化器
for i, data in enumerate(trainloader, 0):
inputs, labels = data
inputs, labels = inputs.to(device), labels.to(device)

# 梯度清零
optimizer.zero_grad()

# 前向傳播
outputs = net(inputs)

# 計算誤差
loss = criterion(outputs, labels)

# 反向傳播
loss.backward()

# 更新模型參數(shù)
optimizer.step()

三、使用PyTorch框架進行實踐

下面通過一個簡單的例子來介紹如何使用PyTorch框架訓練一個簡單的神經(jīng)網(wǎng)絡(luò)。

1. 導入數(shù)據(jù)

在本例中,我們使用sklearn庫的make_classification函數(shù)生成了一個二元分類任務(wù),然后將數(shù)據(jù)集劃分為訓練集和測試集。

import numpy as np
from sklearn.datasets import make_classification
from sklearn.model_selection import train_test_split

# 生成二元分類數(shù)據(jù)
X, y = make_classification(n_samples=1000, n_features=10, n_classes=2)

# 劃分數(shù)據(jù)集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)

2. 構(gòu)建模型

在本例中,我們構(gòu)建了一個包含兩個線性層和一個ReLU激活函數(shù)的神經(jīng)網(wǎng)絡(luò)。

import torch
import torch.nn as nn

class Net(nn.Module):
def __init__(self):
super(Net, self).__init__()
self.fc1 = nn.Linear(10, 5)
self.fc2 = nn.Linear(5, 2)
self.relu = nn.ReLU()

def forward(self, x):
x = self.fc1(x)
x = self.relu(x)
x = self.fc2(x)
return x

# 實例化一個模型對象
net = Net()
print(net)

3. 訓練模型

在訓練模型之前,我們需要指定損失函數(shù)和優(yōu)化器。在本例中,我們使用交叉熵損失函數(shù)和Adam優(yōu)化器。

criterion = nn.CrossEntropyLoss()
optimizer = torch.optim.Adam(net.parameters(), lr=0.01)

然后我們開始迭代訓練模型:

for epoch in range(100):
running_loss = 0.0
for i in range(len(X_train)):
# 將數(shù)據(jù)轉(zhuǎn)化為PyTorch張量
inputs = torch.Tensor(X_train[i])
label = torch.Tensor([y_train[i]]).long()

# 將數(shù)據(jù)放入GPU
if torch.cuda.is_available():
inputs = inputs.to("cuda:0")
label = label.to("cuda:0")

# 將梯度清零
optimizer.zero_grad()

# 前向傳播
outputs = net(inputs)

# 計算損失
loss = criterion(outputs, label)
running_loss += loss.item()

# 反向傳播
loss.backward()

# 更新模型參數(shù)
optimizer.step()

# 打印損失
if epoch % 10 == 9:
print('[%d] loss: %.3f' % (epoch + 1, running_loss / len(X_train)))

4. 測試模型

經(jīng)過一段時間的訓練,我們的模型已經(jīng)學習到了一些有用的特征,接下來可以使用測試數(shù)據(jù)集來評估模型的性能:

correct = 0
total = 0
with torch.no_grad():
for i in range(len(X_test)):
# 將數(shù)據(jù)轉(zhuǎn)化為PyTorch張量
inputs = torch.Tensor(X_test[i])
label = torch.Tensor([y_test[i]]).long()

# 將數(shù)據(jù)放入GPU中
if torch.cuda.is_available():
inputs = inputs.to("cuda:0")
label = label.to("cuda:0")

# 前向傳播
outputs = net(inputs)

# 取得預測結(jié)果
_, predicted = torch.max(outputs.data, 0)
total += 1
if predicted == label:
correct += 1

# 打印模型的預測性能
print('Accuracy on test set: %d %%' % (100 * correct / total))

總結(jié)

本文介紹了PyTorch框架的基本知識、核心概念以及使用PyTorch框架進行深度學習的實踐。通過本文的介紹,讀者可以更加深入地了解PyTorch框架的特點和優(yōu)點,并通過實踐了解如何構(gòu)建和訓練一個簡單的神經(jīng)網(wǎng)絡(luò)。希望讀者能夠從本文中獲得實用的經(jīng)驗,并在自己的項目中成功地應(yīng)用PyTorch框架。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 神經(jīng)網(wǎng)絡(luò)

    關(guān)注

    42

    文章

    4838

    瀏覽量

    107823
  • 深度學習
    +關(guān)注

    關(guān)注

    73

    文章

    5599

    瀏覽量

    124406
  • pytorch
    +關(guān)注

    關(guān)注

    2

    文章

    813

    瀏覽量

    14856
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    PyTorch 中RuntimeError分析

    使用的具體框架(如 Stable Diffusion、ComfyUI)和 PyTorch 版本,我可以給你更精確的修復代碼。需要我?guī)湍愣ㄖ茊幔?
    發(fā)表于 03-06 06:02

    Pytorch 與 Visionfive2 兼容嗎?

    Pytorch 與 Visionfive2 兼容嗎? $ pip3 install torch torchvision torchaudio --index-url https
    發(fā)表于 02-06 08:28

    LuatOS框架的使用(上)

    在資源受限的物聯(lián)網(wǎng)終端設(shè)備中,如何實現(xiàn)快速開發(fā)與穩(wěn)定運行是關(guān)鍵挑戰(zhàn)。LuatOS框架通過將Lua語言與底層硬件抽象層深度融合,提供了一套簡潔高效的開發(fā)范式。本文將圍繞LuatOS框架的使用展開,從
    的頭像 發(fā)表于 01-27 19:38 ?159次閱讀
    LuatOS<b class='flag-5'>框架</b>的使用(上)

    機器學習深度學習中需避免的 7 個常見錯誤與局限性

    無論你是剛入門還是已經(jīng)從事人工智能模型相關(guān)工作一段時間,機器學習深度學習中都存在一些我們需要時刻關(guān)注并銘記的常見錯誤。如果對這些錯誤置之不理,日后可能會引發(fā)諸多麻煩!只要我們密切關(guān)注
    的頭像 發(fā)表于 01-07 15:37 ?203次閱讀
    機器<b class='flag-5'>學習</b>和<b class='flag-5'>深度</b><b class='flag-5'>學習</b>中需避免的 7 個常見錯誤與局限性

    【團購】獨家全套珍藏!龍哥LabVIEW視覺深度學習實戰(zhàn)課(11大系列課程,共5000+分鐘)

    大系列課程,形成\"傳統(tǒng)視覺算法→深度學習建?!I(yè)級部署\"的完整技術(shù)鏈,不論是新手、老手都適合學習。 1. 新手入門 課程通過三層保障體系降低
    發(fā)表于 12-04 09:28

    學習物聯(lián)網(wǎng)怎么入門?

    的相關(guān)書籍和視頻進行學習。也可以通過參加線下班、工作坊和實踐活動來學習。不同的學習方式適合不同的人群,初學者可以根據(jù)自己的實際情況選擇適合自己的學習
    發(fā)表于 10-14 10:34

    摩爾線程發(fā)布Torch-MUSA v2.1.1版本

    近日,摩爾線程發(fā)布其面向PyTorch深度學習框架的MUSA擴展庫——Torch-MUSA v2.1.1。該版本在v2.1.0的基礎(chǔ)上,進一步擴展了對大規(guī)模
    的頭像 發(fā)表于 09-10 11:02 ?1044次閱讀

    ARM入門學習方法分享

    。 以下是一些入門學習方法的分享: 一、 理解基本概念:首先,了解ARM是什么以及它的基本概念是很重要的。ARM(Advanced RISC Machines)指的是一種精簡指令集計算機(RISC
    發(fā)表于 07-23 10:21

    Nordic收購 Neuton.AI 關(guān)于產(chǎn)品技術(shù)的分析

    Nordic Semiconductor 于 2025 年收購了 Neuton.AI,這是一家專注于超小型機器學習(TinyML)解決方案的公司。 Neuton 開發(fā)了一種獨特的神經(jīng)網(wǎng)絡(luò)框架,能夠
    發(fā)表于 06-28 14:18

    提高IT運維效率,深度解讀京東云AIOps落地實踐(異常檢測篇)

    基于深度學習對運維時序指標進行異常檢測,快速發(fā)現(xiàn)線上業(yè)務(wù)問題 時間序列的異常檢測是實際應(yīng)用中的一個關(guān)鍵問題,尤其是在 IT 行業(yè)。我們沒有采用傳統(tǒng)的基于閾值的方法來實現(xiàn)異常檢測,而是通過深度
    的頭像 發(fā)表于 05-22 16:38 ?1036次閱讀
    提高IT運維效率,<b class='flag-5'>深度</b>解讀京東云AIOps落地<b class='flag-5'>實踐</b>(異常檢測篇)

    【「# ROS 2智能機器人開發(fā)實踐」閱讀體驗】視覺實現(xiàn)的基礎(chǔ)算法的應(yīng)用

    : 一、機器人視覺:從理論到實踐 第7章詳細介紹了ROS2在機器視覺領(lǐng)域的應(yīng)用,涵蓋了相機標定、OpenCV集成、視覺巡線、二維碼識別以及深度學習目標檢測等內(nèi)容。通過學習,我認識到:
    發(fā)表于 05-03 19:41

    【「# ROS 2智能機器人開發(fā)實踐」閱讀體驗】機器人入門的引路書

    的非常好的,特別是一些流程圖,很清晰的闡釋了概念 很適合作為初學者入門的引路書 還能了解很多技術(shù)和框架,破除初學者的自負困境,讓初學者知道功能是由很多開發(fā)者維護的,前人已經(jīng)為各種產(chǎn)品搭建了完善的框架。避免陷入得一個人單打獨斗的錯
    發(fā)表于 04-30 01:05

    海思SS626開發(fā)板

    識別/運動跟蹤等)。 主板集成常用視頻硬件接口,所有外設(shè)接口電路均通過嚴格的抗干擾測試,使產(chǎn)品在 EMC 及穩(wěn)定性方面 具有良好表現(xiàn);使用通過穩(wěn)定性測試及深度優(yōu)化的系統(tǒng)軟件(Linux 系統(tǒng)),支持業(yè)界主流深度學習
    發(fā)表于 04-24 10:04

    百度飛槳框架3.0正式版發(fā)布

    大模型訓練成本高?推理效率低?硬件適配難? 4月1日,百度發(fā)布 飛槳框架3.0正式版 !五大特性專為大模型設(shè)計。 作為大模型時代的Infra“基礎(chǔ)設(shè)施”,深度學習框架的重要性愈發(fā)凸顯,
    的頭像 發(fā)表于 04-02 19:03 ?1200次閱讀
    百度飛槳<b class='flag-5'>框架</b>3.0正式版發(fā)布

    嵌入式AI技術(shù)之深度學習:數(shù)據(jù)樣本預處理過程中使用合適的特征變換對深度學習的意義

    ? 作者:蘇勇Andrew 使用神經(jīng)網(wǎng)絡(luò)實現(xiàn)機器學習,網(wǎng)絡(luò)的每個層都將對輸入的數(shù)據(jù)做一次抽象,多層神經(jīng)網(wǎng)絡(luò)構(gòu)成深度學習框架,可以深度理解數(shù)
    的頭像 發(fā)表于 04-02 18:21 ?1522次閱讀