From 6390eba786b4a746b22efd6d282fcb865d1a5075 Mon Sep 17 00:00:00 2001 From: Mateusz Pusz Date: Wed, 18 Sep 2019 21:24:40 -0600 Subject: [PATCH] Dimensions comparison improved --- src/include/units/dimension.h | 5 +++++ src/include/units/quantity.h | 32 ++++++++++++++++---------------- 2 files changed, 21 insertions(+), 16 deletions(-) diff --git a/src/include/units/dimension.h b/src/include/units/dimension.h index 700452a2..38d09fa3 100644 --- a/src/include/units/dimension.h +++ b/src/include/units/dimension.h @@ -145,6 +145,11 @@ namespace std::experimental::units { template struct dimension : downcast_base> {}; + // same_dim + + template + inline constexpr bool same_dim = std::is_same_v; + // dim_invert template diff --git a/src/include/units/quantity.h b/src/include/units/quantity.h index 321c0ad7..1e273b94 100644 --- a/src/include/units/quantity.h +++ b/src/include/units/quantity.h @@ -42,7 +42,7 @@ namespace std::experimental::units { concept bool Quantity = detail::is_quantity; template - concept bool QuantityOf = Quantity && Dimension && std::same_as; + concept bool QuantityOf = Quantity && Dimension && same_dim; // Scalar @@ -69,7 +69,7 @@ namespace std::experimental::units { }; template - requires std::same_as + requires same_dim struct common_quantity, quantity, Rep> { using type = quantity>>, Rep>; }; @@ -126,7 +126,7 @@ namespace std::experimental::units { } // namespace detail template - requires std::same_as + requires same_dim constexpr To quantity_cast(const quantity& q) { using c_ratio = ratio_divide; @@ -175,7 +175,7 @@ namespace std::experimental::units { } template - requires std::same_as && + requires same_dim && std::convertible_to && (treat_as_floating_point || (std::ratio_divide::den == 1 && @@ -251,7 +251,7 @@ namespace std::experimental::units { template [[nodiscard]] constexpr Quantity operator+(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { using common_rep = decltype(lhs.count() + rhs.count()); using ret = common_quantity_t, quantity, common_rep>; @@ -261,7 +261,7 @@ namespace std::experimental::units { template [[nodiscard]] constexpr Quantity operator-(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { using common_rep = decltype(lhs.count() - rhs.count()); using ret = common_quantity_t, quantity, common_rep>; @@ -291,7 +291,7 @@ namespace std::experimental::units { template [[nodiscard]] constexpr Scalar operator*(const quantity& lhs, const quantity& rhs) - requires std::same_as> + requires same_dim> { using common_rep = decltype(lhs.count() * rhs.count()); using ratio = ratio_multiply; @@ -301,7 +301,7 @@ namespace std::experimental::units { template [[nodiscard]] constexpr Quantity operator*(const quantity& lhs, const quantity& rhs) - requires (!std::same_as>) && + requires (!same_dim>) && (treat_as_floating_point || (std::ratio_multiply::den == 1)) { @@ -342,7 +342,7 @@ namespace std::experimental::units { template [[nodiscard]] constexpr Scalar operator/(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { Expects(rhs != std::remove_cvref_t(0)); @@ -354,7 +354,7 @@ namespace std::experimental::units { template [[nodiscard]] constexpr Quantity operator/(const quantity& lhs, const quantity& rhs) - requires (!std::same_as) && + requires (!same_dim) && (treat_as_floating_point || (ratio_divide::den == 1)) { @@ -388,7 +388,7 @@ namespace std::experimental::units { template [[nodiscard]] constexpr bool operator==(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { using ct = common_quantity_t, quantity>; return ct(lhs).count() == ct(rhs).count(); @@ -396,14 +396,14 @@ namespace std::experimental::units { template [[nodiscard]] constexpr bool operator!=(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { return !(lhs == rhs); } template [[nodiscard]] constexpr bool operator<(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { using ct = common_quantity_t, quantity>; return ct(lhs).count() < ct(rhs).count(); @@ -411,21 +411,21 @@ namespace std::experimental::units { template [[nodiscard]] constexpr bool operator<=(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { return !(rhs < lhs); } template [[nodiscard]] constexpr bool operator>(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { return rhs < lhs; } template [[nodiscard]] constexpr bool operator>=(const quantity& lhs, const quantity& rhs) - requires std::same_as + requires same_dim { return !(lhs < rhs); }