android 错误:使用未声明的标识符'vmaxq_f16'

kqlmhetl  于 11个月前  发布在  Android
关注(0)|答案(2)|浏览(142)

每当我尝试使用 neon 16位浮点型内部函数时,我都会遇到这个错误。
是否可以在Android上使用 neon 16位浮点内部函数?
我的代码:

#include <jni.h>
#include <arm_fp16.h>
#include <arm_neon.h>

void useSIMD_f16() {
    float16_t zero = 0;
    float16x8_t zero_f16x8 = vld1q_dup_f16(&zero);
    float16_t one = 1;
    float16x8_t one_f16x8 = vld1q_dup_f16(&one);
    float16x8_t max = vmaxq_f16(zero_f16x8, one_f16x8);
}

字符串
错误:
任务“:app:externalNativeBuildList”执行失败。生成命令失败。使用参数{-C /home/raed/AndroidStudioProjects/SIMD/app/.cxx/cmake/debug/armeabi-v7 a native-lib}执行进程/home/raed/Android/Sdk/cmake/3.10.2.4988404/bin/ninja时出错ninja:正在进入目录“/home/raed/AndroidStudioProjects/SIMD/app/.cxx/cmake/debug/armeabi-v7 a”[1/2]正在生成CXX对象CMakeFiles/native-lib.dir/native-lib.cpp.o常见问题:CMakeFiles/native-lib.dir/native-lib.cpp.o /home/raed/Android/Sdk/ndk/22.1.7171670/toolchains/llvm/prebuilt/linux-x86_64/bin/clang++--target=armv7-none-linux-androideabi23 --gcc-toolchain=/home/raed/Android/Sdk/ndk/22.1.7171670/工具链/llvm/prebuilt/linux-x86_64 --sysroot=/home/raed/Android/Sdk/ndk/22.1.7171670/工具链/llvm/prebuilt/linux-x86_64/sysroot -Dnative_lib_EXPORTS -g -DANDROID -fdata-sections -ffunction-sections -funwind-tables -fstack-protector-strong -no-canonical-prefixes -D_FORTIFY_SOURCE=2 -march=armv7-a -mthumb -Wformat -Werror=format-security -O0 -fno-limit-debug-info -fPIC -MD -MT CMakeFiles/native-lib.dir/native-lib.cpp.o -MF CMakeFiles/native-lib.dir/native-lib.cpp.o.d -o CMakeFiles/native-lib.dir/native-lib.cpp.o -c/home/raed/AndroidStudioProjects/SIMD/app/src/main/cpp/native-lib. cpp/home/raed/AndroidStudioProjects/SIMD/app/src/main/cpp/native-lib.cpp:7:30:error:使用未声明的标识符'vld1q_dup_f16' float16x8_t zero_f16x8 = vld1q_dup_f16(&zero); ^ /home/raed/AndroidStudioProjects/SIMD/app/src/main/cpp/native-lib.cpp:9:29:error:使用未声明的标识符'vld1q_dup_f16' float16x8_t one_f16x8 = vld1q_dup_f16(&one); ^ /home/raed/AndroidStudioProjects/SIMD/app/src/main/cpp/native-lib.cpp:10:23:error:使用未声明的标识符'vmaxq_f16' float16x8_t max = vmaxq_f16(zero_f16x8,one_f16x8);生成^ 3个错误。ninja:build stopped:subcommand failed.

qxsslcnc

qxsslcnc1#

半精度浮点并非在所有Arm目标上都可用。请检查是否定义了__ARM_FEATURE_FP16_VECTOR_ARITHMETIC宏以确定函数是否可用。
是否可以在Android上使用 neon 16位浮点内部函数?
这并不是真正的Android的东西;一些Android设备将支持它,其他人不会。这取决于CPU。

af7jpaap

af7jpaap2#

您需要指定支持半精度浮点运算功能的适当编译器选项和目标体系结构。根据您使用的编译器,选项可能会有所不同。以下是一些示例:
对于Clang for Arm,您可以使用-march=armv8.2-a+fp16来启用特征宏和_Float16数据类型1。
对于GCC for Arm,您可以使用-mfpu=fp-armv8 -march=armv8.2-a+fp16来启用功能宏和_Float16数据类型2。
对于Android NDK,您可以使用-march=armv8.2a+fp16来启用功能宏,但您可能还需要检查__ARM_FP16_FORMAT_IEEE宏以确定半精度值的格式3。

相关问题