From 861f8089c8f86e2f19263a7cd7eeddf2f2745f45 Mon Sep 17 00:00:00 2001 From: DavAug Date: Sun, 7 Mar 2021 15:32:09 +0100 Subject: [PATCH] #183 PMC reduce outputs of MM if not all measured --- erlotinib/_problems.py | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/erlotinib/_problems.py b/erlotinib/_problems.py index 1759cdaf..f35f0dfc 100644 --- a/erlotinib/_problems.py +++ b/erlotinib/_problems.py @@ -290,7 +290,9 @@ def _create_log_likelihood(self, individual): mask = self._data[self._id_key] == individual data = self._data[mask][ [self._time_key, self._biom_key, self._meas_key]] - for output in self._mechanistic_model.outputs(): + outputs = self._mechanistic_model.outputs() + measured_outputs = [] + for output in outputs: # Mask data for biomarker biomarker = self._output_biomarker_dict[output] mask = data[self._biom_key] == biomarker @@ -303,26 +305,31 @@ def _create_log_likelihood(self, individual): temp_df = temp_df[mask] # Collect data for output - times.append(temp_df[self._time_key].to_numpy()) - observations.append(temp_df[self._meas_key].to_numpy()) - - # Count outputs that were measured - # TODO: copy mechanistic model and update model outputs. - # (Useful for e.g. control group and dose group training) - n_measured_outputs = 0 - for output_measurements in observations: - if len(output_measurements) > 0: - n_measured_outputs += 1 + t = temp_df[self._time_key].to_numpy() + o = temp_df[self._meas_key].to_numpy() + if (len(t) > 0) and (len(o) > 0): + times.append(t) + observations.append(o) + measured_outputs.append(output) # If no outputs were measured, do not construct a likelihood - if n_measured_outputs == 0: + if len(measured_outputs) == 0: return None + # If not all outputs were measured, adjust outputs of mechanistic + # model + if len(measured_outputs) != len(outputs): + self._mechanistic_model.set_outputs(measured_outputs) + # Create log-likelihood and set ID to individual log_likelihood = erlo.LogLikelihood( self._mechanistic_model, self._error_models, observations, times) log_likelihood.set_id(individual) + # If outputs were adjusted, reset to original outputs + if len(measured_outputs) != len(outputs): + self._mechanistic_model.set_outputs(outputs) + return log_likelihood def _extract_dosing_regimens(self, dose_key, duration_key):