PowerSensor AI教程1.2 - 数字识别 - dnndk模型编译

准备工作

  1. 安装vmware,vmware在我们的百度网盘可以下载到
    链接:https://pan.baidu.com/s/1nhXQxRgYh9cDEFMw5sMvAQ
    提取码:z1dm

  2. 下载我们准备好的虚拟机
    地址:
    链接:https://pan.baidu.com/s/1mdZV9jn74RCxKp_pUh4mew 提取码:623k

  3. 本章的例程与上一节的相同,请移步
    Powersensor AI教程1.1-数字识别-tf模型训练下载。

介绍

本章主要介绍的PowersensorAI部署的第二个环节,通过xilinx的DNNDK,将tensorflow训练好的模型进行固化、编译等操作。最终生成powersensor可以运行的elf文件。这个环节称为dnndk环节。

编译过程

  1. 打开虚拟机,登录密码是123
    在这里插入图片描述

  2. 在虚拟机的/home/xiaobo/powersensor目录下新建ministNumber文件夹(随教程发布的案例会已经存在),并把案例目录下的dnndk文件夹和dataset_valid文件夹复制到新建的文件夹下面。如果要使用自己新训练的模型,需要把自己的模型(在案例目录/pc/run下面的2个模型文件)替换掉我们准备好的文件。
    dnndkDir

  3. 在虚拟机里的dnndk文件夹里在打开终端:
    在这里插入图片描述

  4. 第一步,模型固定,把tensorflow的权值固定到结构中,指令是./1_vitisAI_keras2frozon.sh

xiaobo@ubuntu:~/powersensor/fashion-minist/dnndk$ ./1_vitisAI_keras2frozon.sh
############################################
Convert keras h5 model to frozon model begin
Vitis AI 1.1
############################################
I0515 05:22:53.318743 139635748165376 keras_to_tensorflow.py:146] Converted output node names are: [u'dense_out/Softmax']
INFO:tensorflow:Froze 8 variables.
I0515 05:22:53.326545 139635748165376 tf_logging.py:115] Froze 8 variables.
INFO:tensorflow:Converted 8 variables to const ops.
I0515 05:22:53.329962 139635748165376 tf_logging.py:115] Converted 8 variables to const ops.
I0515 05:22:53.332588 139635748165376 keras_to_tensorflow.py:178] Saved the freezed graph at frozon_result/model.pb
############################################
Convert completed
############################################

frozon完模型,工具会把网络节点的名称打印出来。一般地,第一个是输入节点,最后一个是输出节点。
在这里插入图片描述

  1. 第二步,量化,注意把2_vitisAI_tf_quantize.sh中的input_nodesinput_shapesoutput_nodes改成与第一步打印的节点名称一致。
    在这里插入图片描述
    在这里插入图片描述
xiaobo@ubuntu:~/powersensor/fashion-minist/dnndk$ ./2_vitisAI_tf_quantize.sh 
#####################################
Quantize begin
Vitis AI 1.1
#####################################
('../dataset/fashion-mnist/t10k-images-idx3-ubyte.gz', '../dataset/fashion-mnist/t10k-labels-idx1-ubyte.gz')
t10k labels:10000
t10k datas shape:(10000,28,28)
INFO: Checking Float Graph...
INFO: Float Graph Check Done.
INFO: Calibrating for 100 iterations...
100% |#########################################################################|
INFO: Calibration Done.
INFO: Generating Deploy Model...
INFO: Deploy Model Generated.
********************* Quantization Summary *********************      
INFO: Output:       
  quantize_eval_model: ./quantize_results/quantize_eval_model.pb       
  deploy_model: ./quantize_results/deploy_model.pb
#####################################
QUANTIZATION COMPLETED
#####################################

  1. 第三步,编译模型
./3_vitisAI_tf_compile.sh 

在这里插入图片描述

记住这两个节点的名称和模型的名称,在Powersensor上的edge阶段就使用这两个名称来引用节点。
编译完成后会在当前目录的compile_result目录下生成dpu_testModel_0.elf文件,这个就是最终要在DPU上运行的二进制库,把它从虚拟机里拷贝出来备用:
dnndkElfFile

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值