diff options
author | William Joye <wjoye@cfa.harvard.edu> | 2018-07-17 15:41:21 (GMT) |
---|---|---|
committer | William Joye <wjoye@cfa.harvard.edu> | 2018-07-17 15:41:21 (GMT) |
commit | ae7281e54851f21509eae19884fc865012f2d53d (patch) | |
tree | a52ae6219064fd0cf3edf67800f8855687f56866 | |
parent | c4f4ab752da20d5144273a201a382bf37e515e17 (diff) | |
parent | 02b9c714f6867eb7bcfd2806804ab395051cb661 (diff) | |
download | blt-ae7281e54851f21509eae19884fc865012f2d53d.zip blt-ae7281e54851f21509eae19884fc865012f2d53d.tar.gz blt-ae7281e54851f21509eae19884fc865012f2d53d.tar.bz2 |
Merge commit '02b9c714f6867eb7bcfd2806804ab395051cb661'
-rw-r--r-- | tkblt/generic/tkbltGrAxis.C | 28 |
1 files changed, 20 insertions, 8 deletions
diff --git a/tkblt/generic/tkbltGrAxis.C b/tkblt/generic/tkbltGrAxis.C index bac6316..8532600 100644 --- a/tkblt/generic/tkbltGrAxis.C +++ b/tkblt/generic/tkbltGrAxis.C @@ -819,18 +819,30 @@ void Axis::linearScale(double min, double max) double range = max - min; if (ops->reqStep > 0.0) { step = ops->reqStep; - while ((2 * step) >= range) + while ((2 * step) >= range && step >= (2 * DBL_EPSILON)) { step *= 0.5; - } + } + } else { range = niceNum(range, 0); step = niceNum(range / ops->reqNumMajorTicks, 1); } - - axisMin = tickMin = floor(min / step) * step + 0.0; - axisMax = tickMax = ceil(max / step) * step + 0.0; - - nTicks = (int)((tickMax-tickMin) / step) + 1; + if (step >= DBL_EPSILON) { + axisMin = tickMin = floor(min / step) * step + 0.0; + axisMax = tickMax = ceil(max / step) * step + 0.0; + nTicks = (int)((tickMax-tickMin) / step) + 1; + } else { + /* + * A zero step can result from having a too small range, such that + * the floating point can no longer represent fractions of it (think + * subnormals). In such a case, let's just have two steps: the + * minimum and the maximum. + */ + axisMin = tickMin = min; + axisMax = tickMax = min + DBL_EPSILON; + step = DBL_EPSILON; + nTicks = 2; + } } majorSweep_.step = step; majorSweep_.initial = tickMin; @@ -870,7 +882,7 @@ void Axis::setRange(AxisRange *rangePtr, double min, double max) rangePtr->max = max; rangePtr->range = max - min; if (fabs(rangePtr->range) < DBL_EPSILON) { - rangePtr->range = 1.0; + rangePtr->range = DBL_EPSILON; } rangePtr->scale = 1.0 / rangePtr->range; } |