1570af302Sopenharmony_ci/*
2570af302Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd.
3570af302Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4570af302Sopenharmony_ci * you may not use this file except in compliance with the License.
5570af302Sopenharmony_ci * You may obtain a copy of the License at
6570af302Sopenharmony_ci *
7570af302Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8570af302Sopenharmony_ci *
9570af302Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10570af302Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11570af302Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12570af302Sopenharmony_ci * See the License for the specific language governing permissions and
13570af302Sopenharmony_ci * limitations under the License.
14570af302Sopenharmony_ci */
15570af302Sopenharmony_ci
16570af302Sopenharmony_ci#include <float.h>
17570af302Sopenharmony_ci#include <math.h>
18570af302Sopenharmony_ci#include "test.h"
19570af302Sopenharmony_ci
20570af302Sopenharmony_ci#define EXPECT_DOUBLE_EQ(a, b)                                             \
21570af302Sopenharmony_ci    do {                                                                   \
22570af302Sopenharmony_ci        if (!(fabs(a - b) < DBL_EPSILON))                                  \
23570af302Sopenharmony_ci            t_error("%s failed: %f is not equal to %f\n", __func__, a, b); \
24570af302Sopenharmony_ci    } while (0)
25570af302Sopenharmony_ci
26570af302Sopenharmony_ci/*
27570af302Sopenharmony_ci * @tc.name      : significand_0100
28570af302Sopenharmony_ci * @tc.desc      : Get mantissa of floating-point number 0.0
29570af302Sopenharmony_ci * @tc.level     : Level 0
30570af302Sopenharmony_ci */
31570af302Sopenharmony_civoid significand_0100(void)
32570af302Sopenharmony_ci{
33570af302Sopenharmony_ci    double d = significand(0.0);
34570af302Sopenharmony_ci    EXPECT_DOUBLE_EQ(0.0, d);
35570af302Sopenharmony_ci}
36570af302Sopenharmony_ci
37570af302Sopenharmony_ci/*
38570af302Sopenharmony_ci * @tc.name      : significand_0200
39570af302Sopenharmony_ci * @tc.desc      : Get mantissa of floating-point number 1.2
40570af302Sopenharmony_ci * @tc.level     : Level 1
41570af302Sopenharmony_ci */
42570af302Sopenharmony_civoid significand_0200(void)
43570af302Sopenharmony_ci{
44570af302Sopenharmony_ci    double d = significand(1.2);
45570af302Sopenharmony_ci    EXPECT_DOUBLE_EQ(1.2, d);
46570af302Sopenharmony_ci}
47570af302Sopenharmony_ci
48570af302Sopenharmony_ci/*
49570af302Sopenharmony_ci * @tc.name      : significand_0300
50570af302Sopenharmony_ci * @tc.desc      : Get mantissa of floating-point number 12.25
51570af302Sopenharmony_ci * @tc.level     : Level 1
52570af302Sopenharmony_ci */
53570af302Sopenharmony_civoid significand_0300(void)
54570af302Sopenharmony_ci{
55570af302Sopenharmony_ci    double d = significand(12.25);
56570af302Sopenharmony_ci    EXPECT_DOUBLE_EQ(1.53125, d);
57570af302Sopenharmony_ci}
58570af302Sopenharmony_ci
59570af302Sopenharmony_ciint main(int argc, char *argv[])
60570af302Sopenharmony_ci{
61570af302Sopenharmony_ci    significand_0100();
62570af302Sopenharmony_ci    significand_0200();
63570af302Sopenharmony_ci    significand_0300();
64570af302Sopenharmony_ci    return t_status;
65570af302Sopenharmony_ci}