Skip to content

Directly use scipy lapack functions instead of scipy wrappers #1468

Open
@jessegrabowski

Description

@jessegrabowski

Description

We take small performance hits by using scipy.linalg functions rather than directly calling lapack functions in our perform methods. These wrappers include a lot of data validation checks that we don't need, and sometimes end up copying things that we don't want to copy.

Instead of using these wrappers, we can use scipy.linalg.get_lapack_funcs to get and use the relevant routine. For example, calling potrs instead of using linalg.cholesky.

Which routine to call is easy to figure out by looking at the scipy source code and checking which function the wrapper calls, and with which arguments.

Here's a list of Op that can be converted, and the LAPACK routines they call:

  • Cholesky (potrf)
  • CholeskySolve (potrs)
  • LUFactor (getrf)
  • LUSolve (getrs)
  • SolveTriangular (trtrs)
  • Solve (depends on the assume_a argument. They all do lu_factor + lu_solve, but the exact routines called depends on the structure of the A matrix)
    • "gen" - getrf + getrs
    • "sym" - sysv
    • "pos" - posv
    • "tridiagonal" - gttrf + gttrs
    • "banded" - gbsv
  • Eigvalsh (complicated -- depends on input arguments. Need to spend some time looking at the scipy wrapper)
  • SolveContinuousLyapunov - trsyl

Routines in tensor.nlinalg might also benefit, but it would require some testing. For example, GESVD and GESDD are LAPACK routines for SVD, which might be better than np.linalg.svd (and related functions, like np.linalg.pinv). As I type this, I can't say if calling these routines directly would be better or worse than calling the numpy function. The numpy code is somewhat harder to peer into than scipy.

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions