| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * | 7 * |
| 8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 27 */ | 27 */ |
| 28 | 28 |
| 29 #ifndef FFTFrame_h | 29 #ifndef FFTFrame_h |
| 30 #define FFTFrame_h | 30 #define FFTFrame_h |
| 31 | 31 |
| 32 #include "platform/PlatformExport.h" | 32 #include "platform/PlatformExport.h" |
| 33 #include "platform/audio/AudioArray.h" | 33 #include "platform/audio/AudioArray.h" |
| 34 #include "wtf/Allocator.h" | 34 #include "wtf/Allocator.h" |
| 35 #include "wtf/Forward.h" | 35 #include "wtf/Forward.h" |
| 36 #include "wtf/PassOwnPtr.h" |
| 36 #include "wtf/Threading.h" | 37 #include "wtf/Threading.h" |
| 37 #include <memory> | |
| 38 | 38 |
| 39 #if OS(MACOSX) | 39 #if OS(MACOSX) |
| 40 #include <Accelerate/Accelerate.h> | 40 #include <Accelerate/Accelerate.h> |
| 41 #elif USE(WEBAUDIO_OPENMAX_DL_FFT) | 41 #elif USE(WEBAUDIO_OPENMAX_DL_FFT) |
| 42 #include <dl/sp/api/omxSP.h> | 42 #include <dl/sp/api/omxSP.h> |
| 43 #elif USE(WEBAUDIO_FFMPEG) | 43 #elif USE(WEBAUDIO_FFMPEG) |
| 44 struct RDFTContext; | 44 struct RDFTContext; |
| 45 #endif | 45 #endif |
| 46 | 46 |
| 47 namespace blink { | 47 namespace blink { |
| (...skipping 19 matching lines...) Expand all Loading... |
| 67 float* realData() const { return const_cast<float*>(m_realData.data()); } | 67 float* realData() const { return const_cast<float*>(m_realData.data()); } |
| 68 float* imagData() const { return const_cast<float*>(m_imagData.data()); } | 68 float* imagData() const { return const_cast<float*>(m_imagData.data()); } |
| 69 | 69 |
| 70 unsigned fftSize() const { return m_FFTSize; } | 70 unsigned fftSize() const { return m_FFTSize; } |
| 71 unsigned log2FFTSize() const { return m_log2FFTSize; } | 71 unsigned log2FFTSize() const { return m_log2FFTSize; } |
| 72 | 72 |
| 73 // CROSS-PLATFORM | 73 // CROSS-PLATFORM |
| 74 // The remaining public methods have cross-platform implementations: | 74 // The remaining public methods have cross-platform implementations: |
| 75 | 75 |
| 76 // Interpolates from frame1 -> frame2 as x goes from 0.0 -> 1.0 | 76 // Interpolates from frame1 -> frame2 as x goes from 0.0 -> 1.0 |
| 77 static std::unique_ptr<FFTFrame> createInterpolatedFrame(const FFTFrame& fra
me1, const FFTFrame& frame2, double x); | 77 static PassOwnPtr<FFTFrame> createInterpolatedFrame(const FFTFrame& frame1,
const FFTFrame& frame2, double x); |
| 78 void doPaddedFFT(const float* data, size_t dataSize); // zero-padding with d
ataSize <= fftSize | 78 void doPaddedFFT(const float* data, size_t dataSize); // zero-padding with d
ataSize <= fftSize |
| 79 double extractAverageGroupDelay(); | 79 double extractAverageGroupDelay(); |
| 80 void addConstantGroupDelay(double sampleFrameDelay); | 80 void addConstantGroupDelay(double sampleFrameDelay); |
| 81 void multiply(const FFTFrame&); // multiplies ourself with frame : effective
ly operator*=() | 81 void multiply(const FFTFrame&); // multiplies ourself with frame : effective
ly operator*=() |
| 82 | 82 |
| 83 private: | 83 private: |
| 84 void interpolateFrequencyComponents(const FFTFrame& frame1, const FFTFrame&
frame2, double x); | 84 void interpolateFrequencyComponents(const FFTFrame& frame1, const FFTFrame&
frame2, double x); |
| 85 | 85 |
| 86 unsigned m_FFTSize; | 86 unsigned m_FFTSize; |
| 87 unsigned m_log2FFTSize; | 87 unsigned m_log2FFTSize; |
| (...skipping 17 matching lines...) Expand all Loading... |
| 105 static OMXFFTSpec_R_F32* contextForSize(unsigned log2FFTSize); | 105 static OMXFFTSpec_R_F32* contextForSize(unsigned log2FFTSize); |
| 106 OMXFFTSpec_R_F32* m_forwardContext; | 106 OMXFFTSpec_R_F32* m_forwardContext; |
| 107 OMXFFTSpec_R_F32* m_inverseContext; | 107 OMXFFTSpec_R_F32* m_inverseContext; |
| 108 AudioFloatArray m_complexData; | 108 AudioFloatArray m_complexData; |
| 109 #endif | 109 #endif |
| 110 }; | 110 }; |
| 111 | 111 |
| 112 } // namespace blink | 112 } // namespace blink |
| 113 | 113 |
| 114 #endif // FFTFrame_h | 114 #endif // FFTFrame_h |
| OLD | NEW |