|
|
@ -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.getFraction() >= OutputType(0.5).getFraction()) != 0) ? ceilFixed(value) : floorFixed(value); |
|
|
|
return (value.getFraction() >= OutputType(0.5).getFraction()) ? ceilFixed(value) : floorFixed(value); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
template< unsigned Integer, unsigned Fraction > |
|
|
|
template< unsigned Integer, unsigned Fraction > |
|
|
@ -136,8 +136,8 @@ constexpr SFixed<Integer, Fraction> roundFixed(const SFixed<Integer, Fraction> & |
|
|
|
using OutputType = SFixed<Integer, Fraction>; |
|
|
|
using OutputType = SFixed<Integer, Fraction>; |
|
|
|
return
|
|
|
|
return
|
|
|
|
signbitFixed(value) |
|
|
|
signbitFixed(value) |
|
|
|
? ((value.getFraction() <= OutputType(0.5).getFraction()) != 0) ? floorFixed(value) : ceilFixed(value) |
|
|
|
? (value.getFraction() <= OutputType(0.5).getFraction()) ? floorFixed(value) : ceilFixed(value) |
|
|
|
: ((value.getFraction() >= OutputType(0.5).getFraction()) != 0) ? ceilFixed(value) : floorFixed(value); |
|
|
|
: (value.getFraction() >= OutputType(0.5).getFraction()) ? ceilFixed(value) : floorFixed(value); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
template< unsigned Integer, unsigned Fraction > |
|
|
|
template< unsigned Integer, unsigned Fraction > |
|
|
|