00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #ifndef EXTERNALFILTER_H
00024 #define EXTERNALFILTER_H
00025
00026 #include "siddefs-fp.h"
00027
00028 namespace reSIDfp
00029 {
00030
00051 class ExternalFilter
00052 {
00053 private:
00057 int Vlp;
00058
00062 int Vhp;
00063
00064 int w0lp_1_s7;
00065
00066 int w0hp_1_s17;
00067
00068 public:
00074 int clock(int Vi);
00075
00079 ExternalFilter();
00080
00086 void setClockFrequency(double frequency);
00087
00091 void reset();
00092 };
00093
00094 }
00095
00096 #if RESID_INLINING || defined(EXTERNALFILTER_CPP)
00097
00098 namespace reSIDfp
00099 {
00100
00101 RESID_INLINE
00102 int ExternalFilter::clock(int Vi)
00103 {
00104 const int dVlp = (w0lp_1_s7 * ((Vi << 11) - Vlp) >> 7);
00105 const int dVhp = (w0hp_1_s17 * (Vlp - Vhp) >> 17);
00106 Vlp += dVlp;
00107 Vhp += dVhp;
00108 return (Vlp - Vhp) >> 11;
00109 }
00110
00111 }
00112
00113 #endif
00114
00115 #endif