[pytorch] Pytorch入門

Pytorch入門

簡單容易上手,感覺比keras好理解多了,和mxnet很像(似乎mxnet有點借鑒pytorch),記一記。

直接從例子開始學,基礎知識咱已經看了很多論文了。。。

import torch
import torch.nn as nn
import torch.nn.functional as F
# Linear 層 就是全連接層
class Net(nn.Module): # 繼承nn.Module,只用定義forward,反向傳播會自動生成def __init__(self): # 初始化方法,這里的初始化是為了forward函數可以直接調過來super(Net,self).__init__() # 調用父類初始化方法# (input_channel,output_channel,kernel_size)self.conv1 = nn.Conv2d(1,6,5) # 第一層卷積self.conv2 = nn.Conv2d(6,16,5)# 第二層卷積self.fc1 = nn.Linear(16*5*5,120) # 這里16*5*5是前向算的self.fc2 = nn.Linear(120,84) # 第二層全連接self.fc3 = nn.Linear(84,10) # 第三層全連接->分類def forward(self,x):x = F.max_pool2d(F.relu(self.conv1(x)),(2,2)) # 卷積一次激活一次然后2*2池化一次x = F.max_pool2d(F.relu(self.conv2(x)),2) # (2,2)與直接寫 2 等價x = x.view(-1,self.num_flatten_features(x)) # 將x展開成向量x = F.relu(self.fc1(x)) # 全連接 + 激活x = F.relu(self.fc2(x)) # 全連接+ 激活x = self.fc3(x) # 最后再全連接return xdef num_flatten_features(self,x):size = x.size()[1:] # 除了batch_size以外的維度,(batch_size,channel,h,w)num_features = 1for s in size:num_features*=sreturn num_features
# ok,模型定義完畢。
net = Net()
print(net)
'''
Net((conv1): Conv2d(1, 6, kernel_size=(5, 5), stride=(1, 1))(conv2): Conv2d(6, 16, kernel_size=(5, 5), stride=(1, 1))(fc1): Linear(in_features=400, out_features=120, bias=True)(fc2): Linear(in_features=120, out_features=84, bias=True)(fc3): Linear(in_features=84, out_features=10, bias=True)
)
'''
params = list(net.parameters())
print(len(params))
print(params[0].size())
'''
10
torch.Size([6, 1, 5, 5])
'''
inpt = torch.randn(1,1,32,32)
out = net(inpt)
print(out)
'''
tensor([[-0.0265, -0.1246, -0.0796,  0.1028, -0.0595,  0.0383,  0.0038, -0.0019,0.1181,  0.1373]], grad_fn=<AddmmBackward>)
'''
target = torch.randn(10)
criterion = nn.MSELoss()
loss = criterion(out,target)
print(loss)
'''
tensor(0.5742, grad_fn=<MseLossBackward>)
'''
net.zero_grad()# 梯度歸零
print(net.conv1.bias.grad)
loss.backward()
print(net.conv1.bias.grad)
'''
None
tensor([-0.0039,  0.0052,  0.0034, -0.0002,  0.0018,  0.0096])
'''
import torch.optim as optim
optimizer = optim.SGD(net.parameters(),lr = 0.01)
optimizer.zero_grad()
output = net(inpt)
loss = criterion(output,target)
loss.backward()
optimizer.step()
# 一個step完成,多個step就寫在循環里

pytorch簡直太好理解了。。繼續蓄力!!

轉載于:https://www.cnblogs.com/aoru45/p/10623046.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/394487.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/394487.shtml
英文地址,請注明出處:http://en.pswp.cn/news/394487.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

無線服務器密碼讓別人改了,wifi密碼被改了怎么辦_wifi密碼被別人改了怎么辦?-192路由網...

wifi密碼被別人改了怎么辦&#xff1f;wifi密碼之所以被別人修改&#xff0c;是因為其他人知道了你路由器的登錄密碼。所以&#xff0c;如果發現自己wifi密碼被別人修改了&#xff0c;應該立刻登錄到路由器設置界面&#xff0c;修改路由器登錄密碼、修改wifi密碼、并調整wifi加…

[archlinux][hardware] 查看SSD的使用壽命

因為最近把16GB的SSD做成了HDD的cache&#xff0c;所以比較關系壽命問題。 使用smartctl工具。 參考&#xff1a;https://www.v2ex.com/t/261373 linux 下面只有 smartmontools 這一個工具&#xff0c;而且只對像三喪和 intel 這樣的大廠支持良好&#xff0c;其余的廠家文檔不全…

leetcode174. 地下城游戲(動態規劃)

一些惡魔抓住了公主&#xff08;P&#xff09;并將她關在了地下城的右下角。地下城是由 M x N 個房間組成的二維網格。我們英勇的騎士&#xff08;K&#xff09;最初被安置在左上角的房間里&#xff0c;他必須穿過地下城并通過對抗惡魔來拯救公主。 騎士的初始健康點數為一個正…

如何設置Windows版Go —快速簡便的指南

by Linda Gregier琳達格雷格(Linda Gregier) Another great language to add to your full-stack developer tool belt is the simple and productive general-purpose programming language of Go.添加到您的全棧開發人員工具帶中的另一種很棒的語言是Go的簡單而高效的通用編…

python計算現場得分_淺談用 Python 計算文本 BLEU 分數

淺談用 Python 計算文本 BLEU 分數BLEU, 全稱為 Bilingual Evaluation Understudy(雙語評估替換), 是一個比較候選文本翻譯與其他一個或多個參考翻譯的評價分數盡管 BLEU 一開始是為翻譯工作而開發, 但它也可以被用于評估文本的質量, 這種文本是為一套自然語言處理任務而生成的…

Unity的幾個特殊文件夾

1.以.開頭的文件夾會被unity忽略&#xff0c;資源不會被導入&#xff0c;腳本不會編譯。 2.Standard Assets和Pro Standard Assets&#xff1a;在這個文件夾中的腳本最先被編譯。 3.Editor&#xff1a;以Editor命名的文件夾允許其中的腳本訪問Unity Editor的API。如果腳本中使用…

怎么上傳文件到kk服務器,VS Code 關于SFTP上傳文件到多服務器的配置

工欲善其事&#xff0c;必先利其器&#xff01;剛學前端的時候一直用的DW來編寫代碼&#xff0c;其功能非常強大&#xff0c;但在Linux下不能用&#xff0c;所以就轉VS Code了。但是剛開始使用VS Code的時候&#xff0c;很多DW上的功能需要自己安裝擴展&#xff0c;并配置才可以…

CentOS7 Firewall NAT 及端口映射

本節介紹用CentOS7的Firewalll來做NAT以及端口映射實驗拓撲:因為我的環境里CentOS7上有KVM虛擬機需要共享網卡上網&#xff0c;所以我把網卡都添加到了橋里面&#xff0c;當然這里也可以不用橋&#xff0c;直接用物理網口&#xff1b;用nmcli創建橋&#xff0c;并添加網口到橋&…

JVM源碼---教你傻瓜式編譯openjdk7(JAVA虛擬機愛好者必看)

LZ經過一個星期斷斷續續的研究&#xff0c;終于成功的搞定了JDK的成功編譯與調試。盡管網絡上的教程也有不少&#xff0c;包括源碼中也有自帶的編譯步驟說明&#xff0c;但真正自己動手的話&#xff0c;還是會遇到不少意料之外的錯誤。 為了方便各位猿友編譯&#xff0c;LZ臨時…

leetcode1105. 填充書架(動態規劃)

附近的家居城促銷&#xff0c;你買回了一直心儀的可調節書架&#xff0c;打算把自己的書都整理到新的書架上。 你把要擺放的書 books 都整理好&#xff0c;疊成一摞&#xff1a;從上往下&#xff0c;第 i 本書的厚度為 books[i][0]&#xff0c;高度為 books[i][1]。 按順序 將…

python 微信bot_使用Tweepy在Python中創建Twitter Bot

python 微信botby Lucas Kohorst盧卡斯科斯特(Lucas Kohorst) 使用Tweepy在Python中創建Twitter Bot (Create a Twitter Bot in Python Using Tweepy) With about 15% of Twitter being composed of bots, I wanted to try my hand at it. I googled how to create a Twitter …

第五周學習進度

1.學習所花時間&#xff1a;單純Java是12個小時左右&#xff1b; 2.代碼量&#xff1a;大約300行&#xff1b; 3.博客量&#xff1a;1篇。 4.了解到的知識點&#xff1a;數據庫語言的增刪改查 5.下周計劃除了掌握課上知識外&#xff0c;還要再復習之前的關于Java的相關知識點。…

另一個域的cookie_一定要知道的第一方Cookie和第三方Cookie

Cookie 是您訪問過的網站創建的文件&#xff0c;用于存儲瀏覽信息&#xff0c;例如您的網站偏好設置或個人資料信息。共有兩種類型的 Cookie&#xff1a;第一方 Cookie 是由地址欄中列出的網站域設置的 Cookie&#xff0c;而第三方 Cookie 來自在網頁上嵌入廣告或圖片等項的其他…

蘋果手機怎么連接不了無線網絡連接服務器,蘋果手機連接wifi顯示無互聯網連接怎么辦?...

在開始對網絡操作以后&#xff0c;也可嘗試著把 iPhone 重新啟動一下&#xff0c;按下 iPhone 電源鍵不放&#xff0c;直到出現關機選項并滑動關機&#xff0c;最后再開機。在 iPhone 的無線局域網列表中&#xff0c;當前連接的這個無線網絡顯示“無互聯網連接”。此時可以通過…

中小企業大數據應用之道:思維在于借力

要想大數據落地&#xff0c;特別是中小企業&#xff0c;首先得有大數據思維&#xff0c;否則大數據的案例不能直接借鑒&#xff0c;自己摸索又怕不專業、坑太多。 何謂大數據思維&#xff0c;個人認為不是什么決策都參考數據&#xff0c;也不是什么問題都要足夠精準&#xff0c…

git學習心得之從遠程倉庫克隆

現在&#xff0c;遠程庫已經準備好了&#xff0c;下一步是用命令git clone克隆一個本地庫&#xff1a; $ git clone gitgithub.com:michaelliao/gitskills.git Cloning into gitskills... remote: Counting objects: 3, done. remote: Total 3 (delta 0), reused 0 (delta 0) R…

leetcode350. 兩個數組的交集 II(hashmap)

給定兩個數組&#xff0c;編寫一個函數來計算它們的交集。 將長度小的數組放入hashmap&#xff0c;記錄出現的次數&#xff0c;遍歷另一個數組&#xff0c;找出交集 class Solution {public int[] intersect(int[] nums1, int[] nums2) {ArrayList<Integer> resnew Arra…

如何使用Swift Playgrounds制作東西

by Harshita Arora通過Harshita Arora 如何使用Swift Playgrounds制作東西 (How to make something with Swift Playgrounds) Just a few days ago, I finished my WWDC 2018 scholarship submission. It was so much fun creating Alice in codeLand. This was my first year…

2018-2019 20165208 網絡對抗 Exp3 免殺原理與實踐

目錄 2018-2019 20165208 網絡對抗 Exp3 免殺原理與實踐實驗內容基礎問題回答實踐過程記錄任務一&#xff1a;正確使用免殺工具或技巧任務二&#xff1a;通過組合應用各種技術實現惡意代碼免殺任務三&#xff1a;用另一電腦實測&#xff0c;在殺軟開啟的情況下&#xff0c;可運…

k均值例子 數據挖掘_人工智能、數據挖掘、機器學習和深度學習的關系

一、人工智能人工智能是計算機科學的一個分支&#xff0c;它企圖了解智能的實質&#xff0c;并生產出一種新的能以人類智能相似的方式做出反應的智能機器。實際應用比如&#xff1a;機器視覺&#xff0c;指紋識別&#xff0c;人臉識別&#xff0c;視網膜識別&#xff0c;虹膜識…