Source code for archABM.aerosol_model_maxplanck

import math
from typing import Tuple

from .parameters import Parameters
from .aerosol_model import AerosolModel


[docs]class AerosolModelMaxPlanck(AerosolModel): """Aerosol transmission estimator Model Calculations of Aerosol Transmission and Infection Risk of COVID-19 in Indoor Environments :cite:`ijerph17218114` An adjustable algorithm to estimate the infection risk for different indoor environments, constrained by published data of human aerosol emissions, SARS-CoV-2 viral loads, infective dose and other parameters. Evaluates typical indoor settings such as an office, a classroom, choir practice, and a reception/party. The model includes a number of modifiable environmental factors that represent relevant physiological parameters and environmental conditions. For simplicity, all subjects are assumed to be equal in terms of breathing, speaking and susceptibility to infection. The model parameters can be easily adjusted to account for different environmental conditions and activities. """ name: str = "MaxPlanck" def __init__(self, params): super().__init__(params) self.params = params
[docs] def get_risk(self, inputs: Parameters) -> Tuple[float, float]: """Calculate the infection risk of an individual in a room and the CO\ :sub:`2` thrown into the air. Args: inputs (Parameters): model parameters Returns: Tuple[float, float]: CO\ :sub:`2` concentration (ppm), and infection risk probability """ params = self.params # inputs: room_area, room_height, room_ventilation_rate, mask_efficiency, time_in_room_h, susceptible_people infection_probability = 1 - 10 ** (math.log10(0.5) / params.RNA_D50) RNA_content = params.RNA_concentration * math.pi / 6 * (params.aerosol_diameter / 10000) ** 3 aerosol_emission = (params.emission_breathing * (1 - params.speaking_breathing_ratio) + params.emission_speaking * params.speaking_breathing_ratio) * 1000 * params.respiratory_rate * 60 aerosol_concentration = aerosol_emission / (inputs.room_area * inputs.room_height * 1000) RNA_concentration = aerosol_concentration * RNA_content RNA_dosis = params.respiratory_rate * 60 * RNA_concentration * params.deposition_rate dosis_infectious = RNA_dosis / (inputs.room_ventilation_rate + 1 / params.virus_lifetime) * (1 - inputs.mask_efficiency) * inputs.time_in_room_h risk_one_person = (1 - ((1 - infection_probability) ** dosis_infectious) ** inputs.num_people) * 100 # Return results dosis_min, dosis_max = 0, 1 co2_min, co2_max = 0, 80 co2_dosis = (dosis_infectious - dosis_min) / (dosis_max - dosis_min) * (co2_max - co2_min) + co2_min air_contamination = co2_dosis infection_risk = risk_one_person return air_contamination, infection_risk