|
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- /*
- ZynAddSubFX - a software synthesizer
-
- Phaser.h - Phaser effect
- Copyright (C) 2002-2005 Nasca Octavian Paul
- Copyright (C) 2009-2010 Ryan Billing
- Copyright (C) 2010-2010 Mark McCurry
- Author: Nasca Octavian Paul
- Ryan Billing
- Mark McCurry
-
- This program is free software; you can redistribute it and/or modify
- it under the terms of version 2 of the GNU General Public License
- as published by the Free Software Foundation.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License (version 2 or later) for more details.
-
- You should have received a copy of the GNU General Public License (version 2)
- along with this program; if not, write to the Free Software Foundation,
- Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-
- */
-
- #ifndef PHASER_H
- #define PHASER_H
- #include "../globals.h"
- #include "Effect.h"
- #include "EffectLFO.h"
-
- #define MAX_PHASER_STAGES 12
-
- class Phaser:public Effect
- {
- public:
- Phaser(const int &insertion_, float *efxoutl_, float *efxoutr_, unsigned int srate, int bufsize);
- ~Phaser();
- void out(const Stereo<float *> &input);
- void setpreset(unsigned char npreset);
- void changepar(int npar, unsigned char value);
- unsigned char getpar(int npar) const;
- void cleanup();
-
- private:
- //Phaser parameters
- EffectLFO lfo; //Phaser modulator
- unsigned char Pvolume; //Used to set wet/dry mix
- unsigned char Pdistortion; //Model distortion added by FET element
- unsigned char Pdepth; //Depth of phaser sweep
- unsigned char Pwidth; //Phaser width (LFO amplitude)
- unsigned char Pfb; //feedback
- unsigned char Poffset; //Model mismatch between variable resistors
- unsigned char Pstages; //Number of first-order All-Pass stages
- unsigned char Poutsub; //if I wish to subtract the output instead of adding
- unsigned char Pphase;
- unsigned char Phyper; //lfo^2 -- converts tri into hyper-sine
- unsigned char Panalog;
-
- //Control parameters
- void setvolume(unsigned char Pvolume);
- void setdepth(unsigned char Pdepth);
- void setfb(unsigned char Pfb);
- void setdistortion(unsigned char Pdistortion);
- void setwidth(unsigned char Pwidth);
- void setoffset(unsigned char Poffset);
- void setstages(unsigned char Pstages);
- void setphase(unsigned char Pphase);
-
- //Internal Variables
- bool barber; //Barber pole phasing flag
- float distortion, width, offsetpct;
- float feedback, depth, phase;
- Stereo<float *> old, xn1, yn1;
- Stereo<float> diff, oldgain, fb;
- float invperiod;
- float offset[12];
-
- float mis;
- float Rmin; // 3N5457 typical on resistance at Vgs = 0
- float Rmax; // Resistor parallel to FET
- float Rmx; // Rmin/Rmax to avoid division in loop
- float Rconst; // Handle parallel resistor relationship
- float C; // Capacitor
- float CFs; // A constant derived from capacitor and resistor relationships
-
- void analog_setup();
- void AnalogPhase(const Stereo<float *> &input);
- //analog case
- float applyPhase(float x, float g, float fb,
- float &hpf, float *yn1, float *xn1);
-
- void normalPhase(const Stereo<float *> &input);
- float applyPhase(float x, float g, float *old);
- };
-
- #endif
|