From fff9d91fb915f58f6cb0f35f7997716da824a65a Mon Sep 17 00:00:00 2001 From: Sandro Campos Date: Thu, 25 Jul 2024 10:25:00 -0400 Subject: [PATCH] Add benchmarks for projected correlation (#29) --- benchmarks/asv.conf.json | 2 +- benchmarks/benchmarks.py | 57 +++++++++++++++++++++++++++++++++------- 2 files changed, 48 insertions(+), 11 deletions(-) diff --git a/benchmarks/asv.conf.json b/benchmarks/asv.conf.json index 831a1a4..6d597d4 100644 --- a/benchmarks/asv.conf.json +++ b/benchmarks/asv.conf.json @@ -15,7 +15,7 @@ "HEAD" ], "install_command": [ - "python -m pip install {wheel_file}" + "python -m pip install -r requirements.txt {wheel_file}" ], "build_command": [ "python -m build --wheel -o {build_cache_dir} {build_dir}" diff --git a/benchmarks/benchmarks.py b/benchmarks/benchmarks.py index c7fedd5..6e171a1 100644 --- a/benchmarks/benchmarks.py +++ b/benchmarks/benchmarks.py @@ -1,16 +1,53 @@ -"""Two sample benchmarks to compute runtime and memory usage. +from pathlib import Path -For more information on writing benchmarks: -https://asv.readthedocs.io/en/stable/writing_benchmarks.html.""" +import lsdb +from corrgi.correlation.projected_correlation import ProjectedCorrelation +from corrgi.estimators.davis_peebles_estimator import DavisPeeblesEstimator +from corrgi.estimators.natural_estimator import NaturalEstimator +from gundam import gundam -from corrgi import example_benchmarks +DATA_DIR_NAME = Path(__file__).parent.parent / "tests" / "data" / "hipscat" +GALS_WEIGHT_DIR = str(DATA_DIR_NAME / "pcf_gals_weight") +GALS1_WEIGHT_DIR = str(DATA_DIR_NAME / "pcf_gals1_weight") +RANS_WEIGHT_DIR = str(DATA_DIR_NAME / "pcf_rans_weight") -def time_computation(): - """Time computations are prefixed with 'time'.""" - example_benchmarks.runtime_computation() +class ProjectedSuite: + """Benchmarks for projected correlation""" + timeout = 600 # in seconds -def mem_list(): - """Memory computations are prefixed with 'mem' or 'peakmem'.""" - return example_benchmarks.memory_computation() + def setup_cache(self): + """Initialize suite""" + return ( + self.create_params(), + lsdb.read_hipscat(GALS_WEIGHT_DIR), + lsdb.read_hipscat(GALS1_WEIGHT_DIR), + lsdb.read_hipscat(RANS_WEIGHT_DIR), + ) + + @staticmethod + def create_params(): + """Create the projected params""" + params = gundam.packpars(kind="pcf") + params.nsepp = 28 # Number of bins of projected separation rp + params.seppmin = 0.02 # Minimum rp in Mpc/h + params.dsepp = 0.12 # Bin size of rp (in log space) + params.nsepv = 1 # Number of bins of LOS separation pi + params.dsepv = 40.0 # Bin size of pi (in linear space) + params.omegam = 0.25 # Omega matter + params.omegal = 0.75 # Omega lambda + params.h0 = 100 # Hubble constant [km/s/Mpc] + return params + + def time_pcf_natural_estimator(self, cache): + """Times the Natural estimator for a projected auto-correlation""" + pcf_params, gals_catalog, _, rans_catalog = cache + estimator = NaturalEstimator(ProjectedCorrelation(params=pcf_params, use_weights=True)) + estimator.compute_autocorrelation_counts(gals_catalog, rans_catalog) + + def time_pccf_davis_peebles_estimator(self, cache): + """Times the Davis-Peebles estimator for a projected cross-correlation""" + pcf_params, gals_catalog, gals1_catalog, rans_catalog = cache + estimator = DavisPeeblesEstimator(ProjectedCorrelation(params=pcf_params, use_weights=True)) + estimator.compute_crosscorrelation_counts(gals_catalog, gals1_catalog, rans_catalog)