错误:使用未声明的标识符“vmaxq_f16”
Posted
技术标签:
【中文标题】错误:使用未声明的标识符“vmaxq_f16”【英文标题】:error: use of undeclared identifier 'vmaxq_f16' 【发布时间】:2021-04-20 22:42:18 【问题描述】:每当我尝试使用 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:externalNativeBuildDebug”执行失败。 构建命令失败。 使用参数执行进程 /home/raed/Android/Sdk/cmake/3.10.2.4988404/bin/ninja 时出错 -C /home/raed/AndroidStudioProjects/SIMD/app/.cxx/cmake/debug/armeabi-v7a native-库 忍者:进入目录`/home/raed/AndroidStudioProjects/SIMD/app/.cxx/cmake/debug/armeabi-v7a' [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/toolchains/llvm/prebuilt/linux-x86_64 --sysroot=/home/raed/Android/Sdk/ndk/22.1.7171670/toolchains/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:错误:使用未声明的标识符“vld1q_dup_f16” float16x8_t zero_f16x8 = vld1q_dup_f16(&zero); ^ /home/raed/AndroidStudioProjects/SIMD/app/src/main/cpp/native-lib.cpp:9:29:错误:使用未声明的标识符“vld1q_dup_f16” float16x8_t one_f16x8 = vld1q_dup_f16(&one); ^ /home/raed/AndroidStudioProjects/SIMD/app/src/main/cpp/native-lib.cpp:10:23: float16x8_t max = vmaxq_f16(zero_f16x8, one_f16x8); ^ 产生 3 个错误。 忍者:构建停止:子命令失败。
【问题讨论】:
【参考方案1】:半精度浮点并非在所有 Arm 目标上都可用。检查是否定义了__ARM_FEATURE_FP16_VECTOR_ARITHMETIC
宏来判断功能是否可用。
难道不能在 Android 上使用 NEON 16 位浮点内在函数吗?
这不是真正的 Android 东西;一些 Android 设备会支持它,而另一些则不会。这取决于 CPU。
【讨论】:
ARM64 (a.k.a. AArch64) v8 的优点之一是它包括 VFPv4、ARM-NEON 和半精度支持,这是旧芯片中的可选扩展——这也意味着 ARM- NEON 也支持真正的除法运算符。如果您的目标是较旧的 ARM 芯片,则必须处理硬件可能支持也可能不支持的事实。 @ChuckWalbourn 虽然适用于半精度扩展/缩小操作,但vmaxq_f16
仅适用于实现 Armv8.2-A 半精度浮点扩展的内核。 @nemequ;对于向量操作(vmaxq_f16
将是),您需要检查__ARM_FEATURE_FP16_VECTOR_ARITHMETIC
。当然,这是编译时检查,而不是运行时检查,因此您需要确定最终执行的内核也具有适当的扩展名。以上是关于错误:使用未声明的标识符“vmaxq_f16”的主要内容,如果未能解决你的问题,请参考以下文章
发布 iOS 构建错误 - 使用未声明的标识符“Twitter”
C 2065 AFX_IDW_MENUBAR未声明的标识符 错误提示
Google iOS SDK 无法存档(使用未声明的标识符错误)