All files / complex-js/functions sign.ts

0% Statements 0/22
0% Branches 0/9
0% Functions 0/1
0% Lines 0/22

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);
}