Fixed GTX_multiple for negative values, issue #51
This commit is contained in:
@@ -51,18 +51,28 @@ namespace glm
|
||||
/// @addtogroup gtx_multiple
|
||||
/// @{
|
||||
|
||||
//! Higher Multiple number of Source.
|
||||
//! From GLM_GTX_multiple extension.
|
||||
template <typename genType>
|
||||
/// Higher multiple number of Source.
|
||||
///
|
||||
/// @tparam genType Floating-point or integer scalar or vector types.
|
||||
/// @param Source
|
||||
/// @param Multiple Must be a null or positive value
|
||||
///
|
||||
/// @see gtx_multiple
|
||||
template <typename genType>
|
||||
genType higherMultiple(
|
||||
genType const & Source,
|
||||
genType const & Source,
|
||||
genType const & Multiple);
|
||||
|
||||
//! Lower Multiple number of Source.
|
||||
//! From GLM_GTX_multiple extension.
|
||||
template <typename genType>
|
||||
/// Lower multiple number of Source.
|
||||
///
|
||||
/// @tparam genType Floating-point or integer scalar or vector types.
|
||||
/// @param Source
|
||||
/// @param Multiple Must be a null or positive value
|
||||
///
|
||||
/// @see gtx_multiple
|
||||
template <typename genType>
|
||||
genType lowerMultiple(
|
||||
genType const & Source,
|
||||
genType const & Source,
|
||||
genType const & Multiple);
|
||||
|
||||
/// @}
|
||||
|
||||
@@ -15,51 +15,72 @@ namespace glm
|
||||
//////////////////////
|
||||
// higherMultiple
|
||||
|
||||
template <typename genType>
|
||||
template <typename genType>
|
||||
GLM_FUNC_QUALIFIER genType higherMultiple
|
||||
(
|
||||
genType const & Source,
|
||||
genType const & Source,
|
||||
genType const & Multiple
|
||||
)
|
||||
{
|
||||
genType Tmp = Source % Multiple;
|
||||
return Tmp ? Source + Multiple - Tmp : Source;
|
||||
assert(genType(0) <= Multiple);
|
||||
|
||||
genType SourceSign = sign(Source);
|
||||
genType SourceAbs = abs(Source);
|
||||
|
||||
genType Tmp = SourceAbs % Multiple;
|
||||
return (Tmp ? SourceAbs + Multiple - Tmp : SourceAbs) * SourceSign;
|
||||
}
|
||||
|
||||
template <>
|
||||
template <>
|
||||
GLM_FUNC_QUALIFIER detail::half higherMultiple
|
||||
(
|
||||
detail::half const & SourceH,
|
||||
detail::half const & SourceH,
|
||||
detail::half const & MultipleH
|
||||
)
|
||||
{
|
||||
float Source = SourceH.toFloat();
|
||||
float Multiple = MultipleH.toFloat();
|
||||
|
||||
int Tmp = int(float(Source)) % int(Multiple);
|
||||
return detail::half(Tmp ? Source + Multiple - float(Tmp) : Source);
|
||||
assert(float(0) <= Multiple);
|
||||
|
||||
float SourceSign = sign(Source);
|
||||
float SourceAbs = abs(Source);
|
||||
|
||||
int Tmp = int(float(SourceAbs)) % int(Multiple);
|
||||
return detail::half(
|
||||
(Tmp ? SourceAbs + Multiple - float(Tmp) : SourceAbs) * SourceSign);
|
||||
}
|
||||
|
||||
template <>
|
||||
template <>
|
||||
GLM_FUNC_QUALIFIER float higherMultiple
|
||||
(
|
||||
float const & Source,
|
||||
float const & Source,
|
||||
float const & Multiple
|
||||
)
|
||||
{
|
||||
int Tmp = int(Source) % int(Multiple);
|
||||
return Tmp ? Source + Multiple - float(Tmp) : Source;
|
||||
assert(float(0) <= Multiple);
|
||||
|
||||
float SourceSign = sign(Source);
|
||||
float SourceAbs = abs(Source);
|
||||
|
||||
int Tmp = int(SourceAbs) % int(Multiple);
|
||||
return (Tmp ? SourceAbs + Multiple - float(Tmp) : SourceAbs) * SourceSign;
|
||||
}
|
||||
|
||||
template <>
|
||||
template <>
|
||||
GLM_FUNC_QUALIFIER double higherMultiple
|
||||
(
|
||||
double const & Source,
|
||||
double const & Source,
|
||||
double const & Multiple
|
||||
)
|
||||
{
|
||||
long Tmp = long(Source) % long(Multiple);
|
||||
return Tmp ? Source + Multiple - double(Tmp) : Source;
|
||||
assert(double(0) <= Multiple);
|
||||
|
||||
double SourceSign = sign(Source);
|
||||
double SourceAbs = abs(Source);
|
||||
|
||||
long Tmp = long(SourceAbs) % long(Multiple);
|
||||
return (Tmp ? SourceAbs + Multiple - double(Tmp) : SourceAbs) * SourceSign;
|
||||
}
|
||||
|
||||
VECTORIZE_VEC_VEC(higherMultiple)
|
||||
@@ -67,10 +88,10 @@ namespace glm
|
||||
//////////////////////
|
||||
// lowerMultiple
|
||||
|
||||
template <typename genType>
|
||||
template <typename genType>
|
||||
GLM_FUNC_QUALIFIER genType lowerMultiple
|
||||
(
|
||||
genType const & Source,
|
||||
genType const & Source,
|
||||
genType const & Multiple
|
||||
)
|
||||
{
|
||||
@@ -78,38 +99,44 @@ namespace glm
|
||||
return Tmp ? Source - Tmp : Source;
|
||||
}
|
||||
|
||||
template <>
|
||||
template <>
|
||||
GLM_FUNC_QUALIFIER detail::half lowerMultiple
|
||||
(
|
||||
detail::half const & SourceH,
|
||||
detail::half const & SourceH,
|
||||
detail::half const & MultipleH
|
||||
)
|
||||
{
|
||||
float Source = SourceH.toFloat();
|
||||
float Multiple = MultipleH.toFloat();
|
||||
|
||||
assert(float(0) <= Multiple);
|
||||
|
||||
int Tmp = int(float(Source)) % int(float(Multiple));
|
||||
return detail::half(Tmp ? Source - float(Tmp) : Source);
|
||||
}
|
||||
|
||||
template <>
|
||||
template <>
|
||||
GLM_FUNC_QUALIFIER float lowerMultiple
|
||||
(
|
||||
float const & Source,
|
||||
float const & Source,
|
||||
float const & Multiple
|
||||
)
|
||||
{
|
||||
assert(float(0) <= Multiple);
|
||||
|
||||
int Tmp = int(Source) % int(Multiple);
|
||||
return Tmp ? Source - float(Tmp) : Source;
|
||||
}
|
||||
|
||||
template <>
|
||||
template <>
|
||||
GLM_FUNC_QUALIFIER double lowerMultiple
|
||||
(
|
||||
double const & Source,
|
||||
double const & Source,
|
||||
double const & Multiple
|
||||
)
|
||||
{
|
||||
assert(double(0) <= Multiple);
|
||||
|
||||
long Tmp = long(Source) % long(Multiple);
|
||||
return Tmp ? Source - double(Tmp) : Source;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user