mirror of
https://github.com/mpusz/mp-units.git
synced 2025-08-04 20:54:28 +02:00
clang-format + TODOs added to ratio
This commit is contained in:
@@ -23,19 +23,22 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <units/bits/external/hacks.h>
|
#include <units/bits/external/hacks.h>
|
||||||
#include <type_traits>
|
|
||||||
#include <numeric>
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
#include <numeric>
|
||||||
|
#include <type_traits>
|
||||||
|
|
||||||
namespace units {
|
namespace units {
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
[[nodiscard]] constexpr T abs(T v) noexcept { return v < 0 ? -v : v; }
|
[[nodiscard]] constexpr T abs(T v) noexcept
|
||||||
|
{
|
||||||
|
return v < 0 ? -v : v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} // namespace detail
|
||||||
|
|
||||||
template<std::intmax_t Num, std::intmax_t Den = 1>
|
template<std::intmax_t Num, std::intmax_t Den = 1>
|
||||||
requires(Den != 0)
|
requires(Den != 0)
|
||||||
struct ratio {
|
struct ratio {
|
||||||
@@ -63,6 +66,17 @@ namespace units {
|
|||||||
template<typename T>
|
template<typename T>
|
||||||
concept Ratio = detail::is_ratio<T>;
|
concept Ratio = detail::is_ratio<T>;
|
||||||
|
|
||||||
|
|
||||||
|
// ratio_add
|
||||||
|
// TODO implement ratio_add
|
||||||
|
// template<Ratio R1, Ratio R2>
|
||||||
|
// using ratio_add = detail::ratio_add_impl<R1, R2>::type;
|
||||||
|
|
||||||
|
// ratio_subtract
|
||||||
|
// TODO implement ratio_subtract
|
||||||
|
// template<Ratio R1, Ratio R2>
|
||||||
|
// using ratio_subtract = detail::ratio_subtract_impl<R1, R2>::type;
|
||||||
|
|
||||||
// ratio_multiply
|
// ratio_multiply
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
@@ -96,7 +110,7 @@ namespace units {
|
|||||||
static constexpr std::intmax_t den = type::den;
|
static constexpr std::intmax_t den = type::den;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
} // namespace detail
|
||||||
|
|
||||||
template<Ratio R1, Ratio R2>
|
template<Ratio R1, Ratio R2>
|
||||||
using ratio_multiply = detail::ratio_multiply_impl<R1, R2>::type;
|
using ratio_multiply = detail::ratio_multiply_impl<R1, R2>::type;
|
||||||
@@ -113,7 +127,7 @@ namespace units {
|
|||||||
static constexpr std::intmax_t den = type::den;
|
static constexpr std::intmax_t den = type::den;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
} // namespace detail
|
||||||
|
|
||||||
template<Ratio R1, Ratio R2>
|
template<Ratio R1, Ratio R2>
|
||||||
using ratio_divide = detail::ratio_divide_impl<R1, R2>::type;
|
using ratio_divide = detail::ratio_divide_impl<R1, R2>::type;
|
||||||
@@ -137,7 +151,7 @@ namespace units {
|
|||||||
using type = ratio<1>;
|
using type = ratio<1>;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
} // namespace detail
|
||||||
|
|
||||||
template<Ratio R, std::size_t N>
|
template<Ratio R, std::size_t N>
|
||||||
using ratio_pow = detail::ratio_pow_impl<R, N>::type;
|
using ratio_pow = detail::ratio_pow_impl<R, N>::type;
|
||||||
@@ -148,8 +162,7 @@ namespace units {
|
|||||||
|
|
||||||
constexpr std::intmax_t sqrt_impl(std::intmax_t v, std::intmax_t l, std::intmax_t r)
|
constexpr std::intmax_t sqrt_impl(std::intmax_t v, std::intmax_t l, std::intmax_t r)
|
||||||
{
|
{
|
||||||
if(l == r)
|
if (l == r) return r;
|
||||||
return r;
|
|
||||||
|
|
||||||
const auto mid = (r + l) / 2;
|
const auto mid = (r + l) / 2;
|
||||||
if (mid * mid >= v)
|
if (mid * mid >= v)
|
||||||
@@ -158,10 +171,7 @@ namespace units {
|
|||||||
return sqrt_impl(v, mid + 1, r);
|
return sqrt_impl(v, mid + 1, r);
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr std::intmax_t sqrt_impl(std::intmax_t v)
|
static constexpr std::intmax_t sqrt_impl(std::intmax_t v) { return sqrt_impl(v, 1, v); }
|
||||||
{
|
|
||||||
return sqrt_impl(v, 1, v);
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename R>
|
template<typename R>
|
||||||
struct ratio_sqrt_impl {
|
struct ratio_sqrt_impl {
|
||||||
@@ -173,12 +183,11 @@ namespace units {
|
|||||||
using type = ratio<0>;
|
using type = ratio<0>;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
} // namespace detail
|
||||||
|
|
||||||
template<Ratio R>
|
template<Ratio R>
|
||||||
using ratio_sqrt = detail::ratio_sqrt_impl<R>::type;
|
using ratio_sqrt = detail::ratio_sqrt_impl<R>::type;
|
||||||
|
|
||||||
|
|
||||||
// common_ratio
|
// common_ratio
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
@@ -191,7 +200,7 @@ namespace units {
|
|||||||
using type = ratio<gcd_num, (R1::den / gcd_den) * R2::den>;
|
using type = ratio<gcd_num, (R1::den / gcd_den) * R2::den>;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
} // namespace detail
|
||||||
|
|
||||||
template<Ratio R1, Ratio R2>
|
template<Ratio R1, Ratio R2>
|
||||||
using common_ratio = detail::common_ratio_impl<R1, R2>::type;
|
using common_ratio = detail::common_ratio_impl<R1, R2>::type;
|
||||||
|
Reference in New Issue
Block a user