<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, May 21, 2013 at 5:00 PM, GRASS GIS <span dir="ltr"><<a href="mailto:trac@osgeo.org" target="_blank">trac@osgeo.org</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im">#1976: r.mapcalc: Allow rounding of floating numbers<br>
-------------------------+--------------------------------------------------<br>
Reporter: pvanbosgeo | Owner: grass-dev@…<br>
Type: enhancement | Status: new<br>
Priority: normal | Milestone: 7.0.0<br>
Component: Raster | Version: unspecified<br>
Keywords: r.mapcalc | Platform: Unspecified<br>
Cpu: Unspecified |<br>
-------------------------+--------------------------------------------------<br>
<br>
</div>Comment(by mmetz):<br>
<br>
Replying to [comment:4 glynn]:<br>
<div class="im"> > Replying to [comment:2 mmetz]:<br>
><br>
> > The output type of round() is now the same like the input type.<br>
><br>
> This changes long-standing behaviour in a way which could break scripts.<br>
<br>
</div> OK. Restoring the original behaviour for round(x) is easy. But it would be<br>
nice to have a round(x, y) function that preserves the data type of x in<br>
order to have a possibility to avoid integer overflow.<br></blockquote><div><br></div><div>I am not sure I understand the solution proposed by Glyn, but does it mean we are back at the results of round always be an integer? That would be disappointing imho. Preserving the data type does make so much more sense.<br>
</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im"><br>
><br>
> > Rounding to a given number of decimal places is supported with<br>
round(x, y)<br>
><br>
> From the mailing list discussion ...<br>
><br>
> Rounding to a given number of decimals is unnecessarily limiting. The<br>
algorithm for generalised rounding is essentially:<br>
><br>
{{{<br>
roundTo(x, k) = round(x / k) * k.<br>
}}}<br>
> Rounding to N decimal places is just a case of using k=1/10^N^. If you<br>
> allow k to be specified directly, then you can round to arbitrary<br>
> steps (e.g. k=5 would round to the nearest multiple of 5, etc).<br>
<br>
</div> I was just looking at the function round() in R which rounds to decimal<br>
places. Generalised rounding makes more sense.<br>
<div class="im"><br>
><br>
> However: there's a slight problem with doing it that way: 0.1 isn't<br>
> exactly representable in binary, so e.g. x/0.1 isn't equal to x*10; it<br>
> would be more accurate to use:<br>
{{{<br>
roundTo(x, k) = round(x * k) / k<br>
}}}<br>
> where k is the reciprocal of the step, so k=10^N^ to round to N decimal<br>
> places (or k=2 to round to 1/2).<br>
<br>
><br>
</div><div class="im"> > Unless someone has a better idea, I plan to change the round() function<br>
so that the second argument is the step value, and add an roundi() (round-<br>
inverse) function where the second argument is the reciprocal of the step<br>
value (to avoid the rounding error when using a step of 10^-N^).<br>
<br>
</div> Sounds good to me.<br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
Ticket URL: <<a href="http://trac.osgeo.org/grass/ticket/1976#comment:5" target="_blank">http://trac.osgeo.org/grass/ticket/1976#comment:5</a>><br>
GRASS GIS <<a href="http://grass.osgeo.org" target="_blank">http://grass.osgeo.org</a>><br>
<br>
</font></span></blockquote></div><br></div></div>