-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathMSHFAudioProcessing.m
52 lines (40 loc) · 1.46 KB
/
MSHFAudioProcessing.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#import "public/MSHFAudioProcessing.h"
@implementation MSHFAudioProcessing
- (id)initWithBufferSize:(int)bufferSize {
self = [super init];
numberOfFrames = bufferSize;
numberOfFramesOver2 = numberOfFrames / 2;
fftNormFactor = -1.0 / 256.0;
outReal = (float *)malloc(sizeof(float) * numberOfFramesOver2);
outImaginary = (float *)malloc(sizeof(float) * numberOfFramesOver2);
out = (float *)malloc(sizeof(float) * numberOfFramesOver2);
output.realp = outReal;
output.imagp = outImaginary;
bufferLog2 = round(log2(numberOfFrames));
fftSetup = vDSP_create_fftsetup(bufferLog2, kFFTRadix2);
window = (float *)malloc(sizeof(float) * numberOfFrames);
vDSP_hann_window(window, numberOfFrames, vDSP_HANN_NORM);
return self;
}
-(void)dealloc {
free(out);
free(outReal);
free(outImaginary);
free(window);
vDSP_destroy_fftsetup(fftSetup);
}
- (void)process:(float *)data withLength:(int)length {
if (!self.delegate)
return;
if (self.fft && length == numberOfFrames) {
vDSP_vmul(data, 1, window, 1, data, 1, numberOfFrames);
vDSP_ctoz((COMPLEX *)data, 2, &output, 1, numberOfFramesOver2);
vDSP_fft_zrip(fftSetup, &output, 1, bufferLog2, FFT_FORWARD);
vDSP_zvabs(&output, 1, out, 1, numberOfFramesOver2);
vDSP_vsmul(out, 1, &fftNormFactor, out, 1, numberOfFramesOver2);
[self.delegate setSampleData:out length:numberOfFramesOver2 / 8];
} else {
[self.delegate setSampleData:data length:length];
}
}
@end