1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
|
/*
ZynAddSubFX - a software synthesizer
FilterParams.h - Parameters for filter
Copyright (C) 2002-2005 Nasca Octavian Paul
Author: Nasca Octavian Paul
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) 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 FILTER_PARAMS_H
#define FILTER_PARAMS_H
class FilterParams
{
public:
void
init(
float sample_rate,
unsigned char Ptype_,
unsigned char Pfreq,
unsigned char Pq_);
void defaults();
REALTYPE getfreq();
REALTYPE getq();
REALTYPE getfreqtracking(REALTYPE notefreq);
unsigned char m_category; // Filter category, one of ZYN_FILTER_TYPE_XXX
unsigned char Ptype;// Filter type (for analog lpf,hpf,bpf..)
unsigned char Pfreq;// Frequency (64-central frequency)
unsigned char Pq; // Q parameters (resonance or bandwidth)
unsigned char m_additional_stages; // filter stages, 0..4, 0 for one stage, 1 for two stages, etc. up to five stages
float m_frequency_tracking; //how the filter frequency is changing according the note frequency, -1 .. 1
float m_gain; // filter's output gain, in dB, -30 .. 30
//Formant filter parameters
unsigned char Pnumformants;//how many formants are used
unsigned char Pformantslowness;//how slow varies the formants
unsigned char Pvowelclearness;//how vowels are kept clean (how much try to avoid "mixed" vowels)
unsigned char Pcenterfreq,Poctavesfreq;//the center frequency of the res. func., and the number of octaves
struct {
struct {
unsigned char freq,amp,q;//frequency,amplitude,Q
}formants[FF_MAX_FORMANTS];
}Pvowels[FF_MAX_VOWELS];
unsigned char Psequencesize;//how many vowels are in the sequence
unsigned char Psequencestretch;//how the sequence is stretched (how the input from filter envelopes/LFOs/etc. is "stretched")
unsigned char Psequencereversed;//if the input from filter envelopes/LFOs/etc. is reversed(negated)
struct {
unsigned char nvowel;//the vowel from the position
} Psequence[FF_MAX_SEQUENCE];
REALTYPE getcenterfreq();
REALTYPE getoctavesfreq();
REALTYPE getfreqpos(REALTYPE freq);
REALTYPE getfreqx(REALTYPE x);
void formantfilterH(int nvowel,int nfreqs,REALTYPE *freqs);//used by UI
REALTYPE getformantfreq(unsigned char freq);
REALTYPE getformantamp(unsigned char amp);
REALTYPE getformantq(unsigned char q);
private:
void defaults(int n);
float m_sample_rate;
//stored default parameters
unsigned char Dtype;
unsigned char Dfreq;
unsigned char Dq;
};
#endif
|