finesse.utilities.polyfit.polyfit2d¶
- finesse.utilities.polyfit.polyfit2d(x, y, z, kx, ky, *, order=None, weights=None)[source]¶
 Two dimensional polynomial fitting by least squares. Fits the functional form f(x,y) = z.
- Parameters:
 - x, y: array-like, 1d
 x and y coordinates.
- z: np.ndarray, 2d
 Surface to fit.
- kx, ky: int
 Polynomial order in x and y, respectively.
- order: int or None
 If None, all coefficients up to maxiumum kx, ky, ie. up to and including x^kx*y^ky, are considered. If int, coefficients up to a maximum of kx+ky <= order are considered.
- weight: array_like, 2d
 Weighting to use for fit. Same dimenstions as z
- Returns:
 - Return parameters from np.linalg.lstsq.
 - soln: np.ndarray
 Array of polynomial coefficients.
- residuals: np.ndarray
 - rank: int
 - s: np.ndarray
 
Notes
Resultant fit can be evaluated with
polyfit2d_eval().Based on code from: https://stackoverflow.com/questions/33964913/equivalent-of-polyfit-for-a-2d-polynomial-in-python