错误:使用未声明的标识符“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”的主要内容,如果未能解决你的问题,请参考以下文章

在 CoreLocation 中使用未声明的标识符错误

发布 iOS 构建错误 - 使用未声明的标识符“Twitter”

C 2065 AFX_IDW_MENUBAR未声明的标识符 错误提示

Google iOS SDK 无法存档(使用未声明的标识符错误)

iOS:Objective-C 创建类属性错误:使用未声明的标识符

接收构建失败错误“使用未声明的标识符‘ParseClientConfiguration’”