[libc] [llvm] [libc][complex] Testing infra for MPC (PR #121261)
Nick Desaulniers via llvm-commits
llvm-commits at lists.llvm.org
Tue Jan 14 09:53:34 PST 2025
================
@@ -0,0 +1,356 @@
+//===-- Utils which wrap MPC ----------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "MPCUtils.h"
+
+#include "src/__support/CPP/array.h"
+#include "src/__support/CPP/stringstream.h"
+#include "utils/MPFRWrapper/MPCommon.h"
+
+#include <stdint.h>
+
+#include "mpc.h"
+
+template <typename T> using FPBits = LIBC_NAMESPACE::fputil::FPBits<T>;
+
+namespace LIBC_NAMESPACE_DECL {
+namespace testing {
+namespace mpc {
+
+static inline cpp::string str(RoundingMode mode) {
+ switch (mode) {
+ case RoundingMode::Upward:
+ return "MPFR_RNDU";
+ case RoundingMode::Downward:
+ return "MPFR_RNDD";
+ case RoundingMode::TowardZero:
+ return "MPFR_RNDZ";
+ case RoundingMode::Nearest:
+ return "MPFR_RNDN";
+ }
+}
+
+class MPCNumber {
+private:
+ unsigned int precision;
+ mpc_t value;
+ mpc_rnd_t mpc_rounding;
+
+public:
+ MPCNumber(unsigned int p) : precision(p), mpc_rounding(MPC_RNDNN) {
+ mpc_init2(value, precision);
+ }
+
+ MPCNumber() : precision(256), mpc_rounding(MPC_RNDNN) {
+ mpc_init2(value, 256);
+ }
+
+ template <typename XType,
+ cpp::enable_if_t<cpp::is_same_v<_Complex float, XType>, bool> = 0>
+ MPCNumber(XType x,
+ unsigned int precision = mpfr::ExtraPrecision<float>::VALUE,
+ RoundingMode rnd = RoundingMode::Nearest)
+ : precision(precision),
+ mpc_rounding(MPC_RND(mpfr::get_mpfr_rounding_mode(rnd),
+ mpfr::get_mpfr_rounding_mode(rnd))) {
+ mpc_init2(value, precision);
+ Complex<float> x_c = cpp::bit_cast<Complex<float>>(x);
+ mpfr_t real, imag;
+ mpfr_init2(real, precision);
+ mpfr_init2(imag, precision);
+ mpfr_set_flt(real, x_c.real, mpfr::get_mpfr_rounding_mode(rnd));
+ mpfr_set_flt(imag, x_c.imag, mpfr::get_mpfr_rounding_mode(rnd));
+ mpc_set_fr_fr(value, real, imag, mpc_rounding);
+ mpfr_clear(real);
+ mpfr_clear(imag);
+ }
+
+ template <typename XType,
+ cpp::enable_if_t<cpp::is_same_v<_Complex double, XType>, bool> = 0>
+ MPCNumber(XType x,
+ unsigned int precision = mpfr::ExtraPrecision<double>::VALUE,
+ RoundingMode rnd = RoundingMode::Nearest)
+ : precision(precision),
+ mpc_rounding(MPC_RND(mpfr::get_mpfr_rounding_mode(rnd),
+ mpfr::get_mpfr_rounding_mode(rnd))) {
+ mpc_init2(value, precision);
+ Complex<double> x_c = cpp::bit_cast<Complex<double>>(x);
+ mpc_set_d_d(value, x_c.real, x_c.imag, mpc_rounding);
+ }
+
+ MPCNumber(const MPCNumber &other)
+ : precision(other.precision), mpc_rounding(other.mpc_rounding) {
+ mpc_init2(value, precision);
+ mpc_set(value, other.value, mpc_rounding);
+ }
+
+ MPCNumber &operator=(const MPCNumber &rhs) {
+ precision = rhs.precision;
+ mpc_rounding = rhs.mpc_rounding;
+ mpc_init2(value, precision);
+ mpc_set(value, rhs.value, mpc_rounding);
+ return *this;
+ }
----------------
nickdesaulniers wrote:
This method seems out of place. Consider moving it after the definitions of the last constructor and destructor.
https://github.com/llvm/llvm-project/pull/121261
More information about the llvm-commits
mailing list