vivarium-public-health 3.0.5__tar.gz → 3.0.6__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/CHANGELOG.rst +6 -0
- {vivarium_public_health-3.0.5/src/vivarium_public_health.egg-info → vivarium_public_health-3.0.6}/PKG-INFO +1 -1
- vivarium_public_health-3.0.6/src/vivarium_public_health/_version.py +1 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/risks/base_risk.py +24 -11
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/risks/effect.py +18 -9
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/risks/implementations/low_birth_weight_and_short_gestation.py +6 -6
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6/src/vivarium_public_health.egg-info}/PKG-INFO +1 -1
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/mock_artifact.py +1 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/risks/test_effect.py +100 -35
- vivarium_public_health-3.0.5/src/vivarium_public_health/_version.py +0 -1
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.bandit +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.flake8 +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.gitattributes +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.github/CODEOWNERS +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.github/pull_request_template.md +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.github/workflows/build.yml +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.github/workflows/deploy.yml +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.gitignore +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.pylintrc +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.readthedocs.yml +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.zenodo.json +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/CODE_OF_CONDUCT.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/CONTRIBUTING.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/Jenkinsfile +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/LICENSE.txt +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/MANIFEST.in +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/Makefile +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/README.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/Makefile +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/nitpick-exceptions +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/_static/style.css +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/_templates/layout.html +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/disease/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/disease/model.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/disease/models.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/disease/special_disease.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/disease/state.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/disease/transition.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/mslt/delay.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/mslt/disease.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/mslt/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/mslt/intervention.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/mslt/magic_wand_components.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/mslt/observer.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/mslt/population.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/plugins/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/plugins/parser.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/population/add_new_birth_cohorts.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/population/base_population.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/population/data_transformations.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/population/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/population/mortality.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/results/disability.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/results/disease.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/results/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/results/mortality.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/results/observer.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/results/risk.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/results/simple_cause.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/results/stratification.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/risks/base_risk.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/risks/data_transformations.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/risks/distributions.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/risks/effect.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/risks/implementations/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/risks/implementations/low_birth_weight_and_short_gestation.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/risks/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/treatment/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/treatment/magic_wand.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/treatment/scale_up.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/treatment/therapeutic_inertia.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/utilities.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/conf.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/tutorials/index.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/tutorials/risk_exposure.rst +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/pyproject.toml +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/setup.cfg +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/setup.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/__about__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/disease/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/disease/model.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/disease/models.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/disease/special_disease.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/disease/state.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/disease/transition.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/mslt/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/mslt/delay.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/mslt/disease.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/mslt/intervention.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/mslt/magic_wand_components.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/mslt/observer.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/mslt/population.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/plugins/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/plugins/parser.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/population/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/population/add_new_birth_cohorts.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/population/base_population.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/population/data_transformations.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/population/mortality.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/columns.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/disability.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/disease.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/mortality.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/observer.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/risk.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/simple_cause.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/results/stratification.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/risks/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/risks/data_transformations.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/risks/distributions.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/risks/implementations/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/treatment/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/treatment/magic_wand.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/treatment/scale_up.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/treatment/therapeutic_inertia.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/utilities.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health.egg-info/SOURCES.txt +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health.egg-info/dependency_links.txt +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health.egg-info/not-zip-safe +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health.egg-info/requires.txt +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health.egg-info/top_level.txt +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/conftest.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/disease/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/disease/test_disease.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/disease/test_special_disease.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/plugins/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/plugins/test_parser.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/population/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/population/conftest.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/population/test_add_new_birth_cohort.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/population/test_base_population.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/population/test_data_transformations.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/population/test_mortality.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_categorical_risk_observer.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_disability.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_disability_observer.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_disease_observer.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_mortality_observer.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_stratification.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/risks/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/risks/conftest.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/risks/test_base_risk.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/risks/test_data_transformations.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/risks/test_distributions.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/risks/test_low_birth_weight_and_short_gestation.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/test_utilities.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/treatment/__init__.py +0 -0
- {vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tox.ini +0 -0
@@ -1,3 +1,9 @@
|
|
1
|
+
**3.0.6 - 09/04/24**
|
2
|
+
|
3
|
+
- Fix bug that was occurring when RiskEffect's rr_source was a float or DataFrame
|
4
|
+
- Better handle exposure column creation in Risk component
|
5
|
+
- Rename LBWSRisk 'exposure_column_name()' staticmethod to not collide with Risk attr
|
6
|
+
|
1
7
|
**3.0.5 - 08/29/24**
|
2
8
|
|
3
9
|
- Add missing results module-level docstrings
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: vivarium_public_health
|
3
|
-
Version: 3.0.
|
3
|
+
Version: 3.0.6
|
4
4
|
Summary: Components for modelling diseases, risks, and interventions with ``vivarium``
|
5
5
|
Home-page: https://github.com/ihmeuw/vivarium_public_health
|
6
6
|
Author: The vivarium developers
|
@@ -0,0 +1 @@
|
|
1
|
+
__version__ = "3.0.6"
|
@@ -123,7 +123,10 @@ class Risk(Component):
|
|
123
123
|
|
124
124
|
@property
|
125
125
|
def columns_created(self) -> List[str]:
|
126
|
-
|
126
|
+
columns_to_create = [self.propensity_column_name]
|
127
|
+
if self.create_exposure_column:
|
128
|
+
columns_to_create.append(self.exposure_column_name)
|
129
|
+
return columns_to_create
|
127
130
|
|
128
131
|
@property
|
129
132
|
def initialization_requirements(self) -> Dict[str, List[str]]:
|
@@ -172,6 +175,16 @@ class Risk(Component):
|
|
172
175
|
self.propensity = self.get_propensity_pipeline(builder)
|
173
176
|
self.exposure = self.get_exposure_pipeline(builder)
|
174
177
|
|
178
|
+
# We want to set this to True iff there is a non-loglinear risk effect
|
179
|
+
# on this risk instance
|
180
|
+
self.create_exposure_column = bool(
|
181
|
+
[
|
182
|
+
component
|
183
|
+
for component in builder.components.list_components()
|
184
|
+
if component.startswith(f"non_log_linear_risk_effect.{self.risk.name}_on_")
|
185
|
+
]
|
186
|
+
)
|
187
|
+
|
175
188
|
def get_distribution_type(self, builder: Builder) -> str:
|
176
189
|
"""Get the distribution type for the risk from the configuration.
|
177
190
|
|
@@ -270,19 +283,19 @@ class Risk(Component):
|
|
270
283
|
########################
|
271
284
|
|
272
285
|
def on_initialize_simulants(self, pop_data: SimulantData) -> None:
|
273
|
-
|
274
|
-
|
275
|
-
{
|
276
|
-
self.propensity_column_name: self.randomness.get_draw(pop_data.index),
|
277
|
-
self.exposure_column_name: self.exposure_distribution.ppf(propensity_values),
|
278
|
-
}
|
286
|
+
propensity = pd.Series(
|
287
|
+
self.randomness.get_draw(pop_data.index), name=self.propensity_column_name
|
279
288
|
)
|
280
|
-
self.population_view.update(
|
289
|
+
self.population_view.update(propensity)
|
290
|
+
self.update_exposure_column(pop_data.index)
|
281
291
|
|
282
292
|
def on_time_step_prepare(self, event: Event) -> None:
|
283
|
-
|
284
|
-
|
285
|
-
|
293
|
+
self.update_exposure_column(event.index)
|
294
|
+
|
295
|
+
def update_exposure_column(self, index: pd.Index) -> None:
|
296
|
+
if self.create_exposure_column:
|
297
|
+
exposure = pd.Series(self.exposure(index), name=self.exposure_column_name)
|
298
|
+
self.population_view.update(exposure)
|
286
299
|
|
287
300
|
##################################
|
288
301
|
# Pipeline sources and modifiers #
|
@@ -157,16 +157,19 @@ class RiskEffect(Component):
|
|
157
157
|
rr_source = configuration.data_sources.relative_risk
|
158
158
|
rr_dist_parameters = configuration.data_source_parameters.relative_risk.to_dict()
|
159
159
|
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
160
|
+
if isinstance(rr_source, str):
|
161
|
+
try:
|
162
|
+
distribution = getattr(import_module("scipy.stats"), rr_source)
|
163
|
+
rng = np.random.default_rng(builder.randomness.get_seed(self.name))
|
164
|
+
rr_data = distribution(**rr_dist_parameters).ppf(rng.random())
|
165
|
+
except AttributeError:
|
166
|
+
rr_data = self.get_filtered_data(builder, rr_source)
|
167
|
+
except TypeError:
|
168
|
+
raise ConfigurationError(
|
169
|
+
f"Parameters {rr_dist_parameters} are not valid for distribution {rr_source}."
|
170
|
+
)
|
171
|
+
else:
|
165
172
|
rr_data = self.get_filtered_data(builder, rr_source)
|
166
|
-
except TypeError:
|
167
|
-
raise ConfigurationError(
|
168
|
-
f"Parameters {rr_dist_parameters} are not valid for distribution {rr_source}."
|
169
|
-
)
|
170
173
|
return rr_data
|
171
174
|
|
172
175
|
def get_filtered_data(
|
@@ -198,6 +201,8 @@ class RiskEffect(Component):
|
|
198
201
|
cat2["parameter"] = "cat2"
|
199
202
|
cat2["value"] = 1
|
200
203
|
rr_data = pd.concat([cat1, cat2], ignore_index=True)
|
204
|
+
if "parameter" in rr_data.index.names:
|
205
|
+
rr_data = rr_data.reset_index("parameter")
|
201
206
|
|
202
207
|
rr_value_cols = list(rr_data["parameter"].unique())
|
203
208
|
rr_data = pivot_categorical(builder, self.risk, rr_data, "parameter")
|
@@ -361,6 +366,10 @@ class NonLogLinearRiskEffect(RiskEffect):
|
|
361
366
|
# Setup methods #
|
362
367
|
#################
|
363
368
|
|
369
|
+
@staticmethod
|
370
|
+
def get_name(risk: EntityString, target: TargetString) -> str:
|
371
|
+
return f"non_log_linear_risk_effect.{risk.name}_on_{target}"
|
372
|
+
|
364
373
|
def build_all_lookup_tables(self, builder: Builder) -> None:
|
365
374
|
rr_data = self.get_relative_risk_data(builder)
|
366
375
|
self.validate_rr_data(rr_data)
|
@@ -191,7 +191,7 @@ class LBWSGRisk(Risk):
|
|
191
191
|
return f"{axis}.birth_exposure"
|
192
192
|
|
193
193
|
@staticmethod
|
194
|
-
def
|
194
|
+
def get_exposure_column_name(axis: str) -> str:
|
195
195
|
return f"{axis}_exposure"
|
196
196
|
|
197
197
|
##############
|
@@ -206,7 +206,7 @@ class LBWSGRisk(Risk):
|
|
206
206
|
|
207
207
|
@property
|
208
208
|
def columns_created(self) -> List[str]:
|
209
|
-
return [self.
|
209
|
+
return [self.get_exposure_column_name(axis) for axis in self.AXES]
|
210
210
|
|
211
211
|
#####################
|
212
212
|
# Lifecycle methods #
|
@@ -256,7 +256,7 @@ class LBWSGRisk(Risk):
|
|
256
256
|
|
257
257
|
def on_initialize_simulants(self, pop_data: SimulantData) -> None:
|
258
258
|
birth_exposures = {
|
259
|
-
self.
|
259
|
+
self.get_exposure_column_name(axis): self.birth_exposures[
|
260
260
|
self.birth_exposure_pipeline_name(axis)
|
261
261
|
](pop_data.index)
|
262
262
|
for axis in self.AXES
|
@@ -318,7 +318,7 @@ class LBWSGRiskEffect(RiskEffect):
|
|
318
318
|
super().__init__("risk_factor.low_birth_weight_and_short_gestation", target)
|
319
319
|
|
320
320
|
self.lbwsg_exposure_column_names = [
|
321
|
-
LBWSGRisk.
|
321
|
+
LBWSGRisk.get_exposure_column_name(axis) for axis in LBWSGRisk.AXES
|
322
322
|
]
|
323
323
|
self.relative_risk_pipeline_name = (
|
324
324
|
f"effect_of_{self.risk.name}_on_{self.target.name}.relative_risk"
|
@@ -433,8 +433,8 @@ class LBWSGRiskEffect(RiskEffect):
|
|
433
433
|
pop = self.population_view.subview(["sex"] + self.lbwsg_exposure_column_names).get(
|
434
434
|
pop_data.index
|
435
435
|
)
|
436
|
-
birth_weight = pop[LBWSGRisk.
|
437
|
-
gestational_age = pop[LBWSGRisk.
|
436
|
+
birth_weight = pop[LBWSGRisk.get_exposure_column_name(BIRTH_WEIGHT)]
|
437
|
+
gestational_age = pop[LBWSGRisk.get_exposure_column_name(GESTATIONAL_AGE)]
|
438
438
|
|
439
439
|
is_male = pop["sex"] == "Male"
|
440
440
|
is_tmrel = (self.TMREL_GESTATIONAL_AGE_INTERVAL.left <= gestational_age) & (
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: vivarium_public_health
|
3
|
-
Version: 3.0.
|
3
|
+
Version: 3.0.6
|
4
4
|
Summary: Components for modelling diseases, risks, and interventions with ``vivarium``
|
5
5
|
Home-page: https://github.com/ihmeuw/vivarium_public_health
|
6
6
|
Author: The vivarium developers
|
@@ -77,6 +77,7 @@ MOCKERS = {
|
|
77
77
|
"population": {
|
78
78
|
"age_bins": make_age_bins(),
|
79
79
|
"structure": make_uniform_pop_data(),
|
80
|
+
"demographic_dimensions": make_uniform_pop_data().drop(["location", "value"], axis=1),
|
80
81
|
"theoretical_minimum_risk_life_expectancy": (
|
81
82
|
build_table_with_age(
|
82
83
|
98.0,
|
@@ -23,6 +23,7 @@ from vivarium_public_health.risks.base_risk import Risk
|
|
23
23
|
from vivarium_public_health.risks.effect import NonLogLinearRiskEffect, RiskEffect
|
24
24
|
from vivarium_public_health.utilities import EntityString
|
25
25
|
|
26
|
+
|
26
27
|
#
|
27
28
|
#
|
28
29
|
# def test_incidence_rate_risk_effect(base_config, base_plugins, mocker):
|
@@ -413,6 +414,95 @@ from vivarium_public_health.utilities import EntityString
|
|
413
414
|
# source=lambda index: pd.Series(0.1, index=index))
|
414
415
|
#
|
415
416
|
# assert np.allclose(from_yearly(0.1, time_step)*50, em(simulation.get_population().index))
|
417
|
+
def _setup_risk_effect_simulation(
|
418
|
+
config: LayeredConfigTree,
|
419
|
+
plugins: LayeredConfigTree,
|
420
|
+
risk: Union[str, Risk],
|
421
|
+
risk_effect: RiskEffect,
|
422
|
+
data: Dict[str, Any],
|
423
|
+
) -> InteractiveContext:
|
424
|
+
components = [
|
425
|
+
TestPopulation(),
|
426
|
+
risk,
|
427
|
+
SI("test_cause"),
|
428
|
+
risk_effect,
|
429
|
+
]
|
430
|
+
|
431
|
+
simulation = InteractiveContext(
|
432
|
+
components=components,
|
433
|
+
configuration=config,
|
434
|
+
plugin_configuration=plugins,
|
435
|
+
setup=False,
|
436
|
+
)
|
437
|
+
|
438
|
+
for key, value in data.items():
|
439
|
+
simulation._data.write(key, value)
|
440
|
+
|
441
|
+
simulation.setup()
|
442
|
+
return simulation
|
443
|
+
|
444
|
+
|
445
|
+
def build_dichotomous_risk_effect_data(rr_value: float) -> pd.DataFrame:
|
446
|
+
df = pd.DataFrame(
|
447
|
+
{
|
448
|
+
"affected_entity": "test_cause",
|
449
|
+
"affected_measure": "incidence_rate",
|
450
|
+
"year_start": 1990,
|
451
|
+
"year_end": 1991,
|
452
|
+
"value": [rr_value, 1.0],
|
453
|
+
},
|
454
|
+
index=pd.Index(["cat1", "cat2"], name="parameter"),
|
455
|
+
)
|
456
|
+
return df
|
457
|
+
|
458
|
+
|
459
|
+
@pytest.mark.parametrize(
|
460
|
+
"rr_source, rr_value",
|
461
|
+
[("str", 2.0), ("float", 0.9), ("DataFrame", 0.5)],
|
462
|
+
)
|
463
|
+
def test_rr_sources(rr_source, rr_value, dichotomous_risk, base_config, base_plugins):
|
464
|
+
risk = dichotomous_risk[0]
|
465
|
+
effect = RiskEffect(risk.name, "cause.test_cause.incidence_rate")
|
466
|
+
base_config.update({"risk_factor.test_risk": {"data_sources": {"exposure": 1.0}}})
|
467
|
+
|
468
|
+
# TMREL of 1
|
469
|
+
tmred = {"distribution": "uniform", "min": 1, "max": 1, "inverted": False}
|
470
|
+
|
471
|
+
data = {
|
472
|
+
f"{risk.name}.tmred": tmred,
|
473
|
+
f"{risk.name}.population_attributable_fraction": 0,
|
474
|
+
"cause.test_cause.incidence_rate": 1,
|
475
|
+
}
|
476
|
+
|
477
|
+
if rr_source == "DataFrame":
|
478
|
+
rr_data = build_dichotomous_risk_effect_data(rr_value)
|
479
|
+
base_config.update(
|
480
|
+
{
|
481
|
+
"risk_effect.test_risk_on_cause.test_cause.incidence_rate": {
|
482
|
+
"data_sources": {"relative_risk": rr_data}
|
483
|
+
}
|
484
|
+
}
|
485
|
+
)
|
486
|
+
elif rr_source == "float":
|
487
|
+
base_config.update(
|
488
|
+
{
|
489
|
+
"risk_effect.test_risk_on_cause.test_cause.incidence_rate": {
|
490
|
+
"data_sources": {"relative_risk": rr_value}
|
491
|
+
}
|
492
|
+
}
|
493
|
+
)
|
494
|
+
else: # rr_source is a string because it gets read from RiskEffect's configuration defaults
|
495
|
+
rr_data = build_dichotomous_risk_effect_data(rr_value)
|
496
|
+
data[f"{risk.name}.relative_risk"] = rr_data
|
497
|
+
|
498
|
+
base_config.update({"risk_factor.test_risk": {"distribution_type": "dichotomous"}})
|
499
|
+
simulation = _setup_risk_effect_simulation(base_config, base_plugins, risk, effect, data)
|
500
|
+
|
501
|
+
pop = simulation.get_population()
|
502
|
+
rate = simulation.get_value("test_cause.incidence_rate")(
|
503
|
+
pop.index, skip_post_processor=True
|
504
|
+
)
|
505
|
+
assert set(rate.unique()) == {rr_value}
|
416
506
|
|
417
507
|
|
418
508
|
##############################
|
@@ -458,33 +548,6 @@ class CustomExposureRisk(Component):
|
|
458
548
|
return data
|
459
549
|
|
460
550
|
|
461
|
-
def _setup_risk_simulation(
|
462
|
-
config: LayeredConfigTree,
|
463
|
-
plugins: LayeredConfigTree,
|
464
|
-
risk: Union[str, Risk],
|
465
|
-
data: Dict[str, Any],
|
466
|
-
) -> InteractiveContext:
|
467
|
-
components = [
|
468
|
-
TestPopulation(),
|
469
|
-
risk,
|
470
|
-
SI("some_disease"),
|
471
|
-
NonLogLinearRiskEffect(risk.name, "cause.some_disease.incidence_rate"),
|
472
|
-
]
|
473
|
-
|
474
|
-
simulation = InteractiveContext(
|
475
|
-
components=components,
|
476
|
-
configuration=config,
|
477
|
-
plugin_configuration=plugins,
|
478
|
-
setup=False,
|
479
|
-
)
|
480
|
-
|
481
|
-
for key, value in data.items():
|
482
|
-
simulation._data.write(key, value)
|
483
|
-
|
484
|
-
simulation.setup()
|
485
|
-
return simulation
|
486
|
-
|
487
|
-
|
488
551
|
@pytest.mark.parametrize(
|
489
552
|
"rr_parameter_data, error_message",
|
490
553
|
[
|
@@ -496,14 +559,12 @@ def _setup_risk_simulation(
|
|
496
559
|
)
|
497
560
|
def test_non_loglinear_effect(rr_parameter_data, error_message, base_config, base_plugins):
|
498
561
|
risk = CustomExposureRisk("risk_factor.test_risk")
|
499
|
-
effect = NonLogLinearRiskEffect(
|
500
|
-
"risk_factor.test_risk", "cause.some_disease.incidence_rate"
|
501
|
-
)
|
562
|
+
effect = NonLogLinearRiskEffect(risk.name, "cause.test_cause.incidence_rate")
|
502
563
|
|
503
564
|
risk_effect_rrs = [2.0, 2.4, 4.0]
|
504
565
|
rr_data = pd.DataFrame(
|
505
566
|
{
|
506
|
-
"affected_entity": "
|
567
|
+
"affected_entity": "test_cause",
|
507
568
|
"affected_measure": "incidence_rate",
|
508
569
|
"year_start": 1990,
|
509
570
|
"year_end": 1991,
|
@@ -518,20 +579,24 @@ def test_non_loglinear_effect(rr_parameter_data, error_message, base_config, bas
|
|
518
579
|
f"{risk.name}.relative_risk": rr_data,
|
519
580
|
f"{risk.name}.tmred": tmred,
|
520
581
|
f"{risk.name}.population_attributable_fraction": 0,
|
521
|
-
"cause.
|
582
|
+
"cause.test_cause.incidence_rate": 1,
|
522
583
|
}
|
523
584
|
|
524
585
|
base_config.update({"population": {"population_size": 10}})
|
525
586
|
|
526
587
|
if error_message:
|
527
588
|
with pytest.raises(ValueError, match=error_message):
|
528
|
-
simulation =
|
589
|
+
simulation = _setup_risk_effect_simulation(
|
590
|
+
base_config, base_plugins, risk, effect, data
|
591
|
+
)
|
529
592
|
return
|
530
593
|
else:
|
531
|
-
simulation =
|
594
|
+
simulation = _setup_risk_effect_simulation(
|
595
|
+
base_config, base_plugins, risk, effect, data
|
596
|
+
)
|
532
597
|
|
533
598
|
pop = simulation.get_population()
|
534
|
-
rate = simulation.get_value("
|
599
|
+
rate = simulation.get_value("test_cause.incidence_rate")(
|
535
600
|
pop.index, skip_post_processor=True
|
536
601
|
)
|
537
602
|
expected_values = np.interp(
|
@@ -1 +0,0 @@
|
|
1
|
-
__version__ = "3.0.5"
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/.github/pull_request_template.md
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/_templates/layout.html
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/api_reference/index.rst
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/docs/source/tutorials/index.rst
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/src/vivarium_public_health/__init__.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/disease/test_special_disease.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/population/test_mortality.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_disability.py
RENAMED
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_disease_observer.py
RENAMED
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/results/test_stratification.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{vivarium_public_health-3.0.5 → vivarium_public_health-3.0.6}/tests/risks/test_distributions.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|