时间:2021-05-22
之前做的一些项目中涉及到feature map 可视化的问题,一个层中feature map的数量往往就是当前层out_channels的值,我们可以通过以下代码可视化自己网络中某层的feature map,个人感觉可视化feature map对调参还是很有用的。
不多说了,直接看代码:
import torchfrom torch.autograd import Variableimport torch.nn as nnimport picklefrom sys import pathpath.append('/residual model path')import residual_modelfrom residual_model import Residual_Modelmodel = 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,out3def get_features(pretrained_model, x, layers = [3, 4, 9]): ## get_features 其实很简单'''1.首先import model 2.将weights load 进model3.熟悉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, out2with 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 modelprint('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的示例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
如何将pytorch中mnist数据集的图像可视化及保存导出一些库importtorchimporttorchvisionimporttorch.utils.d
刚入pytorch的坑,代码还没看太懂。之前用keras用习惯了,第一次使用pytorch还有些不适应,希望广大老司机多多指教。首先说说,我们如何可视化模型。在
可视化编辑模式,通过可视化就可以快速修改页面,实时在线编辑效果。可视化建站系统简单来说就是能看得见的操作建站模式,不需要技术;不需要代码;不需要专业人员,操作模
可视化编辑模式,通过可视化就可以快速修改页面,实时在线编辑效果。可视化建站系统简单来说就是能看得见的操作建站模式,不需要技术;不需要代码;不需要专业人员,操作模
基于python代码的3D地图可视化,供大家参考,具体内容如下介绍使用Python对地图进行3D可视化。以地图为地图,可以在三维空间对轨迹、点进行可视化。库我们