Taxsim as a libary routine

Traditionally Taxsim has read its input from in ASCII from standard in and written the results in ASCII to standard out. This has provided portability and ease of diagnostics. But sometimes it may be inconvenient or slow, so we are experimenting with a fast library interface. This eliminates the ASCII to binary and back conversions. This page documents how to use that version.

Note that the fortran code has no way to report errors other than to abend, as fortran i/o is incompatible with c or Python i/o. If this becomes a problem, we can perhaps address it with stop codes and global variables. I am certainly willing to work with anyone wishing to use Taxsim as a library routine - it isn't efficient to duplicate all the error checking of income.

Source for the library is normally distributed as taxsimdll.f

The library source code differs from the executable program in only 4 lines.The source code contains several references to "isexe" which needs to be set .false. in block data dllexe. Three other changes need to be made to taxsim.f to get taxsimdll.f: sed -e "s/program taxsim/subroutine taxsim/" taxsim.f \ | sed "s/c return/ return/" \ | sed "s@isexe/.true./@isexe/.false./@" >taxsimdll.f Creating the library file is done with: gfortran taxsimdll.f ar cr libtaxsim.a *.o
Input and output are via Fortran common blocks. There is information about accessing common blocks from Python is at: https://numpy.org/doc/stable/f2py/python-usage.html#common-blocks The input vector is common block "xcom" with 55 doublewords (sorry it is numbered from 1, subtract 1 from the index for the c location): 1 taxsimid 2 year 3 state 4 mstat 5 page 6 sage 7 depx 8 dep13 9 dep17 10 dep18 11 pwages 12 swages 13 dividends 14 intrec 15 stcg 16 ltcg 17 otherprop 18 nonprop 19 pensions 20 gssi 21 ui 22 transfers 23 rentpaid 24 proptax 25 otheritem 26 childcare 27 mortgage 28 scorp 29 pbusinc 30 pprofinc 31 sbusinc 32 sprofinc 33 idtl 34 mtr 35 pui 36 sui 37 dep6 38 dep19 39 opt1 40 opt1v 41 opt2 42 opt2v 43 age1 44 age2 45 age3 46 age4 47 age5 48 age6 49 age7 50 age8 51 age9 52 age10 53 psemp 54 ssemp 55 statefip The federal tax output goes to common block "newshr" with length 255 doublewords. To start with, here are two important locations in newshr: 1 fiitax 74 siitax For the rest of the federal results, consult the last few pages of https://taxsim.nber.org/taxsim-ndx.txt where "comnew" is documented.

The state tax intermediate values are in common block "calc", with elements:

1 household income 2 rent paid 3 state agi 4 state personal exemptions 5 standard deduction 6 itemized deductions 7 taxable income 8 property tax cred 9 child care credit 10 earned income credit 11 total credits 12 bracket rate 13 tax before credits 14 rebate 15 fuel/energy credit 16 child tax credit 17 general credit 18 alternative minimum tax 19 deduction for federal taxf 20 rent credit 21 refundablecredits 22 primary taxable income 23 secondary taxable income 24 primary tax 25 secondary tax
Fortran Example This program shows federal and state liability for a California taxpayer at several levels of wage income: implicit double precision(a-h,o-z) common/newshr/c(255) common/xcom/x(55) write(*,*)' wages fiitax siitax' do i=1,55 x(i)=0d0 enddo do i=1,100,10 x(2)=2021d0 x(4)=2d0 x(11)=1000*i call taxsim write(*,*) int(x(11)),int(c(1)),int(c(74)) enddo stop end
C Example If you want to use this library, please do not hesitate to contact me. Daniel Feenberg
617-682-6204 feenberg@nber.org
last update 27 Sep 2024