1 | "use strict";
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports.createLog2 = void 0;
|
7 |
|
8 | var _factory = require("../../utils/factory");
|
9 |
|
10 | var _collection = require("../../utils/collection");
|
11 |
|
12 | var _number = require("../../plain/number");
|
13 |
|
14 | var name = 'log2';
|
15 | var dependencies = ['typed', 'config', 'Complex'];
|
16 | var createLog2 = (0, _factory.factory)(name, dependencies, function (_ref) {
|
17 | var typed = _ref.typed,
|
18 | config = _ref.config,
|
19 | Complex = _ref.Complex;
|
20 |
|
21 | |
22 |
|
23 |
|
24 |
|
25 |
|
26 |
|
27 |
|
28 |
|
29 |
|
30 |
|
31 |
|
32 |
|
33 |
|
34 |
|
35 |
|
36 |
|
37 |
|
38 |
|
39 |
|
40 |
|
41 |
|
42 |
|
43 |
|
44 |
|
45 |
|
46 | var log2 = typed(name, {
|
47 | number: function number(x) {
|
48 | if (x >= 0 || config.predictable) {
|
49 | return (0, _number.log2Number)(x);
|
50 | } else {
|
51 |
|
52 | return _log2Complex(new Complex(x, 0));
|
53 | }
|
54 | },
|
55 | Complex: _log2Complex,
|
56 | BigNumber: function BigNumber(x) {
|
57 | if (!x.isNegative() || config.predictable) {
|
58 | return x.log(2);
|
59 | } else {
|
60 |
|
61 | return _log2Complex(new Complex(x.toNumber(), 0));
|
62 | }
|
63 | },
|
64 | 'Array | Matrix': function ArrayMatrix(x) {
|
65 | return (0, _collection.deepMap)(x, log2);
|
66 | }
|
67 | });
|
68 | |
69 |
|
70 |
|
71 |
|
72 |
|
73 |
|
74 |
|
75 | function _log2Complex(x) {
|
76 | var newX = Math.sqrt(x.re * x.re + x.im * x.im);
|
77 | return new Complex(Math.log2 ? Math.log2(newX) : Math.log(newX) / Math.LN2, Math.atan2(x.im, x.re) / Math.LN2);
|
78 | }
|
79 |
|
80 | return log2;
|
81 | });
|
82 | exports.createLog2 = createLog2; |
\ | No newline at end of file |