/* * Copyright 2009 Phil Burk, Mobileer Inc * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * Aug 26, 2009 * com.jsyn.engine.units.TunableFilter.java */ package com.jsyn.unitgen; import com.jsyn.data.Function; import com.jsyn.ports.UnitFunctionPort; import com.jsyn.ports.UnitInputPort; /** * Convert an input value to an output value. The Function is typically implemented by looking up a * value in a DoubleTable. But other implementations of Function can be used. Input typically ranges * from -1.0 to +1.0. * *
 * 
 *     // A unit that will lookup the function.
 * 	FunctionEvaluator shaper = new FunctionEvaluator();
 * 	synth.add( shaper );
 * 	shaper.start();
 * 	// Define a custom function.
 * 	Function cuber = new Function()
 * 	{
 * 		public double evaluate( double x )
 * 		{
 * 			return x * x * x;
 * 		}
 * 	};
 * 	shaper.function.set(cuber);
 * 
 * 	shaper.input.set( 0.5 );
 *  
 * 
* * @author Phil Burk (C) 2009 Mobileer Inc * @see Function */ public class FunctionEvaluator extends UnitFilter { public UnitInputPort amplitude; public UnitFunctionPort function; public FunctionEvaluator() { addPort(amplitude = new UnitInputPort("Amplitude", 1.0)); addPort(function = new UnitFunctionPort("Function")); } @Override public void generate(int start, int limit) { double[] inputs = input.getValues(); double[] amplitudes = amplitude.getValues(); double[] outputs = output.getValues(); Function functionObject = function.get(); for (int i = start; i < limit; i++) { outputs[i] = functionObject.evaluate(inputs[i]) * amplitudes[i]; } } }