This is an old revision of the document!
This document is an introduction to the structure of the NPU SDK.
Get source: khadas/aml_npu_sdk
$ mkdir workspace && cd workspace $ git clone --recursive https://github.com/khadas/aml_npu_sdk.git
Enter the SDK directory,
$ cd aml_npu_sdk $ ls acuity-toolkit android_sdk Dockerfile docs LICENSE linux_sdk README.md
The SDK contains the SDK, conversion/compilation tools, and docs.
acuity-toolkit #Conversion tool , used to convert AI models android_sdk #Android SDK docs #Conversion related documents collection
Since all linux codes have been supports local compiled, host compilation is no longer supported. Therefore, the contents of linux_sdk have been completely removed.
Enter the Docs directory, DDK_Application_Guide_0.7.pdf describes each document. The document records a series of processes from conversion to integration, as well as some common problems.
acuity-toolkit is the conversion tool directory,
$ cd aml_npu_sdk/acuity-toolkit $ ls bin demo python ReadMe.txt requirements.txt
The main directory of interest is demo,
1. bin #Conversion is a collection of various tools used, most of which are not open source. 2. demo #Conversion script directory, convert AI model location 3. demo_hybird #Mixed Input Conversion Tool 4. mulity_input_demo #mulity input demo 5. python #Used to convert the model and data corresponding to the python API 6. ReadMe.txt #ReadMe.txt file explains how to convert and use 7. requirements.txt #Conversion tool dependent environment
The environment package dependencies required by the conversion tool can be installed directly on the PC or installed through the virtual environment virtualenv.
$ cd aml_npu_sdk/acuity-toolkit $ cat requirements.txt tensorflow==2.0.0 astor==0.8.0 numpy==1.18.0 scipy==1.1.0 Pillow==5.3.0 protobuf==3.11.2 networkx>=1.11 image==1.5.5 lmdb==0.93 onnx==1.6.0 h5py==2.10.0 flatbuffers==1.10 matplotlib==2.1.0 dill==0.2.8.2 ruamel.yaml==0.15.81 ply==3.11 torch==1.2.0
Here, tensorflow==2.0.0 can be replaced by tensorflow==2.0.0a0.
The conversion script is in the acuity-toolkit/demo directory,
$ cd aml_npu_sdk/acuity-toolkit/demo $ ls -1 data model 0_import_model.sh 1_quantize_model.sh 2_export_case_code.sh extractoutput.py inference.sh
Use scripts to convert AI models.
$ cd aml_npu_sdk/acuity-toolkit/demo $ bash 0_import_model.sh && bash 1_quantize_model.sh && bash 2_export_case_code.sh
0_import_model.sh - Import model script. Now, it supports loading Tensorflow, Caffe, Tensorflow Lite, Onnx, Keras, Pytorch and Darknet model.1_quantize_model.sh - Quantize model script. Now, it can quantize model in int8, int16 and uint8.2_export_case_code.sh - Export model script. If you use VIM3, please set optimize to VIPNANOQI_PID0X88. If use VIM3L, please set optimize to VIPNANOQI_PID0X99.
After the conversion is completed, you can see the converted code in the xxxx_nbg_unify directory. Converted model is xxxx.nb. Here is the built-in model as an example.
$ cd aml_npu_sdk/acuity-toolkit/demo/mobilenet_tf_nbg_unify $ ls BUILD makefile.linux mobilenettf.vcxproj vnn_global.h vnn_mobilenettf.h vnn_post_process.h vnn_pre_process.h main.c mobilenet_tf.nb nbg_meta.json vnn_mobilenettf.c vnn_post_process.c vnn_pre_process.c
If your model's input is not a three-channel image, please convert input data to npy format.
For the setting of conversion parameters, please refer to Model_Transcoding and Running User Guide Eng.pdf in Docs.