Mercurial > hg > aimc
annotate carfac/ihc.h @ 643:8b70f4cf00c7
Additional changes to C++ CARFAC on the basis of ronw's comments on r289. Moved CARFAC::Design to CARFAC::CARFAC and CARFAC::Reset(), moved carfac_common.h to common.h, CARFACDetect to carfac_util.h/cc, FloatArray and Float2dArray to ArrayX and ArrayXX, improved variable naming, made a start on improved commenting documentation.
author | alexbrandmeyer |
---|---|
date | Tue, 04 Jun 2013 18:30:22 +0000 |
parents | |
children | e76951e4da20 |
rev | line source |
---|---|
alexbrandmeyer@643 | 1 // |
alexbrandmeyer@643 | 2 // ihc.h |
alexbrandmeyer@643 | 3 // CARFAC Open Source C++ Library |
alexbrandmeyer@643 | 4 // |
alexbrandmeyer@643 | 5 // Created by Alex Brandmeyer on 5/30/13. |
alexbrandmeyer@643 | 6 // |
alexbrandmeyer@643 | 7 // This C++ file is part of an implementation of Lyon's cochlear model: |
alexbrandmeyer@643 | 8 // "Cascade of Asymmetric Resonators with Fast-Acting Compression" |
alexbrandmeyer@643 | 9 // to supplement Lyon's upcoming book "Human and Machine Hearing" |
alexbrandmeyer@643 | 10 // |
alexbrandmeyer@643 | 11 // Licensed under the Apache License, Version 2.0 (the "License"); |
alexbrandmeyer@643 | 12 // you may not use this file except in compliance with the License. |
alexbrandmeyer@643 | 13 // You may obtain a copy of the License at |
alexbrandmeyer@643 | 14 // |
alexbrandmeyer@643 | 15 // http://www.apache.org/licenses/LICENSE-2.0 |
alexbrandmeyer@643 | 16 // |
alexbrandmeyer@643 | 17 // Unless required by applicable law or agreed to in writing, software |
alexbrandmeyer@643 | 18 // distributed under the License is distributed on an "AS IS" BASIS, |
alexbrandmeyer@643 | 19 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
alexbrandmeyer@643 | 20 // See the License for the specific language governing permissions and |
alexbrandmeyer@643 | 21 // limitations under the License. |
alexbrandmeyer@643 | 22 |
alexbrandmeyer@643 | 23 #ifndef CARFAC_IHC_H |
alexbrandmeyer@643 | 24 #define CARFAC_IHC_H |
alexbrandmeyer@643 | 25 |
alexbrandmeyer@643 | 26 #include "common.h" |
alexbrandmeyer@643 | 27 |
alexbrandmeyer@643 | 28 struct IHCParams { |
alexbrandmeyer@643 | 29 IHCParams() { |
alexbrandmeyer@643 | 30 just_half_wave_rectify = false; |
alexbrandmeyer@643 | 31 one_capacitor = true; |
alexbrandmeyer@643 | 32 tau_lpf = 0.000080; |
alexbrandmeyer@643 | 33 tau1_out = 0.0005; |
alexbrandmeyer@643 | 34 tau1_in = 0.010; |
alexbrandmeyer@643 | 35 tau2_out = 0.0025; |
alexbrandmeyer@643 | 36 tau2_in = 0.005; |
alexbrandmeyer@643 | 37 ac_corner_hz = 20.0; |
alexbrandmeyer@643 | 38 }; |
alexbrandmeyer@643 | 39 bool just_half_wave_rectify; |
alexbrandmeyer@643 | 40 bool one_capacitor; |
alexbrandmeyer@643 | 41 FPType tau_lpf; |
alexbrandmeyer@643 | 42 FPType tau1_out; |
alexbrandmeyer@643 | 43 FPType tau1_in; |
alexbrandmeyer@643 | 44 FPType tau2_out; |
alexbrandmeyer@643 | 45 FPType tau2_in; |
alexbrandmeyer@643 | 46 FPType ac_corner_hz; |
alexbrandmeyer@643 | 47 }; |
alexbrandmeyer@643 | 48 |
alexbrandmeyer@643 | 49 struct IHCCoeffs { |
alexbrandmeyer@643 | 50 bool just_half_wave_rectify; |
alexbrandmeyer@643 | 51 bool one_capacitor; |
alexbrandmeyer@643 | 52 FPType lpf_coeff; |
alexbrandmeyer@643 | 53 FPType out1_rate; |
alexbrandmeyer@643 | 54 FPType in1_rate; |
alexbrandmeyer@643 | 55 FPType out2_rate; |
alexbrandmeyer@643 | 56 FPType in2_rate; |
alexbrandmeyer@643 | 57 FPType output_gain; |
alexbrandmeyer@643 | 58 FPType rest_output; |
alexbrandmeyer@643 | 59 FPType rest_cap1; |
alexbrandmeyer@643 | 60 FPType rest_cap2; |
alexbrandmeyer@643 | 61 FPType ac_coeff; |
alexbrandmeyer@643 | 62 FPType cap1_voltage; |
alexbrandmeyer@643 | 63 FPType cap2_voltage; |
alexbrandmeyer@643 | 64 }; |
alexbrandmeyer@643 | 65 |
alexbrandmeyer@643 | 66 struct IHCState { |
alexbrandmeyer@643 | 67 ArrayX ihc_out; |
alexbrandmeyer@643 | 68 ArrayX ihc_accum; |
alexbrandmeyer@643 | 69 ArrayX cap1_voltage; |
alexbrandmeyer@643 | 70 ArrayX cap2_voltage; |
alexbrandmeyer@643 | 71 ArrayX lpf1_state; |
alexbrandmeyer@643 | 72 ArrayX lpf2_state; |
alexbrandmeyer@643 | 73 ArrayX ac_coupler; |
alexbrandmeyer@643 | 74 }; |
alexbrandmeyer@643 | 75 |
alexbrandmeyer@643 | 76 #endif // CARFAC_IHC_H |