flatmax@674
|
1
|
flatmax@598
|
2 // Author Matt Flax <flatmax@>
|
flatmax@597
|
3 //
|
flatmax@597
|
4 // This C++ file is part of an implementation of Lyon's cochlear model:
|
flatmax@597
|
5 // "Cascade of Asymmetric Resonators with Fast-Acting Compression"
|
flatmax@597
|
6 // to supplement Lyon's upcoming book "Human and Machine Hearing"
|
flatmax@597
|
7 //
|
flatmax@597
|
8 // Licensed under the Apache License, Version 2.0 (the "License");
|
flatmax@597
|
9 // you may not use this file except in compliance with the License.
|
flatmax@597
|
10 // You may obtain a copy of the License at
|
flatmax@597
|
11 //
|
flatmax@597
|
12 // http://www.apache.org/licenses/LICENSE-2.0
|
flatmax@597
|
13 //
|
flatmax@597
|
14 // Unless required by applicable law or agreed to in writing, software
|
flatmax@597
|
15 // distributed under the License is distributed on an "AS IS" BASIS,
|
flatmax@597
|
16 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
flatmax@597
|
17 // See the License for the specific language governing permissions and
|
flatmax@597
|
18 // limitations under the License.
|
flatmax@597
|
19 #ifndef CAR_H_
|
flatmax@597
|
20 #define CAR_H_
|
flatmax@597
|
21
|
flatmax@597
|
22 #include "EarComponent.H" // includes the various {CAR, IHC, AGC} {Coeff, Param, State} .H files
|
flatmax@597
|
23
|
flatmax@598
|
24 class Ear;
|
flatmax@598
|
25
|
flatmax@597
|
26 /**
|
flatmax@597
|
27 \author {Matt Flax <flatmax\@>}
|
flatmax@597
|
28 \date 2013.02.08
|
flatmax@597
|
29
|
flatmax@597
|
30 Cascade of asymmetric resonators (CAR).
|
flatmax@597
|
31 */
|
flatmax@597
|
32 class CAR : public EarComponent<CARCoeff, CARParam, CARState> {
|
flatmax@598
|
33 Array<FP_TYPE, Dynamic,1> pole_freqs; ///< The vector of pole frequencies used in filter design and variable estimation
|
flatmax@598
|
34
|
flatmax@598
|
35 protected:
|
flatmax@598
|
36
|
flatmax@598
|
37 /** Method to design the auditory filter coefficients
|
flatmax@598
|
38 \param fs The sample rate in Hz
|
flatmax@612
|
39 \param n_ch The number of channels. The CAR.coeff are one row per channel
|
flatmax@598
|
40 */
|
flatmax@598
|
41 void designFilters(FP_TYPE fs, int n_ch);
|
flatmax@598
|
42
|
flatmax@598
|
43 /** Return the stage gain g needed to get unity gain at DC
|
flatmax@598
|
44 \param relative_undamping Dick whats this ?
|
flatmax@598
|
45 \return The stage gain required to obtain 0 dB at DC.
|
flatmax@598
|
46 */
|
flatmax@598
|
47 Array<FP_TYPE, Dynamic, 1> stageG(Array<FP_TYPE, Dynamic, 1> &relative_undamping);
|
flatmax@598
|
48
|
flatmax@597
|
49 public:
|
flatmax@597
|
50 CAR();
|
flatmax@597
|
51 virtual ~CAR();
|
flatmax@598
|
52
|
flatmax@598
|
53 friend class Ear;
|
flatmax@597
|
54 };
|
flatmax@597
|
55
|
flatmax@597
|
56 #endif // CAR_H_
|