SimPEG.utils.inverse_2x2_block_diagonal#

SimPEG.utils.inverse_2x2_block_diagonal(a11, a12, a21, a22, return_matrix=True, **kwargs)[source]#

Invert a set of 2x2 matricies from vectors containing their elements.

Parameters
a11, a12, a21, a22(n_blocks) numpy.ndarray

All arguments a11, a12, a21, a22 are vectors which contain the corresponding element for all 2x2 matricies

return_matrixbool, optional
  • True: Returns the sparse block 2x2 matrix M.

  • False: Returns the vectors containing the elements of each matrix’ inverse.

Returns
(2 * n_blocks, 2 * n_blocks) scipy.sparse.coo_matrix or list of (n_blocks) numpy.ndarray

If return_matrix = False, the function will return vectors b11, b12, b21, b22. If return_matrix = True, the function will return the block matrix M

Notes

The elements of a 2x2 matrix A are given by:

A=[a11a12a21a22]

For a set of 2x2 matricies, the elements may be stored in a set of 4 distinct vectors a11, a12, a21 and a22. For each matrix, inverse_2x2_block_diagonal ouputs the vectors containing the elements of each matrix’ inverse; i.e. b11, b12, b21 and b22 where:

A1=B=[b11b12b21b22]

For special applications, we may want to output the elements of the inverses of the matricies as a 2x2 block matrix of the form:

M=[D11D12D21D22]

where Dij are diagonal matrices whose non-zero elements are defined by vector bij. Where n is the number of matricies, the block matrix is sparse with dimensions (2n, 2n).

Examples