Utilities using precision floating point summation.
    |  | 
        
          | cbrt(x) Compute the cube root x**(1/3).
 |  |  | 
    |  | 
        
          | cbrt2(x) Compute the cube root squared x**(2/3).
 |  |  | 
    |  | 
        
          | euclid(x,
        y) Appoximate the norm sqrt(x**2 + y**2) by 
      max(abs(x), abs(y)) + min(abs(x), abs(y)) * 
      0.4142....
 |  |  | 
    |  | 
        
          | euclid_(*xs) Appoximate the norm sqrt(sum(x**2 for x in 
      xs)) by cascaded euclid.
 |  |  | 
    |  |  | 
    |  |  | 
    |  | 
        
          | fatan(x) Fast approximation of
 atan(x). |  |  | 
    |  | 
        
          | fatan1(x) Fast approximation of
 atan(x)for0 <= 
      x <= 1, unchecked. |  |  | 
    |  | 
        
          | fatan2(y,
        x) Fast approximation of
 atan2(y, x). |  |  | 
    |  | 
        
          | favg(v1,
        v2,
        f=0.5) Return the average of two values.
 |  |  | 
    |  | 
        
          | fdot(a,
        *b) Return the precision dot product sum(a[i] * b[i] for 
      i=0..len(a)).
 |  |  | 
    |  | 
        
          | fdot3(a,
        b,
        c,
        start=0) Return the precision dot product start + sum(a[i] * 
      b[i] * c[i] for i=0..len(a)).
 |  |  | 
    |  | 
        
          | fhorner(x,
        *cs) Evaluate the polynomial sum(cs[i] * x**i for 
      i=0..len(cs)) using the Horner form.
 |  |  | 
    |  |  | 
    |  | 
        
          | fmean(xs) Compute the accurate mean sum(xs[i] for i=0..len(xs))
      / len(xs).
 |  |  | 
    |  | 
        
          | fmean_(*xs) Compute the accurate mean sum(xs[i] for i=0..len(xs))
      / len(xs).
 |  |  | 
    |  | 
        
          | fpolynomial(x,
        *cs,
        **over) Evaluate the polynomial sum(cs[i] * x**i for 
      i=0..len(cs)) [/ over].
 |  |  | 
    |  | 
        
          | fpowers(x,
        n,
        alts=0) Return a series of powers [x**i for i=1..n].
 |  |  | 
    |  | 
        
          | fprod(xs,
        start=1) Iterable product, like
 math.prodornumpy.prod. |  |  | 
    |  | 
        
          | frange(start,
        number,
        step=1) Generate a range of
 floats. |  |  | 
    | value | 
        
          | freduce(function,
        sequence,
        initial=...) Apply a function of two arguments cumulatively to the items of a 
      sequence, from left to right, so as to reduce the sequence to a 
      single value.
 |  |  | 
    |  | 
        
          | fremainder(x,
        y) Remainder in range
 [-y / 2, y / 2]. |  |  | 
    |  | 
        
          | hypot(x,
        y) Return the Euclidean distance, sqrt(x*x + y*y).
 |  |  | 
    |  | 
        
          | hypot_(*xs) Compute the norm sqrt(sum(x**2 for x in xs)).
 |  |  | 
    |  | 
        
          | hypot1(x) Compute the norm sqrt(1 + x**2).
 |  |  | 
    |  | 
        
          | hypot2(x,
        y) Compute the squared norm x**2 + y**2.
 |  |  | 
    |  | 
        
          | hypot2_(*xs) Compute the squared norm
 sum(x**2 for x in 
      xs). |  |  | 
    |  | 
        
          | norm2(x,
        y) Normalize a 2-dimensional vector.
 |  |  | 
    |  | 
        
          | norm_(*xs) Normalize all n-dimensional vector components.
 |  |  | 
    |  | 
        
          | sqrt0(x) Return the square root iff
 x >EPS02. |  |  | 
    |  | 
        
          | sqrt3(x) Compute the square root, cubed sqrt(x)**3 
      or sqrt(x**3).
 |  |  | 
    |  | 
        
          | sqrt_a(h,
        b) Compute
 aside of a right-angled triangle fromsqrt(h**2 - b**2). |  |  |