摘要:圖神經(jīng)網(wǎng)絡(luò)是近年發(fā)展起來的一個很有前景的深度學(xué)習(xí)方向,也是一種強大的圖點云和流形表示學(xué)習(xí)方法。地址基于的幾何深度學(xué)習(xí)擴展庫是一個基于的幾何深度學(xué)習(xí)擴展庫,用于不規(guī)則結(jié)構(gòu)輸入數(shù)據(jù),例如圖點云和流形。與相比,訓(xùn)練模型的速度快了倍。
過去十年來,深度學(xué)習(xí)方法(例如卷積神經(jīng)網(wǎng)絡(luò)和遞歸神經(jīng)網(wǎng)絡(luò))在許多領(lǐng)域取得了前所未有的成就,例如計算機視覺和語音識別。
研究者主要將深度學(xué)習(xí)方法應(yīng)用于歐氏結(jié)構(gòu)數(shù)據(jù) (Euclidean domains),但在許多重要的應(yīng)用領(lǐng)域,如生物學(xué)、物理學(xué)、網(wǎng)絡(luò)科學(xué)、推薦系統(tǒng)和計算機圖形學(xué),可能不得不處理非歐式結(jié)構(gòu)的數(shù)據(jù),比如圖和流形。
直到最近,深度學(xué)習(xí)在這些特定領(lǐng)域的采用一直很滯后,主要是因為數(shù)據(jù)的非歐氏結(jié)構(gòu)性質(zhì)使得基本操作(例如卷積)的定義相當困難。在這個意義上,幾何深度學(xué)習(xí)將深度學(xué)習(xí)技術(shù)擴展到了圖/流形結(jié)構(gòu)數(shù)據(jù)。
圖神經(jīng)網(wǎng)絡(luò) (GNN)是近年發(fā)展起來的一個很有前景的深度學(xué)習(xí)方向,也是一種強大的圖、點云和流形表示學(xué)習(xí)方法。
然而,實現(xiàn) GNN 具有挑戰(zhàn)性,因為需要在高度稀疏且不規(guī)則、不同大小的數(shù)據(jù)上實現(xiàn)高 GPU 吞吐量。
近日,德國多特蒙德工業(yè)大學(xué)的研究者兩位 Matthias Fey 和 Jan E. Lenssen,提出了一個基于 PyTorch 的幾何深度學(xué)習(xí)擴展庫 PyTorch Geometric (PyG),為 GNN 的研究和應(yīng)用再添利器。
論文:
https://arxiv.org/pdf/1903.02428.pdf
Yann Lecun 也熱情推薦了這個工作,稱贊它是一個快速、美觀的 PyTorch 庫,用于幾何深度學(xué)習(xí) (圖和其他不規(guī)則結(jié)構(gòu)的神經(jīng)網(wǎng)絡(luò))。
作者聲稱,PyG 甚至比幾個月前 NYU、AWS 聯(lián)合開發(fā)的圖神經(jīng)網(wǎng)絡(luò)庫 DGL(Deep Graph Library) 快了 15 倍!
作者在論文中寫道:“這是一個 PyTorch 的幾何深度學(xué)習(xí)擴展庫,它利用專用的 CUDA 內(nèi)核實現(xiàn)了高性能。它遵循一個簡單的消息傳遞 API,將最近提出的大多數(shù)卷積和池化層捆綁到一個統(tǒng)一的框架中。所有實現(xiàn)的方法都支持 CPU 和 GPU 計算,并遵循一個不可變的數(shù)據(jù)流范式,該范式支持圖結(jié)構(gòu)隨時間的動態(tài)變化?!?/p>
PyG 已經(jīng)在 MIT 許可下發(fā)布,可以在 GitHub 上獲取。里面有完整的文檔說明,并提供了作為起點的教程和示例。
地址:
https://github.com/rusty1s/pytorch_geometric
PyTorch Geometry:基于 PyTorch 的幾何深度學(xué)習(xí)擴展庫
PyTorch Geometry 是一個基于 PyTorch 的幾何深度學(xué)習(xí)擴展庫,用于不規(guī)則結(jié)構(gòu)輸入數(shù)據(jù),例如圖 (graphs)、點云 (point clouds) 和流形 (manifolds)。
PyTorch Geometry 包含了各種針對圖形和其他不規(guī)則結(jié)構(gòu)的深度學(xué)習(xí)方法,也稱為幾何深度學(xué)習(xí),來自于許多已發(fā)表的論文。
此外,它還包含一個易于使用的 mini-batch 加載器、多 GPU 支持、大量通用基準數(shù)據(jù)集和有用的轉(zhuǎn)換,既可以學(xué)習(xí)任意圖形,也可以學(xué)習(xí) 3D 網(wǎng)格或點云。
所有面向用戶的 API,據(jù)加載例程、多 GPU 支持、數(shù)據(jù)增強或模型實例化都很大程度上受到 PyTorch 的啟發(fā),以便使它們盡可能保持熟悉。
Neighborhood Aggregation:將卷積算子推廣到不規(guī)則域通常表示為一個鄰域聚合(neighborhood aggregation),或 message passing scheme (Gilmer et al., 2017)。
圖 1
幾乎所有最近提出的鄰域聚合函數(shù)可以利用這個接口,已經(jīng)集成到 PyG 的方法包括 (但不限于):
對于任意圖形學(xué)習(xí),我們已經(jīng)實現(xiàn)了:
GCN (Kipf & Welling, 2017) 和它的簡化版本 SGC (Wu et al., 2019)
spectral chebyshev 和 ARMA filter convolutionss (Defferrard et al., 2016; Bianchi et al., 2019)
GraphSAGE (Hamilton et al., 2017)
attention-based operators GAT (Veli?kovi? et al., 2018) 及 AGNN (Thekumparampil et al., 2018),
Graph Isomorphism Network (GIN) from Xu et al. (2019)
Approximate Personalized Propagation of Neural Predictions (APPNP) operator (Klicpera et al., 2019)
對于學(xué)習(xí)具有多維邊緣特征的點云,流形和圖,我們提供了:
Schlichtkrull et al. (2018) 的 relational GCN operator
PointNet++ (Qi et al., 2017)
PointCNN (Li et al., 2018)
kernel-based methods MPNN (Gilmer et al., 2017),
MoNet (Monti et al., 2017)
SplineCNN (Fey et al., 2018)
以及邊緣卷積算子 EdgeCNN (Wang et al., 2018b).
實驗評估
我們通過對同類評估場景進行綜合比較研究,評估了利用 PyG 所實現(xiàn)方法的正確性。所有使用過的數(shù)據(jù)集的描述和統(tǒng)計可以在論文附錄中找到。
對于所有的實驗,我們都盡可能地遵循各自原始論文的超參數(shù)設(shè)置,GitHub 存儲庫中提供了復(fù)制所有實驗的代碼。
表 2:圖分類的結(jié)果
表 3:點云分類的結(jié)果
我們對多個數(shù)據(jù)模型對進行了多次實驗,并報告了在單個 NVIDIA GTX 1080 Ti 上獲得的整個訓(xùn)練過程的運行情況 (表 4)。與 Deep Graph Library (DGL)(Wang et al., 2018a) 相比,PyG 訓(xùn)練模型的速度快了 15 倍。
表 4:訓(xùn)練 runtime 比較
安裝、教程&示例
PyTorch Geometric 使實現(xiàn)圖卷積網(wǎng)絡(luò)變得非常容易 (請參閱 GitHub 上的教程)。
例如,這就是實現(xiàn)一個邊緣卷積層 (edge convolution layer) 所需的全部代碼:
import torch
from torch.nn import Sequential as Seq, Linear as Lin, ReLU
from torch_geometric.nn import MessagePassing
class EdgeConv(MessagePassing):
? ? def __init__(self, F_in, F_out):
? ? ? ? super(EdgeConv, self).__init__()
? ? ? ? self.mlp = Seq(Lin(2 * F_in, F_out), ReLU(), Lin(F_out, F_out))
? ? def forward(self, x, edge_index):
? ? ? ? # x has shape [N, F_in]
? ? ? ? # edge_index has shape [2, E]
? ? ? ? return self.propagate(aggr="max", edge_index=edge_index, x=x) ?# shape [N, F_out]
? ? def message(self, x_i, x_j):
? ? ? ? # x_i has shape [E, F_in]
? ? ? ? # x_j has shape [E, F_in]
? ? ? ? edge_features = torch.cat([x_i, x_j - x_i], dim=1) ?# shape [E, 2 * F_in]
? ? ? ? return self.mlp(edge_features) ?# shape [E, F_out]
此外,與其他深度圖神經(jīng)網(wǎng)絡(luò)庫相比,PyTorch Geometric 的速度更快:
表:在一塊 NVIDIA GTX 1080Ti 上的訓(xùn)練 runtime
安裝
確保至少安裝了 PyTorch 1.0.0,并驗證 cuda/bin 和 cuda/include 分別位于 $PATH 和$cpathrespecific,例如:
$ python -c "import torch; print(torch.__version__)"
>>> 1.0.0
$ echo $PATH
>>> /usr/local/cuda/bin:...
$ echo $CPATH
>>> /usr/local/cuda/include:...
然后運行:
$ pip install --upgrade torch-scatter
$ pip install --upgrade torch-sparse
$ pip install --upgrade torch-cluster
$ pip install --upgrade torch-spline-conv (optional)
$ pip install torch-geometric
運行示例
cd examples
python cora.py
paper:
https://arxiv.org/pdf/1903.02428.pdf
GitHub:
https://github.com/rusty1s/pytorch_geometric
聲明:本文版權(quán)歸原作者所有,文章收集于網(wǎng)絡(luò),為傳播信息而發(fā),如有侵權(quán),請聯(lián)系小編及時處理,謝謝!歡迎加入本站公開興趣群商業(yè)智能與數(shù)據(jù)分析群
興趣范圍包括各種讓數(shù)據(jù)產(chǎn)生價值的辦法,實際應(yīng)用案例分享與討論,分析工具,ETL工具,數(shù)據(jù)倉庫,數(shù)據(jù)挖掘工具,報表系統(tǒng)等全方位知識
QQ群:81035754
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/4874.html
摘要:截止到今天,已公開發(fā)行一周年。一年以來,社區(qū)中的用戶不斷做出貢獻和優(yōu)化,在此深表感謝。所以與衡量它的指標包括在機器學(xué)習(xí)研究論文中的使用。來自香港科技大學(xué)的在上推出了面向普通觀眾的在線課程。 Yann LeCun Twitter截止到今天,PyTorch 已公開發(fā)行一周年。一年以來,我們致力于打造一個靈活的深度學(xué)習(xí)研究平臺。一年以來,PyTorch 社區(qū)中的用戶不斷做出貢獻和優(yōu)化,在此深表感謝...
摘要:我們對種用于數(shù)據(jù)科學(xué)的開源深度學(xué)習(xí)庫作了排名。于年月發(fā)布了第名,已經(jīng)躋身于深度學(xué)習(xí)庫的上半部分。是最流行的深度學(xué)習(xí)前端第位是排名較高的非框架庫。頗受對數(shù)據(jù)集使用深度學(xué)習(xí)的數(shù)據(jù)科學(xué)家的青睞。深度學(xué)習(xí)庫的完整列表來自幾個來源。 我們對23種用于數(shù)據(jù)科學(xué)的開源深度學(xué)習(xí)庫作了排名。這番排名基于權(quán)重一樣大小的三個指標:Github上的活動、Stack Overflow上的活動以及谷歌搜索結(jié)果。排名結(jié)果...
摘要:深度學(xué)習(xí)是一個對算力要求很高的領(lǐng)域。這一早期優(yōu)勢與英偉達強大的社區(qū)支持相結(jié)合,迅速增加了社區(qū)的規(guī)模。對他們的深度學(xué)習(xí)軟件投入很少,因此不能指望英偉達和之間的軟件差距將在未來縮小。 深度學(xué)習(xí)是一個對算力要求很高的領(lǐng)域。GPU的選擇將從根本上決定你的深度學(xué)習(xí)體驗。一個好的GPU可以讓你快速獲得實踐經(jīng)驗,而這些經(jīng)驗是正是建立專業(yè)知識的關(guān)鍵。如果沒有這種快速的反饋,你會花費過多時間,從錯誤中吸取教訓(xùn)...
摘要:幸運的是,這些正是深度學(xué)習(xí)所需的計算類型。幾乎可以肯定,英偉達是目前執(zhí)行深度學(xué)習(xí)任務(wù)較好的選擇。今年夏天,發(fā)布了平臺提供深度學(xué)習(xí)支持。該工具適用于主流深度學(xué)習(xí)庫如和。因為的簡潔和強大的軟件包擴展體系,它目前是深度學(xué)習(xí)中最常見的語言。 深度學(xué)習(xí)初學(xué)者經(jīng)常會問到這些問題:開發(fā)深度學(xué)習(xí)系統(tǒng),我們需要什么樣的計算機?為什么絕大多數(shù)人會推薦英偉達 GPU?對于初學(xué)者而言哪種深度學(xué)習(xí)框架是較好的?如何將...
摘要:在本節(jié)中,我們將看到一些最流行和最常用的庫,用于機器學(xué)習(xí)和深度學(xué)習(xí)是用于數(shù)據(jù)挖掘,分析和機器學(xué)習(xí)的最流行的庫。愿碼提示網(wǎng)址是一個基于的框架,用于使用多個或進行有效的機器學(xué)習(xí)和深度學(xué)習(xí)。 showImg(https://segmentfault.com/img/remote/1460000018961827?w=999&h=562); 來源 | 愿碼(ChainDesk.CN)內(nèi)容編輯...
閱讀 2036·2021-11-08 13:14
閱讀 2944·2021-10-18 13:34
閱讀 2032·2021-09-23 11:21
閱讀 3595·2019-08-30 15:54
閱讀 1763·2019-08-30 15:54
閱讀 2933·2019-08-29 15:33
閱讀 2588·2019-08-29 14:01
閱讀 1949·2019-08-29 13:52