| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 7690 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 7701 RUNTIME_FUNCTION(MaybeObject*, Runtime_ConstructDouble) { | 7701 RUNTIME_FUNCTION(MaybeObject*, Runtime_ConstructDouble) { |
| 7702 SealHandleScope shs(isolate); | 7702 SealHandleScope shs(isolate); |
| 7703 ASSERT(args.length() == 2); | 7703 ASSERT(args.length() == 2); |
| 7704 CONVERT_NUMBER_CHECKED(uint32_t, hi, Uint32, args[0]); | 7704 CONVERT_NUMBER_CHECKED(uint32_t, hi, Uint32, args[0]); |
| 7705 CONVERT_NUMBER_CHECKED(uint32_t, lo, Uint32, args[1]); | 7705 CONVERT_NUMBER_CHECKED(uint32_t, lo, Uint32, args[1]); |
| 7706 uint64_t result = (static_cast<uint64_t>(hi) << 32) | lo; | 7706 uint64_t result = (static_cast<uint64_t>(hi) << 32) | lo; |
| 7707 return isolate->heap()->AllocateHeapNumber(uint64_to_double(result)); | 7707 return isolate->heap()->AllocateHeapNumber(uint64_to_double(result)); |
| 7708 } | 7708 } |
| 7709 | 7709 |
| 7710 | 7710 |
| 7711 // Cube root approximation, refer to: http://metamerist.com/cbrt/cbrt.htm | |
| 7712 // Using initial approximation adapted from Kahan's cbrt and 4 iterations | |
| 7713 // of Newton's method. | |
| 7714 inline double CubeRootNewtonIteration(double approx, double x) { | |
| 7715 return (1.0 / 3.0) * (x / (approx * approx) + 2 * approx); | |
| 7716 } | |
| 7717 | |
| 7718 | |
| 7719 inline double CubeRoot(double x) { | |
| 7720 static const uint64_t magic = V8_2PART_UINT64_C(0x2A9F7893, 00000000); | |
| 7721 uint64_t xhigh = double_to_uint64(x); | |
| 7722 double approx = uint64_to_double(xhigh / 3 + magic); | |
| 7723 | |
| 7724 approx = CubeRootNewtonIteration(approx, x); | |
| 7725 approx = CubeRootNewtonIteration(approx, x); | |
| 7726 approx = CubeRootNewtonIteration(approx, x); | |
| 7727 return CubeRootNewtonIteration(approx, x); | |
| 7728 } | |
| 7729 | |
| 7730 | |
| 7731 RUNTIME_FUNCTION(MaybeObject*, Runtime_Math_cbrt) { | |
| 7732 SealHandleScope shs(isolate); | |
| 7733 ASSERT(args.length() == 1); | |
| 7734 CONVERT_DOUBLE_ARG_CHECKED(x, 0); | |
| 7735 if (x == 0 || std::isinf(x)) return args[0]; | |
| 7736 double result = (x > 0) ? CubeRoot(x) : -CubeRoot(-x); | |
| 7737 return isolate->heap()->AllocateHeapNumber(result); | |
| 7738 } | |
| 7739 | |
| 7740 | |
| 7741 RUNTIME_FUNCTION(MaybeObject*, Runtime_Math_log1p) { | 7711 RUNTIME_FUNCTION(MaybeObject*, Runtime_Math_log1p) { |
| 7742 SealHandleScope shs(isolate); | 7712 SealHandleScope shs(isolate); |
| 7743 ASSERT(args.length() == 1); | 7713 ASSERT(args.length() == 1); |
| 7744 CONVERT_DOUBLE_ARG_CHECKED(x, 0); | 7714 CONVERT_DOUBLE_ARG_CHECKED(x, 0); |
| 7745 | 7715 |
| 7746 double x_abs = std::fabs(x); | 7716 double x_abs = std::fabs(x); |
| 7747 // Use Taylor series to approximate. With y = x + 1; | 7717 // Use Taylor series to approximate. With y = x + 1; |
| 7748 // log(y) at 1 == log(1) + log'(1)(y-1)/1! + log''(1)(y-1)^2/2! + ... | 7718 // log(y) at 1 == log(1) + log'(1)(y-1)/1! + log''(1)(y-1)^2/2! + ... |
| 7749 // == 0 + x - x^2/2 + x^3/3 ... | 7719 // == 0 + x - x^2/2 + x^3/3 ... |
| 7750 // The closer x is to 0, the fewer terms are required. | 7720 // The closer x is to 0, the fewer terms are required. |
| (...skipping 7270 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 15021 // Handle last resort GC and make sure to allow future allocations | 14991 // Handle last resort GC and make sure to allow future allocations |
| 15022 // to grow the heap without causing GCs (if possible). | 14992 // to grow the heap without causing GCs (if possible). |
| 15023 isolate->counters()->gc_last_resort_from_js()->Increment(); | 14993 isolate->counters()->gc_last_resort_from_js()->Increment(); |
| 15024 isolate->heap()->CollectAllGarbage(Heap::kNoGCFlags, | 14994 isolate->heap()->CollectAllGarbage(Heap::kNoGCFlags, |
| 15025 "Runtime::PerformGC"); | 14995 "Runtime::PerformGC"); |
| 15026 } | 14996 } |
| 15027 } | 14997 } |
| 15028 | 14998 |
| 15029 | 14999 |
| 15030 } } // namespace v8::internal | 15000 } } // namespace v8::internal |
| OLD | NEW |