APIHistogram: Use the new histogram parameter name

The use of mean and variance as histogram parameter names makes more
sense.

This also make it safe to use an empty histogram that holds no samples.

Signed-off-by: Amnon Heiman <amnon@cloudius-systems.com>
This commit is contained in:
Amnon Heiman 2015-10-04 12:42:38 +03:00
parent efc8d5c1e6
commit 9c7ab3fcf6
3 changed files with 19 additions and 9 deletions

View File

@ -551,11 +551,13 @@ public class APIClient {
res.min = obj.getJsonNumber("min").longValue(); res.min = obj.getJsonNumber("min").longValue();
res.sum = obj.getJsonNumber("sum").longValue(); res.sum = obj.getJsonNumber("sum").longValue();
res.variance = obj.getJsonNumber("variance").doubleValue(); res.variance = obj.getJsonNumber("variance").doubleValue();
res.svariance = obj.getJsonNumber("svariance").doubleValue(); res.mean = obj.getJsonNumber("mean").doubleValue();
JsonArray arr = obj.getJsonArray("sample"); JsonArray arr = obj.getJsonArray("sample");
res.sample = new long[arr.size()]; if (arr != null) {
for (int i = 0; i < arr.size(); i++) { res.sample = new long[arr.size()];
res.sample[i] = arr.getJsonNumber(i).longValue(); for (int i = 0; i < arr.size(); i++) {
res.sample[i] = arr.getJsonNumber(i).longValue();
}
} }
return res; return res;
} }

View File

@ -42,6 +42,12 @@ public class APIHistogram extends Histogram {
sampleField.setAccessible(true); sampleField.setAccessible(true);
countField = Histogram.class.getDeclaredField("count"); countField = Histogram.class.getDeclaredField("count");
countField.setAccessible(true); countField.setAccessible(true);
try {
getCount().set(0);
} catch (IllegalArgumentException | IllegalAccessException e) {
// There's no reason to get here
// and there's nothing we can do even if we would
}
} catch (NoSuchFieldException | SecurityException e) { } catch (NoSuchFieldException | SecurityException e) {
e.printStackTrace(); e.printStackTrace();
} }
@ -104,16 +110,18 @@ public class APIHistogram extends Histogram {
clear(); clear();
HistogramValues vals = c.getHistogramValue(url); HistogramValues vals = c.getHistogramValue(url);
try { try {
for (long v : vals.sample) { if (vals.sample != null) {
getSample().update(v); for (long v : vals.sample) {
getSample().update(v);
}
} }
getCount().set(vals.count); getCount().set(vals.count);
getMax().set(vals.max); getMax().set(vals.max);
getMin().set(vals.min); getMin().set(vals.min);
getSum().set(vals.sum); getSum().set(vals.sum);
double[] newValue = new double[2]; double[] newValue = new double[2];
newValue[0] = vals.variance; newValue[0] = vals.mean;
newValue[1] = vals.svariance; newValue[1] = vals.variance;
getVariance().getAndSet(newValue); getVariance().getAndSet(newValue);
} catch (IllegalArgumentException | IllegalAccessException e) { } catch (IllegalArgumentException | IllegalAccessException e) {
e.printStackTrace(); e.printStackTrace();

View File

@ -6,6 +6,6 @@ public class HistogramValues {
public long max; public long max;
public long sum; public long sum;
public double variance; public double variance;
public double svariance; public double mean;
public long sample[]; public long sample[];
} }