// // Plug-in: "MDA SpecMeter" // // Copyright(c)1999-2000 Paul Kellett (maxim digital audio) // Copyright (C) 2008 Dave Robillard // #include "audioeffectx.h" #include #define SILENCE 0.00000001f enum { _PARAM0, // gain NPARAMS }; class mdaSpecMeter; class mdaSpecMeterProgram { friend class mdaSpecMeter; public: mdaSpecMeterProgram(); ~mdaSpecMeterProgram() {} private: float param[NPARAMS]; char name[24]; }; class mdaSpecMeter : public AudioEffectX { public: mdaSpecMeter(audioMasterCallback audioMaster); ~mdaSpecMeter(); virtual void process(float **inputs, float **outputs, LvzInt32 sampleFrames); virtual void processReplacing(float **inputs, float **outputs, LvzInt32 sampleFrames); virtual void setProgram(LvzInt32 program); virtual void setProgramName(char *name); virtual void getProgramName(char *name); virtual void setParameter(LvzInt32 index, float value); virtual float getParameter(LvzInt32 index); virtual void getParameterLabel(LvzInt32 index, char *label); virtual void getParameterDisplay(LvzInt32 index, char *text); virtual void getParameterName(LvzInt32 index, char *text); virtual void setSampleRate(float sampleRate); virtual void suspend(); virtual bool getEffectName(char *name); virtual bool getVendorString(char *text); virtual bool getProductString(char *text); virtual LvzInt32 getVendorVersion() { return 1000; } //accessible from editor long counter; float Lpeak, Lhold, Lmin, Lrms, Rpeak, Rhold, Rmin, Rrms, Corr; // #11 #12 float band[2][16]; //8 16 31 64 125 250 500 1k 2k 4k 8k 16k 32k private: mdaSpecMeterProgram *programs; float param[NPARAMS]; float iK, lpeak, lmin, lrms, rpeak, rmin, rrms, corr, den; float lpp[6][16], rpp[6][16]; long topband, K, kmax; float gain; };