1
#ifndef SEEN_DECIMAL_ROUND_H
2
#define SEEN_DECIMAL_ROUND_H
11
/** Returns x rounded to the nearest \a nplaces decimal places.
13
Implemented in terms of Inkscape::round, i.e. we make no guarantees as to what happens if x is
14
half way between two rounded numbers. Add a note to the documentation if you care which
15
candidate is chosen for such case (round towards -infinity, +infinity, 0, or "even").
17
Note: nplaces is the number of decimal places without using scientific (e) notation, not the
18
number of significant figures. This function may not be suitable for values of x whose
19
magnitude is so far from 1 that one would want to use scientific (e) notation.
21
The current implementation happens to allow nplaces to be negative: e.g. nplaces=-2 means
22
rounding to a multiple of 100. May or may not be useful.
25
decimal_round(double const x, int const nplaces)
27
double const multiplier = std::pow(10.0, nplaces);
28
return Inkscape::round( x * multiplier ) / multiplier;
33
#endif /* !SEEN_DECIMAL_ROUND_H */
38
c-file-style:"stroustrup"
39
c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +))
44
// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4 :