下载
中文
注册

查看dump数据文件

dump文件无法通过文本工具直接查看其内容,为了查看dump文件内容,本文提供以下脚本将dump文件转换为numpy格式文件后,再通过numpy官方提供的能力转为txt文档进行查看。

该功能通过msaccucmp.py脚本实现,该脚本存放在$HOME/Ascend/ascend-toolkit/latest/tools/operator_cmp/compare路径下,命令格式如下:

python3 msaccucmp.py convert -d dump_file [-out output] [-v version] [-t type]

命令格式参数项说明如表1所示。

表1 参数说明

参数名

描述

是否必选

-d

--dump_file

昇腾AI处理器生成的dump文件。

支持指定单个文件;单个路径(不支持递归嵌套,只支持文件的父目录);同时指定多个文件,文件名用逗号隔开,例如-d /{PATH}/dump_file1,/{PATH}/dump_file2。

-out

--output

转换后的数据存放目录,默认为当前路径。

-v

--version

dump文件类型,1代表protobuf序列化后的数据文件,2代表自定义格式的数据文件。默认取值为2。

-t

--type

输出文件的类型。取值为:

  • npy:输出文件保存为numpy格式。
  • msnpy:输出文件保存为numpy格式,一般用于MindSpore场景。
  • bin:输出文件保存为binary格式。

默认值为npy。

查看dump数据文件步骤

  1. 使用安装用户登录开发环境。
  2. 进入$HOME/Ascend/ascend-toolkit/latest/tools/operator_cmp/compare目录。
  3. 执行msaccucmp.py脚本,转换dump文件为numpy文件。
    python3 msaccucmp.py convert -d $HOME/dump -out $HOME/dumptonumpy -v 2
    • msaccucmp.py脚本的各个输入参数使用方法,请参见dump数据文件Format转换
    • -d参数支持传入单个文件,对单个dump文件进行转换,也支持传入目录(不支持递归嵌套,只支持文件的父目录),对整个path下所有的dump文件进行转换。
  4. 调用Python,转换numpy文件为txt文件。举例:
    $ python3
    Python 3 (default, Mar  5 2020, 16:07:54)[GCC 5.4.0 20160609] on linuxType "help", "copyright", "credits" or "license" for more information.
    >>> import numpy as np
    >>> a = np.load("$HOME/dumptonumpy/Pooling.pool1.1147.1589195081588018.output.0.npy")
    >>> b = a.flatten()
    >>> np.savetxt("$HOME/dumptonumpy/Pooling.pool1.1147.1589195081588018.output.0.txt", b)

    转换为.txt格式文件后,维度信息、Dtype均不存在。详细的使用方法请参见numpy官网介绍。