From 07889ea54c4c0499a9d6b4bb7dcc68b2dbeb696d Mon Sep 17 00:00:00 2001 From: Daniel Williams Date: Tue, 3 Sep 2024 10:56:46 +0100 Subject: [PATCH] Added some bug fixes. --- heron/inference.py | 11 +++++++---- heron/injection.py | 2 +- heron/likelihood.py | 7 +++++-- heron/models/lalsimulation.py | 1 - heron/priors.py | 1 + heron/types.py | 3 +++ requirements.txt | 6 +++--- 7 files changed, 20 insertions(+), 11 deletions(-) diff --git a/heron/inference.py b/heron/inference.py index f68d95d..f680c16 100644 --- a/heron/inference.py +++ b/heron/inference.py @@ -6,7 +6,7 @@ import click -from gwpy.timeseries import TimeSeries +from .types import TimeSeries import astropy.units as u from nessai.flowsampler import FlowSampler @@ -84,6 +84,7 @@ def heron_inference(settings): if "data files" in settings.get("data", {}): # Load frame files from disk for ifo in settings["interferometers"]: + print(f"Loading {ifo} data") logger.info( f"Loading {ifo} data from " f"{settings['data']['data files'][ifo]}/{settings['data']['channels'][ifo]}" @@ -93,14 +94,16 @@ def heron_inference(settings): channel=settings["data"]["channels"][ifo], format="gwf", ) - elif "injection" in other_settings: - pass + #elif "injection" in other_settings: + # pass # Make Likelihood if len(settings["interferometers"]) > 1: likelihoods = [] + print("Creating likelihoods") waveform_model = KNOWN_WAVEFORMS[settings["waveform"]["model"]]() for ifo in settings["interferometers"]: + print(f"\t {ifo}") likelihoods.append( KNOWN_LIKELIHOODS[settings.get("likelihood").get("function")]( data[ifo], @@ -113,7 +116,7 @@ def heron_inference(settings): ), ) ) - likelihood = MultiDetector(*likelihoods) + likelihood = MultiDetector(*likelihoods) priors = heron.priors.PriorDict() priors.from_dictionary(settings["priors"]) diff --git a/heron/injection.py b/heron/injection.py index c6f2e6d..a0e357f 100644 --- a/heron/injection.py +++ b/heron/injection.py @@ -115,7 +115,7 @@ def injection_parameters_add_units(parameters): UNITS = {"luminosity_distance": u.megaparsec, "m1": u.solMass, "m2": u.solMass} for parameter, value in parameters.items(): - if not isinstance(value, u.Quantity): + if not isinstance(value, u.Quantity) and parameter in UNITS: parameters[parameter] = value * UNITS[parameter] return parameters diff --git a/heron/likelihood.py b/heron/likelihood.py index 3c8fd05..968d504 100644 --- a/heron/likelihood.py +++ b/heron/likelihood.py @@ -60,7 +60,6 @@ def __init__( self.timeseries = data self.data = np.array(data.data) self.times = data.times - self.C = self.psd.covariance_matrix(times=self.times) self.inverse_C = np.linalg.inv(self.C) @@ -96,7 +95,11 @@ def snr(self, waveform): return np.sqrt(np.abs(h_h)) def log_likelihood(self, waveform, norm=True): - a, b = self.timeseries.determine_overlap(self, waveform) + w = self.timeseries.determine_overlap(self, waveform) + if w is not None: + (a,b) = w + else: + return -np.inf residual = np.array(self.data.data[a[0]:a[1]]) - np.array(waveform.data[b[0]:b[1]]) weighted_residual = ( (residual) @ self.solve(self.C[a[0]:a[1],b[0]:b[1]], residual) * (self.dt * self.dt / 4) / 4 diff --git a/heron/models/lalsimulation.py b/heron/models/lalsimulation.py index 559b90d..df963ec 100644 --- a/heron/models/lalsimulation.py +++ b/heron/models/lalsimulation.py @@ -91,7 +91,6 @@ def _convert_units(self, args): args[name] = argument.to_value(units[mappings[name]]) elif name in mappings.keys() and argument: # This is commented out as it causes problems if e.g. lalnative values are passed - print(f"Performing a mapping on {name}, {argument}") args[name] = (argument * default_units[mappings[name]]).to_value( units[mappings[name]] ) diff --git a/heron/priors.py b/heron/priors.py index bca4049..d5b6265 100644 --- a/heron/priors.py +++ b/heron/priors.py @@ -13,6 +13,7 @@ "Uniform": bilby.prior.Uniform, "PowerLaw": bilby.prior.PowerLaw, "Sine": bilby.prior.Sine, + "Cosine": bilby.prior.Cosine, "UniformSourceFrame": bilby.gw.prior.UniformSourceFrame, "UniformInComponentsMassRatio": bilby.gw.prior.UniformInComponentsMassRatio, } diff --git a/heron/types.py b/heron/types.py index 42765d4..0a36cba 100644 --- a/heron/types.py +++ b/heron/types.py @@ -50,6 +50,9 @@ def is_in(time, timeseries): overlap = timeseries_a.times[0], timeseries_a.times[-1] else: overlap = None + #print("No overlap found") + #print(timeseries_a.times[0], timeseries_a.times[-1]) + #print(timeseries_b.times[0], timeseries_b.times[-1]) return None start_a = np.argmin(np.abs(timeseries_a.times - overlap[0])) diff --git a/requirements.txt b/requirements.txt index 4ba302f..1f1671b 100644 --- a/requirements.txt +++ b/requirements.txt @@ -16,6 +16,6 @@ click asimov pesummary nessai -gpytorch==1.0.1 -torch==2.4.0 -torchvision==0.5.0 +gpytorch +torch +torchvision