Arcane  v4.1.0.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
TestValueConvert.cc
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2025 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7
8#include <gtest/gtest.h>
9
10#include "arcane/utils/ValueConvert.h"
11#include "arcane/utils/internal/ValueConvertInternal.h"
12
13/*---------------------------------------------------------------------------*/
14/*---------------------------------------------------------------------------*/
15
16using namespace Arcane;
17
18/*---------------------------------------------------------------------------*/
19/*---------------------------------------------------------------------------*/
20
21namespace
22{
23
24/*---------------------------------------------------------------------------*/
25/*---------------------------------------------------------------------------*/
26
27template <typename T> void _checkBad(const String& s)
28{
29 T x = {};
30 bool is_bad = builtInGetValue(x, s);
31 std::cout << "CheckBad S=" << s << " X=" << x << " is_bad?=" << is_bad << "\n";
32 ASSERT_TRUE(is_bad);
33}
34
35void _checkDouble(const String& s, double expected_x)
36{
37 Real x = 0;
38 bool is_bad = builtInGetValue(x, s);
39 std::cout << "S=" << s << " X=" << x << " is_bad?=" << is_bad << "\n";
40 ASSERT_FALSE(is_bad);
41 ASSERT_EQ(x, expected_x);
42}
43
44void _checkNaN(const String& s)
45{
46 Real x = 0;
47 bool is_bad = builtInGetValue(x, s);
48 std::cout << "S=" << s << " X=" << x << " is_bad?=" << is_bad << "\n";
49 ASSERT_FALSE(is_bad);
50 ASSERT_TRUE(std::isnan(x));
51}
52
58void _checkValidDouble(double value, double expected_value)
59{
60 // Pour NaN, on ne peut pas faire la comparaison.
61 if (std::isnan(expected_value)) {
62 ASSERT_TRUE(std::isnan(value)) << "value " << value << " is not 'nan'";
63 return;
64 }
65 ASSERT_EQ(value, expected_value);
66}
67
68void _checkReal2(const String& s, Real2 expected_v)
69{
70 Real2 v = {};
71 bool is_bad = builtInGetValue(v, s);
72 std::cout << "S=" << s << " Real2=" << v << " is_bad?=" << is_bad << "\n";
73 ASSERT_FALSE(is_bad) << "Can not convert '" << s << "' to Real2";
74 bool do_test = false;
75 _checkValidDouble(v.x, expected_v.x);
76 _checkValidDouble(v.y, expected_v.y);
77 if (do_test) {
78 ASSERT_EQ(v, expected_v);
79 }
80}
81
82void _checkReal3(const String& s, Real3 expected_v)
83{
84 std::cout << "Real3Compare s='" << s << "'\n";
85 Real3 v = {};
86 bool is_bad = builtInGetValue(v, s);
87 std::cout << "S=" << s << " Real3=" << v << " is_bad?=" << is_bad << "\n";
88 ASSERT_FALSE(is_bad) << "Can not convert '" << s << "' to Real3";
89 bool do_test = false;
90 _checkValidDouble(v.x, expected_v.x);
91 _checkValidDouble(v.y, expected_v.y);
92 _checkValidDouble(v.z, expected_v.z);
93 if (do_test) {
94 ASSERT_EQ(v, expected_v);
95 }
96}
97
98void _testDoubleConvert(bool use_from_chars)
99{
100
101 {
102 // TODO: tester les autres conversions
103 String s = "25e3";
104 Int32 x = 0;
105 bool is_bad = builtInGetValue(x, s);
106 std::cout << "S=" << s << " X=" << x << " is_bad?=" << is_bad << "\n";
107 ASSERT_TRUE(is_bad);
108 }
109 // Avec la version 'from_chars', convertir une chaîne vide est une erreur
110 // mais pas avec la version historique.
111 if (use_from_chars)
112 _checkBad<double>("");
113 _checkDouble("-0x1.81e03f705857bp-16", -2.3e-05);
114 _checkDouble("0x1.81e03f705857bp-16", 2.3e-05);
115 _checkDouble("+0x1.81e03f705857bp-16", 2.3e-05);
116 _checkDouble(" +1.23e42", 1.23e42);
117 _checkDouble(" -1.23e42", -1.23e42);
118 if (!use_from_chars) {
119 _checkDouble("+1.23e42", 1.23e42);
120 }
121
122 _checkBad<double>("d2");
123 _checkBad<double>("2.3w");
124
125 {
126 Real inf_x = std::numeric_limits<Real>::infinity();
127 _checkDouble("inf", inf_x);
128 _checkDouble(" INF", inf_x);
129 _checkDouble(" infinity", inf_x);
130 _checkDouble("INFINITY", inf_x);
131 }
132 {
133 Real minus_inf_x = -std::numeric_limits<Real>::infinity();
134 _checkDouble("-inf", minus_inf_x);
135 _checkDouble(" -INF", minus_inf_x);
136 _checkDouble(" -infinity", minus_inf_x);
137 _checkDouble("-INFINITY", minus_inf_x);
138 }
139
140 {
141 _checkNaN("nan");
142 _checkNaN(" NAN");
143 _checkNaN("NaN");
144 _checkNaN(" nAN");
145 }
146 {
147 String s3 = "23123.132e123";
148 Real total = 0.0;
149 Int32 nb_iter = 1000000 * 10;
150 nb_iter = 1;
151 for (Int32 i = 0; i < nb_iter; ++i) {
152 Real v = {};
153 builtInGetValue(v, s3);
154 total += v;
155 }
156 std::cout << "Total=" << total << "\n";
157 }
158}
159
160void _testReal2Convert(bool use_same_that_real)
161{
162 impl::arcaneSetUseSameValueConvertForAllReal(use_same_that_real);
163 Real v_nan = std::numeric_limits<double>::quiet_NaN();
164 _checkReal2("2.3e1 -1.2", Real2(2.3e1, -1.2));
165 if (use_same_that_real) {
166 _checkReal2("-1.3 nan", Real2(-1.3, v_nan));
167 _checkReal2(" 2.3 -1.3", Real2(2.3, -1.3));
168 }
169 _checkBad<Real2>("2.3 1.2w");
170 _checkBad<Real2>("2.3x");
171 _checkBad<Real2>(" y2.3 1.2");
172}
173
174void _testReal3Convert(bool use_same_that_real)
175{
176 impl::arcaneSetUseSameValueConvertForAllReal(use_same_that_real);
177 Real v_nan = std::numeric_limits<double>::quiet_NaN();
178 Real v_inf = std::numeric_limits<double>::infinity();
179 _checkReal3("2.3e1 -1.2 1.5", Real3(2.3e1, -1.2, 1.5));
180 if (use_same_that_real) {
181 _checkReal3("-1.3 nan 4.6", Real3(-1.3, v_nan, 4.6));
182 _checkReal3("1.3 4.2 inf", Real3(1.3, 4.2, v_inf));
183 _checkReal3("-2.1\t -1.5 1.0e5", Real3(-2.1, -1.5, 1.0e5));
184 _checkReal3(" -2.1 -1.5 1.0e5", Real3(-2.1, -1.5, 1.0e5));
185 //_checkReal3("-2.1 -1.5 +1.0e5", Real3(-2.1, -1.5, 1.0e5));
186 }
187 _checkBad<Real3>("2.3 1.2w");
188 _checkBad<Real3>("2.3x");
189 _checkBad<Real3>("2.3 1.2");
190 _checkBad<Real3>("2.3 -1.2ee2 4.5");
191 _checkBad<Real3>("z2.3 -1.2e2 -2323.3");
192 _checkBad<Real3>("2.3 -1.2e2 -2323.3x");
193}
194
195/*---------------------------------------------------------------------------*/
196/*---------------------------------------------------------------------------*/
197
198} // namespace
199
200/*---------------------------------------------------------------------------*/
201/*---------------------------------------------------------------------------*/
202
203TEST(ValueConvert, Basic)
204{
205 std::cout << "TEST_ValueConvert Basic\n";
206 impl::arcaneSetValueConvertVerbosity(1);
207
208#if defined(ARCANE_HAS_CXX20)
209 impl::arcaneSetIsValueConvertUseFromChars(true);
210 _testDoubleConvert(true);
211 _testReal2Convert(true);
212 _testReal2Convert(false);
213 _testReal3Convert(true);
214 _testReal3Convert(false);
215#endif
216
217 impl::arcaneSetIsValueConvertUseFromChars(false);
218 _testDoubleConvert(false);
219 _testReal2Convert(true);
220 _testReal2Convert(false);
221 _testReal3Convert(true);
222 _testReal3Convert(false);
223}
224
225TEST(ValueConvert, TryParse)
226{
227 {
228 String s2;
230 ASSERT_FALSE(v.has_value());
231 }
232
233 {
234 String s2;
236 ASSERT_TRUE(v.has_value());
237 ASSERT_EQ(v, 4);
238 }
239
240 {
241 String s2("2.3");
243 ASSERT_EQ(v, 2.3);
244 }
245
246 {
247 String s2("2.3w");
249 ASSERT_FALSE(v.has_value());
250 }
251}
252
253/*---------------------------------------------------------------------------*/
254/*---------------------------------------------------------------------------*/
#define ASSERT_FALSE(condition)
Vérifie que condition est faux.
Definition Assertion.h:137
#define ASSERT_TRUE(condition)
Vérifie que condition est vrai.
Definition Assertion.h:125
Classe gérant un vecteur de réel de dimension 2.
Definition Real2.h:121
Classe gérant un vecteur de réel de dimension 3.
Definition Real3.h:132
Chaîne de caractères unicode.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
Real y
deuxième composante du couple
Definition Real2.h:35
Real x
première composante du couple
Definition Real2.h:34
Real y
deuxième composante du triplet
Definition Real3.h:36
Real z
troisième composante du triplet
Definition Real3.h:37
Real x
première composante du triplet
Definition Real3.h:35