示例#1
0
class BasicModel(ModelPipeline):
    def __init__(self, fit_dict, **basic_model_kwargs):
        """
        Generic class for a function to produce predictions from a model
        with the following attributes.

        Args:
            predict_group: (str) which group to make predictions for
            fit_dict: keyword arguments to CurveModel.fit_params()
            **basic_model_kwargs: keyword arguments to CurveModel.__init__()
        """
        super().__init__()
        self.fit_dict = fit_dict
        self.basic_model_kwargs = basic_model_kwargs
        self.mod = None

    def refresh(self):
        self.mod = None

    def fit(self, df):
        self.mod = CurveModel(df=df, **self.basic_model_kwargs)
        self.mod.fit_params(**self.fit_dict)

    def predict(self, times, predict_space, predict_group='all'):
        predictions = self.mod.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        return predictions
示例#2
0
class BasicModel(ModelPipeline):
    def __init__(self, fit_dict, basic_model_dict, **pipeline_kwargs):
        """
        Generic class for a function to produce predictions from a model
        with the following attributes.

        Args:
            **pipeline_kwargs: keyword arguments for the base class of ModelPipeline
            predict_group: (str) which group to make predictions for
            fit_dict: keyword arguments to CurveModel.fit_params()
            basic_model_dict: additional keyword arguments to the CurveModel class
                col_obs_se: (str) of observation standard error
                col_covs: List[str] list of names of covariates to put on the parameters
            param_names (list{str}):
                Names of the parameters in the specific functional form.
            link_fun (list{function}):
                List of link functions for each parameter.
            var_link_fun (list{function}):
                List of link functions for the variables including fixed effects
                and random effects.
        """
        super().__init__(**pipeline_kwargs)
        self.fit_dict = fit_dict
        self.basic_model_dict = basic_model_dict
        self.basic_model_dict.update({'col_obs_se': self.col_obs_se})

        generator_kwargs = pipeline_kwargs
        for arg in self.pop_cols:
            generator_kwargs.pop(arg)

        self.basic_model_dict.update(**generator_kwargs)
        self.mod = None

        self.setup_pipeline()

    def refresh(self):
        self.mod = None

    def fit(self, df, group=None):
        self.mod = CurveModel(df=df, **self.basic_model_dict)
        self.mod.fit_params(**self.fit_dict)

    def predict(self, times, predict_space, predict_group):
        predictions = self.mod.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        return predictions
示例#3
0
class TightLooseBetaPModel(ModelPipeline):
    def __init__(self,
                 loose_beta_fit_dict,
                 tight_beta_fit_dict,
                 loose_p_fit_dict,
                 tight_p_fit_dict,
                 beta_model_extras=None,
                 p_model_extras=None,
                 blend_start_t=2,
                 blend_end_t=30,
                 **basic_model_kwargs):
        """
        Produces two tight-loose models as a convex combination between the two of them,
        and then averages

        Args:
            loose_beta_fit_dict: dictionary of keyword arguments to CurveModel.fit_params() for the loose beta model
            tight_beta_fit_dict: dictionary of keyword arguments to CurveModel.fit_params() fro the tight beta model
            loose_p_fit_dict: dictionary of keyword arguments to CurveModel.fit_params() for the loose p model
            tight_p_fit_dict: dictionary of keyword arguments to CurveModel.fit_params() fro the tight p model
            beta_model_extras: (optional) dictionary of keyword arguments to
                override the basic_model_kwargs for the beta model
            p_model_extras: (optional) dictionary of keyword arguments to
                override the basic_model_kwargs for the p model
            blend_start_t: (int) the time to start blending tight and loose
            blend_end_t: (int) the time to stop blending tight and loose

            predict_group: (str) which group to make predictions for
            **basic_model_kwargs: keyword arguments to the basic model
        """
        super().__init__()
        self.beta_model_kwargs = basic_model_kwargs
        self.p_model_kwargs = basic_model_kwargs

        if beta_model_extras is not None:
            self.beta_model_kwargs = self.beta_model_kwargs.update(
                beta_model_extras)

        if p_model_extras is not None:
            self.p_model_kwargs = self.p_model_kwargs.update(p_model_extras)

        self.loose_beta_fit_dict = loose_beta_fit_dict
        self.tight_beta_fit_dict = tight_beta_fit_dict
        self.loose_p_fit_dict = loose_p_fit_dict
        self.tight_p_fit_dict = tight_p_fit_dict

        self.blend_start_t = blend_start_t
        self.blend_end_t = blend_end_t

        self.loose_beta_model = None
        self.tight_beta_model = None
        self.loose_p_model = None
        self.tight_p_model = None

    def refresh(self):
        self.loose_beta_model = None
        self.tight_beta_model = None
        self.loose_p_model = None
        self.tight_p_model = None

    def fit(self, df):
        self.loose_beta_model = CurveModel(df=df, **self.beta_model_kwargs)
        self.tight_beta_model = CurveModel(df=df, **self.beta_model_kwargs)
        self.loose_p_model = CurveModel(df=df, **self.p_model_kwargs)
        self.tight_p_model = CurveModel(df=df, **self.p_model_kwargs)

        self.loose_beta_model.fit_params(**self.loose_beta_fit_dict)
        self.tight_beta_model.fit_params(**self.tight_beta_fit_dict)
        self.loose_p_model.fit_params(**self.loose_p_fit_dict)
        self.tight_p_model.fit_params(**self.tight_p_fit_dict)

    def predict(self, times, predict_space, predict_group='all'):
        loose_beta_predictions = self.loose_beta_model.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        tight_beta_predictions = self.tight_beta_model.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        loose_p_predictions = self.loose_p_model.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        tight_p_predictions = self.tight_p_model.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        beta_predictions = convex_combination(t=times,
                                              pred1=tight_beta_predictions,
                                              pred2=loose_beta_predictions,
                                              pred_fun=predict_space,
                                              start_day=self.blend_start_t,
                                              end_day=self.blend_end_t)
        p_predictions = convex_combination(t=times,
                                           pred1=tight_p_predictions,
                                           pred2=loose_p_predictions,
                                           pred_fun=predict_space,
                                           start_day=self.blend_start_t,
                                           end_day=self.blend_end_t)
        averaged_predictions = model_average(pred1=beta_predictions,
                                             pred2=p_predictions,
                                             w1=0.5,
                                             w2=0.5,
                                             pred_fun=predict_space)
        return averaged_predictions
示例#4
0
class TightLooseBetaPModel(ModelPipeline):
    def __init__(self,
                 loose_beta_fit_dict,
                 tight_beta_fit_dict,
                 loose_p_fit_dict,
                 tight_p_fit_dict,
                 basic_model_dict,
                 beta_model_extras=None,
                 p_model_extras=None,
                 blend_start_t=2,
                 blend_end_t=30,
                 **pipeline_kwargs):
        """
        Produces two tight-loose models as a convex combination between the two of them,
        and then averages

        Args:
            **pipeline_kwargs: keyword arguments for the base class of ModelPipeline

            loose_beta_fit_dict: dictionary of keyword arguments to CurveModel.fit_params() for the loose beta model
            tight_beta_fit_dict: dictionary of keyword arguments to CurveModel.fit_params() fro the tight beta model
            loose_p_fit_dict: dictionary of keyword arguments to CurveModel.fit_params() for the loose p model
            tight_p_fit_dict: dictionary of keyword arguments to CurveModel.fit_params() fro the tight p model

            basic_model_dict: additional keyword arguments to the CurveModel class
                col_obs_se: (str) of observation standard error
                col_covs: List[str] list of names of covariates to put on the parameters
            param_names (list{str}):
                Names of the parameters in the specific functional form.
            link_fun (list{function}):
                List of link functions for each parameter.
            var_link_fun (list{function}):
                List of link functions for the variables including fixed effects
                and random effects.
            beta_model_extras: (optional) dictionary of keyword arguments to
                override the basic_model_kwargs for the beta model
            p_model_extras: (optional) dictionary of keyword arguments to
                override the basic_model_kwargs for the p model
            blend_start_t: (int) the time to start blending tight and loose
            blend_end_t: (int) the time to stop blending tight and loose
        """
        super().__init__(**pipeline_kwargs)
        generator_kwargs = pipeline_kwargs
        for arg in self.pop_cols:
            generator_kwargs.pop(arg)

        self.basic_model_dict = basic_model_dict
        self.basic_model_dict.update(**generator_kwargs)
        self.basic_model_dict.update({'col_obs_se': self.col_obs_se})

        self.beta_model_kwargs = self.basic_model_dict
        self.p_model_kwargs = self.basic_model_dict

        if beta_model_extras is not None:
            self.beta_model_kwargs = self.beta_model_kwargs.update(
                beta_model_extras)

        if p_model_extras is not None:
            self.p_model_kwargs = self.p_model_kwargs.update(p_model_extras)

        self.loose_beta_fit_dict = loose_beta_fit_dict
        self.tight_beta_fit_dict = tight_beta_fit_dict
        self.loose_p_fit_dict = loose_p_fit_dict
        self.tight_p_fit_dict = tight_p_fit_dict

        self.blend_start_t = blend_start_t
        self.blend_end_t = blend_end_t

        self.loose_beta_model = None
        self.tight_beta_model = None
        self.loose_p_model = None
        self.tight_p_model = None

        self.setup_pipeline()

    def refresh(self):
        self.loose_beta_model = None
        self.tight_beta_model = None
        self.loose_p_model = None
        self.tight_p_model = None

    def fit(self, df):
        self.loose_beta_model = CurveModel(df=df, **self.beta_model_kwargs)
        self.tight_beta_model = CurveModel(df=df, **self.beta_model_kwargs)
        self.loose_p_model = CurveModel(df=df, **self.p_model_kwargs)
        self.tight_p_model = CurveModel(df=df, **self.p_model_kwargs)

        self.loose_beta_model.fit_params(**self.loose_beta_fit_dict)
        self.tight_beta_model.fit_params(**self.tight_beta_fit_dict)
        self.loose_p_model.fit_params(**self.loose_p_fit_dict)
        self.tight_p_model.fit_params(**self.tight_p_fit_dict)

    def predict(self, times, predict_space, predict_group):
        loose_beta_predictions = self.loose_beta_model.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        tight_beta_predictions = self.tight_beta_model.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        loose_p_predictions = self.loose_p_model.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        tight_p_predictions = self.tight_p_model.predict(
            t=times,
            group_name=predict_group,
            prediction_functional_form=predict_space)
        beta_predictions = convex_combination(t=times,
                                              pred1=tight_beta_predictions,
                                              pred2=loose_beta_predictions,
                                              pred_fun=predict_space,
                                              start_day=self.blend_start_t,
                                              end_day=self.blend_end_t)
        p_predictions = convex_combination(t=times,
                                           pred1=tight_p_predictions,
                                           pred2=loose_p_predictions,
                                           pred_fun=predict_space,
                                           start_day=self.blend_start_t,
                                           end_day=self.blend_end_t)
        averaged_predictions = model_average(pred1=beta_predictions,
                                             pred2=p_predictions,
                                             w1=0.5,
                                             w2=0.5,
                                             pred_fun=predict_space)
        return averaged_predictions