00001
00002
00003
00004
00005
00006
00010
00011 #ifndef CSL_FIR_H
00012 #define CSL_FIR_H
00013
00014 #include "CSL_Core.h"
00015
00016 namespace csl {
00017
00018
00019 class FIR;
00020
00024
00025 class FilterSpecification {
00026 public:
00027
00028 friend class FIR;
00029
00030
00031 FilterSpecification(unsigned numTaps = 0, unsigned numBands = 0, double *freqs = NULL, double *resps = NULL, double *weights = NULL);
00032 ~FilterSpecification();
00033
00034
00035 void setFrequencies(double *frequencies);
00036 void setResponses(double *responses);
00037 void setWeights(double *weights);
00038 void setNumTaps(unsigned numTaps);
00039
00040 void planFilter();
00041 double *mTapData;
00042
00043 protected:
00044 unsigned mNumTaps;
00045 unsigned mNumBands;
00046 double *mFrequencies;
00047 double *mResponses;
00048 double *mWeights;
00049
00050 };
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00072
00073 class FIR : public Effect {
00074
00075 public:
00076
00077 FIR (UnitGenerator & in, unsigned numTaps = 2, float * tapDelay = NULL);
00078
00079 FIR (FilterSpecification & fs);
00080 FIR (UnitGenerator & in, char * fileName);
00081 FIR (UnitGenerator & in, FilterSpecification & fs);
00082 ~FIR ();
00083
00084 void setTaps(unsigned numTaps, float *tapDelays);
00085 void readTaps(char *fileName);
00086
00087 void nextBuffer(Buffer &outputBuffer, unsigned outBufNum) throw (CException);
00088
00089 protected:
00090 FilterSpecification *mFilterSpec;
00091 unsigned mOffset;
00092
00093 sample *mDLine;
00094
00095 void resetDLine();
00096
00097
00098 void remez(double h[], int numtaps, int numband, double bands[], double des[], double weight[], int type);
00099
00100 };
00101
00102 }
00103
00104 #endif