]>
git.ipfire.org Git - thirdparty/gcc.git/blob - libstdc++-v3/testsuite/experimental/simd/tests/sincos.cc
1 // Copyright (C) 2020-2023 Free Software Foundation, Inc.
3 // This file is part of the GNU ISO C++ Library. This library is free
4 // software; you can redistribute it and/or modify it under the
5 // terms of the GNU General Public License as published by the
6 // Free Software Foundation; either version 3, or (at your option)
9 // This library is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License along
15 // with this library; see the file COPYING3. If not see
16 // <http://www.gnu.org/licenses/>.
18 // only: float|double|ldouble * * *
20 // expensive: * [1-9] * *
21 #include "bits/verify.h"
22 #include "bits/metahelpers.h"
23 #include "bits/mathreference.h"
24 #include "bits/simd_view.h"
25 #include "bits/test_values.h"
33 using T
= typename
V::value_type
;
35 vir::test::setFuzzyness
<float>(2);
36 vir::test::setFuzzyness
<double>(1);
38 const auto& testdata
= referenceData
<function::sincos
, T
>();
39 std::experimental::experimental::simd_view
<V
>(testdata
).for_each(
40 [&](const V input
, const V expected_sin
, const V expected_cos
) {
41 FUZZY_COMPARE(sin(input
), expected_sin
) << " input = " << input
;
42 FUZZY_COMPARE(sin(-input
), -expected_sin
) << " input = " << input
;
43 FUZZY_COMPARE(cos(input
), expected_cos
) << " input = " << input
;
44 FUZZY_COMPARE(cos(-input
), expected_cos
) << " input = " << input
;