Implement bitwise shift operators (#82)

The bitwise shift operators are provided solely for optimisation purposes.
pull/85/head
Pharap 4 years ago committed by GitHub
parent af74462255
commit 892df22ee8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 81
      src/FixedPoints/SFixedFreeFunctions.h
  2. 81
      src/FixedPoints/UFixedFreeFunctions.h

@ -278,6 +278,28 @@ constexpr auto operator /(const SFixed<IntegerLeft, FractionLeft> & left, const
return (SFixed<Integer, Fraction>(left) op right);\ return (SFixed<Integer, Fraction>(left) op right);\
} }
#define DELETED_BITSHIFT_OPERATOR( type, op )\
template< unsigned Integer, unsigned Fraction >\
constexpr SFixed<Integer, Fraction> operator op (const SFixed<Integer, Fraction> & left, const type & right) = delete;\
\
template< unsigned Integer, unsigned Fraction >\
inline SFixed<Integer, Fraction> operator op##= (const SFixed<Integer, Fraction> & left, const type & right) = delete;
#define BITSHIFT_OPERATOR( type, op )\
template< unsigned Integer, unsigned Fraction >\
constexpr SFixed<Integer, Fraction> operator op (const SFixed<Integer, Fraction> & left, const type & right)\
{\
using InternalType = typename SFixed<Integer, Fraction>::InternalType;\
return SFixed<Integer, Fraction>::fromInternal(static_cast<InternalType>(left.getInternal() op right));\
}\
\
template< unsigned Integer, unsigned Fraction >\
inline SFixed<Integer, Fraction> & operator op##= (SFixed<Integer, Fraction> & left, const type & right)\
{\
left = (left op right);\
return left;\
}
#define LOGIC_OPERATORS( type )\ #define LOGIC_OPERATORS( type )\
LOGIC_OPERATOR( type, == )\ LOGIC_OPERATOR( type, == )\
LOGIC_OPERATOR( type, != )\ LOGIC_OPERATOR( type, != )\
@ -292,32 +314,53 @@ constexpr auto operator /(const SFixed<IntegerLeft, FractionLeft> & left, const
ARITHMETIC_OPERATOR( type, * )\ ARITHMETIC_OPERATOR( type, * )\
ARITHMETIC_OPERATOR( type, / ) ARITHMETIC_OPERATOR( type, / )
#define OPERATORS( type ) \ #define DELETED_BITSHIFT_OPERATORS( type ) \
DELETED_BITSHIFT_OPERATOR( type, << )\
DELETED_BITSHIFT_OPERATOR( type, >> )
#define BITSHIFT_OPERATORS( type ) \
BITSHIFT_OPERATOR( type, << )\
BITSHIFT_OPERATOR( type, >> )
#define FLOAT_OPERATORS( type ) \
LOGIC_OPERATORS( type )\ LOGIC_OPERATORS( type )\
ARITHMETIC_OPERATORS( type ) ARITHMETIC_OPERATORS( type )\
DELETED_BITSHIFT_OPERATORS( type )
OPERATORS( float )
OPERATORS( double ) #define INTEGER_OPERATORS( type ) \
OPERATORS( long double ) LOGIC_OPERATORS( type )\
ARITHMETIC_OPERATORS( type )\
OPERATORS( char ) BITSHIFT_OPERATORS( type )
OPERATORS( unsigned char )
OPERATORS( signed char ) FLOAT_OPERATORS( float )
OPERATORS( unsigned short int ) FLOAT_OPERATORS( double )
OPERATORS( signed short int ) FLOAT_OPERATORS( long double )
OPERATORS( unsigned int )
OPERATORS( signed int ) INTEGER_OPERATORS( char )
OPERATORS( unsigned long int ) INTEGER_OPERATORS( unsigned char )
OPERATORS( signed long int ) INTEGER_OPERATORS( signed char )
OPERATORS( unsigned long long int ) INTEGER_OPERATORS( unsigned short int )
OPERATORS( signed long long int ) INTEGER_OPERATORS( signed short int )
INTEGER_OPERATORS( unsigned int )
INTEGER_OPERATORS( signed int )
INTEGER_OPERATORS( unsigned long int )
INTEGER_OPERATORS( signed long int )
INTEGER_OPERATORS( unsigned long long int )
INTEGER_OPERATORS( signed long long int )
// Prevent Macro-bleed: // Prevent Macro-bleed:
#undef OPERATORS #undef INTEGER_OPERATORS
#undef FLOAT_OPERATORS
#undef ARITHMETIC_OPERATORS #undef ARITHMETIC_OPERATORS
#undef LOGIC_OPERATORS #undef LOGIC_OPERATORS
#undef BITSHIFT_OPERATORS
#undef DELETED_BITSHIFT_OPERATORS
#undef ARITHMETIC_OPERATOR #undef ARITHMETIC_OPERATOR
#undef LOGIC_OPERATOR #undef LOGIC_OPERATOR
#undef BITSHIFT_OPERATOR
#undef DELETED_BITSHIFT_OPERATOR
FIXED_POINTS_END_NAMESPACE FIXED_POINTS_END_NAMESPACE

@ -278,6 +278,28 @@ constexpr auto operator /(const UFixed<IntegerLeft, FractionLeft> & left, const
return (UFixed<Integer, Fraction>(left) op right);\ return (UFixed<Integer, Fraction>(left) op right);\
} }
#define DELETED_BITSHIFT_OPERATOR( type, op )\
template< unsigned Integer, unsigned Fraction >\
constexpr UFixed<Integer, Fraction> operator op (const UFixed<Integer, Fraction> & left, const type & right) = delete;\
\
template< unsigned Integer, unsigned Fraction >\
inline UFixed<Integer, Fraction> operator op##= (const UFixed<Integer, Fraction> & left, const type & right) = delete;
#define BITSHIFT_OPERATOR( type, op )\
template< unsigned Integer, unsigned Fraction >\
constexpr UFixed<Integer, Fraction> operator op (const UFixed<Integer, Fraction> & left, const type & right)\
{\
using InternalType = typename UFixed<Integer, Fraction>::InternalType;\
return UFixed<Integer, Fraction>::fromInternal(static_cast<InternalType>(left.getInternal() op right));\
}\
\
template< unsigned Integer, unsigned Fraction >\
inline UFixed<Integer, Fraction> & operator op##= (UFixed<Integer, Fraction> & left, const type & right)\
{\
left = (left op right);\
return left;\
}
#define LOGIC_OPERATORS( type )\ #define LOGIC_OPERATORS( type )\
LOGIC_OPERATOR( type, == )\ LOGIC_OPERATOR( type, == )\
LOGIC_OPERATOR( type, != )\ LOGIC_OPERATOR( type, != )\
@ -292,32 +314,53 @@ constexpr auto operator /(const UFixed<IntegerLeft, FractionLeft> & left, const
ARITHMETIC_OPERATOR( type, * )\ ARITHMETIC_OPERATOR( type, * )\
ARITHMETIC_OPERATOR( type, / ) ARITHMETIC_OPERATOR( type, / )
#define OPERATORS( type ) \ #define DELETED_BITSHIFT_OPERATORS( type ) \
DELETED_BITSHIFT_OPERATOR( type, << )\
DELETED_BITSHIFT_OPERATOR( type, >> )
#define BITSHIFT_OPERATORS( type ) \
BITSHIFT_OPERATOR( type, << )\
BITSHIFT_OPERATOR( type, >> )
#define FLOAT_OPERATORS( type ) \
LOGIC_OPERATORS( type )\ LOGIC_OPERATORS( type )\
ARITHMETIC_OPERATORS( type ) ARITHMETIC_OPERATORS( type )\
DELETED_BITSHIFT_OPERATORS( type )
OPERATORS( float )
OPERATORS( double ) #define INTEGER_OPERATORS( type ) \
OPERATORS( long double ) LOGIC_OPERATORS( type )\
ARITHMETIC_OPERATORS( type )\
OPERATORS( char ) BITSHIFT_OPERATORS( type )
OPERATORS( unsigned char )
OPERATORS( signed char ) FLOAT_OPERATORS( float )
OPERATORS( unsigned short int ) FLOAT_OPERATORS( double )
OPERATORS( signed short int ) FLOAT_OPERATORS( long double )
OPERATORS( unsigned int )
OPERATORS( signed int ) INTEGER_OPERATORS( char )
OPERATORS( unsigned long int ) INTEGER_OPERATORS( unsigned char )
OPERATORS( signed long int ) INTEGER_OPERATORS( signed char )
OPERATORS( unsigned long long int ) INTEGER_OPERATORS( unsigned short int )
OPERATORS( signed long long int ) INTEGER_OPERATORS( signed short int )
INTEGER_OPERATORS( unsigned int )
INTEGER_OPERATORS( signed int )
INTEGER_OPERATORS( unsigned long int )
INTEGER_OPERATORS( signed long int )
INTEGER_OPERATORS( unsigned long long int )
INTEGER_OPERATORS( signed long long int )
// Prevent Macro-bleed: // Prevent Macro-bleed:
#undef OPERATORS #undef INTEGER_OPERATORS
#undef FLOAT_OPERATORS
#undef ARITHMETIC_OPERATORS #undef ARITHMETIC_OPERATORS
#undef LOGIC_OPERATORS #undef LOGIC_OPERATORS
#undef BITSHIFT_OPERATORS
#undef DELETED_BITSHIFT_OPERATORS
#undef ARITHMETIC_OPERATOR #undef ARITHMETIC_OPERATOR
#undef LOGIC_OPERATOR #undef LOGIC_OPERATOR
#undef BITSHIFT_OPERATOR
#undef DELETED_BITSHIFT_OPERATOR
FIXED_POINTS_END_NAMESPACE FIXED_POINTS_END_NAMESPACE
Loading…
Cancel
Save