Source code for lenstronomy.LensModel.Profiles.flexion

from lenstronomy.LensModel.Profiles.base_profile import LensProfileBase

__all__ = ['Flexion']


[docs]class Flexion(LensProfileBase): """ class for flexion """ param_names = ['g1', 'g2', 'g3', 'g4', 'ra_0', 'dec_0'] lower_limit_default = {'g1': -0.1, 'g2': -0.1, 'g3': -0.1, 'g4': -0.1, 'ra_0': -100, 'dec_0': -100} upper_limit_default = {'g1': 0.1, 'g2': 0.1, 'g3': 0.1, 'g4': 0.1, 'ra_0': 100, 'dec_0': 100}
[docs] def function(self, x, y, g1, g2, g3, g4, ra_0=0, dec_0=0): x_ = x - ra_0 y_ = y - dec_0 f_ = 1./6 * (g1 * x_**3 + 3*g2 * x_**2 * y_ + 3*g3 * x_ * y_**2 + g4 * y_**3) return f_
[docs] def derivatives(self, x, y, g1, g2, g3, g4, ra_0=0, dec_0=0): x_ = x - ra_0 y_ = y - dec_0 f_x = 1./2.*g1*x_**2 + g2*x_*y_ + 1./2.*g3*y_**2 f_y = 1./2.*g2*x_**2 + g3*x_*y_ + 1./2.*g4*y_**2 return f_x, f_y
[docs] def hessian(self, x, y, g1, g2, g3, g4, ra_0=0, dec_0=0): x_ = x - ra_0 y_ = y - dec_0 f_xx = g1*x_ + g2*y_ f_yy = g3*x_ + g4*y_ f_xy = g2*x_ + g3*y_ return f_xx, f_xy, f_xy, f_yy