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}