我构建了 Android 项目,在其中使用带有LibXTract的 Android NDK来提取音频特征。LibXTrac 使用fftw3库。项目由运行简单示例形式 libxtract 的按钮组成:
JNIEXPORT void JNICALL Java_com_androidnative1_NativeClass_showText(JNIEnv *env, jclass clazz)
{
float mean = 0, vector[] = {.1, .2, .3, .4, -.5, -.4, -.3, -.2, -.1}, spectrum[10];
int n, N = 9;
float argf[4];
argf[0] = 8000.f;
argf[1] = XTRACT_MAGNITUDE_SPECTRUM;
argf[2] = 0.f;
argf[3] = 0.f;
xtract[XTRACT_MEAN]((void *)&vector, N, 0, (void *)&mean);
__android_log_print(ANDROID_LOG_DEBUG, "AndNat", "com_androidnative1_NativeClass.c before");
xtract_init_fft(N, XTRACT_SPECTRUM);
__android_log_print(ANDROID_LOG_DEBUG, "AndNat", "com_androidnative1_NativeClass.c after");
// Comment for test purpose
//xtract_init_bark(1, argf[1], 1);
//xtract[XTRACT_SPECTRUM]((void *)&vector, N, &argf[0], (void *)&spectrum[0]);
}
libxtract 函数xtract_init_fft位于jni/libxtract/jni/src/init.c执行 fftw3 函数fftwf_plan_r2r_1d位于jni/fftw3/jni/api/plan-r2r-1d.c
__android_log_print(ANDROID_LOG_DEBUG, "AndNat", "libxtract/src/init.c before");
fft_plans.spectrum_plan = fftwf_plan_r2r_1d(N, input, output, FFTW_R2HC, optimisation);
__android_log_print(ANDROID_LOG_DEBUG, "AndNat", "libxtract/src/init.c after");
应用程序挂在fftwf_paln_r2r_1d内而没有崩溃或任何外部错误我必须强制它停止工作。
fftwf_paln_r2r_1d看起来像:
X(plan) X(plan_r2r_1d)(int n, R *in, R *out, X(r2r_kind) kind, unsigned flags)
{
__android_log_print(ANDROID_LOG_DEBUG, "AndNat", "fftw3/api/plan-r2r-1d.c");
return X(plan_r2r)(1, &n, in, out, &kind, flags);
}
从 CatLog 我可以看到:
07-16 18:50:09.615: D/AndNat(7313): com_androidnative1_NativeClass.c before
07-16 18:50:09.615: D/AndNat(7313): libxtract/src/init.c before
07-16 18:50:09.615: D/AndNat(7313): fftw3/api/plan-r2r-1d.c
我使用 gen.sh 脚本为 fftw3 和 libxtract 生成 config.h 并成功定位在源文件夹中。两个库都是静态构建的,并与共享库 libcom_androidnative1_NativeClass.so 链接
命令
nm -Ca libcom_androidnative1_NativeClass.so
表明包含使用的功能。
应用程序构建并部署到设备没有任何问题。
我用标志 --disable-alloca,--enable-float和 LibXTract 用标志--enable-fft和--disable-dependency-tracking构建 fftw3
仅在库源代码中添加了 dbgprint 并从 LibXtract 中删除了定义 XTRACT_FFT,因为它无法检测到 fftw 库。
如果有人对我这种奇怪的行为有任何想法,请提供帮助。
在这里,我将整个项目放在 github 中,所以也许有人可以帮助我处理这个问题。