您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關如何使用pytorchviz和Netron可視化pytorch網絡結構,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
pip install graphviz
pip install tochviz (或pip install git+https://github.com/szagoruyko/pytorchviz)
Graphviz 是 AT&T 開發的一款開源的圖形可視化軟件,可以根據dot腳本語言中繪制的無向圖(顯示了對象間最簡單的關系)畫出直觀的樹形圖。
Graphviz在Windows中的安裝需要下載Release包,并配置環境變量,否則會報錯:
graphviz.backend.ExecutableNotFound: failed to execute [‘dot’, ‘-Tpng’, ‘-O’, ‘tmp’], make sure the Graphviz executables are on your systems’ PATH
Graphviz下載地址 https://graphviz.gitlab.io/_pages/Download/Download_windows.html
下載之后解壓出來是一個“release”文件夾,把“release\bin”目錄添加到系統環境變量,之后在終端中輸入“dot -V”,顯示以下信息表示Graphviz配置成功:
# Created by 牧野 CSDN
import torch
from torch import nn
from torchviz import make_dot, make_dot_from_trace
model = nn.Sequential()
model.add_module('W0', nn.Linear(8, 16))
model.add_module('tanh', nn.Tanh())
model.add_module('W1', nn.Linear(16, 1))
x = torch.randn(1,8)
vis_graph = make_dot(model(x), params=dict(model.named_parameters()))
vis_graph.view() # 會在當前目錄下保存一個“Digraph.gv.pdf”文件,并在默認瀏覽器中打開
with torch.onnx.set_training(model, False):
trace, _ = torch.jit.get_trace_graph(model, args=(x,))
make_dot_from_trace(trace)
調用“make_dot”方法創建一個dot對象,使用“view”方法顯示出來。
pytorch2.2和1.3版本中使用“torch.jit.get_trace_graph”可能會報錯,1.1版本ok。
AttributeError: 'torch._C.Value' object has no attribute 'uniqueName'
可視化結果:
Netron開源地址: https://github.com/lutzroeder/Netron
Netron的開發者是Lutz Roeder,一位來自微軟Visual Studio團隊的帥哥:
Netron是一款支持離線查看“各種”神經網絡框架的模型可視化神器,其中的“各種”包括:
ONNX (.onnx, .pb, .pbtxt)
Keras (.h6, .keras)
Core ML (.mlmodel)
Caffe (.caffemodel, .prototxt)
Caffe2 (predict_net.pb, predict_net.pbtxt)
MXNet (.model, -symbol.json)
NCNN (.param)
TensorFlow Lite (.tflite)
TorchScript (.pt, .pth)
PyTorch (.pt, .pth)
Torch (.t7)
Arm NN (.armnn)
BigDL (.bigdl, .model)
Chainer, (.npz, .h6)
CNTK (.model, .cntk)
Deeplearning4j (.zip)
Darknet (.cfg)
ML.NET (.zip)
MNN (.mnn)
OpenVINO (.xml)
PaddlePaddle (.zip, __model__)
scikit-learn (.pkl)
TensorFlow.js (model.json, .pb)
TensorFlow (.pb, .meta, .pbtxt)
嗯,夠多了。
Netron使用很簡單,作者提供了各個平臺的安裝包,安裝之后打開,把保存的模型文件拖入就可以了。
還以上邊的模型為例,先把pytorch模型保存出來:
import torch
from torch import nn
from torchviz import make_dot, make_dot_from_trace
model = nn.Sequential()
model.add_module('W0', nn.Linear(8, 16))
model.add_module('tanh', nn.Tanh())
model.add_module('W1', nn.Linear(16, 1))
torch.save(model, 'model.pth') # 保存模型
之后用Netron打開保存的“model.pth”:
網絡結構很清晰,一目了然,右側還能顯示操作的進一步信息。
看完上述內容,你們對如何使用pytorchviz和Netron可視化pytorch網絡結構有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。