tetl 0.1.0
Embedded Template Library
Loading...
Searching...
No Matches
remainder.hpp
Go to the documentation of this file.
1// SPDX-License-Identifier: BSL-1.0
2// SPDX-FileCopyrightText: Copyright (C) 2021 Tobias Hienzsch
3
4#ifndef TETL_CMATH_REMAINDER_HPP
5#define TETL_CMATH_REMAINDER_HPP
6
7#include <etl/_3rd_party/gcem/gcem.hpp>
8#include <etl/_concepts/integral.hpp>
9#include <etl/_type_traits/is_constant_evaluated.hpp>
10
11namespace etl {
12
13namespace detail {
14
15inline constexpr struct remainder {
16 template <typename Float>
17 [[nodiscard]] constexpr auto operator()(Float x, Float y) const noexcept -> Float
18 {
20#if __has_builtin(__builtin_remainderf)
21 if constexpr (etl::same_as<Float, float>) {
22 return __builtin_remainderf(x, y);
23 }
24#endif
25#if __has_builtin(__builtin_remainder)
26 if constexpr (etl::same_as<Float, double>) {
27 return __builtin_remainder(x, y);
28 }
29#endif
30 }
31 return etl::detail::gcem::fmod(x, y);
32 }
33} remainder;
34
35} // namespace detail
36
37/// \ingroup cmath
38/// @{
39
40/// Computes the remainder of the floating point division operation x/y.
41/// \details https://en.cppreference.com/w/cpp/numeric/math/remainder
42[[nodiscard]] constexpr auto remainder(float x, float y) noexcept -> float
43{
44 return etl::detail::remainder(x, y);
45}
46
47/// Computes the remainder of the floating point division operation x/y.
48/// \details https://en.cppreference.com/w/cpp/numeric/math/remainder
49[[nodiscard]] constexpr auto remainderf(float x, float y) noexcept -> float
50{
51 return etl::detail::remainder(x, y);
52}
53
54/// Computes the remainder of the floating point division operation x/y.
55/// \details https://en.cppreference.com/w/cpp/numeric/math/remainder
56[[nodiscard]] constexpr auto remainder(double x, double y) noexcept -> double
57{
58 return etl::detail::remainder(x, y);
59}
60
61/// Computes the remainder of the floating point division operation x/y.
62/// \details https://en.cppreference.com/w/cpp/numeric/math/remainder
63[[nodiscard]] constexpr auto remainder(long double x, long double y) noexcept -> long double
64{
65 return etl::detail::remainder(x, y);
66}
67
68/// Computes the remainder of the floating point division operation x/y.
69/// \details https://en.cppreference.com/w/cpp/numeric/math/remainder
70[[nodiscard]] constexpr auto remainderl(long double x, long double y) noexcept -> long double
71{
72 return etl::detail::remainder(x, y);
73}
74
75/// Computes the remainder of the floating point division operation x/y.
76/// \details https://en.cppreference.com/w/cpp/numeric/math/remainder
77template <integral Int>
78[[nodiscard]] constexpr auto remainder(Int x, Int y) noexcept -> double
79{
80 return etl::detail::remainder(static_cast<double>(x), static_cast<double>(y));
81}
82
83/// @}
84
85} // namespace etl
86
87#endif // TETL_CMATH_REMAINDER_HPP
constexpr auto remainder(Int x, Int y) noexcept -> double
Computes the remainder of the floating point division operation x/y.
Definition remainder.hpp:78
constexpr auto remainderf(float x, float y) noexcept -> float
Computes the remainder of the floating point division operation x/y.
Definition remainder.hpp:49
constexpr auto remainderl(long double x, long double y) noexcept -> long double
Computes the remainder of the floating point division operation x/y.
Definition remainder.hpp:70
constexpr auto remainder(double x, double y) noexcept -> double
Computes the remainder of the floating point division operation x/y.
Definition remainder.hpp:56
constexpr auto remainder(long double x, long double y) noexcept -> long double
Computes the remainder of the floating point division operation x/y.
Definition remainder.hpp:63
constexpr auto remainder(float x, float y) noexcept -> float
Definition remainder.hpp:42
Definition adjacent_find.hpp:9
constexpr auto is_constant_evaluated() noexcept -> bool
Detects whether the function call occurs within a constant-evaluated context. Returns true if the eva...
Definition is_constant_evaluated.hpp:17