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}