public inbox for libstdc++@gcc.gnu.org
 help / color / mirror / Atom feed
From: Nathaniel Shead <nathanieloshead@gmail.com>
To: Jonathan Wakely <jwakely@redhat.com>
Cc: libstdc++@gcc.gnu.org, gcc-patches@gcc.gnu.org
Subject: Re: [PATCH] libstdc++: Add missing functions to <cmath> [PR79700]
Date: Tue, 21 Feb 2023 22:22:11 +1100	[thread overview]
Message-ID: <Y/SpY7IRgpGd00ly@Thaum.localdomain> (raw)
In-Reply-To: <CACb0b4=av=OkHKuN+911KwLezdjKtTMHmaDn1LvYQdmYAxSGNg@mail.gmail.com>

On Mon, Feb 20, 2023 at 12:08:38PM +0000, Jonathan Wakely wrote:
> On Mon, 20 Feb 2023 at 11:57, Nathaniel Shead <nathanieloshead@gmail.com> wrote:
> >
> > On Mon, Feb 20, 2023 at 10:30 PM Jonathan Wakely <jwakely@redhat.com> wrote:
> > >
> > > On Mon, 20 Feb 2023 at 11:23, Nathaniel Shead via Libstdc++
> > > <libstdc++@gcc.gnu.org> wrote:
> > > >
> > > > The comments on PR79700 mentioned that it was somewhat ambiguous whether
> > > > these functions were supposed to exist for C++11 or not. I chose to add
> > > > them there, since other resources (such as cppreference) seem to think
> > > > that C++11 should be the standard these functions were introduced, and I
> > > > don't know of any reason to do otherwise.
> > > >
> > > > Tested on x86_64-linux.
> > >
> > > Thanks for the patch, but this needs tests for the new declarations
> > > (which are tedious to write, which is the main reason I haven't
> > > already pushed my own very similar patch).
> > >
> >
> > Ah OK, fair enough. Where should the tests go? The only tests I could
> > find for the existing (non -f/l) functions was just tests for their
> > existence in testsuite/26_numerics/headers/cmath/functions_std_c++17.cc
> > which I just added the new functions to - I guess I'll add a new file
> > here and test that all the functions can be called and give the same
> > results as the relevant overloaded variants?
> 
> Yeah, that sounds great, thanks!
> 

How does this look?

-- 8< --

This patch adds the -f and -l variants of the C89 <math.h> functions to
<cmath> under namespace std (so std::sqrtf, std::fabsl, etc.) for C++11
and up.

libstdc++-v3/ChangeLog:

	PR libstdc++/79700
	* include/c_global/cmath (acosf, acosl, asinf, asinl, atanf,
        atanl, atan2f, atan2l, ceilf, ceill, cosf, cosl, coshf, coshl,
        expf, expl, fabsf, fabsl, floorf, floorl, fmodf, fmodl, frexpf,
        frexpl, ldexpf, ldexpl, logf, logl, log10f, log10l, modff,
        modfl, powf, powl, sinf, sinl, sinhf, sinhl, sqrtf, sqrtl, tanf,
        tanl, tanhf, tanhl): Add aliases in namespace std.
        * testsuite/26_numerics/headers/cmath/equivalent_functions.cc:
        New test.
	* testsuite/26_numerics/headers/cmath/functions_std_c++17.cc:
        Add checks for existence of above names.

Signed-off-by: Nathaniel Shead <nathanieloshead@gmail.com>
---
 libstdc++-v3/include/c_global/cmath           | 111 +++++++++
 .../headers/cmath/equivalent_functions.cc     | 224 ++++++++++++++++++
 .../headers/cmath/functions_std_c++17.cc      |  45 ++++
 3 files changed, 380 insertions(+)
 create mode 100644 libstdc++-v3/testsuite/26_numerics/headers/cmath/equivalent_functions.cc

diff --git a/libstdc++-v3/include/c_global/cmath b/libstdc++-v3/include/c_global/cmath
index 568eb354c2d..eaebde33dee 100644
--- a/libstdc++-v3/include/c_global/cmath
+++ b/libstdc++-v3/include/c_global/cmath
@@ -1767,6 +1767,117 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
 
 #if __cplusplus >= 201103L
 
+#undef acosf
+#undef acosl
+#undef asinf
+#undef asinl
+#undef atanf
+#undef atanl
+#undef atan2f
+#undef atan2l
+#undef ceilf
+#undef ceill
+#undef cosf
+#undef cosl
+#undef coshf
+#undef coshl
+#undef expf
+#undef expl
+#undef fabsf
+#undef fabsl
+#undef floorf
+#undef floorl
+#undef fmodf
+#undef fmodl
+#undef frexpf
+#undef frexpl
+#undef ldexpf
+#undef ldexpl
+#undef logf
+#undef logl
+#undef log10f
+#undef log10l
+#undef modff
+#undef modfl
+#undef powf
+#undef powl
+#undef sinf
+#undef sinl
+#undef sinhf
+#undef sinhl
+#undef sqrtf
+#undef sqrtl
+#undef tanf
+#undef tanl
+#undef tanhf
+#undef tanhl
+
+  using ::acosf;
+  using ::acosl;
+
+  using ::asinf;
+  using ::asinl;
+
+  using ::atanf;
+  using ::atanl;
+
+  using ::atan2f;
+  using ::atan2l;
+
+  using ::ceilf;
+  using ::ceill;
+
+  using ::cosf;
+  using ::cosl;
+
+  using ::coshf;
+  using ::coshl;
+
+  using ::expf;
+  using ::expl;
+
+  using ::fabsf;
+  using ::fabsl;
+
+  using ::floorf;
+  using ::floorl;
+
+  using ::fmodf;
+  using ::fmodl;
+
+  using ::frexpf;
+  using ::frexpl;
+
+  using ::ldexpf;
+  using ::ldexpl;
+
+  using ::logf;
+  using ::logl;
+
+  using ::log10f;
+  using ::log10l;
+
+  using ::modff;
+  using ::modfl;
+
+  using ::powf;
+  using ::powl;
+
+  using ::sinf;
+  using ::sinl;
+
+  using ::sinhf;
+  using ::sinhl;
+
+  using ::sqrtf;
+  using ::sqrtl;
+
+  using ::tanf;
+  using ::tanl;
+
+  using ::tanhf;
+  using ::tanhl;
+
 #ifdef _GLIBCXX_USE_C99_MATH_TR1
 
 #undef acosh
diff --git a/libstdc++-v3/testsuite/26_numerics/headers/cmath/equivalent_functions.cc b/libstdc++-v3/testsuite/26_numerics/headers/cmath/equivalent_functions.cc
new file mode 100644
index 00000000000..8639279e8a1
--- /dev/null
+++ b/libstdc++-v3/testsuite/26_numerics/headers/cmath/equivalent_functions.cc
@@ -0,0 +1,224 @@
+// Copyright (C) 2023 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library.  This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING3.  If not see
+// <http://www.gnu.org/licenses/>.
+
+// { dg-do run { target c++11 } }
+
+#include <testsuite_hooks.h>
+
+#include <type_traits>
+#include <cmath>
+// also include functions in global namespace
+#include <math.h>
+
+static_assert(std::is_same<decltype(std::acosf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::asinf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::atanf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::atan2f(0.0, 0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::ceilf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::cosf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::coshf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::expf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::fabsf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::floorf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::fmodf(0.0, 0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::frexpf(0.0, nullptr)), float>::value, "");
+static_assert(std::is_same<decltype(std::ldexpf(0.0, 0)), float>::value, "");
+static_assert(std::is_same<decltype(std::logf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::log10f(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::modff(0.0, nullptr)), float>::value, "");
+static_assert(std::is_same<decltype(std::powf(0.0, 0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::sinf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::sinhf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::sqrtf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::tanf(0.0)), float>::value, "");
+static_assert(std::is_same<decltype(std::tanhf(0.0)), float>::value, "");
+
+static_assert(std::is_same<decltype(std::acosl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::asinl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::atanl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::atan2l(0.0, 0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::ceill(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::cosl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::coshl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::expl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::fabsl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::floorl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::fmodl(0.0, 0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::frexpl(0.0, nullptr)), long double>::value, "");
+static_assert(std::is_same<decltype(std::ldexpl(0.0, 0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::logl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::log10l(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::modfl(0.0, nullptr)), long double>::value, "");
+static_assert(std::is_same<decltype(std::powl(0.0, 0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::sinl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::sinhl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::sqrtl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::tanl(0.0)), long double>::value, "");
+static_assert(std::is_same<decltype(std::tanhl(0.0)), long double>::value, "");
+
+void
+test_float_global()
+{
+  float x = 1.0f;
+
+  int e1 = 0;
+  int e2 = 0;
+  float i1 = 0.0f;
+  float i2 = 0.0f;
+
+  VERIFY(::acosf(x) == std::acosf(x));
+  VERIFY(::asinf(x) == std::asinf(x));
+  VERIFY(::atanf(x) == std::atanf(x));
+  VERIFY(::atan2f(x, x) == std::atan2f(x, x));
+  VERIFY(::ceilf(x) == std::ceilf(x));
+  VERIFY(::cosf(x) == std::cosf(x));
+  VERIFY(::coshf(x) == std::coshf(x));
+  VERIFY(::expf(x) == std::expf(x));
+  VERIFY(::fabsf(x) == std::fabsf(x));
+  VERIFY(::floorf(x) == std::floorf(x));
+  VERIFY(::fmodf(x, x) == std::fmodf(x, x));
+  VERIFY(::frexpf(x, &e1) == std::frexpf(x, &e2));
+  VERIFY(e1 == e2);
+  VERIFY(::ldexpf(x, 1) == std::ldexpf(x, 1));
+  VERIFY(::logf(x) == std::logf(x));
+  VERIFY(::log10f(x) == std::log10f(x));
+  VERIFY(::modff(x, &i1) == std::modff(x, &i2));
+  VERIFY(i1 == i2);
+  VERIFY(::powf(x, x) == std::powf(x, x));
+  VERIFY(::sinf(x) == std::sinf(x));
+  VERIFY(::sinhf(x) == std::sinhf(x));
+  VERIFY(::sqrtf(x) == std::sqrtf(x));
+  VERIFY(::tanf(x) == std::tanf(x));
+  VERIFY(::tanhf(x) == std::tanhf(x));
+}
+
+void
+test_float_overload()
+{
+  float x = 1.0f;
+
+  int e1 = 0;
+  int e2 = 0;
+  float i1 = 0.0f;
+  float i2 = 0.0f;
+
+  VERIFY(std::acos(x) == std::acosf(x));
+  VERIFY(std::asin(x) == std::asinf(x));
+  VERIFY(std::atan(x) == std::atanf(x));
+  VERIFY(std::atan2(x, x) == std::atan2f(x, x));
+  VERIFY(std::ceil(x) == std::ceilf(x));
+  VERIFY(std::cos(x) == std::cosf(x));
+  VERIFY(std::cosh(x) == std::coshf(x));
+  VERIFY(std::exp(x) == std::expf(x));
+  VERIFY(std::fabs(x) == std::fabsf(x));
+  VERIFY(std::floor(x) == std::floorf(x));
+  VERIFY(std::fmod(x, x) == std::fmodf(x, x));
+  VERIFY(std::frexp(x, &e1) == std::frexpf(x, &e2));
+  VERIFY(e1 == e2);
+  VERIFY(std::ldexp(x, 1) == std::ldexpf(x, 1));
+  VERIFY(std::log(x) == std::logf(x));
+  VERIFY(std::log10(x) == std::log10f(x));
+  VERIFY(std::modf(x, &i1) == std::modff(x, &i2));
+  VERIFY(i1 == i2);
+  VERIFY(std::pow(x, x) == std::powf(x, x));
+  VERIFY(std::sin(x) == std::sinf(x));
+  VERIFY(std::sinh(x) == std::sinhf(x));
+  VERIFY(std::sqrt(x) == std::sqrtf(x));
+  VERIFY(std::tan(x) == std::tanf(x));
+  VERIFY(std::tanh(x) == std::tanhf(x));
+}
+
+void
+test_long_double_global()
+{
+  long double x = 1.0L;
+
+  int e1 = 0;
+  int e2 = 0;
+  long double i1 = 0.0L;
+  long double i2 = 0.0L;
+
+  VERIFY(::acosl(x) == std::acosl(x));
+  VERIFY(::asinl(x) == std::asinl(x));
+  VERIFY(::atanl(x) == std::atanl(x));
+  VERIFY(::atan2l(x, x) == std::atan2l(x, x));
+  VERIFY(::ceill(x) == std::ceill(x));
+  VERIFY(::cosl(x) == std::cosl(x));
+  VERIFY(::coshl(x) == std::coshl(x));
+  VERIFY(::expl(x) == std::expl(x));
+  VERIFY(::fabsl(x) == std::fabsl(x));
+  VERIFY(::floorl(x) == std::floorl(x));
+  VERIFY(::fmodl(x, x) == std::fmodl(x, x));
+  VERIFY(::frexpl(x, &e1) == std::frexpl(x, &e2));
+  VERIFY(e1 == e2);
+  VERIFY(::ldexpl(x, 1) == std::ldexpl(x, 1));
+  VERIFY(::logl(x) == std::logl(x));
+  VERIFY(::log10l(x) == std::log10l(x));
+  VERIFY(::modfl(x, &i1) == std::modfl(x, &i2));
+  VERIFY(i1 == i2);
+  VERIFY(::powl(x, x) == std::powl(x, x));
+  VERIFY(::sinl(x) == std::sinl(x));
+  VERIFY(::sinhl(x) == std::sinhl(x));
+  VERIFY(::sqrtl(x) == std::sqrtl(x));
+  VERIFY(::tanl(x) == std::tanl(x));
+  VERIFY(::tanhl(x) == std::tanhl(x));
+}
+
+void
+test_long_double_overload()
+{
+  long double x = 1.0L;
+
+  int e1 = 0;
+  int e2 = 0;
+  long double i1 = 0.0L;
+  long double i2 = 0.0L;
+
+  VERIFY(std::acos(x) == std::acosl(x));
+  VERIFY(std::asin(x) == std::asinl(x));
+  VERIFY(std::atan(x) == std::atanl(x));
+  VERIFY(std::atan2(x, x) == std::atan2l(x, x));
+  VERIFY(std::ceil(x) == std::ceill(x));
+  VERIFY(std::cos(x) == std::cosl(x));
+  VERIFY(std::cosh(x) == std::coshl(x));
+  VERIFY(std::exp(x) == std::expl(x));
+  VERIFY(std::fabs(x) == std::fabsl(x));
+  VERIFY(std::floor(x) == std::floorl(x));
+  VERIFY(std::fmod(x, x) == std::fmodl(x, x));
+  VERIFY(std::frexp(x, &e1) == std::frexpl(x, &e2));
+  VERIFY(e1 == e2);
+  VERIFY(std::ldexp(x, 1) == std::ldexpl(x, 1));
+  VERIFY(std::log(x) == std::logl(x));
+  VERIFY(std::log10(x) == std::log10l(x));
+  VERIFY(std::modf(x, &i1) == std::modfl(x, &i2));
+  VERIFY(i1 == i2);
+  VERIFY(std::pow(x, x) == std::powl(x, x));
+  VERIFY(std::sin(x) == std::sinl(x));
+  VERIFY(std::sinh(x) == std::sinhl(x));
+  VERIFY(std::sqrt(x) == std::sqrtl(x));
+  VERIFY(std::tan(x) == std::tanl(x));
+  VERIFY(std::tanh(x) == std::tanhl(x));
+}
+
+int
+main ()
+{
+  test_float_global();
+  test_float_overload();
+  test_long_double_global();
+  test_long_double_overload();
+}
diff --git a/libstdc++-v3/testsuite/26_numerics/headers/cmath/functions_std_c++17.cc b/libstdc++-v3/testsuite/26_numerics/headers/cmath/functions_std_c++17.cc
index 3b4ada1a756..c6ec636c183 100644
--- a/libstdc++-v3/testsuite/26_numerics/headers/cmath/functions_std_c++17.cc
+++ b/libstdc++-v3/testsuite/26_numerics/headers/cmath/functions_std_c++17.cc
@@ -44,6 +44,51 @@ namespace gnu
   using std::tan;
   using std::tanh;
 
+  using std::acosf;
+  using std::acosl;
+  using std::asinf;
+  using std::asinl;
+  using std::atanf;
+  using std::atanl;
+  using std::atan2f;
+  using std::atan2l;
+  using std::ceilf;
+  using std::ceill;
+  using std::cosf;
+  using std::cosl;
+  using std::coshf;
+  using std::coshl;
+  using std::expf;
+  using std::expl;
+  using std::fabsf;
+  using std::fabsl;
+  using std::floorf;
+  using std::floorl;
+  using std::fmodf;
+  using std::fmodl;
+  using std::frexpf;
+  using std::frexpl;
+  using std::ldexpf;
+  using std::ldexpl;
+  using std::logf;
+  using std::logl;
+  using std::log10f;
+  using std::log10l;
+  using std::modff;
+  using std::modfl;
+  using std::powf;
+  using std::powl;
+  using std::sinf;
+  using std::sinl;
+  using std::sinhf;
+  using std::sinhl;
+  using std::sqrtf;
+  using std::sqrtl;
+  using std::tanf;
+  using std::tanl;
+  using std::tanhf;
+  using std::tanhl;
+
   using std::assoc_laguerre;
   using std::assoc_laguerref;
   using std::assoc_laguerrel;
-- 
2.34.1


  reply	other threads:[~2023-02-21 11:22 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-02-20 11:23 Nathaniel Shead
2023-02-20 11:30 ` Jonathan Wakely
2023-02-20 11:57   ` Nathaniel Shead
2023-02-20 12:08     ` Jonathan Wakely
2023-02-21 11:22       ` Nathaniel Shead [this message]
2023-04-17  8:10         ` [Ping][PATCH] " Nathaniel Shead
2023-04-18  8:47           ` Jonathan Wakely
2023-05-17  8:37             ` Nathaniel Shead
2023-05-17  9:05               ` Jonathan Wakely
2023-05-17  9:38                 ` Nathaniel Shead
2023-05-17 10:07                   ` Jonathan Wakely
2023-11-11  0:43                     ` Jonathan Wakely

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=Y/SpY7IRgpGd00ly@Thaum.localdomain \
    --to=nathanieloshead@gmail.com \
    --cc=gcc-patches@gcc.gnu.org \
    --cc=jwakely@redhat.com \
    --cc=libstdc++@gcc.gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).