-
Notifications
You must be signed in to change notification settings - Fork 9
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
gh-124: use cosmology.api
over the cosmology
package
#397
base: main
Are you sure you want to change the base?
Changes from 14 commits
2455fe0
e600795
0621f3d
cf52194
88428cb
2b8912f
96b7030
c4221b3
187063a
16087c8
0a83b2e
663f80a
c8e5ddd
55854dc
d88aa44
44011dc
ff590a9
c7745ef
83f6c12
d5e47ac
fce38f0
6398920
e63c668
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -37,11 +37,11 @@ | |
import numpy as np | ||
import numpy.typing as npt | ||
|
||
from cosmology.api import StandardCosmology, CosmologyConstantsNamespace | ||
|
||
if typing.TYPE_CHECKING: | ||
import collections.abc | ||
|
||
from cosmology import Cosmology | ||
|
||
from glass.shells import RadialWindow | ||
|
||
|
||
|
@@ -269,7 +269,10 @@ def shear_from_convergence( | |
class MultiPlaneConvergence: | ||
"""Compute convergence fields iteratively from multiple matter planes.""" | ||
|
||
def __init__(self, cosmo: Cosmology) -> None: | ||
def __init__( | ||
self, | ||
cosmo: StandardCosmology[npt.NDArray[np.float64], npt.NDArray[np.float64]], | ||
) -> None: | ||
"""Create a new instance to iteratively compute the convergence.""" | ||
self.cosmo = cosmo | ||
|
||
|
@@ -301,7 +304,7 @@ def add_window(self, delta: npt.NDArray[np.float64], w: RadialWindow) -> None: | |
zsrc, | ||
w.za, | ||
w.wa, | ||
) | ||
), | ||
) | ||
|
||
self.add_plane(delta, zsrc, lens_weight) | ||
|
@@ -327,15 +330,17 @@ def add_plane( | |
w2, self.w3 = self.w3, wlens | ||
|
||
# extrapolation law | ||
x2, self.x3 = self.x3, self.cosmo.xm(self.z3) | ||
hubble_length = CosmologyConstantsNamespace.c / StandardCosmology.H0 | ||
x2 = self.x3 | ||
self.x3 = self.cosmo.transverse_comoving_distance(self.z3) / hubble_length | ||
Comment on lines
+484
to
+485
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I've split these so the line isn't really long |
||
r12 = self.r23 | ||
r13, self.r23 = self.cosmo.xm([z1, self.z2], self.z3) / self.x3 | ||
r13, self.r23 = self.cosmo.transverse_comoving_distance([z1, self.z2], self.z3) / (hubble_length * self.x3) | ||
t = r13 / r12 | ||
|
||
# lensing weight of mass plane to be added | ||
f = 3 * self.cosmo.omega_m / 2 | ||
f = 3 * self.cosmo.Omega_m0 / 2 | ||
f *= x2 * self.r23 | ||
f *= (1 + self.z2) / self.cosmo.ef(self.z2) | ||
f *= (1 + self.z2) / self.cosmo.H_over_H0(self.z2) | ||
f *= w2 | ||
|
||
# create kappa planes on first iteration | ||
|
@@ -377,7 +382,7 @@ def wlens(self) -> float: | |
|
||
def multi_plane_matrix( | ||
shells: collections.abc.Sequence[RadialWindow], | ||
cosmo: Cosmology, | ||
cosmo: StandardCosmology[npt.NDArray[np.float64], npt.NDArray[np.float64]], | ||
) -> npt.NDArray[np.float64]: | ||
"""Compute the matrix of lensing contributions from each shell.""" | ||
mpc = MultiPlaneConvergence(cosmo) | ||
|
@@ -391,7 +396,7 @@ def multi_plane_matrix( | |
def multi_plane_weights( | ||
weights: npt.NDArray[np.float64], | ||
shells: collections.abc.Sequence[RadialWindow], | ||
cosmo: Cosmology, | ||
cosmo: StandardCosmology[npt.NDArray[np.float64], npt.NDArray[np.float64]], | ||
) -> npt.NDArray[np.float64]: | ||
""" | ||
Compute effective weights for multi-plane convergence. | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -21,7 +21,7 @@ classifiers = [ | |
"Typing :: Typed", | ||
] | ||
dependencies = [ | ||
"cosmology>=2022.10.9", | ||
"cosmology.api>=0.1.0", | ||
"gaussiancl>=2022.10.21", | ||
"healpix>=2022.11.1", | ||
"healpy>=1.15.0", | ||
|
@@ -50,6 +50,7 @@ docs = [ | |
] | ||
examples = [ | ||
"camb", | ||
"cosmology", | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
"glass.ext.camb", | ||
"jupyter", | ||
"matplotlib", | ||
|
@@ -156,6 +157,7 @@ lint.isort = {known-first-party = [ | |
], sections = {"cosmo" = [ | ||
"camb", | ||
"cosmology", | ||
"cosmology.api", | ||
]}} | ||
lint.per-file-ignores = {"__init__.py" = [ | ||
"F401", # unused-import | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -16,7 +16,7 @@ | |
from glass.shells import RadialWindow | ||
|
||
if typing.TYPE_CHECKING: | ||
from cosmology import Cosmology | ||
from cosmology.api import StandardCosmology | ||
|
||
|
||
@pytest.fixture | ||
|
@@ -31,20 +31,21 @@ def shells() -> list[RadialWindow]: | |
|
||
|
||
@pytest.fixture | ||
def cosmo() -> Cosmology: | ||
def cosmo() -> StandardCosmology[npt.NDArray[np.float64], npt.NDArray[np.float64]]: | ||
class MockCosmology: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I've changed the mock to match the names from |
||
@property | ||
def omega_m(self) -> float: | ||
def Omega_m0(self) -> float: # noqa: N802 | ||
return 0.3 | ||
|
||
def ef(self, z: npt.NDArray[np.float64]) -> npt.NDArray[np.float64]: | ||
return (self.omega_m * (1 + z) ** 3 + 1 - self.omega_m) ** 0.5 | ||
def H_over_H0(self, z: npt.NDArray[np.float64]) -> npt.NDArray[np.float64]: # noqa: N802 | ||
return (self.Omega_m0 * (1 + z) ** 3 + 1 - self.Omega_m0) ** 0.5 | ||
|
||
def xm( | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There is no equivalently named function in cosmology.api.Standard.Cosmology.transverse_comoving_distance(z) / (cosmology.api.CosmologyConstantsNamespace.c / cosmology.api.Standard.Cosmology.H0) |
||
self, | ||
z: npt.NDArray[np.float64], | ||
z2: npt.NDArray[np.float64] | None = None, | ||
) -> npt.NDArray[np.float64]: | ||
"""Dimensionless transverse comoving distance.""" | ||
if z2 is None: | ||
return np.array(z) * 1000 | ||
return (np.array(z2) - np.array(z)) * 1000 | ||
|
@@ -97,7 +98,7 @@ def test_deflect_many(rng: np.random.Generator) -> None: | |
|
||
def test_multi_plane_matrix( | ||
shells: list[RadialWindow], | ||
cosmo: Cosmology, | ||
cosmo: StandardCosmology[npt.NDArray[np.float64], npt.NDArray[np.float64]], | ||
rng: np.random.Generator, | ||
) -> None: | ||
mat = multi_plane_matrix(shells, cosmo) | ||
|
@@ -119,7 +120,7 @@ def test_multi_plane_matrix( | |
|
||
def test_multi_plane_weights( | ||
shells: list[RadialWindow], | ||
cosmo: Cosmology, | ||
cosmo: StandardCosmology[npt.NDArray[np.float64], npt.NDArray[np.float64]], | ||
rng: np.random.Generator, | ||
) -> None: | ||
w_in = np.eye(len(shells)) | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have reverted #21 as I believe it is broken/needs testing. Don't want to waste time porting.