mxnet下如何查看中间结果
https://blog.csdn.net/disen10/article/details/79376631
固定权重:https://www.cnblogs.com/chenyliang/p/6780019.html
固定权重:https://discuss.gluon.ai/t/topic/1164
查看权重
在训练过程中,有时候我们为了debug而需要查看中间某一步的权重信息,在mxnet中,我们可以很方便的调用get_params()方法来得到权重信息。
- '''
- 查看权重示例代码
- 转载时注明地址:http://blog.csdn.net/u010414386?viewmode=contents
- '''
- import mxnet as mx
- sym, arg_params, aux_params = mx.model.load_checkpoint('resnet-50',0)#载入模型
- mod = mx.mod.Module(symbol=sym,context=mx.gpu()) #创建Module
- mod.bind(for_training=False,data_shapes=[('data',(1,3,224,224))]) #绑定,此代码为预测代码,所以training参数设为False
- mod.set_params(arg_params,aux_params)
- import numpy as np
- import cv2
- def get_image(filename):
- img = cv2.imread(filename)
- img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)
- img = cv2.resize(img,(224,224))
- img = np.swapaxes(img,0,2)
- img = np.swapaxes(img,1,2)
- img = img[np.newaxis,:]
- return img
- from collections import namedtuple
- Batch = namedtuple('Batch',['data'])
- img = get_image('val_1000/0.jpg') #获取图片
- mod.forward(Batch([mx.nd.array(img)])) #预测结果
- ################################################
- #debug模式下,获取权重信息
- keys = mod.get_params()[0].keys() # 列出所有权重名称
- conv_w = mod.get_params()[0]['conv0_weight'] #获取想要查看的权重信息,如conv_weight
- print conv_w.asnumpy() #查看具体数值
- ################################################
- prob = mod.get_outputs()[0].asnumpy()
- y = np.argsort(np.squeeze(prob))[::-1]
- print('truth label %d; top-1 predict label %d' % (val_label[0], y[0]))
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
查看中间输出结果
由于mxnet的网络由symbol组成,而symbol又属于符号式编程,所以我们不能像上面查看权重一样直接查看,我们需要把我们想看的输出结果保存下来。
- '''
- 方法一
- 查看中间结果代码
- 转载时注明地址:http://blog.csdn.net/u010414386?viewmode=contents
- '''
- import mxnet as mx
- net = mx.symbol.Variable('data')
- fc1 = mx.symbol.FullyConnected(data=net, name='fc1', num_hidden=128)
- net = mx.symbol.Activation(data=fc1, name='relu1', act_type="relu")
- net = mx.symbol.FullyConnected(data=net, name='fc2', num_hidden=64)
- out = mx.symbol.SoftmaxOutput(data=net, name='softmax')
- # 通过把两个输出组成一个group来得到自己需要查看的中间层输出结果
- group = mx.symbol.Group([fc1, out])
- print group.list_outputs()
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- '''
- 方法二
- 有时候我们使用别人的模型,所以无法像方法一一样在定义模型的时候就确定需要查看的中间层输出结果,
- 这时候我们使用get_internals()方法来查找自己需要查看的中间层
- 转载时注明地址:http://blog.csdn.net/u010414386?viewmode=contents
- '''
- import mxnet as mx
- sym, arg_params, aux_params = mx.model.load_checkpoint('resnet-50',0)#载入模型
- ########################################################################
- args = sym.get_internals().list_outputs() #获得所有中间输出
- internals = model.symbol.get_internals()
- fc1 = internals['fc1_output']
- conv = internals['stage4_unit3_conv1_output']
- group = mx.symbol.Group([fc1, sym, conv]) #把需要输出的结果按group方式组合起来,这样就可以得到中间层的输出
- #########################################################################
- mod = mx.mod.Module(symbol=group,context=mx.gpu()) #创建Module
- mod.bind(for_training=False,data_shapes=[('data',(1,3,224,224))]) #绑定,此代码为预测代码,所以training参数设为False
- mod.set_params(arg_params,aux_params)
- import numpy as np
- import cv2
- def get_image(filename):
- img = cv2.imread(filename)
- img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)
- img = cv2.resize(img,(224,224))
- img = np.swapaxes(img,0,2)
- img = np.swapaxes(img,1,2)
- img = img[np.newaxis,:]
- return img
- from collections import namedtuple
- Batch = namedtuple('Batch',['data'])
- img = get_image('val_1000/0.jpg') #获取图片
- mod.forward(Batch([mx.nd.array(img)])) #预测结果
- prob = mod.get_outputs()[0].asnumpy()
- y = np.argsort(np.squeeze(prob))[::-1]
- print('truth label %d; top-1 predict label %d' % (val_label[0], y[0]))
mxnet下如何查看中间结果的更多相关文章
- Linux下如何查看版本信息
Linux下如何查看版本信息, 包括位数.版本信息以及CPU内核信息.CPU具体型号等等,整个CPU信息一目了然. 1.# uname -a (Linux查看版本当前操作系统内核信息) L ...
- Linux下怎么查看当前系统的版本
Linux下怎么查看当前系统的版本: uname -r 功能说明:uname用来获取电脑和操作系统的相关信息. 语 法:uname [-amnrsvpio][--help][--version] ...
- 在windows和linux下如何查看80端口占用情况?是被哪个进程占用?如何终止等
一.在windows下如何查看80端口占用情况?是被哪个进程占用?如何终止等 这里主要是用到windows下的DOS工具,点击"开始"--"运行",输入&quo ...
- 在linux下,查看一个运行中的程序, 占用了多少内存
1. 在linux下,查看一个运行中的程序, 占用了多少内存, 一般的命令有 (1). ps aux: 其中 VSZ(或VSS)列 表示,程序占用了多少虚拟内存. RSS列 表示, 程序占用了多少物 ...
- linux下如何查看mysql、apache是否安装,并卸载
--linux下如何查看mysql.apache是否安装,并卸载? http://blog.163.com/dengxiuhua126@126/blog/static/1186077720137311 ...
- Linux 下实时查看日志
Linux 下实时查看日志 cat /var/log/*.log 如果日志在更新,如何实时查看 tail -f /var/log/messages 还可以使用 watch -d -n 1 cat /v ...
- Linux下如何查看tomcat是否安装、启动、文件路径、进程ID
Linux下如何查看tomcat是否安装.启动.文件路径.进程ID 在Linux系统下,Tomcat使用命令的操作! 检测是否有安装了Tomcat: rpm -qa|grep tomcat 查看Tom ...
- Linux下内存查看命令
在Linux下面,我们常用top命令来查看系统进程,top也能显示系统内存.我们常用的Linux下查看内容的专用工具是free命令. Linux下内存查看命令free详解: 在Linux下查看内存我们 ...
- Linux之Ubuntu下如何查看已安装的软件/库文件【摘抄】
本文属于实用性质,且属于摘抄别处,出自:[Ubuntu 下如何查看已安装的软件](http://blog.csdn.net/m1205979825/article/details/40855583) ...
随机推荐
- jQuery-velocity.js 插件的简易使用
初识Velocity动画,感觉它并没有那么强大,但是渐渐感觉它的ui动画可以让我们简易的使用到我们的项目中. Velocity动画的简介: 下载地址:http://www.julian.com/res ...
- [LeetCode] 240. Search a 2D Matrix II_Medium tag: Binary Search
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...
- [LeetCode] 405. Convert a Number to Hexadecimal_Easy tag: Bit Manipulation
Given an integer, write an algorithm to convert it to hexadecimal. For negative integer, two’s compl ...
- SEO--多领域
1.社交媒体SEO优化,例如:视频,吸引流量 2.电商SEO,很多不是皇冠的商家也可以被搜索到 3.新媒体 微博 和 微信营销 手机端的SEO等.传统的SEO已经渐渐不具备竞争力 SEO盈利:网盟.广 ...
- 当我的url请求会变成jsp页面路径时的解决办法
@RequestMapping(value="shippingOrder") $.post("/ezsh/orderAd/shippingOrder",para ...
- C# Dapper 简单实例
/// <summary> /// 分页信息 /// </summary> public class PageInfo<T> { /// & ...
- mybatis3 前台传数组 的处理
/** * 分页按条件查询权限列表 * @param keywords * @return */ @RequestMapping(value = "/getByCondition2" ...
- mysql字符集问题,及排序规则
字符集问题: 基本概念 • 字符(Character)是指人类语言中最小的表义符号.例如’A'.’B'等:• 给定一系列字符,对每个字符赋予一个数值,用数值来代表对应的字符,这一数值就是字符的编码(E ...
- 《大话设计模式》c++实现 原型模式
意图:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 主要解决:在运行期建立和删除原型. 何时使用: 1.当一个系统应该独立于它的产品创建,构成和表示时. 2.当要实例化的类是在运行 ...
- 《Semantic Sentence Matching with Densely-connected Recurrent and Co-attentive Information》DRCN 句子匹配
模型结构 首先是模型图: 传统的注意力机制无法保存多层原始的特征,根据DenseNet的启发,作者将循环网络的隐层的输出与最后一层连接. 另外加入注意力机制,代替原来的卷积.由于最后的特征维度过大,加 ...