本文介绍了从长数组计算百分位数?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
鉴于一长串的延迟(以毫秒为单位),我想根据它们计算百分位数.我得到了以下起作用的方法,但是我不确定如何验证这是否给了我准确的结果?
Given a long array of latencies which are in milliseconds, I want to calculate percentile from them. I got below method which does the work but I am not sure how I can verify whether this gives me accurate result?
public static long[] percentiles(long[] latencies, double... percentiles) {
Arrays.sort(latencies, 0, latencies.length);
long[] values = new long[percentiles.length];
for (int i = 0; i < percentiles.length; i++) {
int index = (int) (percentiles[i] * latencies.length);
values[i] = latencies[index];
}
return values;
}
我想从 latency
数组中获得第50、95、99和99.9%的百分位数.
I would like to get 50th, 95th, 99th and 99.9th percentile from latencies
array.
long[] percs = percentiles(latencies, 0.5, 0.95, 0.99, 0.999);
在很长的等待时间下,这是否是获得百分位数的正确方法?我正在使用 Java 7.
Is this the right way to get percentile given a long array of latencies? I am working with Java 7.
推荐答案
这是您要寻找的:
public static void main(String[] args) {
List<Long> latencies = new List<Long>() { 3, 6, 7, 8, 8, 9, 10, 13, 15, 16, 20 };
System.out.println(percentile(latencies,25));
System.out.println(percentile(latencies, 50));
System.out.println(percentile(latencies, 75));
System.out.println(percentile(latencies, 100));
}
public static long percentile(List<Long> latencies, double percentile) {
Collections.sort(latencies);
int index = (int) Math.ceil(percentile / 100.0 * latencies.size());
return latencies.get(index-1);
}
这篇关于从长数组计算百分位数?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!