gdb nnet3-compute
gdb nnet3-compute测试命令
$ matrix-dim 'scp: head -n 1 data/test/feats.scp|'
~/kaldi/src/bin/matrix-dim 'scp: head -n 1 data/test/feats.scp|'
foo 20560 39
$ nnet3-compute --frame_subsampling-factor=3 exp/chain/tuning/tdnn_c/final.mdl 'scp:
head -n 1 data/test/feats.scp|' ark:-|matrix
-dim ark:-
foo 6854 1808
void DecodableNnetSimple::EnsureFrameIsComputed(int32 subsampled_frame)
gdb_cmd=$(mktemp XXXX.gdb)
cat <<EOF > $gdb_cmd
set pagination off
set logging redirect on
set logging overwrite on
set logging file ./nnet3-compute.log
set logging on
b kaldi::nnet3::DecodableNnetSimple::EnsureFrameIsComputed
commands
printf "subsampled_frame=%d", subsampled_frame
c
end
run
quit
EOF
gdb -x $gdb_cmd --args nnet3-compute --frame_subsampling-factor=3 exp/chain/tuning/tdnn_c/final.mdl 'scp: head -n 1 data/test/feats.scp|' ark:/dev/null
grep '^subsampled_frame' ./nnet3-compute.log
subsampled_frame=0
subsampled_frame=17
subsampled_frame=34
subsampled_frame=51
subsampled_frame=68[Thread 0x7fffe29ff700 (LWP 984) exited]
帧)的第一帧
且EnsureFrameIsComputed函数一次计算一个chunk
监视DoNnetComputation函数的参数
gdb_cmd=$(mktemp XXXX.gdb)
cat <<EOF > $gdb_cmd
set pagination off
set logging redirect on
set logging overwrite on
set logging file ./nnet3-compute.log
set logging on
b kaldi::nnet3::DecodableNnetSimple::DoNnetComputation
commands
printf "input_t_start=%d,output_t_start=%d", input_t_start, output_t_start
c
end
run
quit
EOF
gdb -x $gdb_cmd --args nnet3-compute --frame_subsampling-factor=3 exp/chain/tuning/tdnn_c/final.mdl 'scp: head -n 1 data/test/feats.scp|' ark:/dev/null
grep '^input_t_start' ./nnet3-compute.log
input_t_start=-23,output_t_start=0
input_t_start=28,output_t_start=51
input_t_start=79,output_t_start=102
input_t_start=130,output_t_start=153
...
input_t_start=20428,output_t_start=20451
input_t_start=20479,output_t_start=20502
input_t_start=20530,output_t_start=20553[Thread 0x7fffe29ff700 (LWP 7120) exited]
这说明,DoNnetComputation函数的:
- 参数input_t_start表示当前chunk输出第一帧所依赖的输入帧中第一帧的索引(即当前帧的索引
−
左上文); - 参数output_t_start表示当前chunk输出第一帧所对应的输入帧的索引;
监视kaldi::nnet3::NnetComputer::ExecuteCommand中NnetComputation::Command &c.command_type
gdb_cmd=$(mktemp XXXX.gdb)
cat <<EOF > $gdb_cmd
set pagination off
set logging redirect on
set logging overwrite on
set logging file ./nnet3-compute.log
set logging on
b kaldi::nnet3::NnetComputer::ExecuteCommand
commands
p computation_.commands[program_counter_].command_type
c
end
run
quit
EOF
gdb -x $gdb_cmd --args nnet3-compute --frame_subsampling-factor=3 exp/chain/tuning/tdnn_c/final.mdl 'scp: head -n 1 data/test/feats.scp|' ark:/dev/null
grep '^\$' ./nnet3-compute.log
command_typed的规律
$ sed -n '/^\$/s/.* //p' ./nnet3-compute.log | less
kaldi::nnet3::kNoOperationPermanent * 1
kaldi::nnet3::kAllocMatrix * 8
kaldi::nnet3::kCopyRows * 5
kaldi::nnet3::kDeallocMatrix * 8
kaldi::nnet3::kPropagate * 19
...
kaldi::nnet3::kNoOperationPermanent * 1
kaldi::nnet3::kAllocMatrix * 8
kaldi::nnet3::kCopyRows * 5
kaldi::nnet3::kDeallocMatrix * 8
kaldi::nnet3::kPropagate * 19
各个运算的次数
$ sed -n '/^\$/s/.* //p' ./nnet3-compute.log | perl -e 'my %hash;while (<>){chomp;$ha
sh{$_}+=1;}for $i (keys %hash){printf("%s %d\n", $i, $hash{$i})}'
kaldi::nnet3::kCopyRows 2020
kaldi::nnet3::kPropagate 7676
kaldi::nnet3::kDeallocMatrix 3234
kaldi::nnet3::kAllocMatrix 3234
kaldi::nnet3::kNoOperationPermanent 404
kaldi::nnet3::kMatrixCopy 3234
- kaldi::nnet3::kCopyRows
发生在以下组件结点中:
component-node name=tdnn1.affine component=tdnn1.affine input=Append(Offset(input, -2), Offset(input, -1), input, Offset(input, 1), Offset(input, 2)) input-dim=195 output-dim=256
行特性向量,符合"kaldi::nnet3::kCopyRows * 5"。
- kaldi::nnet3::kPropagate
帧。这可能与TDNN对左右上下文的依赖有关。
- kaldi::nnet3::kDeallocMatrix
在网络中进行每一个矩阵运算之后,都需要从内存中收回对应的矩阵空间
- kaldi::nnet3::kAllocMatrix
在网络中进行每一个矩阵运算(NaturalGradientAffineComponent、FixedAffineComponent等)之前,都需要从模型中将矩阵拷贝到内存中。
- kaldi::nnet3::kNoOperationPermanent
帧,默认chunk大小为50,由于frame_subsampling_factor=3,chunk大小变为其整数倍——51。这样,整条语句的chunk数为ceil(20560/51)=404。
这与"kaldi::nnet3::kNoOperationPermanent"的个数相匹配,这说明,每个chunk运行一次"kaldi::nnet3::kNoOperationPermanent"。
- kaldi::nnet3::kMatrixCopy
在网络中进行每一个矩阵运算(NaturalGradientAffineComponent、FixedAffineComponent等)之前,从预计算组件中将上一层的输出结果拷贝至当前组件中
gdb nnet3-compute的更多相关文章
- gdb 调试入门,大牛写的高质量指南
引用自:http://blog.jobbole.com/107759/ gdb 调试 ncurses 全过程: 发现网上的“gdb 示例”只有命令而没有对应的输出,我有点不满意.gdb 是 GNU 调 ...
- gdb 调试 ncurses 全过程:
转载地址: http://blog.jobbole.com/107759/ gdb 调试 ncurses 全过程: 发现网上的“gdb 示例”只有命令而没有对应的输出,我有点不满意.gdb 是 GNU ...
- Android gdb so
gdb debug an android application 1.gdb 要有gdbserver 一般模拟器默认装有gdbserver,如2.3.3的模拟器,看一下有没有: D:\Develope ...
- gdb help all 帮助信息
Command class: aliases ni -- Step one instruction rc -- Continue program being debugged but run it i ...
- linux应用调试技术之GDB和GDBServer
1.调试原理 GDB调试是应用程序在开发板上运行,然后在PC机上对开发板上得应用程序进行调试,PC机运行GDB,开发板上运行GDBServer.在应用程序调试的时候,pc机上的gdb向开发板上的GDB ...
- 新手如何在gdb中存活
网络上已经有很多gdb调试的文章了,为什么我还要写这篇文章呢,因为本文是写给gdb新手的,目的就是通过一个简单的例子来让新手很快上手.一旦上手入门了,其他的问题就可以自己去搜索搞定了.右边是gdb的L ...
- GDB 多线程调试:只停止断点的线程,其他线程任然执行; 或只运行某些线程 其他线程中断
多线程调试之痛 调试器(如VS2008和老版GDB)往往只支持all-stop模式,调试多线程程序时,如果某个线程断在一个断点上,你的调试器会让整个程序freeze,直到你continue这个线程,程 ...
- GDB调试命令
1.查看源码: list [函数名][行数] 2.暂停程序 (1)设置断点: a.break + [源代码行号][源代码函数名][内存地址] b.break ... if condition .. ...
- 关于gdb和shp的FID问题
gdb的FID从1开始,并且FID唯一,从数字化时开始,每个图形对应唯一的FID,删除图形亦删除对应的FID.FID可能出现中断的情况. shp的FID从0开始,并且永远连续.删除图形,则编号在其下面 ...
随机推荐
- Linux Mint chrome浏览器提示“需要安装adobe flash player”
出现这种情况,是因为系统没有安装flash 插件造成的,用以下的命令安装: sudo apt-get install adobe-flashplugin 安装完成后,重启浏览器. 如果chrome浏览 ...
- 【shell实例】定时21:00-21:05,循环调用DSQL脚本,其它时段自动退出
1.功能描述: 每日21:00定时调起test.sh,循环调起DSQL脚本test.dsql,直到21:05程序自动退出,捕获日志到相应log文件中. 2.日志文件: (1)日期.log文件中含Err ...
- storm ui 网页一直出现提示loading summary
在更换了一次storm的版本之后:访问 http://mini1:8080/index.html 来查看storm的运行情况,但是出现了网页一直出现提示loading summary,但是通过透明的弹 ...
- 多态练习题(通过UML建模语言来实现饲养员喂养动物)
项目需求如下图: package com.Summer_0428.cn; /** * @author Summer * 1.构建一个食物抽象类,Bone和Fish分别为其实现类,通过super传参. ...
- HTTP对静态资源的优化
HTTP的If-Modified-Since和Modified-Since标签 在第一次请求静态资源时响应头会携带一个Modified-Since标签,里面存放的是静态资源的最后修改时间,在之后对该静 ...
- pyecharts使用
安装 pyecharts 兼容 Python2 和 Python3.目前版本为 0.1.2 pip install pyecharts 入门 首先开始来绘制你的第一个图表 from pyecharts ...
- Photoshop快速给美女人像换头发
今天给大家带来的教程是应用PS来抠出人物图片的发丝和修改头发的颜色. OK开始今天的教程 1.将素材文件拖拽进PS,CTRL+J复制一层. 2.应用快速选择工具大致的将头发部分选区出来,不需要太过仔细 ...
- python操作Excel、openpyxl 之图表,折线图、饼图、柱状图等
一.准备 需要模块: from openpyxl.workbook import Workbook from openpyxl.chart import Series,LineChart, Refer ...
- mysql 增删改查基础操作的语法
前提,数据表的结构是这样的 一.插入内容到数据表 INSERT INTO `数据库名`.`数据表名` (`t_title`, `t_con`) VALUES ('标题1', '内容1'); 或这样 I ...
- Zookeeper+Kafka集群部署(转)
Zookeeper+Kafka集群部署 主机规划: 10.200.3.85 Kafka+ZooKeeper 10.200.3.86 Kafka+ZooKeeper 10.200.3.87 Kaf ...