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 27 matching lines...) Expand all Loading... |
38 #include <ipps.h> | 38 #include <ipps.h> |
39 #endif // USE(WEBAUDIO_IPP) | 39 #endif // USE(WEBAUDIO_IPP) |
40 | 40 |
41 namespace WebCore { | 41 namespace WebCore { |
42 | 42 |
43 // A basic biquad (two-zero / two-pole digital filter) | 43 // A basic biquad (two-zero / two-pole digital filter) |
44 // | 44 // |
45 // It can be configured to a number of common and very useful filters: | 45 // It can be configured to a number of common and very useful filters: |
46 // lowpass, highpass, shelving, parameteric, notch, allpass, ... | 46 // lowpass, highpass, shelving, parameteric, notch, allpass, ... |
47 | 47 |
48 class PLATFORM_EXPORT Biquad { | 48 class PLATFORM_EXPORT Biquad FINAL { |
49 public: | 49 public: |
50 Biquad(); | 50 Biquad(); |
51 ~Biquad(); | 51 ~Biquad(); |
52 | 52 |
53 void process(const float* sourceP, float* destP, size_t framesToProcess); | 53 void process(const float* sourceP, float* destP, size_t framesToProcess); |
54 | 54 |
55 // frequency is 0 - 1 normalized, resonance and dbGain are in decibels. | 55 // frequency is 0 - 1 normalized, resonance and dbGain are in decibels. |
56 // Q is a unitless quality factor. | 56 // Q is a unitless quality factor. |
57 void setLowpassParams(double frequency, double resonance); | 57 void setLowpassParams(double frequency, double resonance); |
58 void setHighpassParams(double frequency, double resonance); | 58 void setHighpassParams(double frequency, double resonance); |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
109 double m_x1; // input delayed by 1 sample | 109 double m_x1; // input delayed by 1 sample |
110 double m_x2; // input delayed by 2 samples | 110 double m_x2; // input delayed by 2 samples |
111 double m_y1; // output delayed by 1 sample | 111 double m_y1; // output delayed by 1 sample |
112 double m_y2; // output delayed by 2 samples | 112 double m_y2; // output delayed by 2 samples |
113 #endif | 113 #endif |
114 }; | 114 }; |
115 | 115 |
116 } // namespace WebCore | 116 } // namespace WebCore |
117 | 117 |
118 #endif // Biquad_h | 118 #endif // Biquad_h |
OLD | NEW |