plectrum

Plectrum: instrument tuner for Android
Log | Files | Refs | README | LICENSE

SineGenerator.java (1755B)


      1 /*
      2 *      _______                       _____   _____ _____  
      3 *     |__   __|                     |  __ \ / ____|  __ \ 
      4 *        | | __ _ _ __ ___  ___  ___| |  | | (___ | |__) |
      5 *        | |/ _` | '__/ __|/ _ \/ __| |  | |\___ \|  ___/ 
      6 *        | | (_| | |  \__ \ (_) \__ \ |__| |____) | |     
      7 *        |_|\__,_|_|  |___/\___/|___/_____/|_____/|_|     
      8 *                                                         
      9 * -------------------------------------------------------------
     10 *
     11 * TarsosDSP is developed by Joren Six at IPEM, University Ghent
     12 *  
     13 * -------------------------------------------------------------
     14 *
     15 *  Info: http://0110.be/tag/TarsosDSP
     16 *  Github: https://github.com/JorenSix/TarsosDSP
     17 *  Releases: http://0110.be/releases/TarsosDSP/
     18 *  
     19 *  TarsosDSP includes modified source code by various authors,
     20 *  for credits and info, see README.
     21 * 
     22 */
     23 
     24 package be.tarsos.dsp.synthesis;
     25 
     26 import be.tarsos.dsp.AudioEvent;
     27 import be.tarsos.dsp.AudioProcessor;
     28 
     29 public class SineGenerator implements AudioProcessor{
     30 	
     31 	private double gain;
     32 	private double frequency;
     33 	private double phase;
     34 	
     35 	public SineGenerator(){
     36 		this(1.0,440);
     37 	}
     38 	
     39 	public SineGenerator(double gain,double frequency){
     40 		this.gain = gain;
     41 		this.frequency = frequency;
     42 		this.phase = 0;
     43 	}
     44 
     45 	@Override
     46 	public boolean process(AudioEvent audioEvent) {
     47 		float[] buffer = audioEvent.getFloatBuffer();
     48 		double sampleRate = audioEvent.getSampleRate();
     49 		double twoPiF = 2 * Math.PI * frequency;
     50 		double time = 0;
     51 		for(int i = 0 ; i < buffer.length ; i++){
     52 			time = i / sampleRate;
     53 			buffer[i] += (float) (gain * Math.sin(twoPiF * time + phase));
     54 		}
     55 		phase = twoPiF * buffer.length / sampleRate + phase;
     56 		return true;
     57 	}
     58 
     59 	@Override
     60 	public void processingFinished() {
     61 	}
     62 }