plectrum

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

ZeroCrossingRateProcessor.java (1555B)


      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;
     25 
     26 /**
     27  * Calculates the zero crossing rate for a frame.
     28  * @author Joren Six
     29  *
     30  */
     31 public class ZeroCrossingRateProcessor implements AudioProcessor{
     32 
     33 	private float zeroCrossingRate = 0;
     34 	@Override
     35 	public boolean process(AudioEvent audioEvent) {
     36 		float[] buffer = audioEvent.getFloatBuffer();
     37 		
     38 		int numberOfZeroCrossings = 0;
     39 		for(int i = 1 ; i < buffer.length ; i++){
     40 			if(buffer[i] * buffer[i-1] < 0){
     41 				numberOfZeroCrossings++;
     42 			}
     43 		}
     44 		
     45 		zeroCrossingRate = numberOfZeroCrossings / (float) (buffer.length - 1);
     46 		
     47 		return true;
     48 	}
     49 	
     50 	public float getZeroCrossingRate(){
     51 		return zeroCrossingRate;
     52 	}
     53 
     54 	@Override
     55 	public void processingFinished() {
     56 	}
     57 
     58 }