Source code for emodpy_tbhiv.interventions.bcg
from emod_api import schema_to_class as s2c
import emod_api.interventions.common as common
import emod_api.interventions.utils as utils
from emodpy_tbhiv.interventions import purge_campaign_event
co_event = "BcgDistributed"
[docs]def BCG(
camp,
trigger_treatment_list,
initial_efficacy=1.0,
vaccine_take=1,
age_take_decay=1.0,
box_duration_yrs=1,
immune_decay_yrs=0,
start_day=1,
duration=-1,
property_restrictions_list=[],
nodeIDs=[],
cost=0,
black_period=0,
black_trigger='Blackout',
event_name='Vaccine Health Seeking'):
"""
Create and return triggered campaign event that issues an BCG vaccine intervention.
Args:
camp: Centralized campaign module instance.
trigger_treatment_list: List of 1 or more triggers (or events or signals) which are listened to and trigger the distribution of the intervention. There is no default.
initial_efficacy: Initial efficacy of the vaccine. Defaults to 1.0.
vaccine_take: Fraction of the population receiving the vaccine for whom it is efficacious. Defaults to 1.0.
age_take_decay: ... Defaults to 1.0.
box_duration_yrs: Period of time over which the initial efficacy persists before decay. Defaults to 1 year.
immune_decay_yrs: Period of time over which the efficacy decays to 0. Defaults to 0.
start_day: The timestep when this campaign event takes effect. Defaults to 1.
duration: How long the campaign event remains in effect. Defaults to forever.
property_restrictions_list: Optiional list of Individual Properties to limit the intervention to.
nodeIDs: Optiona list of node ids to target. Defaults to all.
cost: Per unit 'price' of each intervention.
black_period: Undocumented.
black_trigger: Undocumented.
event_name: Undocumented.
Returns:
New campaign event that can be added to the campaign.
"""
if box_duration_yrs > 150:
raise ValueError( f"It seems that your value of box_duration_yrs ({box_duration_yrs}) might be in units of days instead of years." )
if immune_decay_yrs > 150:
raise ValueError( f"It seems that your value of immune_duration_yrs ({immune_duration_yrs}) might be in units of days instead of years." )
# First, get the objects
schema_path = camp.schema_path
act_intervention = s2c.get_class_with_defaults( "BCGVaccine", schema_path )
act_intervention.Cost_To_Consumer = cost
waning = s2c.get_class_with_defaults( "WaningEffectBoxExponential", schema_path )
bcast_intervention = s2c.get_class_with_defaults( "BroadcastEvent", schema_path )
# Second, hook them up
act_intervention.Waning_Config = waning
bcast_intervention.Broadcast_Event = camp.get_send_trigger( co_event )
# Third, do the actual settings
act_intervention.Vaccine_Take = vaccine_take
act_intervention.Vaccine_Take_Age_Decay_Rate = age_take_decay
waning.Initial_Effect = initial_efficacy
waning.Box_Duration = box_duration_yrs*365
waning.Decay_Time_Constant = immune_decay_yrs*365
event = common.TriggeredCampaignEvent( camp, start_day,event_name, trigger_treatment_list, [ act_intervention, bcast_intervention ], Node_Ids=nodeIDs, Duration=duration, Property_Restrictions=property_restrictions_list )
purge_campaign_event( event )
return event
[docs]def new_intervention_as_file( camp, filename=None ):
camp.add( BCG( camp, trigger_treatment_list=[ "Births" ] ) )
if filename is None:
filename = "bcg.json"
camp.save( filename )
return filename