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:
parent
efc8d5c1e6
commit
9c7ab3fcf6
@ -551,12 +551,14 @@ 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");
|
||||||
|
if (arr != null) {
|
||||||
res.sample = new long[arr.size()];
|
res.sample = new long[arr.size()];
|
||||||
for (int i = 0; i < arr.size(); i++) {
|
for (int i = 0; i < arr.size(); i++) {
|
||||||
res.sample[i] = arr.getJsonNumber(i).longValue();
|
res.sample[i] = arr.getJsonNumber(i).longValue();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 {
|
||||||
|
if (vals.sample != null) {
|
||||||
for (long v : vals.sample) {
|
for (long v : vals.sample) {
|
||||||
getSample().update(v);
|
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();
|
||||||
|
@ -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[];
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user