Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Reform to remove head of household filing status #3163

Merged
merged 28 commits into from
Dec 18, 2023
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
25cdc49
Reform standard deduction remove head of household filing status
mzx-4real Oct 17, 2023
ff06f10
Fill in __init__.py; Change name of functions
mzx-4real Oct 22, 2023
97a454e
Merge branch 'master' of https://github.com/PolicyEngine/policyengine…
mzx-4real Oct 22, 2023
036e76f
Merge branch 'master' of https://github.com/PolicyEngine/policyengine…
mzx-4real Oct 24, 2023
e7201b3
Add reform to reform lists and add unit test; Hoh formula still incom…
mzx-4real Oct 24, 2023
07e5768
Use fix amount as temp
mzx-4real Oct 24, 2023
1be3104
Small fix
mzx-4real Oct 24, 2023
1d31c8a
Merge upstream master
mzx-4real Nov 1, 2023
5a884ea
Fix
mzx-4real Nov 1, 2023
257aa1f
Merge branch 'master' of https://github.com/PolicyEngine/policyengine…
mzx-4real Nov 2, 2023
722db8d
Fix
mzx-4real Nov 2, 2023
cc23061
debug purpose
mzx-4real Nov 3, 2023
3c301c5
debug
mzx-4real Nov 3, 2023
5b2cc16
Merge branch 'master' of https://github.com/PolicyEngine/policyengine…
mzx-4real Nov 4, 2023
486d461
Fix
mzx-4real Nov 4, 2023
7ced0d4
small fix
mzx-4real Nov 4, 2023
c331f23
Merge branch 'master' of https://github.com/PolicyEngine/policyengine…
mzx-4real Nov 18, 2023
b74f28a
Suggested change
mzx-4real Nov 18, 2023
61c671b
Suggested change
mzx-4real Nov 27, 2023
84cec26
Merge branch 'master' of https://github.com/PolicyEngine/policyengine…
mzx-4real Nov 27, 2023
228101c
Small fix
mzx-4real Nov 27, 2023
fe7e998
Merge branch 'master' of https://github.com/policyengine/policyengine…
MaxGhenis Dec 18, 2023
18bd705
Change to Romney
MaxGhenis Dec 18, 2023
a18d8cf
add readme
MaxGhenis Dec 18, 2023
e389e8f
add FilingStatus enum
MaxGhenis Dec 18, 2023
14abecc
formatting nit
MaxGhenis Dec 18, 2023
bb75ea7
add remove_head_of_household reform to test
MaxGhenis Dec 18, 2023
82c5b25
add to reform
MaxGhenis Dec 18, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions changelog_entry.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
- bump: minor
changes:
added:
- Reform for the Tax Foundation growth and opportunity plan.

Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
description: The head of household filing status will be eliminated if this is true and converted to single.
values:
2000-01-01: false
metadata:
unit: bool
label: Tax Foundation growth and opportunity plan remove standard deduction head of household filing status
reference:
- title: Tax Foundation Details and Analysis of a Tax Reform Plan for Growth and Opportunity
href: https://taxfoundation.org/research/all/federal/growth-opportunity-us-tax-reform-plan/#Revenue
9 changes: 9 additions & 0 deletions policyengine_us/reforms/reforms.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@
from .dc_tax_threshold_joint_ratio import (
create_dc_tax_threshold_joint_ratio_reform,
)
from .tax_foundation.growth_and_opportunity import (
create_remove_standard_deduction_head_of_household_reform,
)
from policyengine_core.reforms import Reform
import warnings

Expand All @@ -17,12 +20,18 @@ def create_structural_reforms_from_parameters(parameters, period):
dc_tax_threshold_joint_ratio_reform = (
create_dc_tax_threshold_joint_ratio_reform(parameters, period)
)
remove_standard_deduction_head_of_household = (
create_remove_standard_deduction_head_of_household_reform(
parameters, period
)
)

reforms = [
afa_reform,
winship_reform,
dc_kccatc_reform,
dc_tax_threshold_joint_ratio_reform,
remove_standard_deduction_head_of_household,
]
reforms = tuple(filter(lambda x: x is not None, reforms))

Expand Down
mzx-4real marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
from .remove_standard_deduction_head_of_household import (
create_remove_standard_deduction_head_of_household_reform,
)
mzx-4real marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
from policyengine_us.model_api import *


def create_remove_standard_deduction_head_of_household() -> Reform:
class basic_standard_deduction(Variable):
value_type = float
entity = TaxUnit
label = "Basic Standard Deduction (Eliminating HoH)"
unit = USD
documentation = "The Basic standard deduction under the tax foundation growth and opportunity plan"
definition_period = YEAR

def formula(tax_unit, period, parameters):
std = parameters(period).gov.irs.deductions.standard
filing_status = tax_unit("filing_status", period)
statuses = filing_status.possible_values
separate_filer_itemizes = tax_unit("separate_filer_itemizes", period)
claimed_as_dependent_elsewhere = tax_unit(
"tax_unit_dependent_elsewhere", period
)
if (
mzx-4real marked this conversation as resolved.
Show resolved Hide resolved
parameters(
period
).gov.contrib.tax_foundation.growth_and_opportunity.remove_head_of_household
== True
):
standard_deduction = select(
[
filing_status == statuses.SINGLE,
filing_status == statuses.SEPARATE,
filing_status == statuses.JOINT,
filing_status == statuses.WIDOW,
filing_status == statuses.HEAD_OF_HOUSEHOLD,
],
[
std.amount[filing_status],
std.amount[filing_status],
std.amount[filing_status],
std.amount[filing_status],
13850, # this should be single amount, use fix amount as temp
mzx-4real marked this conversation as resolved.
Show resolved Hide resolved
],
)
else:
standard_deduction = std.amount[filing_status]

standard_deduction_if_dependent = min_(
standard_deduction,
max_(
std.dependent.additional_earned_income
+ tax_unit("tax_unit_earned_income", period),
std.dependent.amount,
),
)

return select(
[
separate_filer_itemizes,
claimed_as_dependent_elsewhere,
True,
],
[
0,
standard_deduction_if_dependent,
standard_deduction,
],
)

class additional_standard_deduction(Variable):
value_type = float
entity = TaxUnit
label = "Additional Standard Deduction (Eliminating HoH)"
unit = USD
documentation = "The additional standard deduction under the tax foundation growth and opportunity plan"
definition_period = YEAR

def formula(tax_unit, period, parameters):
std = parameters(period).gov.irs.deductions.standard
filing_status = tax_unit("filing_status", period)
statuses = filing_status.possible_values
aged_blind_count = tax_unit("aged_blind_count", period)
if (
mzx-4real marked this conversation as resolved.
Show resolved Hide resolved
parameters(
period
).gov.contrib.tax_foundation.growth_and_opportunity.remove_head_of_household
== True
):
additional_standard_deduction_per_count = select(
[
MaxGhenis marked this conversation as resolved.
Show resolved Hide resolved
filing_status == statuses.SINGLE,
filing_status == statuses.SEPARATE,
filing_status == statuses.JOINT,
filing_status == statuses.WIDOW,
filing_status == statuses.HEAD_OF_HOUSEHOLD,
],
[
std.aged_or_blind.amount[filing_status],
std.aged_or_blind.amount[filing_status],
std.aged_or_blind.amount[filing_status],
std.aged_or_blind.amount[filing_status],
1850, # this should be single amount, use fix amount as temp
],
)
else:
additional_standard_deduction_per_count = std.aged_or_blind.amount[
filing_status
]
return aged_blind_count * additional_standard_deduction_per_count

class reform(Reform):
def apply(self):
self.update_variable(basic_standard_deduction)

return reform


def create_remove_standard_deduction_head_of_household_reform(
parameters, period, bypass: bool = False
):
if bypass:
return create_remove_standard_deduction_head_of_household()

p = parameters(period).gov.contrib.tax_foundation.growth_and_opportunity

if p.remove_head_of_household > 0:
return create_remove_standard_deduction_head_of_household()
else:
return None


remove_standard_deduction_head_of_household = (
create_remove_standard_deduction_head_of_household_reform(
None, None, bypass=True
)
)
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
- name: Remove standard deduction head of household filing status
period: 2023
reforms: policyengine_us.reforms.tax_foundation.growth_and_opportunity.remove_standard_deduction_head_of_household.remove_standard_deduction_head_of_household
input:
gov.contrib.tax_foundation.growth_and_opportunity.remove_head_of_household : True
# tax unit basic standard deduction
filing_status: HEAD_OF_HOUSEHOLD
separate_filer_itemizes: False
mzx-4real marked this conversation as resolved.
Show resolved Hide resolved
tax_unit_dependent_elsewhere: False
mzx-4real marked this conversation as resolved.
Show resolved Hide resolved
tax_unit_earned_income: 0
# tax unit additional standard deduction
aged_blind_count: 2
output:
basic_standard_deduction: 13_850 # Calculate after hoh formula is done
additional_standard_deduction: 3_700 # Calculate after hoh formula is done