|
|
@ -127,7 +127,7 @@ template< unsigned Integer, unsigned Fraction > |
|
|
|
constexpr UFixed<Integer, Fraction> roundFixed(const UFixed<Integer, Fraction> & value) |
|
|
|
constexpr UFixed<Integer, Fraction> roundFixed(const UFixed<Integer, Fraction> & value) |
|
|
|
{ |
|
|
|
{ |
|
|
|
using OutputType = UFixed<Integer, Fraction>; |
|
|
|
using OutputType = UFixed<Integer, Fraction>; |
|
|
|
return (value.getInternal() & OutputType::MidpointMask) != 0 ? ceilFixed(value) : floorFixed(value); |
|
|
|
return ((value.getFraction() >= OutputType(0.5).getFraction()) != 0) ? ceilFixed(value) : floorFixed(value); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
template< unsigned Integer, unsigned Fraction > |
|
|
|
template< unsigned Integer, unsigned Fraction > |
|
|
@ -135,13 +135,9 @@ constexpr SFixed<Integer, Fraction> roundFixed(const SFixed<Integer, Fraction> & |
|
|
|
{ |
|
|
|
{ |
|
|
|
using OutputType = SFixed<Integer, Fraction>; |
|
|
|
using OutputType = SFixed<Integer, Fraction>; |
|
|
|
return
|
|
|
|
return
|
|
|
|
( |
|
|
|
signbitFixed(value) |
|
|
|
((value.getInternal() & OutputType::MidpointMask) != 0) && |
|
|
|
? ((value.getFraction() <= OutputType(0.5).getFraction()) != 0) ? floorFixed(value) : ceilFixed(value) |
|
|
|
(!signbitFixed(value) || |
|
|
|
: ((value.getFraction() >= OutputType(0.5).getFraction()) != 0) ? ceilFixed(value) : floorFixed(value); |
|
|
|
((value.getInternal() & OutputType::LesserMidpointMask) != 0)) |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
? ceilFixed(value) |
|
|
|
|
|
|
|
: floorFixed(value); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
template< unsigned Integer, unsigned Fraction > |
|
|
|
template< unsigned Integer, unsigned Fraction > |
|
|
|