All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.mentalog.util.DetailedBenchmarker Maven / Gradle / Ivy

There is a newer version: 2.1.2
Show newest version
package org.mentalog.util;

import java.text.NumberFormat;
import java.util.Iterator;
import java.util.Map;
import java.util.TreeMap;

public class DetailedBenchmarker extends Benchmarker {
	
	private TreeMap results = new TreeMap();
	private int size;
	
	public DetailedBenchmarker() {
	    super();
    }

	public DetailedBenchmarker(int warmup) {
	    super(warmup);
    }
	
	@Override
	public void reset() {
		super.reset();
		size = 0;
		results.clear();
	}
	
	@Override
	public boolean measure(long lastTime) {
		boolean counted = super.measure(lastTime);
		if (counted) {
			Integer count = results.get(lastTime);
			if (count == null) {
				results.put(lastTime, 1);
			} else {
				results.put(lastTime, count.intValue() + 1);
			}
			size++;
		}
		return counted;
	}
	
	private String formatPercentage(double x) {
		NumberFormat percentFormat = NumberFormat.getPercentInstance();
		percentFormat.setMaximumFractionDigits(3);
		return percentFormat.format(x);
	}
	
	private void addPercentile(StringBuilder sb, double perc) {
		
		if (results.isEmpty()) {
			return;
		}

		long max = -1;
		
		long x = Math.round(perc * size);
		Iterator> iter = results.entrySet().iterator();
		int i = 0;
		long sum = 0;
		while(iter.hasNext()) {
			Map.Entry entry = iter.next();
			long time = entry.getKey();
			int count = entry.getValue();
			i += count;
			sum += (count * time);
			if (i >= x) {
				max = time;
				break;
			}
		}
		sb.append(" | ").append(formatPercentage(perc)).append(": avg=").append(sum / i).append(" max=").append(max);
	}
	
	@Override
	public String results() {
		StringBuilder sb = new StringBuilder(super.results());

		addPercentile(sb, 0.75D);
		addPercentile(sb, 0.9D);
		addPercentile(sb, 0.99D);
		addPercentile(sb, 0.999D);
		addPercentile(sb, 0.9999D);
		addPercentile(sb, 0.99999D);
		
		return sb.toString();
	}
	
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy