Source code for lenstronomy.ImSim.de_lens

__author__ = "sibirrer"

import numpy as np
import sys

from lenstronomy.Util.package_util import exporter

export, __all__ = exporter()


[docs] @export def get_param_WLS(A, C_D_inv, d, inv_bool=True): """Returns the parameter values given. :param A: response matrix Nd x Ns (Nd = # data points, Ns = # parameters) :param C_D_inv: inverse covariance matrix of the data, Nd x Nd, diagonal form :param d: data array, 1-d Nd :param inv_bool: boolean, whether returning also the inverse matrix or just solve the linear system :return: 1-d array of parameter values """ M = A.T.dot(np.multiply(C_D_inv, A.T).T) if inv_bool: if np.linalg.cond(M) < 5 / sys.float_info.epsilon: M_inv = _stable_inv(M) else: M_inv = np.zeros_like(M) R = A.T.dot(np.multiply(C_D_inv, d)) B = M_inv.dot(R) else: if np.linalg.cond(M) < 5 / sys.float_info.epsilon: R = A.T.dot(np.multiply(C_D_inv, d)) B = _solve_stable(M, R) # try: # B = np.linalg.solve(M, R).T # except: # B = np.zeros(len(A.T)) else: B = np.zeros(len(A.T)) M_inv = None image = A.dot(B) return B, M_inv, image
[docs] @export def marginalisation_const(M_inv): """Get marginalisation constant 1/2 log(M_beta) for flat priors. :param M_inv: 2D covariance matrix :return: float """ sign, log_det = np.linalg.slogdet(M_inv) if sign == 0: return -(10**15) return sign * log_det / 2
[docs] @export def marginalization_new(M_inv, d_prior=None): """ :param M_inv: 2D covariance matrix :param d_prior: maximum prior length of linear parameters :return: log determinant with eigenvalues to be smaller or equal d_prior """ if d_prior is None: return marginalisation_const(M_inv) v, w = np.linalg.eig(M_inv) sign_v = np.sign(v) v_abs = np.abs(v) v_abs[v_abs > d_prior**2] = d_prior**2 log_det = np.sum(np.log(v_abs)) * np.prod(sign_v) if np.isnan(log_det): return -(10**15) m = len(v) return log_det / 2 + m / 2.0 * np.log(np.pi / 2.0) - m * np.log(d_prior)
def _stable_inv(m): """Stable linear inversion. :param m: square matrix to be inverted :return: inverse of M (or zeros) """ try: m_inv = np.linalg.inv(m) except: m_inv = np.zeros_like(m) return m_inv def _solve_stable(m, r): """ :param m: matrix :param r: vector :return: solution for B = M x R """ try: b = np.linalg.solve(m, r).T except: n = np.shape(m)[0] b = np.zeros(n) return b