zynaddsubfx

ZynAddSubFX open source synthesizer
Log | Files | Refs | Submodules | LICENSE

Filter.cpp (2367B)


      1 /*
      2   ZynAddSubFX - a software synthesizer
      3 
      4   Filter.cpp - Filters, uses analog,formant,etc. filters
      5   Copyright (C) 2002-2005 Nasca Octavian Paul
      6   Author: Nasca Octavian Paul
      7 
      8   This program is free software; you can redistribute it and/or
      9   modify it under the terms of the GNU General Public License
     10   as published by the Free Software Foundation; either version 2
     11   of the License, or (at your option) any later version.
     12 */
     13 
     14 #include <cmath>
     15 #include <cstdio>
     16 #include <cassert>
     17 
     18 #include "Filter.h"
     19 #include "AnalogFilter.h"
     20 #include "FormantFilter.h"
     21 #include "SVFilter.h"
     22 #include "MoogFilter.h"
     23 #include "CombFilter.h"
     24 #include "../Params/FilterParams.h"
     25 #include "../Misc/Allocator.h"
     26 
     27 namespace zyn {
     28 
     29 Filter::Filter(unsigned int srate, int bufsize)
     30     : outgain(1.0f),
     31       samplerate(srate),
     32       buffersize(bufsize)
     33 {
     34     alias();
     35 }
     36 
     37 Filter *Filter::generate(Allocator &memory, const FilterParams *pars,
     38         unsigned int srate, int bufsize)
     39 {
     40     assert(srate != 0);
     41     assert(bufsize != 0);
     42 
     43     unsigned char Ftype   = pars->Ptype;
     44     unsigned char Fstages = pars->Pstages;
     45 
     46     Filter *filter;
     47     switch(pars->Pcategory) {
     48         case 1:
     49             filter = memory.alloc<FormantFilter>(pars, &memory, srate, bufsize);
     50             break;
     51         case 2:
     52             filter = memory.alloc<SVFilter>(Ftype, 1000.0f, pars->getq(), Fstages, srate, bufsize);
     53             filter->outgain = dB2rap(pars->getgain());
     54             if(filter->outgain > 1.0f)
     55                 filter->outgain = sqrt(filter->outgain);
     56             break;
     57         case 3:
     58             filter = memory.alloc<MoogFilter>(Ftype, 1000.0f, pars->getq(), srate, bufsize);
     59             filter->setgain(pars->getgain());
     60             break;
     61         case 4:
     62             filter = memory.alloc<CombFilter>(&memory, Ftype, 1000.0f, pars->getq(), srate, bufsize);
     63             filter->setgain(pars->getgain());
     64             break;
     65         default:
     66             filter = memory.alloc<AnalogFilter>(Ftype, 1000.0f, pars->getq(), Fstages, srate, bufsize);
     67             if((Ftype >= 6) && (Ftype <= 8))
     68                 filter->setgain(pars->getgain());
     69             else
     70                 filter->outgain = dB2rap(pars->getgain());
     71             break;
     72     }
     73     return filter;
     74 }
     75 
     76 float Filter::getrealfreq(float freqpitch)
     77 {
     78     return powf(2.0f, freqpitch + 9.96578428f); //log2(1000)=9.95748f
     79 }
     80 
     81 }