rknn_matmul_api_demo是一个使用matmul C API在NPU上执行矩阵乘法的示例。包含静态shape和动态shape两种模式。
用法:
静态shape模式
Usage: ./rknn_matmul_api_demo <matmul_type> <M,K,N> <B_layout> <AC_layout> <loop_count> <core_mask> <print_result> <iommu_domain_id> matmul_type = 1: RKNN_FLOAT16_MM_FLOAT16_TO_FLOAT32 matmul_type = 2: RKNN_INT8_MM_INT8_TO_INT32 matmul_type = 4: RKNN_FLOAT16_MM_FLOAT16_TO_FLOAT16 matmul_type = 7: RKNN_FLOAT16_MM_INT4_TO_FLOAT32 matmul_type = 10: RKNN_INT4_MM_INT4_TO_INT16 Example: A = [4,64], B = [64,32], int8 matmul test command as followed: ./rknn_matmul_api_demo 2 4,64,32
动态shape模式
./rknn_matmul_api_dynshape_demo <matmul_type> <M1K1N1#M2K2N2#...> <B_layout> <AC_layout> <loop_count> <core_mask> M_shapes: M shape array, which separeted by ',' matmul_type = 1: RKNN_FLOAT16_MM_FLOAT16_TO_FLOAT32 matmul_type = 2: RKNN_INT8_MM_INT8_TO_INT32 matmul_type = 4: RKNN_FLOAT16_MM_FLOAT16_TO_FLOAT16 matmul_type = 7: RKNN_FLOAT16_MM_INT4_TO_FLOAT32 matmul_type = 10: RKNN_INT4_MM_INT4_TO_INT16 Example: A = [1,64]#[4,64]#[8,64], B = [64,32], int8 matmul test command as followed: feature+const: ./rknn_matmul_api_dynshape_demo 2 1,64,32#4,64,32#8,64,32 1 1 two feature: ./rknn_matmul_api_dynshape_demo 2 1,64,32#4,64,32#8,64,32 2 1
Aarch64 Linux 示例
编译
首先导入GCC_COMPILER,例如export GCC_COMPILER=~/opt/gcc-linaro-7.5.0-2019.12-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu
,然后执行如下命令:
./build-linux.sh -t <target> -a <arch> -b <build_type>]
# 例如:
./build-linux.sh -t rk3588 -a aarch64 -b Release
安装
将 install/rknn_matmul_api_demo_Linux 拷贝到设备上。
- 如果使用Rockchip的EVB板,可以使用以下命令:
连接设备并将程序传输到/userdata
adb push install/rknn_matmul_api_demo_Linux /userdata/
- 如果你的板子有sshd服务,可以使用scp命令或者其他方式将程序和模型传输到板子上。
运行
adb shell
cd /userdata/rknn_matmul_api_demo_Linux/
export LD_LIBRARY_PATH=./lib
./rknn_matmul_api_demo 2 4 64 32
或者
export LD_LIBRARY_PATH=./lib
./rknn_matmul_api_dynshape_demo 2 1,64,32#4,64,32#8,64,32 1 1
Android 示例
编译
首先导入ANDROID_NDK_PATH,例如export ANDROID_NDK_PATH=~/opts/ndk/android-ndk-r18b
,然后执行如下命令:
./build-android.sh -t <target> -a <arch> [-b <build_type>]
# 例如:
./build-android.sh -t rk3568 -a arm64-v8a -b Release
安装
连接设备并将程序传输到/data
adb push install/rknn_matmul_api_demo_Android /data/
运行
adb shell
cd /data/rknn_matmul_api_demo_Android/
export LD_LIBRARY_PATH=./lib
./rknn_matmul_api_demo 2 4 64 32
或者
export LD_LIBRARY_PATH=./lib
./rknn_matmul_api_dynshape_demo 2 1,64,32#4,64,32#8,64,32 1 1