Mercurial > hg > aimc
comparison trunk/C++/CARParam.H @ 597:359bcd461dd1
First commit. Refer to the api [1] 'Philosophy of the implementation' for information on the approach used to implement CARFAC in C++.
[1] aimc/C++/api/html/index.html
author | flatmax |
---|---|
date | Sat, 09 Feb 2013 23:53:48 +0000 |
parents | |
children | 34dccba19c54 |
comparison
equal
deleted
inserted
replaced
596:b58758854b88 | 597:359bcd461dd1 |
---|---|
1 // Copyright 2013 Matt R. Flax <flatmax\@> All Rights Reserved. | |
2 // Author Matt Flax <flatmax\@> | |
3 // | |
4 // This C++ file is part of an implementation of Lyon's cochlear model: | |
5 // "Cascade of Asymmetric Resonators with Fast-Acting Compression" | |
6 // to supplement Lyon's upcoming book "Human and Machine Hearing" | |
7 // | |
8 // Licensed under the Apache License, Version 2.0 (the "License"); | |
9 // you may not use this file except in compliance with the License. | |
10 // You may obtain a copy of the License at | |
11 // | |
12 // http://www.apache.org/licenses/LICENSE-2.0 | |
13 // | |
14 // Unless required by applicable law or agreed to in writing, software | |
15 // distributed under the License is distributed on an "AS IS" BASIS, | |
16 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
17 // See the License for the specific language governing permissions and | |
18 // limitations under the License. | |
19 #ifndef CARPARAMS_H_ | |
20 #define CARPARAMS_H_ | |
21 | |
22 #include "Parameters.H" | |
23 | |
24 /** | |
25 \author {Matt Flax <flatmax\@>} | |
26 \date 2013.02.08 | |
27 | |
28 Parameters for the Cascaded Auditory Resonators | |
29 */ | |
30 class CARParam : public Parameters { | |
31 FP_TYPE velocity_scale; ///< for the velocity nonlinearity | |
32 FP_TYPE v_offset; ///< offset gives a quadratic part | |
33 FP_TYPE min_zeta; ///< minimum damping factor in mid-freq channels | |
34 FP_TYPE max_zeta; ///< maximum damping factor in mid-freq channels | |
35 FP_TYPE first_pole_theta; ///< Dick, whats this ? | |
36 FP_TYPE zero_ratio; ///< how far zero is above pole | |
37 FP_TYPE high_f_damping_compression; ///< 0 to 1 to compress zeta | |
38 FP_TYPE ERB_per_step; ///< assume G&M's ERB formula | |
39 FP_TYPE min_pole_Hz; ///< Dick, whats this ? | |
40 FP_TYPE ERB_break_freq; ///< Greenwood map's break freq. | |
41 FP_TYPE ERB_Q; ///< Glasberg and Moore's high-cf ratio | |
42 | |
43 public: | |
44 | |
45 /// Constructor with default parameter values | |
46 CARParam(FP_TYPE velocity_scale_=0.1, FP_TYPE v_offset_=0.04, FP_TYPE min_zeta_=0.10, FP_TYPE max_zeta_=0.35, | |
47 FP_TYPE first_pole_theta_=0.85*M_PI, FP_TYPE zero_ratio_=sqrt(2.), FP_TYPE high_f_damping_compression_=0.5, | |
48 FP_TYPE ERB_per_step_=0.5, FP_TYPE min_pole_Hz_=30., FP_TYPE ERB_break_freq_=165.3, | |
49 FP_TYPE ERB_Q_=1000./(24.7*4.37)); | |
50 virtual ~CARParam(); ///< Destructor | |
51 }; | |
52 | |
53 #endif // CARPARAMS_H_ |