/*============================================================================= Copyright (c) 2011-2017 Bolero MURAKAMI 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) =============================================================================*/ #ifndef SPROUT_NUMERIC_DFT_DETAIL_SINUSOID_HPP #define SPROUT_NUMERIC_DFT_DETAIL_SINUSOID_HPP #include #include #include namespace sprout { namespace detail { template inline SPROUT_CONSTEXPR T sinusoid_value(T const& amplitude, T const& phase, T const& d, Index i) { using sprout::sin; return amplitude * sin(d * T(i) + phase); } template inline SPROUT_CONSTEXPR T sinusoid_value_d(T const& frequency, Size size) { return sprout::math::two_pi() * frequency / T(size); } template inline SPROUT_CONSTEXPR T sinusoid_value_d(T const& frequency) { return sprout::math::two_pi() * frequency; } } // namespace detail } // namespace sprout #endif // #ifndef SPROUT_NUMERIC_DFT_DETAIL_SINUSOID_HPP