annotate carfac/ear_output.h @ 611:0fbaf443ec82

Carfac C++ revision 3, indluding more style improvements. The output structs are now classes again, and have separate storage methods for each output structure along with flags in the Run and RunSegment methods to allow for only storing NAPs if desired.
author alexbrandmeyer
date Fri, 17 May 2013 19:52:45 +0000
parents 01986636257a
children 586b0677aae8
rev   line source
alexbrandmeyer@609 1 //
alexbrandmeyer@609 2 // ear_output.h
alexbrandmeyer@609 3 // CARFAC Open Source C++ Library
alexbrandmeyer@609 4 //
alexbrandmeyer@609 5 // Created by Alex Brandmeyer on 5/10/13.
alexbrandmeyer@609 6 //
alexbrandmeyer@609 7 // This C++ file is part of an implementation of Lyon's cochlear model:
alexbrandmeyer@609 8 // "Cascade of Asymmetric Resonators with Fast-Acting Compression"
alexbrandmeyer@609 9 // to supplement Lyon's upcoming book "Human and Machine Hearing"
alexbrandmeyer@609 10 //
alexbrandmeyer@609 11 // Licensed under the Apache License, Version 2.0 (the "License");
alexbrandmeyer@609 12 // you may not use this file except in compliance with the License.
alexbrandmeyer@609 13 // You may obtain a copy of the License at
alexbrandmeyer@609 14 //
alexbrandmeyer@609 15 // http://www.apache.org/licenses/LICENSE-2.0
alexbrandmeyer@609 16 //
alexbrandmeyer@609 17 // Unless required by applicable law or agreed to in writing, software
alexbrandmeyer@609 18 // distributed under the License is distributed on an "AS IS" BASIS,
alexbrandmeyer@609 19 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
alexbrandmeyer@609 20 // See the License for the specific language governing permissions and
alexbrandmeyer@609 21 // limitations under the License.
alexbrandmeyer@609 22
alexbrandmeyer@609 23 #ifndef CARFAC_Open_Source_C___Library_ear_output_h
alexbrandmeyer@609 24 #define CARFAC_Open_Source_C___Library_ear_output_h
alexbrandmeyer@609 25
alexbrandmeyer@609 26 #include "carfac_common.h"
alexbrandmeyer@609 27
alexbrandmeyer@611 28 class EarOutput {
alexbrandmeyer@611 29 public:
alexbrandmeyer@611 30 void InitOutput(int n_ch, int32_t n_tp);
alexbrandmeyer@611 31 void MergeOutput(EarOutput output, int32_t start, int32_t length);
alexbrandmeyer@611 32 void StoreNAPOutput(int32_t timepoint, int n_ch, FloatArray nap);
alexbrandmeyer@611 33 void StoreBMOutput(int32_t timepoint, int n_ch, FloatArray bm);
alexbrandmeyer@611 34 void StoreOHCOutput(int32_t timepoint, int n_ch, FloatArray ohc);
alexbrandmeyer@611 35 void StoreAGCOutput(int32_t timepoint, int n_ch, FloatArray agc);
alexbrandmeyer@611 36 private:
alexbrandmeyer@609 37 int n_ch_;
alexbrandmeyer@611 38 int32_t n_timepoints_;
alexbrandmeyer@609 39 FloatArray2d nap_;
alexbrandmeyer@609 40 FloatArray2d nap_decim_;
alexbrandmeyer@609 41 FloatArray2d ohc_;
alexbrandmeyer@609 42 FloatArray2d agc_;
alexbrandmeyer@609 43 FloatArray2d bm_;
alexbrandmeyer@609 44 };
alexbrandmeyer@609 45
alexbrandmeyer@610 46 #endif