HistogramVisual: put min. and max. in quantile array

This commit is contained in:
Nelson Ray 2012-11-06 16:55:35 -08:00
parent 0a42f18cc3
commit 217caa3a04
3 changed files with 10 additions and 18 deletions

View File

@ -132,10 +132,15 @@ public class Histogram
return buf.array();
}
/**
* Returns a visual representation of a histogram object.
* Initially returns an array of just the min. and max. values
* but can also support the addition of quantiles.
*/
public HistogramVisual asVisual() {
float[] visualCounts = new float[bins.length - 2];
for(int i = 0; i < visualCounts.length; ++i) visualCounts[i] = (float)bins[i + 1];
return new HistogramVisual(breaks, visualCounts, new float[]{}, min, max);
return new HistogramVisual(breaks, visualCounts, new float[]{min, max});
}
public static Histogram fromBytes(byte[] bytes) {

View File

@ -29,17 +29,14 @@ public class HistogramVisual
{
@JsonProperty final public double[] breaks;
@JsonProperty final public double[] counts;
// an array of the quantiles including the min. and max.
@JsonProperty final public double[] quantiles;
@JsonProperty final double min;
@JsonProperty final double max;
@JsonCreator
public HistogramVisual(
@JsonProperty double[] breaks,
@JsonProperty double[] counts,
@JsonProperty double[] quantiles,
@JsonProperty double min,
@JsonProperty double max
@JsonProperty double[] quantiles
)
{
Preconditions.checkArgument(breaks != null, "breaks must not be null");
@ -49,16 +46,12 @@ public class HistogramVisual
this.breaks = breaks;
this.counts = counts;
this.quantiles = quantiles;
this.min = min;
this.max = max;
}
public HistogramVisual(
float[] breaks,
float[] counts,
float[] quantiles,
float min,
float max
float[] quantiles
)
{
Preconditions.checkArgument(breaks != null, "breaks must not be null");
@ -71,8 +64,6 @@ public class HistogramVisual
for(int i = 0; i < breaks.length; ++i) this.breaks[i] = breaks[i];
for(int i = 0; i < counts.length; ++i) this.counts[i] = counts[i];
for(int i = 0; i < quantiles.length; ++i) this.quantiles[i] = quantiles[i];
this.min = min;
this.max = max;
}
@Override
@ -81,9 +72,7 @@ public class HistogramVisual
return "HistogramVisual{" +
"counts=" + Arrays.toString(counts) +
", breaks=" + Arrays.toString(breaks) +
", min=" + min +
", quantiles=" + Arrays.toString(quantiles) +
", max=" + max +
'}';
}
}

View File

@ -68,9 +68,7 @@ public class HistogramTest
Map<String,Object> expectedObj = Maps.newLinkedHashMap();
expectedObj.put("breaks", Arrays.asList(visualBreaks));
expectedObj.put("counts", Arrays.asList(visualCounts));
expectedObj.put("quantiles", Arrays.asList(new Double[]{}));
expectedObj.put("min", -1.0);
expectedObj.put("max", 1.0);
expectedObj.put("quantiles", Arrays.asList(new Double[]{-1.0, 1.0}));
Map<String,Object> obj = (Map<String, Object>)objectMapper.readValue(json, Object.class);
Assert.assertEquals(expectedObj, obj);