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 "functionalext.h"
19570af302Sopenharmony_ci
20570af302Sopenharmony_ci/**
21570af302Sopenharmony_ci * @tc.name      : __fpclassifyf_0100
22570af302Sopenharmony_ci * @tc.desc      : The parameter is valid, x is 1.0, can get the integer value matching the
23570af302Sopenharmony_ci *                 classification macro constant.
24570af302Sopenharmony_ci * @tc.level     : Level 0
25570af302Sopenharmony_ci */
26570af302Sopenharmony_civoid __fpclassifyf_0100(void)
27570af302Sopenharmony_ci{
28570af302Sopenharmony_ci    float x = 1.0;
29570af302Sopenharmony_ci    int ret = __fpclassifyf(x);
30570af302Sopenharmony_ci    EXPECT_EQ("__fpclassifyf_0100", ret, FP_NORMAL);
31570af302Sopenharmony_ci}
32570af302Sopenharmony_ci
33570af302Sopenharmony_ci/**
34570af302Sopenharmony_ci * @tc.name      : __fpclassifyf_0200
35570af302Sopenharmony_ci * @tc.desc      : The parameter is valid, x is NAN, can get the integer value matching the
36570af302Sopenharmony_ci *                 classification macro constant.
37570af302Sopenharmony_ci * @tc.level     : Level 1
38570af302Sopenharmony_ci */
39570af302Sopenharmony_civoid __fpclassifyf_0200(void)
40570af302Sopenharmony_ci{
41570af302Sopenharmony_ci    float x = NAN;
42570af302Sopenharmony_ci    int ret = __fpclassifyf(x);
43570af302Sopenharmony_ci    EXPECT_EQ("__fpclassifyf_0200", ret, FP_NAN);
44570af302Sopenharmony_ci}
45570af302Sopenharmony_ci
46570af302Sopenharmony_ci/**
47570af302Sopenharmony_ci * @tc.name      : __fpclassifyf_0300
48570af302Sopenharmony_ci * @tc.desc      : The parameter is valid, x is INFINITY, can get the integer value matching the
49570af302Sopenharmony_ci *                 classification macro constant.
50570af302Sopenharmony_ci * @tc.level     : Level 1
51570af302Sopenharmony_ci */
52570af302Sopenharmony_civoid __fpclassifyf_0300(void)
53570af302Sopenharmony_ci{
54570af302Sopenharmony_ci    float x = INFINITY;
55570af302Sopenharmony_ci    int ret = __fpclassifyf(x);
56570af302Sopenharmony_ci    EXPECT_EQ("__fpclassifyf_0300", ret, FP_INFINITE);
57570af302Sopenharmony_ci}
58570af302Sopenharmony_ci
59570af302Sopenharmony_ci/**
60570af302Sopenharmony_ci * @tc.name      : __fpclassifyf_0400
61570af302Sopenharmony_ci * @tc.desc      : The parameter is valid, x is -0.0, can get the integer value matching the
62570af302Sopenharmony_ci *                 classification macro constant.
63570af302Sopenharmony_ci * @tc.level     : Level 1
64570af302Sopenharmony_ci */
65570af302Sopenharmony_civoid __fpclassifyf_0400(void)
66570af302Sopenharmony_ci{
67570af302Sopenharmony_ci    float x = -0.0;
68570af302Sopenharmony_ci    int ret = __fpclassifyf(x);
69570af302Sopenharmony_ci    EXPECT_EQ("__fpclassifyf_0400", ret, FP_ZERO);
70570af302Sopenharmony_ci}
71570af302Sopenharmony_ci
72570af302Sopenharmony_ciint main(int argc, char *argv[])
73570af302Sopenharmony_ci{
74570af302Sopenharmony_ci    __fpclassifyf_0100();
75570af302Sopenharmony_ci    __fpclassifyf_0200();
76570af302Sopenharmony_ci    __fpclassifyf_0300();
77570af302Sopenharmony_ci    __fpclassifyf_0400();
78570af302Sopenharmony_ci    return t_status;
79570af302Sopenharmony_ci}