flatmax@592: flatmax@592: flatmax@592:
flatmax@592: flatmax@592: flatmax@592:![]() |
flatmax@592:
flatmax@592:
flatmax@592:
flatmax@592: CARFAC C++
flatmax@592:
flatmax@592:
flatmax@592: C++ implementation of CARFAC
flatmax@592: |
flatmax@592:
flatmax@592:
flatmax@592:
flatmax@592:
00001 // Copyright 2013 Matt R. Flax <flatmax\@> All Rights Reserved. flatmax@594: 00002 // Author Matt Flax <flatmax@> flatmax@592: 00003 // flatmax@592: 00004 // This C++ file is part of an implementation of Lyon's cochlear model: flatmax@592: 00005 // "Cascade of Asymmetric Resonators with Fast-Acting Compression" flatmax@592: 00006 // to supplement Lyon's upcoming book "Human and Machine Hearing" flatmax@592: 00007 // flatmax@592: 00008 // Licensed under the Apache License, Version 2.0 (the "License"); flatmax@592: 00009 // you may not use this file except in compliance with the License. flatmax@592: 00010 // You may obtain a copy of the License at flatmax@592: 00011 // flatmax@592: 00012 // http://www.apache.org/licenses/LICENSE-2.0 flatmax@592: 00013 // flatmax@592: 00014 // Unless required by applicable law or agreed to in writing, software flatmax@592: 00015 // distributed under the License is distributed on an "AS IS" BASIS, flatmax@592: 00016 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. flatmax@592: 00017 // See the License for the specific language governing permissions and flatmax@592: 00018 // limitations under the License. flatmax@592: 00019 #ifndef CAR_H_ flatmax@592: 00020 #define CAR_H_ flatmax@592: 00021 flatmax@592: 00022 #include "EarComponent.H" // includes the various {CAR, IHC, AGC} {Coeff, Param, State} .H files flatmax@592: 00023 flatmax@594: 00024 class Ear; flatmax@594: 00025 flatmax@594: 00032 class CAR : public EarComponent<CARCoeff, CARParam, CARState> { flatmax@594: 00033 Array<FP_TYPE, Dynamic,1> pole_freqs; flatmax@594: 00034 flatmax@594: 00035 protected: flatmax@594: 00036 flatmax@594: 00040 void designFilters(FP_TYPE fs, int n_ch); flatmax@594: 00041 flatmax@594: 00046 Array<FP_TYPE, Dynamic, 1> stageG(Array<FP_TYPE, Dynamic, 1> &relative_undamping); flatmax@594: 00047 flatmax@594: 00048 public: flatmax@594: 00049 CAR(); flatmax@594: 00050 virtual ~CAR(); flatmax@594: 00051 flatmax@594: 00052 friend class Ear; flatmax@594: 00053 }; flatmax@594: 00054 flatmax@594: 00055 #endif // CAR_H_ flatmax@592: