Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | import absImpl from '../internal/absImpl'; import argImpl from '../internal/argImpl'; import { IComplex, IComplexConstructor } from '../internal/complex'; import mask from '../internal/mask'; import getAbs from '../methods/getAbs'; import getArg from '../methods/getArg'; export default function sign<T extends IComplex> (Complex: IComplexConstructor<T>, z: IComplex | number, i = 0): T { let zReal: number; let zImag: number let zAbs: number; let zArg: number; let zMask: mask; if (typeof z === 'number') { zReal = z; zImag = i; zAbs = absImpl(z, i); zArg = NaN; zMask = mask.HAS_CARTESIAN | mask.HAS_ABS; } else { zReal = z._real; zImag = z._imag; zAbs = getAbs(z); zArg = z._arg; zMask = z._mask; } if (zAbs === 0) { return new Complex(0, 0, 0, 0, mask.HAS_ALL); } if (zAbs !== Infinity) { return new Complex(zReal / zAbs, zImag / zAbs, 1, zArg, zMask | mask.HAS_ABS); } const zSignArg = typeof z === 'number' ? argImpl(zReal, zImag) : getArg(z); return new Complex(NaN, NaN, 1, zSignArg, mask.HAS_POLAR); } |