Use template instanciation
This commit is contained in:
parent
c5776a725e
commit
1cd48f1523
@ -83,7 +83,7 @@ namespace detail
|
|||||||
template <typename T, precision P, template <typename, precision> class vecType>
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
GLM_FUNC_QUALIFIER vecType<T, P> pow(vecType<T, P> const & base, vecType<T, P> const & exponent)
|
GLM_FUNC_QUALIFIER vecType<T, P> pow(vecType<T, P> const & base, vecType<T, P> const & exponent)
|
||||||
{
|
{
|
||||||
return detail::functor2<T, P, vecType>::call(::std::pow, base, exponent);
|
return detail::functor2<T, P, vecType>::call(pow, base, exponent);
|
||||||
}
|
}
|
||||||
|
|
||||||
// exp
|
// exp
|
||||||
@ -91,7 +91,7 @@ namespace detail
|
|||||||
template <typename T, precision P, template <typename, precision> class vecType>
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
GLM_FUNC_QUALIFIER vecType<T, P> exp(vecType<T, P> const & x)
|
GLM_FUNC_QUALIFIER vecType<T, P> exp(vecType<T, P> const & x)
|
||||||
{
|
{
|
||||||
return detail::functor1<T, T, P, vecType>::call(::std::exp, x);
|
return detail::functor1<T, T, P, vecType>::call(exp, x);
|
||||||
}
|
}
|
||||||
|
|
||||||
// log
|
// log
|
||||||
@ -99,7 +99,7 @@ namespace detail
|
|||||||
template <typename T, precision P, template <typename, precision> class vecType>
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
GLM_FUNC_QUALIFIER vecType<T, P> log(vecType<T, P> const & x)
|
GLM_FUNC_QUALIFIER vecType<T, P> log(vecType<T, P> const & x)
|
||||||
{
|
{
|
||||||
return detail::functor1<T, T, P, vecType>::call(::std::log, x);
|
return detail::functor1<T, T, P, vecType>::call(log, x);
|
||||||
}
|
}
|
||||||
|
|
||||||
//exp2, ln2 = 0.69314718055994530941723212145818f
|
//exp2, ln2 = 0.69314718055994530941723212145818f
|
||||||
|
@ -33,80 +33,82 @@ namespace glm
|
|||||||
{
|
{
|
||||||
// sec
|
// sec
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType sec
|
GLM_FUNC_QUALIFIER genType sec(genType angle)
|
||||||
(
|
|
||||||
genType const & angle
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'sec' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'sec' only accept floating-point values");
|
||||||
|
|
||||||
return genType(1) / glm::cos(angle);
|
return genType(1) / glm::cos(angle);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(sec)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> sec(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'sec' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(sec, x);
|
||||||
|
}
|
||||||
|
|
||||||
// csc
|
// csc
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType csc
|
GLM_FUNC_QUALIFIER genType csc(genType angle)
|
||||||
(
|
|
||||||
genType const & angle
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'csc' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'csc' only accept floating-point values");
|
||||||
|
|
||||||
return genType(1) / glm::sin(angle);
|
return genType(1) / glm::sin(angle);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(csc)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> csc(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'csc' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(csc, x);
|
||||||
|
}
|
||||||
|
|
||||||
// cot
|
// cot
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType cot
|
GLM_FUNC_QUALIFIER genType cot(genType angle)
|
||||||
(
|
|
||||||
genType const & angle
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'cot' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'cot' only accept floating-point values");
|
||||||
|
|
||||||
return genType(1) / glm::tan(angle);
|
return genType(1) / glm::tan(angle);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(cot)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> cot(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'cot' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(cot, x);
|
||||||
|
}
|
||||||
|
|
||||||
// asec
|
// asec
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType asec
|
GLM_FUNC_QUALIFIER genType asec(genType x)
|
||||||
(
|
|
||||||
genType const & x
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'asec' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'asec' only accept floating-point values");
|
||||||
|
|
||||||
return acos(genType(1) / x);
|
return acos(genType(1) / x);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(asec)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> asec(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'asec' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(asec, x);
|
||||||
|
}
|
||||||
|
|
||||||
// acsc
|
// acsc
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType acsc
|
GLM_FUNC_QUALIFIER genType acsc(genType x)
|
||||||
(
|
|
||||||
genType const & x
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'acsc' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'acsc' only accept floating-point values");
|
||||||
|
|
||||||
return asin(genType(1) / x);
|
return asin(genType(1) / x);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(acsc)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> acsc(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'acsc' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(acsc, x);
|
||||||
|
}
|
||||||
|
|
||||||
// acot
|
// acot
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType acot
|
GLM_FUNC_QUALIFIER genType acot(genType x)
|
||||||
(
|
|
||||||
genType const & x
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'acot' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'acot' only accept floating-point values");
|
||||||
|
|
||||||
@ -114,89 +116,100 @@ namespace glm
|
|||||||
return pi_over_2 - atan(x);
|
return pi_over_2 - atan(x);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(acot)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> acot(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'acot' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(acot, x);
|
||||||
|
}
|
||||||
|
|
||||||
// sech
|
// sech
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType sech
|
GLM_FUNC_QUALIFIER genType sech(genType angle)
|
||||||
(
|
|
||||||
genType const & angle
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'sech' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'sech' only accept floating-point values");
|
||||||
|
|
||||||
return genType(1) / glm::cosh(angle);
|
return genType(1) / glm::cosh(angle);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(sech)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> sech(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'sech' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(sech, x);
|
||||||
|
}
|
||||||
|
|
||||||
// csch
|
// csch
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType csch
|
GLM_FUNC_QUALIFIER genType csch(genType angle)
|
||||||
(
|
|
||||||
genType const & angle
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'csch' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'csch' only accept floating-point values");
|
||||||
|
|
||||||
return genType(1) / glm::sinh(angle);
|
return genType(1) / glm::sinh(angle);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(csch)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> csch(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'csch' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(csch, x);
|
||||||
|
}
|
||||||
|
|
||||||
// coth
|
// coth
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType coth
|
GLM_FUNC_QUALIFIER genType coth(genType angle)
|
||||||
(
|
|
||||||
genType const & angle
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'coth' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'coth' only accept floating-point values");
|
||||||
|
|
||||||
return glm::cosh(angle) / glm::sinh(angle);
|
return glm::cosh(angle) / glm::sinh(angle);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(coth)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> coth(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'coth' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(coth, x);
|
||||||
|
}
|
||||||
|
|
||||||
// asech
|
// asech
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType asech
|
GLM_FUNC_QUALIFIER genType asech(genType x)
|
||||||
(
|
|
||||||
genType const & x
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'asech' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'asech' only accept floating-point values");
|
||||||
|
|
||||||
return acosh(genType(1) / x);
|
return acosh(genType(1) / x);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(asech)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> asech(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'asech' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(asech, x);
|
||||||
|
}
|
||||||
|
|
||||||
// acsch
|
// acsch
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType acsch
|
GLM_FUNC_QUALIFIER genType acsch(genType x)
|
||||||
(
|
|
||||||
genType const & x
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'acsch' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'acsch' only accept floating-point values");
|
||||||
|
return acsch(genType(1) / x);
|
||||||
return asinh(genType(1) / x);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(acsch)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> acsch(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'acsch' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(acsch, x);
|
||||||
|
}
|
||||||
|
|
||||||
// acoth
|
// acoth
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
GLM_FUNC_QUALIFIER genType acoth
|
GLM_FUNC_QUALIFIER genType acoth(genType x)
|
||||||
(
|
|
||||||
genType const & x
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'acoth' only accept floating-point values");
|
GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'acoth' only accept floating-point values");
|
||||||
|
|
||||||
return atanh(genType(1) / x);
|
return atanh(genType(1) / x);
|
||||||
}
|
}
|
||||||
|
|
||||||
VECTORIZE_VEC(acoth)
|
template <typename T, precision P, template <typename, precision> class vecType>
|
||||||
|
GLM_FUNC_QUALIFIER vecType<T, P> acoth(vecType<T, P> const & x)
|
||||||
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'acoth' only accept floating-point inputs");
|
||||||
|
return detail::functor1<T, T, P, vecType>::call(acoth, x);
|
||||||
|
}
|
||||||
}//namespace glm
|
}//namespace glm
|
||||||
|
Loading…
Reference in New Issue
Block a user