14514f5e3Sopenharmony_ci/*
24514f5e3Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd.
34514f5e3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
44514f5e3Sopenharmony_ci * you may not use this file except in compliance with the License.
54514f5e3Sopenharmony_ci * You may obtain a copy of the License at
64514f5e3Sopenharmony_ci *
74514f5e3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
84514f5e3Sopenharmony_ci *
94514f5e3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
104514f5e3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
114514f5e3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
124514f5e3Sopenharmony_ci * See the License for the specific language governing permissions and
134514f5e3Sopenharmony_ci * limitations under the License.
144514f5e3Sopenharmony_ci */
154514f5e3Sopenharmony_ci
164514f5e3Sopenharmony_ci#include "ecmascript/base/math_helper.h"
174514f5e3Sopenharmony_ci#include "ecmascript/tests/test_helper.h"
184514f5e3Sopenharmony_ci
194514f5e3Sopenharmony_ciusing namespace panda::ecmascript;
204514f5e3Sopenharmony_ciusing namespace panda::ecmascript::base;
214514f5e3Sopenharmony_ci
224514f5e3Sopenharmony_cinamespace panda::test {
234514f5e3Sopenharmony_ciclass MathHelperTest : public BaseTestWithScope<false> {
244514f5e3Sopenharmony_ci};
254514f5e3Sopenharmony_ci
264514f5e3Sopenharmony_ciHWTEST_F_L0(MathHelperTest, GetIntLog2_001)
274514f5e3Sopenharmony_ci{
284514f5e3Sopenharmony_ci    const uint32_t commonInput = static_cast<uint32_t>(0b111111111) << 13; // 13 : left shift digit
294514f5e3Sopenharmony_ci    const uint32_t maxInput = std::numeric_limits<uint32_t>::max();
304514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::GetIntLog2(commonInput), 13U);
314514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::GetIntLog2(maxInput), 0U);
324514f5e3Sopenharmony_ci}
334514f5e3Sopenharmony_ci
344514f5e3Sopenharmony_ciHWTEST_F_L0(MathHelperTest, GetIntLog2_002)
354514f5e3Sopenharmony_ci{
364514f5e3Sopenharmony_ci    const uint64_t commonInput = static_cast<uint64_t>(0b111111111) << 53; // 53 : left shift digit
374514f5e3Sopenharmony_ci    const uint64_t maxInput = std::numeric_limits<uint64_t>::max();
384514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::GetIntLog2(commonInput), 53U);
394514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::GetIntLog2(maxInput), 0U);
404514f5e3Sopenharmony_ci}
414514f5e3Sopenharmony_ci
424514f5e3Sopenharmony_ciHWTEST_F_L0(MathHelperTest, Asinh)
434514f5e3Sopenharmony_ci{
444514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::Asinh(1), 0.88137358701954302523260932497979);
454514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::Asinh(+0), +0.0);
464514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::Asinh(-0), -0.0);
474514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::Asinh(-1), -0.88137358701954302523260932497979);
484514f5e3Sopenharmony_ci
494514f5e3Sopenharmony_ci    double nanResult = MathHelper::Asinh(std::numeric_limits<double>::signaling_NaN());
504514f5e3Sopenharmony_ci    EXPECT_TRUE(std::isnan(nanResult));
514514f5e3Sopenharmony_ci}
524514f5e3Sopenharmony_ci
534514f5e3Sopenharmony_ciHWTEST_F_L0(MathHelperTest, Atanh)
544514f5e3Sopenharmony_ci{
554514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::Atanh(0), 0);
564514f5e3Sopenharmony_ci    EXPECT_EQ(MathHelper::Atanh(0.5), std::atanh(0.5));
574514f5e3Sopenharmony_ci
584514f5e3Sopenharmony_ci    double infResult = MathHelper::Atanh(-1); // limit value
594514f5e3Sopenharmony_ci    EXPECT_TRUE(std::isinf(infResult));
604514f5e3Sopenharmony_ci
614514f5e3Sopenharmony_ci    double nanResult = MathHelper::Atanh(2); // out of input range
624514f5e3Sopenharmony_ci    EXPECT_TRUE(std::isnan(nanResult));
634514f5e3Sopenharmony_ci}
644514f5e3Sopenharmony_ci}  // namespace panda::test
65