forked from PSLmodels/Tax-Calculator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsimtax.py
104 lines (99 loc) · 5.28 KB
/
simtax.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
"""
SIMple input-output capabilities for TAX-calculator used in validation work
"""
# CODING-STYLE CHECKS:
# pycodestyle --ignore=E402 simtax.py
# pylint --disable=locally-disabled simtax.py
import argparse
import sys
from taxcalc import SimpleTaxIO
def main():
"""
Contains command-line interface to the Tax-Calculator SimpleTaxIO class.
"""
# parse command-line arguments:
parser = argparse.ArgumentParser(
prog='python simtax.py',
description=('Writes to a file the federal tax OUTPUT for the tax '
'filing units specified in the INPUT file with the '
'OUTPUT computed from the INPUT using the Tax-Calculator.'
' Both the INPUT and OUTPUT files use Internet-TAXSIM '
'format. The OUTPUT filename is the INPUT filename '
'with the ".out-simtax" string appended if no --reform '
'option is specified; otherwise the OUTPUT filename is '
'the INPUT filename with the ".out-simtax-REFORM" string '
'appended (excluding any ".json" ending to the REFORM '
'filename). The OUTPUT file contains the first 28 '
'Internet-TAXSIM output variables. Use --iohelp flag '
'for more information. For details on Internet-TAXSIM '
'version 9.3 INPUT and OUTPUT formats, go to '
'http://users.nber.org/~taxsim/taxsim-calc9/'))
parser.add_argument('--iohelp',
help=('optional flag to show INPUT and OUTPUT '
'variable definitions and exit'),
default=False,
action="store_true")
parser.add_argument('--reform',
help=('REFORM is name of optional file that contains '
'tax reform "policy" parameters (any "behavior" '
'or "growth" or "consumption" parameters are '
'ignored); the REFORM file is specified using '
'JSON that may include //-comments. No --reform '
'implies use of current-law policy.'),
default=None)
parser.add_argument('--exact',
help=('optional flag to suppress smoothing in income '
'tax calculations that eliminate marginal-tax-'
'rate-complicating "stair-steps". The default '
'is to smooth, and therefore, not to do the '
' exact calculations called for in the tax '
'law.'),
default=False,
action="store_true")
parser.add_argument('--taxsim2441',
help=('optional flag to emulate the Internet-TAXSIM '
'practice of approximating the number of '
'children eligible for the child care expense '
'credit on Form 2441 by the total number of '
'dependents of any age. The default practice '
'is to approximate with the number of '
'dependents under age 17.'),
default=False,
action="store_true")
parser.add_argument('--records',
help=('optional flag that causes the output file to '
'be a CSV-formatted file containing for each '
'INPUT filing unit the TAXYEAR values of each '
'variable in the Records.USABLE_READ_VARS set. '
'If the --records option is specified, the '
'output file name will be the same as if the '
'option was not specified, except that the '
'"out-simtax" part is replaced by "records"'),
default=False,
action="store_true")
parser.add_argument('INPUT', nargs='?', default='',
help=('INPUT is name of required file that contains '
'tax-filing-unit information in Internet-TAXSIM '
'format.'))
args = parser.parse_args()
# optionally show INPUT and OUTPUT variable definitions and exit
if args.iohelp:
SimpleTaxIO.show_iovar_definitions()
return 0
# check INPUT filename
if args.INPUT == '':
sys.stderr.write('ERROR: must specify INPUT file name;\n')
sys.stderr.write('USAGE: python simtax.py --help\n')
return 1
# instantiate SimpleTaxIO object and do tax calculations
simtax = SimpleTaxIO(input_filename=args.INPUT,
reform=args.reform,
exact_calculations=args.exact,
emulate_taxsim_2441_logic=args.taxsim2441,
output_records=args.records)
simtax.calculate(writing_output_file=True, exact_output=args.exact)
# return no-error exit code
return 0
# end of main function code
if __name__ == '__main__':
sys.exit(main())