【周易AIPU 仿真】一个硬件工程师跑:R329 开发板docker下仿真流程

首发极术社区
如对Arm相关技术感兴趣,欢迎私信aijishu20加入技术微信群。

docker 环境搭建

镜像

在这里插入图片描述

24M网速 一分钟搞定.
copy到ubuntu 服务器
在这里插入图片描述

容器

在这里插入图片描述

之后所有操作都在容器中了.记住关键 CONTAINER ID
进入docker 环境
sudo docker exec -it e97638d58202 /bin/sh 可以开多窗口
sudo docker attach e97638d58202 好像只能开单窗口
docker 和主机传输文件
sudo docker cp e97638d58202:/share/resnet_101_mode/result.jpeg

跑通demo

cd ~/demos/tflite ./run_sim.sh python3 quant_predict.py

跑通模型

构建自己的目录

mkdir /share
docker 没有安装git
apt-get install git
下载所需文件和仓库
在这里插入图片描述
在这里插入图片描述

备注
在这里插入图片描述

导出图需要安装
python3 setup.py install

下载模型

https://github.com/tensorflow/models/tree/master/research/slim#pre-trained-models

创建模型文件夹
mkdir resnet_101_mode
docker 支持wget 直接在docker 下载
wget wget http://download.tensorflow.org/models/resnet_v1_101_2016_08_28.tar.gz
解压模型
tar -xvzf resnet_v1_101_2016_08_28.tar.gz

pb 文件生成

导出图
python ../models/research/slim/export_inference_graph.py -alsologtostderr -model_name=resnet_v1_101 -image_size=224 -labels_offset=1 -output_file=./resnet_v1_101_inf.pb
固化
python3 ../tensorflow/tensorflow/python/tools/freeze_graph.py --input_graph=./resnet_v1_101_inf.pb --input_checkpoint=./resnet_v1_101.ckpt --input_binary=true --output_graph=./resnet_v1_101_frozen.pb --output_node_names=resnet_v1_101/predictions/Reshape_1
在这里插入图片描述

在这里插入图片描述

数据集

模型原本就是使用模型使用 ILSVRC2012
docker 中 /root/demos/tflite/dataset/
直接使用dataset
cp /root/demos/tflite/dataset/ /share
python3 preprocess_dataset.py
在这里插入图片描述

里面就是dataset 原始数据和标签裁剪了5个.

cfg
build.cfg
`
[Common]
mode=build

[Parser]
model_name = resnet_101
detection_postprocess = 
model_domain = image_classification
output = resnet_v1_101/predictions/Reshape_1
input_model = ./resnet_v1_101_frozen.pb
input = input
input_shape = [1,224,224,3]

[AutoQuantizationTool]
model_name = resnet_101
quantize_method = SYMMETRIC
ops_per_channel = DepthwiseConv
calibration_data = ../dataset/dataset.npy
calibration_label = ../dataset/label.npy
preprocess_mode = normalize
quant_precision=int8
reverse_rgb = False
label_id_offset = 0

[GBuilder]
outputs=./aipu.bin
profile= True
target=Z1_0701
`
执行过程
`
root@e97638d58202:/share/resnet_101_mode# aipubuild resnet_v1_101_build.cfg 
WARNING:tensorflow:
The TensorFlow contrib module will not be included in TensorFlow 2.0.
For more information, please see:
  * https://github.com/tensorflow/community/blob/master/rfcs/20180907-contrib-sunset.md
  * https://github.com/tensorflow/addons
  * https://github.com/tensorflow/io (for I/O related ops)
If you depend on functionality not listed there, please file an issue.

[I] Parsing model....
[I] [Parser]: Begin to parse tensorflow model resnet_101...
WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/AIPUBuilder/Parser/passes/tf/__init__.py:73: The name tf.ConfigProto is deprecated. Please use tf.compat.v1.ConfigProto instead.

ck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv1/Conv2D)!
t_7/bottleneck_v1/conv2/Conv2D)!
(resnet_v1_101/block3/unit_9/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_3/bottleneck_v1/add[?,7,7,2048])!
[I] [Parser]: Parser done!
[I] Parse model complete
[I] Quantizing model....
[I] AQT start: model_name:resnet_101, calibration_method:MEAN, batch_size:1
[I] ==== read ir ================
[I]     float32 ir txt: /tmp/AIPUBuilder_1626518697.8210652/resnet_101.txt
[I]     float32 ir bin2: /tmp/AIPUBuilder_1626518697.8210652/resnet_101.bin
[I] ==== read ir DONE.===========
WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.placeholder is deprecated. Please use tf.compat.v1.placeholder instead.

WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.nn.max_pool is deprecated. Please use tf.nn.max_pool2d instead.

WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.nn.avg_pool is deprecated. Please use tf.nn.avg_pool2d instead.

[I] ==== auto-quantization ======
WARNING:tensorflow:From /usr/local/bin/aipubuild:8: tf_record_iterator (from tensorflow.python.lib.io.tf_record) is deprecated and will be removed in a future version.
Instructions for updating:
Use eager execution and: 
`tf.data.TFRecordDataset(path)`
WARNING:tensorflow:Entity <bound method ImageNet.data_transform_fn of <AIPUBuilder.AutoQuantizationTool.auto_quantization.data_set.ImageNet object at 0x7f14cac790b8>> could not be transformed and will be executed as-is. Please report this to the AutoGraph team. When filing the bug, set the verbosity to 10 (on Linux, `export AUTOGRAPH_VERBOSITY=10`) and attach the full output. Cause: <cyfunction ImageNet.data_transform_fn at 0x7f153a50ff60> is not a module, class, method, function, traceback, frame, or code object
WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/tensorflow_core/python/autograph/impl/api.py:330: The name tf.FixedLenFeature is deprecated. Please use tf.io.FixedLenFeature instead.

WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/tensorflow_core/python/autograph/impl/api.py:330: The name tf.parse_single_example is deprecated. Please use tf.io.parse_single_example instead.

WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/tensorflow_core/python/framework/func_graph.py:915: The name tf.image.resize_images is deprecated. Please use tf.image.resize instead.

WARNING:tensorflow:From /usr/local/bin/aipubuild:8: DatasetV1.make_one_shot_iterator (from tensorflow.python.data.ops.dataset_ops) is deprecated and will be removed in a future version.
Instructions for updating:
Use `for ... in dataset:` to iterate over a dataset. If using `tf.estimator`, return the `Dataset` object directly from your input function. As a last resort, you can use `tf.compat.v1.data.make_one_shot_iterator(dataset)`.
WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.global_variables_initializer is deprecated. Please use tf.compat.v1.global_variables_initializer instead.

WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.local_variables_initializer is deprecated. Please use tf.compat.v1.local_variables_initializer instead.


[I]     step1: get max/min statistic value DONE
[I]     step2: quantization each op DONE
[I]     step3: build quantization forward DONE
[I]     step4: show output scale of end node:
[I]             layer_id:146, layer_top:resnet_v1_101/predictions/Reshape_1_0, output_scale:[375.57007]
[I] ==== auto-quantization DONE =
[I] Quantize model complete
[I] Building ...
[I] [common_options.h: 276] BuildTool version: 4.0.175. Build for target Z1_0701 at frequency 800MHz
[I] [common_options.h: 297] using default profile events to profile AIFF

[I] [IRChecker] Start to check IR: /tmp/AIPUBuilder_1626518697.8210652/resnet_101_int8.txt
[I] [IRChecker] model_name: resnet_101
[I] [IRChecker] IRChecker: All IR pass
[I] [graph.cpp : 846] loading graph weight: /tmp/AIPUBuilder_1626518697.8210652/resnet_101_int8.bin size: 0x2a971a4
[I] [builder.cpp:1059] Total memory for this graph: 0x3148da0 Bytes
[I] [builder.cpp:1060] Text   section:  0x00046f20 Bytes
[I] [builder.cpp:1061] RO     section:  0x00007100 Bytes
[I] [builder.cpp:1062] Desc   section:  0x0000d200 Bytes
[I] [builder.cpp:1063] Data   section:  0x02a80380 Bytes
[I] [builder.cpp:1064] BSS    section:  0x0062d400 Bytes
[I] [builder.cpp:1065] Stack         :  0x00040400 Bytes
[I] [builder.cpp:1066] Workspace(BSS):  0x000c4000 Bytes
Total errors: 0,  warnings: 0
`
#### run.cfg
#### run
`
[Common]
mode=run

[Parser]
model_name = resnet_101
detection_postprocess = 
model_domain = image_classification
output = resnet_v1_101/predictions/Reshape_1
input_model = ./resnet_v1_101_frozen.pb
input = input
input_shape = [1,224,224,3]
output_dir = ./

[AutoQuantizationTool]
model_name = resnet_101
quantize_method = SYMMETRIC
ops_per_channel = DepthwiseConv
calibration_data = ../dataset/dataset.npy
calibration_label = ../dataset/label.npy
preprocess_mode = normalize
quant_precision=int8
reverse_rgb = False
label_id_offset = 0

[GBuilder]
inputs=./model/input.bin
simulator=aipu_simulator_z1
outputs=output_resnet_101.bin
profile= True
target=Z1_0701
`
执行
`
root@e97638d58202:/share/resnet_101_mode# aipubuild resnet_v1_101_run.cfg 
WARNING:tensorflow:
The TensorFlow contrib module will not be included in TensorFlow 2.0.
For more information, please see:
  * https://github.com/tensorflow/community/blob/master/rfcs/20180907-contrib-sunset.md
  * https://github.com/tensorflow/addons
  * https://github.com/tensorflow/io (for I/O related ops)
If you depend on functionality not listed there, please file an issue.

[I] Parsing model....
[I] [Parser]: Begin to parse tensorflow model resnet_101...
WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/AIPUBuilder/Parser/passes/tf/__init__.py:73: The name tf.ConfigProto is deprecated. Please use tf.compat.v1.ConfigProto instead.

WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/AIPUBuilder/Parser/passes/tf/__init__.py:73: The name tf.Session is deprecated. Please use tf.compat.v1.Session instead.

2021-07-17 10:47:19.906208: I tensorflow/core/platform/cpu_feature_guard.cc:142] Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2 FMA
2021-07-17 10:47:19.928265: I tensorflow/core/platform/profile_utils/cpu_utils.cc:94] CPU Frequency: 4200000000 Hz
2021-07-17 10:47:19.928792: I tensorflow/compiler/xla/service/service.cc:168] XLA service 0x14413940 initialized for platform Host (this does not guarantee that XLA will be used). Devices:
2021-07-17 10:47:19.928824: I tensorflow/compiler/xla/service/service.cc:176]   StreamExecutor device (0): Host, Default Version
[I] [Parser]: Bias Op (resnet_v1_101/logits/BiasAdd[?,1,1,1000]) is fused into Linear Op (resnet_v1_101/logits/Conv2D[?,1,1,1000])!
[I] [Parser]: BatchNorm Op (resnet_v1_101/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_1/bottleneck_v1/shortcut/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_1/bottleneck_v1/shortcut/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_1/bottleneck_v1/shortcut/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_1/bottleneck_v1/shortcut/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_1/bottleneck_v1/shortcut/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_1/bottleneck_v1/shortcut/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_1/bottleneck_v1/shortcut/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_1/bottleneck_v1/shortcut/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv1/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv1/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv2/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv2/Conv2D)!
[I] [Parser]: BatchNorm Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv3/BatchNorm/FusedBatchNormV3) is fused into Linear Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv3/Conv2D)!
[I] [Parser]: Relu Op (resnet_v1_101/conv1/Relu[?,112,112,64]) is fused into Op (resnet_v1_101/conv1/Conv2D[?,112,112,64])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv1/Relu[?,56,56,64]) is fused into Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv1/Conv2D[?,56,56,64])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv2/Relu[?,56,56,64]) is fused into Op (resnet_v1_101/block1/unit_1/bottleneck_v1/conv2/Conv2D[?,56,56,64])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv1/Relu[?,56,56,64]) is fused into Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv1/Conv2D[?,56,56,64])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv2/Relu[?,56,56,64]) is fused into Op (resnet_v1_101/block1/unit_2/bottleneck_v1/conv2/Conv2D[?,56,56,64])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv1/Relu[?,56,56,64]) is fused into Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv1/Conv2D[?,56,56,64])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv2/Relu[?,28,28,64]) is fused into Op (resnet_v1_101/block1/unit_3/bottleneck_v1/conv2/Conv2D[?,28,28,64])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv1/Relu[?,28,28,128]) is fused into Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv1/Conv2D[?,28,28,128])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv2/Relu[?,28,28,128]) is fused into Op (resnet_v1_101/block2/unit_1/bottleneck_v1/conv2/Conv2D[?,28,28,128])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv1/Relu[?,28,28,128]) is fused into Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv1/Conv2D[?,28,28,128])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv2/Relu[?,28,28,128]) is fused into Op (resnet_v1_101/block2/unit_2/bottleneck_v1/conv2/Conv2D[?,28,28,128])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv1/Relu[?,28,28,128]) is fused into Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv1/Conv2D[?,28,28,128])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv2/Relu[?,28,28,128]) is fused into Op (resnet_v1_101/block2/unit_3/bottleneck_v1/conv2/Conv2D[?,28,28,128])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv1/Relu[?,28,28,128]) is fused into Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv1/Conv2D[?,28,28,128])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv2/Relu[?,14,14,128]) is fused into Op (resnet_v1_101/block2/unit_4/bottleneck_v1/conv2/Conv2D[?,14,14,128])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_1/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_2/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_3/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_4/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_5/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_6/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_7/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_8/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_9/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_10/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_11/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_12/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_13/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_14/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_15/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_16/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_17/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_18/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_19/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_20/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_21/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv2/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_22/bottleneck_v1/conv2/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv1/Relu[?,14,14,256]) is fused into Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv1/Conv2D[?,14,14,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv2/Relu[?,7,7,256]) is fused into Op (resnet_v1_101/block3/unit_23/bottleneck_v1/conv2/Conv2D[?,7,7,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv1/Relu[?,7,7,512]) is fused into Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv1/Conv2D[?,7,7,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv2/Relu[?,7,7,512]) is fused into Op (resnet_v1_101/block4/unit_1/bottleneck_v1/conv2/Conv2D[?,7,7,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv1/Relu[?,7,7,512]) is fused into Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv1/Conv2D[?,7,7,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv2/Relu[?,7,7,512]) is fused into Op (resnet_v1_101/block4/unit_2/bottleneck_v1/conv2/Conv2D[?,7,7,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv1/Relu[?,7,7,512]) is fused into Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv1/Conv2D[?,7,7,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv2/Relu[?,7,7,512]) is fused into Op (resnet_v1_101/block4/unit_3/bottleneck_v1/conv2/Conv2D[?,7,7,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_1/bottleneck_v1/Relu[?,56,56,256]) is fused into Op (resnet_v1_101/block1/unit_1/bottleneck_v1/add[?,56,56,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_2/bottleneck_v1/Relu[?,56,56,256]) is fused into Op (resnet_v1_101/block1/unit_2/bottleneck_v1/add[?,56,56,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block1/unit_3/bottleneck_v1/Relu[?,28,28,256]) is fused into Op (resnet_v1_101/block1/unit_3/bottleneck_v1/add[?,28,28,256])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_1/bottleneck_v1/Relu[?,28,28,512]) is fused into Op (resnet_v1_101/block2/unit_1/bottleneck_v1/add[?,28,28,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_2/bottleneck_v1/Relu[?,28,28,512]) is fused into Op (resnet_v1_101/block2/unit_2/bottleneck_v1/add[?,28,28,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_3/bottleneck_v1/Relu[?,28,28,512]) is fused into Op (resnet_v1_101/block2/unit_3/bottleneck_v1/add[?,28,28,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block2/unit_4/bottleneck_v1/Relu[?,14,14,512]) is fused into Op (resnet_v1_101/block2/unit_4/bottleneck_v1/add[?,14,14,512])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_1/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_1/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_2/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_2/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_3/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_3/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_4/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_4/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_5/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_5/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_6/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_6/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_7/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_7/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_8/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_8/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_9/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_9/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_10/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_10/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_11/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_11/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_12/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_12/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_13/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_13/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_14/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_14/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_15/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_15/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_16/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_16/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_17/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_17/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_18/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_18/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_19/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_19/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_20/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_20/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_21/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_21/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_22/bottleneck_v1/Relu[?,14,14,1024]) is fused into Op (resnet_v1_101/block3/unit_22/bottleneck_v1/add[?,14,14,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block3/unit_23/bottleneck_v1/Relu[?,7,7,1024]) is fused into Op (resnet_v1_101/block3/unit_23/bottleneck_v1/add[?,7,7,1024])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_1/bottleneck_v1/Relu[?,7,7,2048]) is fused into Op (resnet_v1_101/block4/unit_1/bottleneck_v1/add[?,7,7,2048])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_2/bottleneck_v1/Relu[?,7,7,2048]) is fused into Op (resnet_v1_101/block4/unit_2/bottleneck_v1/add[?,7,7,2048])!
[I] [Parser]: Relu Op (resnet_v1_101/block4/unit_3/bottleneck_v1/Relu[?,7,7,2048]) is fused into Op (resnet_v1_101/block4/unit_3/bottleneck_v1/add[?,7,7,2048])!
[I] [Parser]: Parser done!
[I] Parse model complete
[I] Quantizing model....
[I] AQT start: model_name:resnet_101, calibration_method:MEAN, batch_size:1
[I] ==== read ir ================
[I]     float32 ir txt: /tmp/AIPUBuilder_1626518838.188256/resnet_101.txt
[I]     float32 ir bin2: /tmp/AIPUBuilder_1626518838.188256/resnet_101.bin
[I] ==== read ir DONE.===========
WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.placeholder is deprecated. Please use tf.compat.v1.placeholder instead.

WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.nn.max_pool is deprecated. Please use tf.nn.max_pool2d instead.

WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.nn.avg_pool is deprecated. Please use tf.nn.avg_pool2d instead.

[I] ==== auto-quantization ======
WARNING:tensorflow:From /usr/local/bin/aipubuild:8: tf_record_iterator (from tensorflow.python.lib.io.tf_record) is deprecated and will be removed in a future version.
Instructions for updating:
Use eager execution and: 
`tf.data.TFRecordDataset(path)`
WARNING:tensorflow:Entity <bound method ImageNet.data_transform_fn of <AIPUBuilder.AutoQuantizationTool.auto_quantization.data_set.ImageNet object at 0x7fd19bf50b38>> could not be transformed and will be executed as-is. Please report this to the AutoGraph team. When filing the bug, set the verbosity to 10 (on Linux, `export AUTOGRAPH_VERBOSITY=10`) and attach the full output. Cause: <cyfunction ImageNet.data_transform_fn at 0x7fd20f7f4f60> is not a module, class, method, function, traceback, frame, or code object
WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/tensorflow_core/python/autograph/impl/api.py:330: The name tf.FixedLenFeature is deprecated. Please use tf.io.FixedLenFeature instead.

WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/tensorflow_core/python/autograph/impl/api.py:330: The name tf.parse_single_example is deprecated. Please use tf.io.parse_single_example instead.

WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/tensorflow_core/python/framework/func_graph.py:915: The name tf.image.resize_images is deprecated. Please use tf.image.resize instead.

WARNING:tensorflow:From /usr/local/bin/aipubuild:8: DatasetV1.make_one_shot_iterator (from tensorflow.python.data.ops.dataset_ops) is deprecated and will be removed in a future version.
Instructions for updating:
Use `for ... in dataset:` to iterate over a dataset. If using `tf.estimator`, return the `Dataset` object directly from your input function. As a last resort, you can use `tf.compat.v1.data.make_one_shot_iterator(dataset)`.
WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.global_variables_initializer is deprecated. Please use tf.compat.v1.global_variables_initializer instead.

WARNING:tensorflow:From /usr/local/bin/aipubuild:8: The name tf.local_variables_initializer is deprecated. Please use tf.compat.v1.local_variables_initializer instead.


[I]     step1: get max/min statistic value DONE
[I]     step2: quantization each op DONE
[I]     step3: build quantization forward DONE
[I]     step4: show output scale of end node:
[I]             layer_id:146, layer_top:resnet_v1_101/predictions/Reshape_1_0, output_scale:[375.57007]
[I] ==== auto-quantization DONE =
[I] Quantize model complete
[I] Building ...
[I] [common_options.h: 276] BuildTool version: 4.0.175. Build for target Z1_0701 at frequency 800MHz
[I] [common_options.h: 297] using default profile events to profile AIFF

[I] [IRChecker] Start to check IR: /tmp/AIPUBuilder_1626518838.188256/resnet_101_int8.txt
[I] [IRChecker] model_name: resnet_101
[I] [IRChecker] IRChecker: All IR pass
[I] [graph.cpp : 846] loading graph weight: /tmp/AIPUBuilder_1626518838.188256/resnet_101_int8.bin size: 0x2a971a4
[I] [builder.cpp:1059] Total memory for this graph: 0x3148da0 Bytes
[I] [builder.cpp:1060] Text   section:  0x00046f20 Bytes
[I] [builder.cpp:1061] RO     section:  0x00007100 Bytes
[I] [builder.cpp:1062] Desc   section:  0x0000d200 Bytes
[I] [builder.cpp:1063] Data   section:  0x02a80380 Bytes
[I] [builder.cpp:1064] BSS    section:  0x0062d400 Bytes
[I] [builder.cpp:1065] Stack         :  0x00040400 Bytes
[I] [builder.cpp:1066] Workspace(BSS):  0x000c4000 Bytes
[I] [main.cpp  : 467] # autogenrated by aipurun, do NOT modify!
LOG_FILE=log_default
FAST_FWD_INST=0
INPUT_INST_CNT=1
INPUT_DATA_CNT=2
CONFIG=Z1-0701
LOG_LEVEL=0
INPUT_INST_FILE0=/tmp/temp_3c12a6ed2bbd0b525c74f6ff0526d.text
INPUT_INST_BASE0=0x0
INPUT_INST_STARTPC0=0x0
INPUT_DATA_FILE0=/tmp/temp_3c12a6ed2bbd0b525c74f6ff0526d.ro
INPUT_DATA_BASE0=0x10000000
INPUT_DATA_FILE1=/tmp/temp_3c12a6ed2bbd0b525c74f6ff0526d.data
INPUT_DATA_BASE1=0x20000000
OUTPUT_DATA_CNT=2
OUTPUT_DATA_FILE0=output_resnet_101.bin
OUTPUT_DATA_BASE0=0x23200000
OUTPUT_DATA_SIZE0=0x3e8
OUTPUT_DATA_FILE1=profile_data.bin
OUTPUT_DATA_BASE1=0x22ac0780
OUTPUT_DATA_SIZE1=0xe00
RUN_DESCRIPTOR=BIN[0]

[I] [main.cpp  : 118] run simulator:
aipu_simulator_z1 /tmp/temp_3c12a6ed2bbd0b525c74f6ff0526d.cfg
[INFO]:SIMULATOR START!
[INFO]:========================================================================
[INFO]:                             STATIC CHECK
[INFO]:========================================================================
[INFO]:  INST START ADDR : 0x0(0)
[INFO]:  INST END ADDR   : 0x46f1f(290591)
[INFO]:  INST SIZE       : 0x46f20(290592)
[INFO]:  PACKET CNT      : 0x46f2(18162)
[INFO]:  INST CNT        : 0x11bc8(72648)
[INFO]:------------------------------------------------------------------------
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x44e: 0x472021b(POP R27,Rc7) vs 0x5f00000(MVI R0,0x0,Rc7), PACKET:0x44e(1102) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x45b: 0x472021b(POP R27,Rc7) vs 0x5f00000(MVI R0,0x0,Rc7), PACKET:0x45b(1115) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x5c0: 0x472021b(POP R27,Rc7) vs 0x9f80020(ADD.S R0,R0,0x1,Rc7), PACKET:0x5c0(1472) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x7fd: 0x4520180(BRL R0) vs 0x47a03e4(ADD R4,R0,R31,Rc7), PACKET:0x7fd(2045) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x996: 0x4720204(POP R4,Rc7) vs 0x9f80020(ADD.S R0,R0,0x1,Rc7), PACKET:0x996(2454) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0xe40: 0x4720204(POP R4,Rc7) vs 0x47a1be0(ADD R0,R6,R31,Rc7), PACKET:0xe40(3648) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x1266: 0x472021b(POP R27,Rc7) vs 0x5f00000(MVI R0,0x0,Rc7), PACKET:0x1266(4710) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x1273: 0x472021b(POP R27,Rc7) vs 0x5f00000(MVI R0,0x0,Rc7), PACKET:0x1273(4723) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x13d8: 0x472021b(POP R27,Rc7) vs 0x9f80020(ADD.S R0,R0,0x1,Rc7), PACKET:0x13d8(5080) SLOT:0 vs 3
[WARN]:[0803] INST WR/RD REG CONFLICT! PACKET 0x1575: 0x4520180(BRL R0) vs 0x47a03e5(ADD R5,R0,R31,Rc7), PACKET:0x1575(5493) SLOT:0 vs 3
[INFO]:========================================================================
[INFO]:                             STATIC CHECK END
[INFO]:========================================================================

[INFO]:AIPU START RUNNING: BIN[0]
[INFO]:TOTAL TIME: 20.021330s. 
[INFO]:SIMULATOR EXIT!
[I] [main.cpp  : 135] Simulator finished.
Total errors: 0,  warnings: 0
root@e97638d58202:/share/resnet_101_mode# 
`

预测结果

先copy 代码和必须文件

cp /root/demos/tflite/output_ref.bin ./
cp /root/demos/tflite/imagenet_classes.py ./
cp /root/demos/tflite/quant_predict.py ./
cp ../resnet_v1_152_mode/model/input.bin ./model/
cp /root/demos/tflite/output_ref.bin ./

更改quant_predict.py 为自己output_resnet_101.bin

最后一步:

root@e97638d58202:/share/resnet_101_mode# ls^C
root@e97638d58202:/share/resnet_101_mode# python3 quant_predict.py 
predict first 5 label:
    index  230, prob 235, name: Old English sheepdog, bobtail
    index  231, prob  19, name: Shetland sheepdog, Shetland sheep dog, Shetland
    index  999, prob   0, name: ear, spike, capitulum
    index  342, prob   0, name: hog, pig, grunter, squealer, Sus scrofa
    index  340, prob   0, name: sorrel
true first 5 label:
    index  232, prob  83, name: collie
    index  231, prob  83, name: Shetland sheepdog, Shetland sheep dog, Shetland
    index  158, prob  41, name: papillon
    index  170, prob  40, name: borzoi, Russian wolfhound
    index  161, prob  39, name: Afghan hound, Afghan
Detect picture save to result.jpeg

前5类正确. OK.
在这里插入图片描述

最后所有文件都在/share 中.传gitee.

在这里插入图片描述
在这里插入图片描述

https://gitee.com/ejuoy/r329_docker_share

百度云连接

链接:https://pan.baidu.com/s/1uVfPgknJnwDLn4Gzi5z8Ew
提取码:g441

相关阅读:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值