Skip to content

Commit

Permalink
Use a different approach
Browse files Browse the repository at this point in the history
  • Loading branch information
hsinfan1996 authored Feb 8, 2025
1 parent 1c5b27a commit cdd19ee
Showing 1 changed file with 10 additions and 15 deletions.
25 changes: 10 additions & 15 deletions clmm/theory/parent_class.py
Original file line number Diff line number Diff line change
Expand Up @@ -273,18 +273,20 @@ def _eval_excess_surface_density_2h(
)

def _eval_rdelta(self, z_cl):
return compute_rdelta(self.mdelta, z_cl, self.cosmo, self.massdef, self.delta_mdef)
delta_mdef = self._get_delta_mdef(z_cl)
return compute_rdelta(self.mdelta, z_cl, self.cosmo, self.massdef, delta_mdef)

def _eval_mass_in_radius(self, r3d, z_cl):
alpha = self._get_einasto_alpha(z_cl) if self.halo_profile_model == "einasto" else None
delta_mdef = self._get_delta_mdef(z_cl)
return compute_profile_mass_in_radius(
r3d,
z_cl,
self.cosmo,
self.mdelta,
self.cdelta,
self.massdef,
self.delta_mdef,
delta_mdef,
self.halo_profile_model,
alpha,
)
Expand All @@ -293,13 +295,14 @@ def _convert_mass_concentration(
self, z_cl, massdef=None, delta_mdef=None, halo_profile_model=None, alpha=None
):
alpha1 = self._get_einasto_alpha(z_cl) if self.halo_profile_model == "einasto" else None
delta_mdef1 = self._get_delta_mdef(z_cl)
return convert_profile_mass_concentration(
self.mdelta,
self.cdelta,
z_cl,
self.cosmo,
massdef=self.massdef,
delta_mdef=self.delta_mdef,
delta_mdef=delta_mdef1,
halo_profile_model=self.halo_profile_model,
alpha=alpha1,
massdef2=massdef,
Expand All @@ -308,9 +311,10 @@ def _convert_mass_concentration(
alpha2=alpha,
)

def _set_delta_mdef_virial(self, z_cl):
"Sets the delta_mdef value to the modeling object for mdef='virial'"
self.delta_mdef = int(self._get_delta_mdef_virial(z_cl))
def _get_delta_mdef(self, z_cl):
if self.massdef == "virial":
return int(self._get_delta_mdef_virial(z_cl))
return self.delta_mdef

# 3.1. Miscentering functions

Expand Down Expand Up @@ -1622,9 +1626,6 @@ def eval_rdelta(self, z_cl):
if self.validate_input:
validate_argument(locals(), "z_cl", float, argmin=0)

if self.massdef == "virial":
self._set_delta_mdef_virial(z_cl)

return self._eval_rdelta(z_cl)

def eval_mass_in_radius(self, r3d, z_cl, verbose=False):
Expand Down Expand Up @@ -1671,9 +1672,6 @@ def eval_mass_in_radius(self, r3d, z_cl, verbose=False):
if self.halo_profile_model == "einasto" and verbose:
print(f"Einasto alpha (in) = {self._get_einasto_alpha(z_cl=z_cl)}")

if self.massdef == "virial":
self._set_delta_mdef_virial(z_cl)

return self._eval_mass_in_radius(r3d, z_cl)

def convert_mass_concentration(
Expand Down Expand Up @@ -1730,9 +1728,6 @@ def convert_mass_concentration(
f"{self._get_einasto_alpha(z_cl=z_cl) if alpha is None else alpha}"
)

if self.massdef == "virial":
self._set_delta_mdef_virial(z_cl)

return self._convert_mass_concentration(
z_cl, massdef, delta_mdef, halo_profile_model, alpha
)
Expand Down

0 comments on commit cdd19ee

Please sign in to comment.