Mercurial > hg > aimc
annotate carfac/ihc.h @ 662:7e18c84ca2b7
Small cleanup of eigen usage in SAI implementation.
author | ronw@google.com |
---|---|
date | Tue, 16 Jul 2013 19:56:11 +0000 |
parents | e76951e4da20 |
children |
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 |
ronw@646 | 28 // Inner hair cell (IHC) parameters, which are used to design the IHC filters. |
alexbrandmeyer@643 | 29 struct IHCParams { |
alexbrandmeyer@643 | 30 IHCParams() { |
alexbrandmeyer@643 | 31 just_half_wave_rectify = false; |
alexbrandmeyer@643 | 32 one_capacitor = true; |
alexbrandmeyer@643 | 33 tau_lpf = 0.000080; |
alexbrandmeyer@643 | 34 tau1_out = 0.0005; |
alexbrandmeyer@643 | 35 tau1_in = 0.010; |
alexbrandmeyer@643 | 36 tau2_out = 0.0025; |
alexbrandmeyer@643 | 37 tau2_in = 0.005; |
alexbrandmeyer@643 | 38 ac_corner_hz = 20.0; |
ronw@646 | 39 } |
ronw@646 | 40 |
alexbrandmeyer@643 | 41 bool just_half_wave_rectify; |
alexbrandmeyer@643 | 42 bool one_capacitor; |
alexbrandmeyer@643 | 43 FPType tau_lpf; |
alexbrandmeyer@643 | 44 FPType tau1_out; |
alexbrandmeyer@643 | 45 FPType tau1_in; |
alexbrandmeyer@643 | 46 FPType tau2_out; |
alexbrandmeyer@643 | 47 FPType tau2_in; |
alexbrandmeyer@643 | 48 FPType ac_corner_hz; |
alexbrandmeyer@643 | 49 }; |
alexbrandmeyer@643 | 50 |
ronw@646 | 51 // Inner hair cell filter coefficients, which are derived from a set of |
ronw@646 | 52 // IHCParams. |
alexbrandmeyer@643 | 53 struct IHCCoeffs { |
alexbrandmeyer@643 | 54 bool just_half_wave_rectify; |
alexbrandmeyer@643 | 55 bool one_capacitor; |
alexbrandmeyer@643 | 56 FPType lpf_coeff; |
alexbrandmeyer@643 | 57 FPType out1_rate; |
alexbrandmeyer@643 | 58 FPType in1_rate; |
alexbrandmeyer@643 | 59 FPType out2_rate; |
alexbrandmeyer@643 | 60 FPType in2_rate; |
alexbrandmeyer@643 | 61 FPType output_gain; |
alexbrandmeyer@643 | 62 FPType rest_output; |
alexbrandmeyer@643 | 63 FPType rest_cap1; |
alexbrandmeyer@643 | 64 FPType rest_cap2; |
alexbrandmeyer@643 | 65 FPType ac_coeff; |
alexbrandmeyer@643 | 66 FPType cap1_voltage; |
alexbrandmeyer@643 | 67 FPType cap2_voltage; |
alexbrandmeyer@643 | 68 }; |
alexbrandmeyer@643 | 69 |
ronw@646 | 70 // Inner hair cell filter state. |
alexbrandmeyer@643 | 71 struct IHCState { |
alexbrandmeyer@643 | 72 ArrayX ihc_out; |
alexbrandmeyer@643 | 73 ArrayX ihc_accum; |
alexbrandmeyer@643 | 74 ArrayX cap1_voltage; |
alexbrandmeyer@643 | 75 ArrayX cap2_voltage; |
alexbrandmeyer@643 | 76 ArrayX lpf1_state; |
alexbrandmeyer@643 | 77 ArrayX lpf2_state; |
alexbrandmeyer@643 | 78 ArrayX ac_coupler; |
alexbrandmeyer@643 | 79 }; |
alexbrandmeyer@643 | 80 |
ronw@646 | 81 #endif // CARFAC_IHC_H |