我目前正在尝试计算 iphone 扬声器/麦克风往返的频率响应。我在扬声器上播放正弦扫描,通过麦克风录制并尝试从中获得频率响应。最终目标是能够将 FR 乘以任何给定的声音,使其听起来像 iphone 的扬声器/麦克风。
到目前为止我的代码:
//apply window function
vDSP_vmul(sineSweepMic,1,hammingWindow,1,sineSweepMic,1,n);
vDSP_vmul(sineSweepFile,1,hammingWindow,1,sineSweepFile,1,n);
//put both signals in complex arrays
vDSP_ctoz((DSPComplex *)sineSweepMic, 2, &fftSineSweepMic, 1, nOver2);
vDSP_ctoz((DSPComplex *)sineSweepFile, 2, &fftSineSweepFile, 1, nOver2);
//fft of both file and mic sweeps
vDSP_fft_zrip(fftSetup, &fftSineSweepFile, 1, log2n, FFT_FORWARD);
vDSP_fft_zrip(fftSetup, &fftSineSweepMic, 1, log2n, FFT_FORWARD);
//back to interleaved
vDSP_ztoc(&fftSineSweepFile, 1, (COMPLEX *)sineSweepFile, 2, nOver2);
vDSP_ztoc(&fftSineSweepMic, 1, (COMPLEX *)sineSweepMic, 2, nOver2);
//divide mic-sweep by file-sweep to create frequency response
vDSP_vdiv(sineSweepFile, 1, sineSweepMic, 1, frequencyResponse, 1, n);
到目前为止,这有效,当我将 FR 与初始文件扫描相乘时,它听起来像麦克风扫描。
我的问题: 这仅适用于生成 FR 的确切文件(扫描)。一旦我使用 FR 修改其他声音,例如音乐,只会出现噪音。
我像这样使用FR(在频域中,交错的,不复杂的,甚至相同的长度):
vDSP_vmul(soundToModify, 1, frequencyResponse, 1, soundToModify, 1, n);
我在扬声器上播放的文件的正弦扫描:
我记录的正弦扫描(可见衰减的低频):
我的文件正弦扫描在频域中与在代码中生成的 FR 相乘:
我的目标: 在我的理解中,频率响应是关于每个频率的信息,它被系统衰减或放大了多少(在我的示例中,它无法再现低频)。为了获得这种信息,我生成了一个包含每个所需频率(正弦扫描)的声音,播放它并通过划分记录扫描/文件扫描(代码中的划分)来分析每个频率是如何被修改的。
通过将此频域中的 FR 乘以任何声音,应该修改频率幅度以模仿我系统上的播放,对吗?
谢谢!
更新: 最后,故障是缺少复杂的算术,正弦扫描和粉红噪声作为恢复脉冲响应的脉冲效果很好。
要获得工作代码,只需将记录的扫描 fft 数据除以初始扫描 fft 数据即可。