2013-08-08 09:54:33 +00:00
|
|
|
/*=============================================================================
|
2016-02-25 09:48:28 +00:00
|
|
|
Copyright (c) 2011-2016 Bolero MURAKAMI
|
2013-08-08 09:54:33 +00:00
|
|
|
https://github.com/bolero-MURAKAMI/Sprout
|
|
|
|
|
|
|
|
Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
=============================================================================*/
|
2012-02-25 14:59:46 +00:00
|
|
|
#ifndef SPROUT_MATH_CONSTANTS_HPP
|
|
|
|
#define SPROUT_MATH_CONSTANTS_HPP
|
|
|
|
|
|
|
|
#include <sprout/config.hpp>
|
|
|
|
|
|
|
|
namespace sprout {
|
|
|
|
namespace math {
|
|
|
|
//
|
|
|
|
// pi
|
|
|
|
//
|
|
|
|
template<typename T>
|
2012-04-04 13:23:41 +00:00
|
|
|
inline SPROUT_CONSTEXPR T pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(3.14159265358979323846264338327950288419716939937510582097494459230781640628620899862803482534211706798214808651L);
|
2012-02-25 14:59:46 +00:00
|
|
|
}
|
2013-02-14 09:02:43 +00:00
|
|
|
//
|
|
|
|
// half_pi
|
|
|
|
//
|
2012-02-25 14:59:46 +00:00
|
|
|
template<typename T>
|
2012-05-04 13:13:17 +00:00
|
|
|
inline SPROUT_CONSTEXPR T half_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(1.57079632679489661923132169163975144209858469968755291048747229615390820314310449931401741267105853399107404326L);
|
2012-02-25 14:59:46 +00:00
|
|
|
}
|
2013-02-14 09:02:43 +00:00
|
|
|
//
|
|
|
|
// third_pi
|
|
|
|
// two_thirds_pi
|
|
|
|
//
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T third_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(1.04719755119659774615421446109316762806572313312503527365831486410260546876206966620934494178070568932738269550L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T two_thirds_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(2.09439510239319549230842892218633525613144626625007054731662972820521093752413933241868988356141137865476539101L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
//
|
|
|
|
// quarter_pi
|
|
|
|
// three_quarters_pi
|
|
|
|
//
|
2012-05-04 13:13:17 +00:00
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T quarter_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.78539816339744830961566084581987572104929234984377645524373614807695410157155224965700870633552926699553702163L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T three_quarters_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(2.35619449019234492884698253745962716314787704953132936573120844423086230471465674897102611900658780098661106488L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
//
|
|
|
|
// two_pi
|
|
|
|
// four_pi
|
|
|
|
//
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T two_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(6.28318530717958647692528676655900576839433879875021164194988918461563281257241799725606965068423413596429617303L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T four_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(12.56637061435917295385057353311801153678867759750042328389977836923126562514483599451213930136846827192859234606L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
//
|
|
|
|
// two_div_pi
|
|
|
|
// root_two_div_pi
|
|
|
|
//
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T two_div_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.636619772367581343075535053490057448137838582961825794990669376235587190536906140360455211065012343824291370907L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T root_two_div_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.797884560802865355879892119868763736951717262329869315331851659341315851798603677002504667814613872860605117725L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
//
|
|
|
|
// root_pi
|
|
|
|
// one_div_root_pi
|
|
|
|
// root_one_div_pi
|
|
|
|
// two_div_root_pi
|
|
|
|
//
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T root_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(1.77245385090551602729816748334114518279754945612238712821380778985291128459103218137495065673854466541622682362L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T one_div_root_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.564189583547756286948079451560772585844050629328998856844085721710642468441493414486743660202107363443028347906L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T root_one_div_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.564189583547756286948079451560772585844050629328998856844085721710642468441493414486743660202107363443028347906L);
|
2013-02-14 09:02:43 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T two_div_root_pi() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(1.128379167095512573896158903121545171688101258657997713688171443421284936882986828973487320404214726886056695812L);
|
2012-05-04 13:13:17 +00:00
|
|
|
}
|
|
|
|
//
|
2012-05-05 09:50:17 +00:00
|
|
|
// half
|
2013-04-29 01:56:46 +00:00
|
|
|
// quarter
|
2012-05-05 09:50:17 +00:00
|
|
|
// third
|
2014-03-17 06:26:58 +00:00
|
|
|
// two_thirds
|
2012-05-04 07:40:25 +00:00
|
|
|
//
|
|
|
|
template<typename T>
|
2012-05-05 09:50:17 +00:00
|
|
|
inline SPROUT_CONSTEXPR T half() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.5L);
|
2012-05-05 09:50:17 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
2013-04-29 01:56:46 +00:00
|
|
|
inline SPROUT_CONSTEXPR T quarter() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.25L);
|
2013-04-29 01:56:46 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
2012-05-05 09:50:17 +00:00
|
|
|
inline SPROUT_CONSTEXPR T third() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333L);
|
2012-05-05 09:50:17 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
2014-03-17 06:26:58 +00:00
|
|
|
inline SPROUT_CONSTEXPR T two_thirds() {
|
|
|
|
return static_cast<T>(0.66666666666666666666666666666666666666666666666666666666666666666666666666666666666666666666666666666666666666L);
|
2012-05-04 07:40:25 +00:00
|
|
|
}
|
2012-05-04 09:02:42 +00:00
|
|
|
//
|
2012-05-05 09:50:17 +00:00
|
|
|
// root_two
|
2013-09-19 17:40:19 +00:00
|
|
|
// root_three
|
2012-05-04 09:02:42 +00:00
|
|
|
// half_root_two
|
|
|
|
//
|
|
|
|
template<typename T>
|
2012-05-05 09:50:17 +00:00
|
|
|
inline SPROUT_CONSTEXPR T root_two() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(1.41421356237309504880168872420969807856967187537694807317667973799073247846210703885038753432764157273501384623L);
|
2012-05-05 09:50:17 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
2013-09-19 17:40:19 +00:00
|
|
|
inline SPROUT_CONSTEXPR T root_three() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(1.73205080756887729352744634150587236694280525381038062805580697945193301690880003708114618675724857567562614142L);
|
2013-09-19 17:40:19 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
2012-05-04 09:02:42 +00:00
|
|
|
inline SPROUT_CONSTEXPR T half_root_two() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.707106781186547524400844362104849039284835937688474036588339868995366239231053519425193767163820786367506923115L);
|
2012-05-04 09:02:42 +00:00
|
|
|
}
|
|
|
|
//
|
|
|
|
// e
|
|
|
|
//
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T e() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(2.71828182845904523536028747135266249775724709369995957496696762772407663035354759457138217852516642742746639193L);
|
2012-05-04 09:02:42 +00:00
|
|
|
}
|
|
|
|
//
|
|
|
|
// ln_ten
|
2012-05-05 09:50:17 +00:00
|
|
|
// ln_two
|
2012-05-04 09:02:42 +00:00
|
|
|
//
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T ln_ten() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(2.30258509299404568401799145468436420760110148862877297603332790096757260967735248023599720508959829834196778404L);
|
2012-05-04 09:02:42 +00:00
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T ln_two() {
|
2014-03-17 06:26:58 +00:00
|
|
|
return static_cast<T>(0.693147180559945309417232121458176568075500134360255254120680009493393621969694715605863326996418687542001481021L);
|
2012-05-04 09:02:42 +00:00
|
|
|
}
|
2014-03-17 08:06:41 +00:00
|
|
|
//
|
|
|
|
// phi
|
|
|
|
//
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR T phi() {
|
|
|
|
return static_cast<T>(1.61803398874989484820458683436563811772030917980576286213544862270526046281890244970720720418939113748475408807L);
|
|
|
|
}
|
2012-02-25 14:59:46 +00:00
|
|
|
} // namespace math
|
|
|
|
} // namespace sprout
|
|
|
|
|
|
|
|
#endif // #ifndef SPROUT_MATH_CONSTANTS_HPP
|