forked from Revenue-Academy/Microsimulation_Training
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp002.py
83 lines (70 loc) · 3.43 KB
/
app002.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
"""
app1.py illustrates use of pitaxcalc-demo release 2.0.0 (India version).
USAGE: python app2.py
"""
from babel.numbers import format_currency
from taxcalc import *
import numpy as np
def remove_decimal(S):
S = str(S)
S = S[:-3]
return S
def ind_currency(curr):
curr_str = format_currency(curr, 'INR', locale='en_IN').replace(u'\xa0', u' ')
return(remove_decimal(curr_str))
# create Records object containing pit.csv and pit_weights.csv input data
recs = Records()
# create Records object containing pit.csv and pit_weights.csv input data
#grecs = GSTRecords(data='gst.csv', weights='gst_weights.csv')
grecs = GSTRecords()
# create CorpRecords object containing cit.csv and cit_weights.csv input data
crecs = CorpRecords()
# create Policy object containing current-law policy
pol = Policy()
# specify Calculator object for current-law policy
calc1 = Calculator(policy=pol, records=recs, gstrecords=grecs,
corprecords=crecs, verbose=False)
# specify Calculator object for reform in JSON file
reform = Calculator.read_json_param_objects('GST_reform.json', None)
pol.implement_reform(reform['policy'])
calc2 = Calculator(policy=pol, records=recs, gstrecords=grecs,
corprecords=crecs, verbose=False)
# loop through years 2017, 2018, and 2019 and print out pitax
for year in range(2017, 2023):
print('\n')
calc1.advance_to_year(year)
calc2.advance_to_year(year)
calc1.calc_all()
id_gst1 = calc1.garray('ID_NO')
gst_cereal1 = calc1.garray('gst_cereal')
total_consumption1 = calc1.garray('total consumption')
gst_total1 = calc1.garray('gst')
wgt_gst1 = calc1.garray('weight')
weighted_gst_cereal1 = calc1.weighted_garray('gst_cereal')
weighted_gst1 = calc1.weighted_garray('gst')
weighted_consumption = calc1.weighted_garray('total consumption')
total_consumption_all1 = calc1.weighted_total_garray('total consumption')
total_consumption_all1 = total_consumption_all1 / 10**7
total_gst1 = calc1.weighted_total_garray('gst') / 10**7
total_weight1 = calc1.weighted_total_garray('weight') / 10**7
print(f'***** Due to Current Law in {year} *****')
print(f'Total Consumption in - {year}: {ind_currency(total_consumption_all1)} Cr.')
print(f'Total GST Potential in - {year}: {ind_currency(total_gst1)} Cr.')
print(f'Total Number of Households in - {year}: {ind_currency(total_weight1)[1:]}')
calc2.calc_all()
id_gst2 = calc2.garray('ID_NO')
gst_cereal2 = calc2.garray('gst_cereal')
total_consumption2 = calc2.garray('total consumption')
gst_total2 = calc2.garray('gst')
wgt_gst2 = calc2.garray('weight')
weighted_gst_cereal2 = calc2.weighted_garray('gst_cereal')
weighted_gst2 = calc2.weighted_garray('gst')
weighted_consumption = calc2.weighted_garray('total consumption')
total_consumption_all2 = calc2.weighted_total_garray('total consumption')
total_consumption_all2 = total_consumption_all2 / 10**7
total_gst2 = calc2.weighted_total_garray('gst') / 10**7
total_weight2 = calc2.weighted_total_garray('weight') / 10**7
print(f'***** Due to Reform in {year} *****')
print(f'Total Consumption in - {year}: {ind_currency(total_consumption_all2)} Cr.')
print(f'Total GST Potential in - {year}: {ind_currency(total_gst2)} Cr.')
print(f'Total Number of Households in - {year}: {ind_currency(total_weight2)[1:]}')