From 6dda0816f1cf6edb14155f59cb2373c7a474d484 Mon Sep 17 00:00:00 2001 From: jdebacker Date: Mon, 19 Dec 2022 17:19:22 -0500 Subject: [PATCH 1/6] format --- environment.yml | 10 +-- examples/run_oguk.py | 6 +- oguk/calibrate.py | 190 ++++++++++++----------------------------- oguk/get_micro_data.py | 12 +-- 4 files changed, 70 insertions(+), 148 deletions(-) diff --git a/environment.yml b/environment.yml index 100068a..e967598 100644 --- a/environment.yml +++ b/environment.yml @@ -2,10 +2,10 @@ name: oguk-dev channels: - conda-forge dependencies: -- python<=3.7.11 -- dask==2.30.0 -- dask-core==2.30.0 -- distributed==2.30.1 +- python<3.10.0 +- dask +- dask-core +- distributed - paramtools>=0.15.0 - pip - pytest>=6.0 @@ -20,4 +20,4 @@ dependencies: - pip: - jupyter-book>=0.8.0 - ogcore - - openfisca-uk>=0.21.0 + - PolicyEngine-UK>=0.36.0 diff --git a/examples/run_oguk.py b/examples/run_oguk.py index f1085bd..888de7e 100644 --- a/examples/run_oguk.py +++ b/examples/run_oguk.py @@ -3,7 +3,7 @@ import json import time import os -from openfisca_core.model_api import Reform +from policyengine_core.model_api import Reform from oguk.calibrate import Calibration from ogcore import output_tables as ot from ogcore import output_plots as op @@ -14,11 +14,11 @@ # default reform -from openfisca_uk.api import * +from policyengine_uk.api import * def get_default_reform(): - from openfisca_tools.reforms import set_parameter + from policyengine_core.reforms import set_parameter return set_parameter( "tax.income_tax.rates.uk[0].rate", 0.3, "year:2022:10" diff --git a/oguk/calibrate.py b/oguk/calibrate.py index 6999cce..0839ba7 100644 --- a/oguk/calibrate.py +++ b/oguk/calibrate.py @@ -143,135 +143,75 @@ def get_tax_function_parameters( np.ones(p.T + p.S - p.BW) * dict_params["tfunc_frac_tax_payroll"][-1], ) - - # Reorder indices of tax function and tile for all years after - # budget window ends - num_etr_params = dict_params["tfunc_etr_params_S"].shape[2] - num_mtrx_params = dict_params["tfunc_mtrx_params_S"].shape[2] - num_mtry_params = dict_params["tfunc_mtry_params_S"].shape[2] - # First check to see if tax parameters that are used were - # estimated with a budget window and ages that are as long as - # the those implied based on the start year and model age. - # N.B. the tax parameters dictionary does not save the years - # that correspond to the parameter estimates, so the start year - # used there may name match what is used in a run that reads in - # some cached tax function parameters. Likewise for age. + # Conduct checks to be sure tax function params are consistent + # with the model run params_list = ["etr", "mtrx", "mtry"] - BW_in_tax_params = dict_params["tfunc_etr_params_S"].shape[1] - S_in_tax_params = dict_params["tfunc_etr_params_S"].shape[0] - if p.BW != BW_in_tax_params: + BW_in_tax_params = dict_params["BW"] + start_year_in_tax_params = dict_params["start_year"] + S_in_tax_params = dict_params["tfunc_etr_params_S"][0].shape[0] + # Check that start years are consistent in model and cached tax functions + if p.start_year != start_year_in_tax_params: print( - "Warning: There is a discrepency between the start" + "Input Error: There is a discrepancy between the start" + " year of the model and that of the tax functions!!" ) - # After printing warning, make it work by tiling - if p.BW > BW_in_tax_params: - for item in params_list: - dict_params["tfunc_" + item + "_params_S"] = np.concatenate( - ( - dict_params["tfunc_" + item + "_params_S"], - np.tile( - dict_params["tfunc_" + item + "_params_S"][ - :, -1, : - ].reshape(S_in_tax_params, 1, num_etr_params), - (1, p.BW - BW_in_tax_params, 1), - ), - ), - axis=1, - ) - dict_params["tfunc_avg_" + item] = np.append( - dict_params["tfunc_avg_" + item], - np.tile( - dict_params["tfunc_avg_" + item][-1], - (p.BW - BW_in_tax_params), - ), - ) + assert False + # Check that S is consistent in model and cached tax functions + # Note: even if p.age_specific = False, the arrays coming from + # ogcore.txfunc_est should be of length S if p.S != S_in_tax_params: print( - "Warning: There is a discrepency between the ages" + "Input Error: There is a discrepancy between the ages" + " used in the model and those in the tax functions!!" ) - # After printing warning, make it work by tiling - if p.S > S_in_tax_params: - for item in params_list: - dict_params["tfunc_" + item + "_params_S"] = np.concatenate( - ( - dict_params["tfunc_" + item + "_params_S"], - np.tile( - dict_params["tfunc_" + item + "_params_S"][ - -1, :, : - ].reshape(1, p.BW, num_etr_params), - (p.S - S_in_tax_params, 1, 1), - ), - ), - axis=0, - ) - etr_params = np.empty((p.T, p.S, num_etr_params)) - mtrx_params = np.empty((p.T, p.S, num_mtrx_params)) - mtry_params = np.empty((p.T, p.S, num_mtry_params)) - etr_params[: p.BW, :, :] = np.transpose( - dict_params["tfunc_etr_params_S"][: p.S, : p.BW, :], axes=[1, 0, 2] - ) - etr_params[p.BW :, :, :] = np.tile( - np.transpose( - dict_params["tfunc_etr_params_S"][: p.S, -1, :].reshape( - p.S, 1, num_etr_params - ), - axes=[1, 0, 2], - ), - (p.T - p.BW, 1, 1), - ) - mtrx_params[: p.BW, :, :] = np.transpose( - dict_params["tfunc_mtrx_params_S"][: p.S, : p.BW, :], - axes=[1, 0, 2], - ) - mtrx_params[p.BW :, :, :] = np.transpose( - dict_params["tfunc_mtrx_params_S"][: p.S, -1, :].reshape( - p.S, 1, num_mtrx_params - ), - axes=[1, 0, 2], - ) - mtry_params[: p.BW, :, :] = np.transpose( - dict_params["tfunc_mtry_params_S"][: p.S, : p.BW, :], - axes=[1, 0, 2], - ) - mtry_params[p.BW :, :, :] = np.transpose( - dict_params["tfunc_mtry_params_S"][: p.S, -1, :].reshape( - p.S, 1, num_mtry_params - ), - axes=[1, 0, 2], - ) + assert False + + # Extrapolate tax function parameters for years after budget window + # list of list: BW x S - either an array of function at that element... + etr_params = [[None] * p.S] * p.T + mtrx_params = [[None] * p.S] * p.T + mtry_params = [[None] * p.S] * p.T + for s in range(p.S): + for t in range(p.T): + if t < p.BW: + etr_params[t][s] = dict_params["tfunc_etr_params_S"][t][s] + mtrx_params[t][s] = dict_params["tfunc_mtrx_params_S"][t][ + s + ] + mtry_params[t][s] = dict_params["tfunc_mtry_params_S"][t][ + s + ] + else: + etr_params[t][s] = dict_params["tfunc_etr_params_S"][-1][s] + mtrx_params[t][s] = dict_params["tfunc_mtrx_params_S"][-1][ + s + ] + mtry_params[t][s] = dict_params["tfunc_mtry_params_S"][-1][ + s + ] if p.constant_rates: print("Using constant rates!") - # Make all ETRs equal the average - etr_params = np.zeros(etr_params.shape) - # set shift to average rate - etr_params[: p.BW, :, 10] = np.tile( - dict_params["tfunc_avg_etr"].reshape(p.BW, 1), (1, p.S) - ) - etr_params[p.BW :, :, 10] = dict_params["tfunc_avg_etr"][-1] - - # # Make all MTRx equal the average - mtrx_params = np.zeros(mtrx_params.shape) - # set shift to average rate - mtrx_params[: p.BW, :, 10] = np.tile( - dict_params["tfunc_avg_mtrx"].reshape(p.BW, 1), (1, p.S) - ) - mtrx_params[p.BW :, :, 10] = dict_params["tfunc_avg_mtrx"][-1] - - # # Make all MTRy equal the average - mtry_params = np.zeros(mtry_params.shape) - # set shift to average rate - mtry_params[: p.BW, :, 10] = np.tile( - dict_params["tfunc_avg_mtry"].reshape(p.BW, 1), (1, p.S) - ) - mtry_params[p.BW :, :, 10] = dict_params["tfunc_avg_mtry"][-1] + # Make all tax rates equal the average + p.tax_func_type = "linear" + etr_params = [[None] * p.S] * p.T + mtrx_params = [[None] * p.S] * p.T + mtry_params = [[None] * p.S] * p.T + for s in range(p.S): + for t in range(p.T): + if t < p.BW: + etr_params[t][s] = dict_params["tfunc_avg_etr"][t] + mtrx_params[t][s] = dict_params["tfunc_avg_mtrx"][t] + mtry_params[t][s] = dict_params["tfunc_avg_mtry"][t] + else: + etr_params[t][s] = dict_params["tfunc_avg_etr"][-1] + mtrx_params[t][s] = dict_params["tfunc_avg_mtrx"][-1] + mtry_params[t][s] = dict_params["tfunc_avg_mtry"][-1] if p.zero_taxes: print("Zero taxes!") - etr_params = np.zeros(etr_params.shape) - mtrx_params = np.zeros(mtrx_params.shape) - mtry_params = np.zeros(mtry_params.shape) + etr_params = [[0] * p.S] * p.T + mtrx_params = [[0] * p.S] * p.T + mtry_params = [[0] * p.S] * p.T tax_param_dict = { "etr_params": etr_params, "mtrx_params": mtrx_params, @@ -302,24 +242,6 @@ def read_tax_func_estimate(self, p, tax_func_path): if os.path.exists(tax_func_path): print("Tax Function Path Exists") dict_params = safe_read_pickle(tax_func_path) - # check to see if tax_functions compatible - current_taxcalc = pkg_resources.get_distribution("taxcalc").version - try: - if current_taxcalc != dict_params["tax_calc_version"]: - print( - "WARNING: Tax function parameters estimated" - + " from Tax Calculator version that is not " - + " the one currently installed on this machine." - ) - print( - "Current TC version is ", - current_taxcalc, - ", Estimated tax functions from version ", - dict_params.get("tax_calc_version", None), - ) - flag = 1 - except KeyError: - pass try: if p.start_year != dict_params["start_year"]: print( diff --git a/oguk/get_micro_data.py b/oguk/get_micro_data.py index 35f7994..3dd8334 100644 --- a/oguk/get_micro_data.py +++ b/oguk/get_micro_data.py @@ -1,7 +1,7 @@ """ ------------------------------------------------------------------------ This program extracts tax rate and income data from the microsimulation -model (OpenFisca-UK). +model (PolicyEngine-UK). ------------------------------------------------------------------------ """ from dask import delayed, compute @@ -9,11 +9,11 @@ import numpy as np import os import pickle -from openfisca_uk import Microsimulation +from policyengine_uk import Microsimulation import pandas as pd import warnings -from openfisca_uk.api import * -from openfisca_uk.data import EnhancedFRS, SynthFRS +from policyengine_uk.api import * +from policyengine_uk.data import EnhancedFRS, SynthFRS import logging logging.basicConfig(level=logging.INFO) @@ -42,7 +42,7 @@ def get_household_mtrs( - reform: ReformType, + reform: Reform, variable: str, period: int = None, baseline: Microsimulation = None, @@ -51,7 +51,7 @@ def get_household_mtrs( """Calculates household MTRs with respect to a given variable. Args: - reform (ReformType): The reform to apply to the simulation. + reform (Reform): The reform to apply to the simulation. variable (str): The variable to increase. period (int): The period (year) to calculate the MTRs for. kwargs (dict): Additional arguments to pass to the simulation. From 8721f40a8f21b01a5cd33a3b6521ff3de1a2e71a Mon Sep 17 00:00:00 2001 From: jdebacker Date: Fri, 20 Jan 2023 15:08:41 -0500 Subject: [PATCH 2/6] use list length to get S --- oguk/calibrate.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/oguk/calibrate.py b/oguk/calibrate.py index 0839ba7..6b84ee9 100644 --- a/oguk/calibrate.py +++ b/oguk/calibrate.py @@ -148,7 +148,7 @@ def get_tax_function_parameters( params_list = ["etr", "mtrx", "mtry"] BW_in_tax_params = dict_params["BW"] start_year_in_tax_params = dict_params["start_year"] - S_in_tax_params = dict_params["tfunc_etr_params_S"][0].shape[0] + S_in_tax_params = len(dict_params["tfunc_etr_params_S"][0]) # Check that start years are consistent in model and cached tax functions if p.start_year != start_year_in_tax_params: print( From e03a7a9b633bcea910d588d966e52bbb3f0003b0 Mon Sep 17 00:00:00 2001 From: jdebacker Date: Mon, 3 Apr 2023 15:00:43 -0400 Subject: [PATCH 3/6] Resolving pre-commit-hook changes --- oguk/calibrate.py | 1 - oguk/get_micro_data.py | 3 ++- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/oguk/calibrate.py b/oguk/calibrate.py index 6b84ee9..b7d078b 100644 --- a/oguk/calibrate.py +++ b/oguk/calibrate.py @@ -25,7 +25,6 @@ def __init__( client=None, num_workers=1, ): - self.estimate_tax_functions = estimate_tax_functions self.estimate_beta = estimate_beta self.estimate_chi_n = estimate_chi_n diff --git a/oguk/get_micro_data.py b/oguk/get_micro_data.py index 3dd8334..f6ebd15 100644 --- a/oguk/get_micro_data.py +++ b/oguk/get_micro_data.py @@ -96,7 +96,8 @@ def get_calculator_output(baseline, year, reform=None, data=None): """ # create a simulation - sim_kwargs = dict(dataset=dataset, year=2022) + # sim_kwargs = dict(dataset=dataset, year=2022) + sim_kwargs = dict(dataset=dataset) if reform is None: sim = Microsimulation(**sim_kwargs) reform = () From af5348159d7a23323d987f9079a101cd6fc74e78 Mon Sep 17 00:00:00 2001 From: jdebacker Date: Wed, 15 May 2024 15:05:14 -0400 Subject: [PATCH 4/6] save for future work --- .pre-commit-config.yaml | 11 ----- environment.yml | 2 +- examples/run_oguk.py | 27 +----------- oguk/calibrate.py | 75 +++++++++------------------------- oguk/demographics.py | 1 + oguk/get_micro_data.py | 3 +- oguk/tests/test_run_example.py | 1 + 7 files changed, 25 insertions(+), 95 deletions(-) delete mode 100644 .pre-commit-config.yaml diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml deleted file mode 100644 index b2ed11b..0000000 --- a/.pre-commit-config.yaml +++ /dev/null @@ -1,11 +0,0 @@ -repos: -- repo: https://github.com/pre-commit/pre-commit-hooks - rev: v2.3.0 - hooks: - - id: check-yaml - - id: end-of-file-fixer - - id: trailing-whitespace -- repo: https://github.com/psf/black - rev: 19.3b0 - hooks: - - id: black \ No newline at end of file diff --git a/environment.yml b/environment.yml index 9e3e565..99182d6 100644 --- a/environment.yml +++ b/environment.yml @@ -24,7 +24,6 @@ dependencies: - coverage - requests - xlwt -- openpyxl - statsmodels - linearmodels - black @@ -32,5 +31,6 @@ dependencies: - jupyter - pip: - jupyter-book>=0.8.0 + - openpyxl>=3.1.2 - ogcore - PolicyEngine-UK>=0.38.6 diff --git a/examples/run_oguk.py b/examples/run_oguk.py index c0538e3..ca7f1be 100644 --- a/examples/run_oguk.py +++ b/examples/run_oguk.py @@ -3,13 +3,9 @@ import json import time import os -<<<<<<< HEAD -from policyengine_core.model_api import Reform -======= import copy from policyengine_core.reforms import Reform -from policyengine_uk.api import * ->>>>>>> upstream/main +from policyengine_uk.model_api import * from oguk.calibrate import Calibration from ogcore.parameters import Specifications from ogcore import output_tables as ot @@ -18,27 +14,6 @@ from ogcore.utils import safe_read_pickle from argparse import ArgumentParser -<<<<<<< HEAD -# default reform - -from policyengine_uk.api import * - - -def get_default_reform(): - from policyengine_core.reforms import set_parameter - - return set_parameter( - "tax.income_tax.rates.uk[0].rate", 0.3, "year:2022:10" - ) - - -start_time = time.time() -# Set start year and last year -START_YEAR = 2022 -from ogcore.parameters import Specifications - -======= ->>>>>>> upstream/main def main(reform=None): # Define parameters to use for multiprocessing diff --git a/oguk/calibrate.py b/oguk/calibrate.py index da30874..d445d33 100644 --- a/oguk/calibrate.py +++ b/oguk/calibrate.py @@ -30,6 +30,10 @@ def __init__( self.estimate_beta = estimate_beta self.estimate_chi_n = estimate_chi_n if estimate_tax_functions: + if tax_func_path is not None: + run_micro = False + else: + run_micro = True self.tax_function_params = self.get_tax_function_parameters( p, iit_reform, @@ -37,7 +41,7 @@ def __init__( data, client, num_workers, - run_micro=True, + run_micro=run_micro, tax_func_path=tax_func_path, ) # if estimate_beta: @@ -68,7 +72,7 @@ def __init__( def get_tax_function_parameters( self, p, - iit_reform={}, + pit_reform={}, guid="", data="", client=None, @@ -108,12 +112,15 @@ def get_tax_function_parameters( # If run_micro is false, check to see if parameters file exists # and if it is consistent with Specifications instance if not run_micro: - dict_params, run_micro = self.read_tax_func_estimate(tax_func_path) + dict_params, run_micro = self.read_tax_func_estimate( + p, tax_func_path + ) + taxcalc_version = "Cached tax parameters, no taxcalc version" if run_micro: micro_data, taxcalc_version = get_micro_data.get_data( baseline=p.baseline, start_year=p.start_year, - reform=iit_reform, + reform=pit_reform, data=data, path=p.output_base, client=client, @@ -131,12 +138,11 @@ def get_tax_function_parameters( analytical_mtrs=p.analytical_mtrs, tax_func_type=p.tax_func_type, age_specific=p.age_specific, - reform=iit_reform, + reform=pit_reform, data=data, client=client, num_workers=num_workers, tax_func_path=tax_func_path, - graph_est=True, ) mean_income_data = dict_params["tfunc_avginc"][0] frac_tax_payroll = np.append( @@ -144,7 +150,6 @@ def get_tax_function_parameters( np.ones(p.T + p.S - p.BW) * dict_params["tfunc_frac_tax_payroll"][-1], ) -<<<<<<< HEAD # Conduct checks to be sure tax function params are consistent # with the model run params_list = ["etr", "mtrx", "mtry"] @@ -153,33 +158,9 @@ def get_tax_function_parameters( S_in_tax_params = len(dict_params["tfunc_etr_params_S"][0]) # Check that start years are consistent in model and cached tax functions if p.start_year != start_year_in_tax_params: -======= - for key in dict_params: - try: - dict_params[key] = np.array(dict_params[key]) - except TypeError: - pass - # Reorder indices of tax function and tile for all years after - # budget window ends - num_etr_params = dict_params["tfunc_etr_params_S"].shape[2] - num_mtrx_params = dict_params["tfunc_mtrx_params_S"].shape[2] - num_mtry_params = dict_params["tfunc_mtry_params_S"].shape[2] - # First check to see if tax parameters that are used were - # estimated with a budget window and ages that are as long as - # the those implied based on the start year and model age. - # N.B. the tax parameters dictionary does not save the years - # that correspond to the parameter estimates, so the start year - # used there may name match what is used in a run that reads in - # some cached tax function parameters. Likewise for age. - params_list = ["etr", "mtrx", "mtry"] - BW_in_tax_params = dict_params["tfunc_etr_params_S"].shape[0] - S_in_tax_params = dict_params["tfunc_etr_params_S"].shape[1] - if p.BW != BW_in_tax_params: ->>>>>>> upstream/main print( "Input Error: There is a discrepancy between the start" + " year of the model and that of the tax functions!!" - + f"p.BW = {p.BW}, BW_in_tax_params = {BW_in_tax_params}" ) assert False # Check that S is consistent in model and cached tax functions @@ -189,9 +170,7 @@ def get_tax_function_parameters( print( "Input Error: There is a discrepancy between the ages" + " used in the model and those in the tax functions!!" - + f"p.S = {p.S}, S_in_tax_params = {S_in_tax_params}" ) -<<<<<<< HEAD assert False # Extrapolate tax function parameters for years after budget window @@ -217,26 +196,6 @@ def get_tax_function_parameters( mtry_params[t][s] = dict_params["tfunc_mtry_params_S"][-1][ s ] -======= - # After printing warning, make it work by tiling - if p.S > S_in_tax_params: - for item in params_list: - dict_params["tfunc_" + item + "_params_S"] = np.concatenate( - ( - dict_params["tfunc_" + item + "_params_S"], - np.tile( - dict_params["tfunc_" + item + "_params_S"][ - -1, :, : - ].reshape(1, p.BW, num_etr_params), - (p.S - S_in_tax_params, 1, 1), - ), - ), - axis=0, - ) - etr_params = dict_params["tfunc_etr_params_S"] - mtrx_params = dict_params["tfunc_mtrx_params_S"] - mtry_params = dict_params["tfunc_mtry_params_S"] ->>>>>>> upstream/main if p.constant_rates: print("Using constant rates!") @@ -290,6 +249,7 @@ def read_tax_func_estimate(self, p, tax_func_path): if os.path.exists(tax_func_path): print("Tax Function Path Exists") dict_params = safe_read_pickle(tax_func_path) + # check to see if tax_functions compatible try: if p.start_year != dict_params["start_year"]: print( @@ -300,11 +260,14 @@ def read_tax_func_estimate(self, p, tax_func_path): except KeyError: pass try: + p.BW = dict_params["BW"] # QUICK FIX if p.BW != dict_params["BW"]: print( - "Model budget window length is not " - + "consistent with tax function parameter " - + "estimates" + "Model budget window length is " + + str(p.BW) + + " but the tax function parameter " + + "estimates have a budget window length of " + + str(dict_params["BW"]) ) flag = 1 except KeyError: diff --git a/oguk/demographics.py b/oguk/demographics.py index d28e0e6..ffd35fb 100755 --- a/oguk/demographics.py +++ b/oguk/demographics.py @@ -19,6 +19,7 @@ b_zero_eq_artctan_func() ------------------------------------------------------------------------------- """ + # Import packages import os import numpy as np diff --git a/oguk/get_micro_data.py b/oguk/get_micro_data.py index d58899f..5abe36d 100644 --- a/oguk/get_micro_data.py +++ b/oguk/get_micro_data.py @@ -4,6 +4,7 @@ model (PolicyEngine-UK). ------------------------------------------------------------------------ """ + from dask import delayed, compute import dask.multiprocessing import numpy as np @@ -12,7 +13,7 @@ from policyengine_uk import Microsimulation import pandas as pd import warnings -from policyengine_uk.api import * +from policyengine_uk.model_api import * from policyengine_uk.data import EnhancedFRS, SynthFRS import logging diff --git a/oguk/tests/test_run_example.py b/oguk/tests/test_run_example.py index dfa7372..a367a41 100644 --- a/oguk/tests/test_run_example.py +++ b/oguk/tests/test_run_example.py @@ -3,6 +3,7 @@ work by making sure that it does not break (is still running) after 5 minutes (300 seconds). """ + import multiprocessing import time import os From abee36ae0c647021495f94d456d088d7096dfba6 Mon Sep 17 00:00:00 2001 From: jdebacker Date: Wed, 15 May 2024 15:05:55 -0400 Subject: [PATCH 5/6] update versions in GH Actions --- .github/workflows/build_and_test.yml | 7 ++++--- .github/workflows/check_black.yml | 4 ++-- .github/workflows/deploy_docs.yml | 6 +++--- .github/workflows/docs_check.yml | 4 ++-- .github/workflows/version_check.yml | 6 +++--- environment.yml | 3 +-- 6 files changed, 15 insertions(+), 15 deletions(-) diff --git a/.github/workflows/build_and_test.yml b/.github/workflows/build_and_test.yml index 7d6b03a..1f549bb 100644 --- a/.github/workflows/build_and_test.yml +++ b/.github/workflows/build_and_test.yml @@ -13,11 +13,11 @@ jobs: steps: - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@master with: persist-credentials: false - name: Set up Python - uses: actions/setup-python@v2 + uses: actions/setup-python@v5 with: python-version: 3.9 - name: Install @@ -34,8 +34,9 @@ jobs: run: | pytest -m 'not local' --cov=./ --cov-report=xml --maxfail=0 - name: Upload coverage to Codecov - uses: codecov/codecov-action@v3 + uses: codecov/codecov-action@v4 with: + token: ${{ secrets.CODECOV_TOKEN }} files: ./coverage.xml flags: unittests name: codecov-umbrella diff --git a/.github/workflows/check_black.yml b/.github/workflows/check_black.yml index 6a0aa63..09c4d90 100644 --- a/.github/workflows/check_black.yml +++ b/.github/workflows/check_black.yml @@ -6,8 +6,8 @@ jobs: lint: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 - - uses: actions/setup-python@v2 + - uses: actions/checkout@master + - uses: actions/setup-python@v5 - uses: psf/black@stable with: options: "-l 79 --check" diff --git a/.github/workflows/deploy_docs.yml b/.github/workflows/deploy_docs.yml index 4e03b49..cf47180 100644 --- a/.github/workflows/deploy_docs.yml +++ b/.github/workflows/deploy_docs.yml @@ -9,19 +9,19 @@ jobs: runs-on: ubuntu-latest steps: - name: Checkout - uses: actions/checkout@v2 # If you're using actions/checkout@v2 you must set persist-credentials to false in most cases for the deployment to work correctly. + uses: actions/checkout@master with: persist-credentials: false - name: Setup Miniconda - uses: conda-incubator/setup-miniconda@v2 + uses: conda-incubator/setup-miniconda@v3 with: activate-environment: oguk-dev environment-file: environment.yml python-version: 3.9 auto-activate-base: false - name: Set up Python - uses: actions/setup-python@v2 + uses: actions/setup-python@v5 with: python-version: 3.9 diff --git a/.github/workflows/docs_check.yml b/.github/workflows/docs_check.yml index e80987b..437092f 100644 --- a/.github/workflows/docs_check.yml +++ b/.github/workflows/docs_check.yml @@ -6,11 +6,11 @@ jobs: runs-on: ubuntu-latest steps: - name: Checkout - uses: actions/checkout@v2 # If you're using actions/checkout@v2 you must set persist-credentials to false in most cases for the deployment to work correctly. + uses: actions/checkout@master with: persist-credentials: false - name: Set up Python - uses: actions/setup-python@v2 + uses: actions/setup-python@v5 with: python-version: 3.9 diff --git a/.github/workflows/version_check.yml b/.github/workflows/version_check.yml index 6647c8e..b9d6da5 100644 --- a/.github/workflows/version_check.yml +++ b/.github/workflows/version_check.yml @@ -7,12 +7,12 @@ jobs: name: Check versioning runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@master with: fetch-depth: 0 - name: Set up Python - uses: actions/setup-python@v2 + uses: actions/setup-python@v5 with: - python-version: 3.7 + python-version: 3.9 - name: Check version number has been properly updated run: ".github/is-version-number-acceptable.sh" diff --git a/environment.yml b/environment.yml index 99182d6..4e545e2 100644 --- a/environment.yml +++ b/environment.yml @@ -2,7 +2,7 @@ name: oguk-dev channels: - conda-forge dependencies: -- python>=3.7.7, <=3.11 # This restriction can be removed as soon as these packages support Python 3.10 +- python>=3.7.7, <3.12 # This restriction can be removed as soon as these packages support Python 3.10 - ipython - setuptools - psutil @@ -27,7 +27,6 @@ dependencies: - statsmodels - linearmodels - black -- pre-commit - jupyter - pip: - jupyter-book>=0.8.0 From 3dc9a0cc80605bb38e225d891206eeafeb294827 Mon Sep 17 00:00:00 2001 From: jdebacker Date: Wed, 15 May 2024 15:07:00 -0400 Subject: [PATCH 6/6] add PSL catalog file --- PSL_catalog.json | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 PSL_catalog.json diff --git a/PSL_catalog.json b/PSL_catalog.json new file mode 100644 index 0000000..5e4eea8 --- /dev/null +++ b/PSL_catalog.json @@ -0,0 +1,34 @@ +{ + "name": "OG-UK", + "img": "https://raw.githubusercontent.com/PSLmodels/OG-UK/main/docs/OG-UK_logo.png", + "banner_title": "OG-UK", + "banner_subtitle": "Large-scale open source overlapping generations model of UK fiscal policy", + "detailed_description": "https://raw.githubusercontent.com/PSLmodels/OG-UK/main/README.md", + "policy_area": "Policy analysis, policy reform, fiscal policy, tax, benefits, social security, public finance, macroeconomic analysis, general equilibrium, dynamic scoring, overlapping generations, OG, OLG", + "geography": "USA", + "language": "Python", + "maintainers": [ + { + "name": "Richard W. Evans", + "image": "https://github.com/rickecon.png", + "link": "https://github.com/rickecon" + }, + { + "name": "Jason DeBacker", + "image": "https://github.com/jdebacker.png", + "link": "https://github.com/jdebacker" + }, + { + "name": "Jon Pycroft", + "image": "https://avatars.githubusercontent.com/u/65815956?v=4", + "link": "https://github.com/jpycroft/" + } + ], + "links": { + "code_repository": "https://github.com/PSLmodels/OG-UK", + "user_documentation": "https://pslmodels.github.io/OG-UK", + "contributor_documentation": "https://pslmodels.github.io/OG-UK/content/contributing/contributor_guide.html", + "webapp": "", + "recent_changes": "https://github.com/PSLmodels/OG-UK/blob/main/CHANGELOG.md" + } +}