中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

pytorch 可視化feature map的示例代碼

發布時間:2020-09-20 00:15:36 來源:腳本之家 閱讀:384 作者:牛丸4 欄目:開發技術

之前做的一些項目中涉及到feature map 可視化的問題,一個層中feature map的數量往往就是當前層out_channels的值,我們可以通過以下代碼可視化自己網絡中某層的feature map,個人感覺可視化feature map對調參還是很有用的。

不多說了,直接看代碼:

import torch
from torch.autograd import Variable
import torch.nn as nn
import pickle

from sys import path
path.append('/residual model path')
import residual_model
from residual_model import Residual_Model

model = Residual_Model()
model.load_state_dict(torch.load('./model.pkl'))



class myNet(nn.Module):
  def __init__(self,pretrained_model,layers):
    super(myNet,self).__init__()
    self.net1 = nn.Sequential(*list(pretrained_model.children())[:layers[0]])
    self.net2 = nn.Sequential(*list(pretrained_model.children())[:layers[1]])
    self.net3 = nn.Sequential(*list(pretrained_model.children())[:layers[2]])

  def forward(self,x):
    out1 = self.net1(x)
    out2 = self.net(out1)
    out3 = self.net(out2)
    return out1,out2,out3

def get_features(pretrained_model, x, layers = [3, 4, 9]): ## get_features 其實很簡單
'''
1.首先import model 
2.將weights load 進model
3.熟悉model的每一層的位置,提前知道要輸出feature map的網絡層是處于網絡的那一層
4.直接將test_x輸入網絡,*list(model.chidren())是用來提取網絡的每一層的結構的。net1 = nn.Sequential(*list(pretrained_model.children())[:layers[0]]) ,就是第三層前的所有層。

'''
  net1 = nn.Sequential(*list(pretrained_model.children())[:layers[0]]) 
#  print net1 
  out1 = net1(x) 

  net2 = nn.Sequential(*list(pretrained_model.children())[layers[0]:layers[1]]) 
#  print net2 
  out2 = net2(out1) 

  #net3 = nn.Sequential(*list(pretrained_model.children())[layers[1]:layers[2]]) 
  #out3 = net3(out2) 

  return out1, out2
with open('test.pickle','rb') as f:
  data = pickle.load(f)
x = data['test_mains'][0]
x = Variable(torch.from_numpy(x)).view(1,1,128,1) ## test_x必須為Varibable
#x = Variable(torch.randn(1,1,128,1))
if torch.cuda.is_available():
  x = x.cuda() # 如果模型的訓練是用cuda加速的話,輸入的變量也必須是cuda加速的,兩個必須是對應的,網絡的參數weight都是用cuda加速的,不然會報錯
  model = model.cuda()
output1,output2 = get_features(model,x)## model是訓練好的model,前面已經import 進來了Residual model
print('output1.shape:',output1.shape)
print('output2.shape:',output2.shape)
#print('output3.shape:',output3.shape)
output_1 = torch.squeeze(output2,dim = 0)
output_1_arr = output_1.data.cpu().numpy() # 得到的cuda加速的輸出不能直接轉變成numpy格式的,當時根據報錯的信息首先將變量轉換為cpu的,然后轉換為numpy的格式
output_1_arr = output_1_arr.reshape([output_1_arr.shape[0],output_1_arr.shape[1]])

以上這篇pytorch 可視化feature map的示例代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平舆县| 松桃| 岳阳市| 图片| 鄯善县| 平舆县| 乳山市| 六安市| 东乌珠穆沁旗| 连城县| 山西省| 壤塘县| 龙山县| 即墨市| 定结县| 新竹市| 宁国市| 新干县| 芦山县| 禄丰县| 晋宁县| 嘉义市| 石林| 太和县| 武陟县| 阿拉善右旗| 阜新市| 乡城县| 和林格尔县| 枞阳县| 垦利县| 玉林市| 新民市| 深州市| 连南| 乌拉特中旗| 郑州市| 奉新县| 南涧| 涟水县| 保德县|