今回は、vDSPにて高速フーリエ変換(FFT)のやり方を紹介します。 vDSPにはFFTを行う為のいくつかの関数が用意されています。 この記事では、FFTを行うためのプログラムを一つにまとめた、FFT()という関数を作るところから始めたいと思います。 FFTを行う手順として、 FFTのフレームサイズを指定する。 FFTフレームサイズ分のオーディオデータを取得する。 2で取得したオーディオデータに窓関数を掛け合わせる。 窓関数を掛け合わせたオーディオデータをDSPSplitComplex型のデータ領域に格納する。 FFTを行う。 スケーリングを行う。(vDSP独特の仕様) とここまでがあります。 この中で DSPSplitComplex型 というデータタイプが現れますが、これは以下のような構造体をなしていて、信号の実数部と虚数部を格納する事ができます。
![[vDSP][信号処理]オーディオ・音声分析への道5 高速フーリエ変換 FFT - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/c75ca24f6008079ba9510075e2d9ab5e3203a269/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9JTVCdkRTUCU1RCU1QiVFNCVCRiVBMSVFNSU4RiVCNyVFNSU4NyVBNiVFNyU5MCU4NiU1RCVFMyU4MiVBQSVFMyU4MyVCQyVFMyU4MyU4NyVFMyU4MiVBMyVFMyU4MiVBQSVFMyU4MyVCQiVFOSU5RiVCMyVFNSVBMyVCMCVFNSU4OCU4NiVFNiU5RSU5MCVFMyU4MSVCOCVFMyU4MSVBRSVFOSU4MSU5MzUlMjAlRTklQUIlOTglRTklODAlOUYlRTMlODMlOTUlRTMlODMlQkMlRTMlODMlQUElRTMlODIlQTglRTUlQTQlODklRTYlOEYlOUIlMjBGRlQmdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT01NiZ0eHQtY2xpcD1lbGxpcHNpcyZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPTg5NzU3MTMxY2NjNjNmZDViMzM5ZmViZjYwMmZkZjQ0%26mark-x%3D142%26mark-y%3D112%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwVGFsb2theSZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTM2JnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnM9ZmVjNzdjMDA0MjVmN2M0ZGViNGIzY2M4NTAwMWIyYTg%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3D23f6d272863a10b44a690a9d3d0ebf55)