Beispiel #1
0
static void activateNotch_iir(LADSPA_Handle instance) {
    Notch_iir *plugin_data = (Notch_iir *)instance;
    iir_stage_t*first = plugin_data->first;
    iirf_t*iirf1 = plugin_data->iirf1;
    iirf_t*iirf2 = plugin_data->iirf2;
    float lfc = plugin_data->lfc;
    long sample_rate = plugin_data->sample_rate;
    iir_stage_t*second = plugin_data->second;
    float ufc = plugin_data->ufc;

    ufc = (*(plugin_data->center) - *(plugin_data->width)*0.5f)/(float)sample_rate;
    lfc = (*(plugin_data->center) + *(plugin_data->width)*0.5f)/(float)sample_rate;
    first = init_iir_stage(IIR_STAGE_LOWPASS,10,3,2);
    second = init_iir_stage(IIR_STAGE_HIGHPASS,10,3,2);
    iirf1 = init_iirf_t(first);
    iirf2 = init_iirf_t(second);
    chebyshev(iirf1, first, 2*CLAMP((int)(*(plugin_data->stages)),1,10), IIR_STAGE_LOWPASS, ufc, 0.5f);
    chebyshev(iirf2, second, 2*CLAMP((int)(*(plugin_data->stages)),1,10), IIR_STAGE_HIGHPASS, lfc, 0.5f);
    plugin_data->first = first;
    plugin_data->iirf1 = iirf1;
    plugin_data->iirf2 = iirf2;
    plugin_data->lfc = lfc;
    plugin_data->sample_rate = sample_rate;
    plugin_data->second = second;
    plugin_data->ufc = ufc;

}
static void activateBandpass_iir(LADSPA_Handle instance) {
	Bandpass_iir *plugin_data = (Bandpass_iir *)instance;
	iir_stage_t*first = plugin_data->first;
	iir_stage_t*gt = plugin_data->gt;
	iirf_t*iirf = plugin_data->iirf;
	float lfc = plugin_data->lfc;
	long sample_rate = plugin_data->sample_rate;
	iir_stage_t*second = plugin_data->second;
	float ufc = plugin_data->ufc;
	
	ufc = (*(plugin_data->center) + *(plugin_data->width)*0.5f)/(float)sample_rate;
	lfc = (*(plugin_data->center) - *(plugin_data->width)*0.5f)/(float)sample_rate;
	first = init_iir_stage(IIR_STAGE_LOWPASS,10,3,2);
	second = init_iir_stage(IIR_STAGE_HIGHPASS,10,3,2);                  
	gt = init_iir_stage(IIR_STAGE_BANDPASS,20,3,2); 
	iirf = init_iirf_t(gt);
	chebyshev(iirf, first, 2*CLAMP((int)(*(plugin_data->stages)),1,10), IIR_STAGE_LOWPASS, ufc, 0.5f);
	chebyshev(iirf, second, 2*CLAMP((int)(*(plugin_data->stages)),1,10), IIR_STAGE_HIGHPASS, lfc, 0.5f);
	combine_iir_stages(IIR_STAGE_BANDPASS, gt, first, second,0,0);
	plugin_data->first = first;
	plugin_data->gt = gt;
	plugin_data->iirf = iirf;
	plugin_data->lfc = lfc;
	plugin_data->sample_rate = sample_rate;
	plugin_data->second = second;
	plugin_data->ufc = ufc;

}
static void activateHighpass_iir(LADSPA_Handle instance) {
	Highpass_iir *plugin_data = (Highpass_iir *)instance;
	iir_stage_t*gt = plugin_data->gt;
	iirf_t*iirf = plugin_data->iirf;
	long sample_rate = plugin_data->sample_rate;
	
	gt = init_iir_stage(IIR_STAGE_HIGHPASS,10,3,2);
	iirf = init_iirf_t(gt);
	chebyshev(iirf, gt, 2*CLAMP((int)(*(plugin_data->stages)),1,10), IIR_STAGE_HIGHPASS, *(plugin_data->cutoff)/(float)sample_rate, 0.5f);
	plugin_data->gt = gt;
	plugin_data->iirf = iirf;
	plugin_data->sample_rate = sample_rate;

}
Beispiel #4
0
static void activateBwxover_iir(LV2_Handle instance)
{
  Bwxover_iir *plugin_data = (Bwxover_iir *)instance;
  iirf_t* iirf __attribute__ ((unused)) = plugin_data->iirf;
  iir_stage_t* gt __attribute__ ((unused)) = plugin_data->gt;
  long sample_rate __attribute__ ((unused)) = plugin_data->sample_rate;
                    
                  plugin_data->gt = init_iir_stage(IIR_STAGE_LOWPASS,1,3,2);
                  plugin_data->iirf = init_iirf_t(plugin_data->gt);
                  butterworth_stage(plugin_data->gt, 0, *(plugin_data->cutoff), 
		  			   *(plugin_data->resonance), 
					   sample_rate);
                
}
static void activateButthigh_iir(LADSPA_Handle instance) {
	Butthigh_iir *plugin_data = (Butthigh_iir *)instance;
	iir_stage_t*gt = plugin_data->gt;
	iirf_t*iirf = plugin_data->iirf;
	long sample_rate = plugin_data->sample_rate;
	
	gt = init_iir_stage(IIR_STAGE_LOWPASS,1,3,2);
	iirf = init_iirf_t(gt);
	butterworth_stage(gt, 1, *(plugin_data->cutoff), 
	                           *(plugin_data->resonance), 
	                         sample_rate);
	plugin_data->gt = gt;
	plugin_data->iirf = iirf;
	plugin_data->sample_rate = sample_rate;

}
Beispiel #6
0
static void activateBandpass_iir(LV2_Handle instance)
{
  Bandpass_iir *plugin_data = (Bandpass_iir *)instance;
  iirf_t* iirf __attribute__ ((unused)) = plugin_data->iirf;
  iir_stage_t* gt __attribute__ ((unused)) = plugin_data->gt;
  iir_stage_t* first __attribute__ ((unused)) = plugin_data->first;
  iir_stage_t* second __attribute__ ((unused)) = plugin_data->second;
  long sample_rate __attribute__ ((unused)) = plugin_data->sample_rate;
  float ufc __attribute__ ((unused)) = plugin_data->ufc;
  float lfc __attribute__ ((unused)) = plugin_data->lfc;
                    
                  plugin_data->ufc = (*(plugin_data->center) + *(plugin_data->width)*0.5f)/(float)sample_rate;
                  plugin_data->lfc = (*(plugin_data->center) - *(plugin_data->width)*0.5f)/(float)sample_rate;
                  plugin_data->first = init_iir_stage(IIR_STAGE_LOWPASS,10,3,2);
                  plugin_data->second = init_iir_stage(IIR_STAGE_HIGHPASS,10,3,2);                  
                  plugin_data->gt = init_iir_stage(IIR_STAGE_BANDPASS,20,3,2); 
                  plugin_data->iirf = init_iirf_t(plugin_data->gt);
                  chebyshev(plugin_data->iirf, plugin_data->first, 2*CLAMP((int)(*(plugin_data->stages)),1,10), IIR_STAGE_LOWPASS, plugin_data->ufc, 0.5f);
                  chebyshev(plugin_data->iirf, plugin_data->second, 2*CLAMP((int)(*(plugin_data->stages)),1,10), IIR_STAGE_HIGHPASS, plugin_data->lfc, 0.5f);
                  combine_iir_stages(IIR_STAGE_BANDPASS, plugin_data->gt, plugin_data->first, plugin_data->second,0,0);
                
}