annotate C++/CARParam.H @ 592:76c6b3fd0a05

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