Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00030
00032
00033
00034 #ifndef IIR_FILTER_HPP_
00035 #define IIR_FILTER_HPP_
00036
00037 #include <telekyb_defines/telekyb_defines.hpp>
00038 #include <telekyb_base/Time.hpp>
00039
00040 #include <vector>
00041 #include <list>
00042
00043 namespace TELEKYB_NAMESPACE
00044 {
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058 class IIRLowPass {};
00059 class IIRFiltDeriv {};
00060 class IIRLowPassButtW {};
00061 class IIRFiltDerivButtW {};
00062
00069 class IIRFilter{
00070 private:
00071 std::vector< std::vector<double> > _inCoeff;
00072 std::vector<double> _outCoeff;
00073 std::vector< std::list<double> > _pastIns;
00074 std::list<double> _pastOuts;
00075 int _order;
00076 int _inNum;
00077 std::list<double>::iterator outIt,inIt;
00078 int iCo,iIn;
00079
00080 void _kernelConstructor(std::vector< std::vector<double> > &inputCoeff,std::vector<double> &outputCoeff);
00081 public:
00082
00093 IIRFilter(std::vector<double> &inputCoeff,std::vector<double> &outputCoef);
00094
00105 IIRFilter(std::vector< std::vector<double> > &inputCoeff,std::vector<double> &outputCoef);
00106
00112 IIRFilter(IIRLowPass dummyType, double wn, double csi, double ts);
00113
00119 IIRFilter(IIRFiltDeriv dummyType, double wn, double csi, double ts);
00120
00121
00122
00123
00124
00130 IIRFilter(IIRLowPassButtW dummyType, double wn, double ts);
00131
00132
00133
00139 IIRFilter(IIRFiltDerivButtW dummyType, double wn, double ts);
00140
00141
00142
00143
00144 ~IIRFilter();
00145
00147 IIRFilter(const IIRFilter& t);
00148
00150 IIRFilter& operator=(const IIRFilter& t);
00151
00156 void step(double in,double& out);
00157
00161 void step(const std::vector<double>& in,double& out);
00162 };
00163
00164
00165
00166 }
00167 #endif
00168
00169
00170
00171