Fixed "off by one bucket" bug in range facet's binning algorithm.

git-svn-id: http://google-refine.googlecode.com/svn/trunk@336 7d457c2a-affb-35e4-300a-418c747d4874
This commit is contained in:
David Huynh 2010-03-22 22:04:29 +00:00
parent 19ba207d27
commit f5d270e35a
4 changed files with 17 additions and 7 deletions

View File

@ -73,7 +73,7 @@ public class ExpressionNumericRowBinner implements RowVisitor {
double d = ((Number) value).doubleValue(); double d = ((Number) value).doubleValue();
int bin = (int) Math.round((d - _index.getMin()) / _index.getStep()); int bin = (int) Math.floor((d - _index.getMin()) / _index.getStep());
bins[bin]++; bins[bin]++;
} else { } else {

View File

@ -62,12 +62,16 @@ public class NumericBinIndex {
} }
if (_min >= _max) { if (_min >= _max) {
_step = 0; _step = 1;
_min = 0;
_max = _step;
_bins = new int[1]; _bins = new int[1];
return; return;
} }
double diff = _max - _min; double diff = _max - _min;
_step = 1; _step = 1;
if (diff > 10) { if (diff > 10) {
while (_step * 100 < diff) { while (_step * 100 < diff) {
@ -79,18 +83,24 @@ public class NumericBinIndex {
} }
} }
double originalMax = _max;
_min = (Math.floor(_min / _step) * _step); _min = (Math.floor(_min / _step) * _step);
_max = (Math.ceil(_max / _step) * _step); _max = (Math.ceil(_max / _step) * _step);
int binCount = 1 + (int) Math.ceil((_max - _min) / _step); int binCount = (int) ((_max - _min) / _step);
if (binCount > 100) { if (binCount > 100) {
_step *= 2; _step *= 2;
binCount = Math.round((1 + binCount) / 2); binCount = Math.round((1 + binCount) / 2);
} }
if (_max <= originalMax) {
_max += _step;
binCount++;
}
_bins = new int[binCount]; _bins = new int[binCount];
for (double d : allValues) { for (double d : allValues) {
int bin = (int) Math.round((d - _min) / _step); int bin = (int) Math.floor((d - _min) / _step);
_bins[bin]++; _bins[bin]++;
} }
} }

View File

@ -172,7 +172,7 @@ public class RangeFacet implements Facet {
_eval, _cellIndex, _selectNumeric, _selectNonNumeric, _selectBlank, _selectError) { _eval, _cellIndex, _selectNumeric, _selectNonNumeric, _selectBlank, _selectError) {
protected boolean checkValue(double d) { protected boolean checkValue(double d) {
return d <= _to; return d < _to;
}; };
}; };
} else { } else {
@ -180,7 +180,7 @@ public class RangeFacet implements Facet {
_eval, _cellIndex, _selectNumeric, _selectNonNumeric, _selectBlank, _selectError) { _eval, _cellIndex, _selectNumeric, _selectNonNumeric, _selectBlank, _selectError) {
protected boolean checkValue(double d) { protected boolean checkValue(double d) {
return d >= _from && d <= _to; return d >= _from && d < _to;
}; };
}; };
} }

View File

@ -141,7 +141,7 @@ img {
.ui-widget-content a.ui-state-default.ui-slider-handle:last-child { .ui-widget-content a.ui-state-default.ui-slider-handle:last-child {
background: url(../images/slider-right-bracket.png) no-repeat bottom right; background: url(../images/slider-right-bracket.png) no-repeat bottom right;
border: none; border: none;
margin-left: -3px; margin-left: -2px;
top: -10px; top: -10px;
} }
.ui-slider .ui-slider-handle { .ui-slider .ui-slider-handle {