300 likes | 423 Views
Seminar on POHEM – Tables. Philippe Finès September 2011. 1. Introduction. In the process of developing a program in POHEM, a few tools exist Debugging – step by step analysis of the statements executed, with a display of the values of the variables used
E N D
Seminar on POHEM – Tables Philippe Finès September 2011 1
Introduction In the process of developing a program in POHEM, a few tools exist Debugging – step by step analysis of the statements executed, with a display of the values of the variables used Tables – storage and display of values produced during the execution BioBrowser – display of biographies of individuals in the simulation 2
Usage of tables End-user Developer 3
Once the execution is finished, one can open a table and display its contents on the screen POHEM screen
… or do File > Export > Excel In this screen, the user selects the statistics the table style the tables to export
In this screen, the user indicates the directory and name of the exported table
Example of code for Tablexxx.mpp: Table.OA.mpp 12
partition HUI_CAT_PRE_SURG_4 {0.245, 0.544, 0.75}; partition OA_AGE_GROUP {5,10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90 }; partition YEAR_2001_to_2021 {2001,2002,2003,2004,2005,2006,2007,2008,2009,2010, 2011,2012,2013,2014,2015,2016,2017,2018,2019,2020, 2021,2022}; table Person tgHUIcat_MR_OK_4 { sex+ * split(truncated_age,OA_AGE_GROUP)+ * split(gHUI_OA,HUI_CAT_PRE_SURG_4)+ * split(calendar_year,YEAR_2001_2021) + * { unit, first_entrances(OA_Event_State,OA_Primary_Surgery), value_at_first_entrance(OA_Event_State,OA_Primary_Surgery,gHUI_OA), value_at_first_entrance(OA_Event_State,OA_Primary_Surgery,gHUI_OA)/ first_entrances(OA_Event_State,OA_Primary_Surgery) } }; These statements may be declared anywhere (i.e. in this module or in another) For each sex (+ total) For each age category (+ total) For each category of HUI pre surgery (+ total) For each year from 2001 to 2021 (+ total) Compute the following: Nb of persons Nb of time the state is a Primary Surgery Value of HUI the 1st time the state is a Primary Surgery Average value of HUI the 1st time the state is a Primary Surgery Purpose: We wanted to verify that the average HUI lies within its boundaries (debugging) We wanted to know whether the probability of having a primary surgery varies with HUI pre-surgery Example 1
table Person tAMIevents_CulturalOrigin [dominant && alive && calendar_year==pStartYear] //EN AMI events by cultural origin { { nz_delta( duration()), // count entrances( cad_state, DH_MI1 ), // INDEX AMI incidence entrances( gDiabetes, DIAB_YES ), // Diabetes incidence duration(), // py duration( cad_state, DH_MI1 ), // INDEX AMI prevalence py duration( gDiabetes, DIAB_YES ), // Diabetes prevalence py nz_delta( duration( cad_state, DH_MI1 )), // INDEX AMI prevalence counts nz_delta( duration( gDiabetes, DIAB_YES )) // Diabetes prevalence counts } * sex+ // sex * gCulturalOrigin+ // cultural origin }; Among living persons in 2001 (filter) By sex (+ total) By cultural origin (+ total) Compute the following: Nb of persons Nb of persons with AMI Nb of persons with Diabetes Purpose: We wanted to count the incidence and prevalence of these 2 risk outcomes Example 2
partition YEAR_2001_to_2021 {2001,2002,2003,2004,2005,2006,2007,2008,2009,2010, 2011,2012,2013,2014,2015,2016,2017,2018,2019,2020, 2021,2022}; table Person tHUImeanb { split(calendar_year,YEAR_2001_to_2021)+ * sex+ * OA_Event_State+ * { unit, duration(), weighted_duration ( gHUI_OA ), weighted_duration ( gHUI_OA ) / unit, weighted_duration ( gHUI_OA ) / duration() } }; For each year from 2001 to 2021 (+ total) For each sex (+ total) For each state Compute the following: Nb of persons Duration of time spent in that state (i.e. persons-years) “Sum of values of HUI” Average HUI per individual (not recommended) Average HUI per person-year Purpose: We wanted to compute the average HUI per OA state (see next slide) Example 3
actor Person (in PersonCore.mpp) { //EN Integer age when actor started LIFE_SPAN lifespan_age_start; table Person Life_Expectancy //EN Life expectancy, HALE and average HUI of initial population { sex+ * lifespan_age_start+ * { unit, //EN Nb persons duration(), //EN Person-years decimals=2 N.B.: “decimals=2” is a correct statement, it is used in the label part weighted_duration(gHUI_OA), //EN Total HUI duration()/unit, //EN LE decimals=2 weighted_duration(gHUI_OA)/unit, //EN HALE decimals=2 weighted_duration(gHUI_OA)/duration() //EN Average HUI decimals=2 } }; Example 4 This title appears in the list of tables All that appears after the // is a label in the table
Example 4 – Excel file produced Last 2 columns computed in excel
partition OA_AGE_GROUP {5,10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90 }; table Person tnboaCA //EN Nb of OAs in CA { sex+ * split(truncated_age,OA_AGE_GROUP)+ * {unit, //EN Units (0A) entrances(alive, FALSE), //EN Deaths value_at_entrances (alive, FALSE, IndexOA_event), //EN counts the number of IndexOA_event at time of Death event(entrances(IndexOA_event, TRUE))/duration(IndexOA_event,FALSE), // Incidence rate decimals=9 event(entrances(IndexOA_event, TRUE)), // New incident cases duration(IndexOA_event,FALSE), // Denominator for incidence nz_delta(duration(PrevOA_event, TRUE))/nz_delta(duration()), // Prevalence 2001 rate decimals=9 nz_delta(duration(PrevOA_event, TRUE)), // Numerator of prevalence nz_delta(duration()), // Denominator of prevalence /* nz_delta(duration(IndexOA_event, TRUE)) +nz_delta(duration(PrevOA_event, TRUE)), // Cumulative prevalence */ nz_delta(duration(IndexOA_event, TRUE)) , // Cumulative prevalence /* (nz_delta(duration(IndexOA_event, TRUE))+nz_delta(duration(PrevOA_event, TRUE)))/nz_delta(duration()), // Prevalence rate */ nz_delta(duration(IndexOA_event, TRUE))/nz_delta(duration()), // Prevalence rate decimals=9 duration(IndexOA_event, TRUE), duration(), duration(IndexOA_event, TRUE)/duration() } * calendar_year+ }; Example 5 This title appears in the list of tables All that appears after the // is a label in the table
Example 5 – Excel file produced Rows with label in italics computed in excel
Example 5 – Excel file produced Females
Thank you • Questions?
APPENDIX: The “derived states” in ModGen (from ModGen documentation)
Derived states associated with changes to actor states • Listed in alphabetic order: • changes( state )The number of times the classificationstate has changed so far in the simulation.e.g. changes (dfle) records the number of times the disability status has changed. Consider a person who survived to age 77 and whose disability status changed every 10 years from the age of 15 onwards. The value of changeswould be zero until the person turned 15 years old, 1 until the person turned 25 years old, 2 until the person’s 35 birthday, and so on. At the age of death changeswould equal 7. • entrances( variable, state )The number of times the variable has entered the state to that point in time in the simulation. e.g. entrances ( dfle, SEVERE_DIS) records the number of times an individual has entered the severe disability state to that point in the simulation. If a person survived to age 75, and his disability status entered the severe state at age 25 and 60, then the value returned by entrances is 0 until he turned 25 , 1 until he turns 60, and 2 for the remainder of his life. • exits( variable, state )The number of times the variable exited the state so far in the simulated lifetime.e.g. exits ( dfle, SEVERE_DIS) records the number of times an individual has exited the severe disability state to that point in the simulation. If a person survived to age 75, and his disability status entered the severe state at age 25 and 60 and exited the severe status at 31, then the value returned by exits is 0 until he turned 31 and 1 for the remainder of his life. • undergone_change( variable )The value of this function is 1 if the variable has changed its state by that point in the simulation and 0 otherwise.e.g. Consider a person who survived to age 75 and who became disabled at age 68. Then, the value of undergone_change( dfle) is 0 until he turns 68 year old and 1 for the remainder of his life. • undergone_entrance( variable, state )The value of this function is 1 if the variablehas entered the stateby that point in the simulation and 0 otherwise.e.g. Consider a person who survived to age 75 and who became severely disabled at age 68. Then, the value of undergone_entrance(dfle, SEVERE_DIS) is 0 until he turns 68 year old and 1 for the remainder of his life. • transitions( variable, from state, to state )The number of times the variable has entered the "to state" from the "from state" so far in the simulated lifetime.eg. transitions ( dfle, MILD_DIS, MEDIUM_DIS) records the number of times an individual left the mild disability state to enter the medium disability state so far in the simulation.
value_at_changes ( variable, recordedvariable )The sum of the values of the recordedvariable when the variable changes. This function is used, in conjunction with changes, to calculate the average value of a recordedvariable as the variables has changed so far in a simulation.e.g. value_at_changes ( dfle, age) records the sum of each age at which the disability status changes. If a person survived to age 77, and his disability status changed every 10 years from age 15 onwards, then the value returned by the function at the age of death is 15+25+35+45+55+65+75 = 260. The average age of change would be given by dividing this result by the number of changes: 260/7=37.1 • value_at_entrances ( variable, state, recordedvariable)The sum of the values of the recordedvariable at which the value of variable entered the state. This function is used, in conjunction with entrances, to calculate the average value of a recordedvariable for entrances into a state over the simulated lifetime.e.g. value_at_entrances ( dfle, SEVERE_DIS, age) records the sum of each age at which the disability status entered the severe state. If a person survived to age 75, and his disability status entered the severe state at age 25 and 60, then the value ofvalue_at_entrances is 0 to his 25th birthday, 25 to his 60 birthday, and 85 until the time of his death. • value_at_exits ( variable, state, recordedvariable )The sum of the values of the recordedvariable at which the value of variable exited the state. This function is used, in conjunction with exits to calculate the average value of a recorded variable for exits out of a state over the simulated lifetime.eg. value_at_exits ( dfle, SEVERE_DIS, age) records the sum of each age at which the disability status left the severe state. If a person survived to age 75, and his disability status entered the severe state at age 25 and 60 and exited the severe status at 31, then the value ofvalue_at_exits is 0 to his 31st birthday, and 31 until the time of his death. • value_at_first_change( variable, recordedvariable )The value of the recordedvariable at which time the value of variable first changed. If the variable has not yet changed its the state at that point in the lifetime, then the function has a value of zero.e.g. value_at_first_change ( dfle, age) records the age of a person at which the disability status first changed. If a person survived to age 70, and his disability status changed at age 25 and 60, then the value of value_at_first_change is 0 until he turned 25 and 25 for the remainder of his life.
value_at_first_entrance( variable, state, recordedvariable )The value of the recordedvariable at which time the value of variable first entered the state. If the variable has not yet entered the state at that point in the lifetime, then the function has a value of zero.e.g. value_at_first_entrance ( dfle, SEVERE_DIS, age) records the age of a person at which the disability status first entered the severe state. If a person survived to age 70, and his disability status entered the severe state at age 25 and 60, then the value of value_at_first_entrance is 0 until he turned 25 and 25 for the remainder of his life. • value_at_transitions ( variable, from state, to state, recorded variable )The sum of the values of the recorded variable at which the value of variable left the from state and entered the tostate. This function is used, in conjunction with transitions, to calculate the average value of a recorded variableas the variableshas changed so far.eg. value_at_transitions ( dfle, MILD_DIS, MEDIUM_DIS, age) records the sum of each age at which the disability status left the mild state and entered the severe state. • value_at_latest_change( variable, recordedvariable )The value of the recordedvariable at which the value of variable last changed. If the classification variable never changed, then the function returns a zero.e.g. value_at_latest_change ( dfle, age) records the age of a person at which the disability status last changed its state. If a person survived to age 75, and his disability status changed age 25 and at 60, then the value returned by value_at_latest_entrance is 0 to his 25 birthday, 25 to his 60th birthday, and 60 until the time of his death. • value_at_latest_entrance(variable, state, recordedvariable)The value of the recordedvariable at which the value of variable last entered the state. If the classification variable never entered the classification state, then the function returns a zero.e.g. value_at_latest_entrance ( dfle, SEVERE_DIS, age) records the age of a person at which the disability status last entered the severe state. If a person survived to age 75, and his disability status entered the severe state at age 25 and at 60, then the value returned by value_at_latest_entrance is 0 to his 25 birthday, 25 to his 60th birthday, and 60 until the time of his death.
Derived states associated with durations of actor states • The following expressions accumulate the values of a variable over the range of time an actor was in a specified state. When these expressions are used inside a table specification, then Modgen duration is only calculated for the time the actor is in the domain of the table. For example, if a table filter included residency status, then the duration of immigrant actor would only count the time the actor was a resident. • A subset of these functions or expressions operate on states over "spells" (i.e. periods of time over which a state assumes a specific value). These spell functions fall into two classes, those that operate on a "current” or “active" spell, and those that operate on a "completed” or “previous" spell. These two classes of functions behave very differently. In particular, the "active" functions are saw-tooth in form, returning to zero at the end of each spell, whereas the "completed" functions are step-like in form. • active_spell_delta ( variable, state, analysis variable )This reports on the change that the analysis variable has undergone since the variable has been in the state.eg. active_spell_delta ( dfle, MILD_DIS, earnings) records the sum of earnings over the time an individual has currently been in the mild disability state in the simulation. • active_spell_duration ( variable, state )The length of time the variable has currently been in the state from its last transition from a previous state in the simulation. If the actor has been in the same state for its entire lifetime to date, then the value of this function is zero.eg. active_spell_duration ( dfle, MILD_DIS) records the length of time an individual has currently been in the mild disability state in the simulation. Consider a person who has survived to age 75, his disability status entered the mild state at age 20, exited the mild state at 25, returned to it at aged 60, and stayed in this state until the time of his death. The value of active_spell_duration is 0 until he turned 20, 1 when he is 21, 2 when he is 22, and so on until his 25th birthday. At that point active_spell_duration would return to zero, until age 60 where it would be incremented by 1 for each year until he died.
active_spell_weighted_duration ( variable, state, weighting variable )This is a weighted version of active_spell_duration. It could be used to determine, for example, the income earned so far during the current (on-going) spell of employment. This would be done by using the earningsrate variable as the weightingvariable. • completed_spell_delta (variable, state, analysis variable)This reports on the change that the analysis variable has undergone in the last completed spell in which the variable was in the state.eg. completed_spell_delta (dfle, MILD_DIS, earnings) records the sum of earnings over the previous completed time an individual was in the mild disability state in the simulation. • completed_spell_duration(variable, state)The length of time the variable was last in the state. If the actor has been in the same state for its entire lifetime to date, then the value of this function is zero.eg. completed_spell_duration ( dfle, MILD_DIS) records the length of time an individual was last in the mild disability state. Consider a person survived to age 75, and his disability status entered the mild state at age 20, exited the mild state at 25, returned to it at aged 60, and stayed in this state until the time of his death. The value of completed_spell_duration is 0 until he turned 25, and 5 until the time of the actor’s death. • completed_spell_weighted_duration (variable, state, weighting variable)This is a weighted version of completed_spell_duration. It could be used to determine, for example, the income earned during a previous spell. This would be done by using the earningsrate variable as the weightingvariable. • duration( variable, state ) or duration()The length of time the value of the actor variable has been in the state so far in the simulated lifetime. If the variable and state are not specified, then durationcumulates duration during the existence of the actor. It performs the same function as duration(life_status, ALIVE).eg. duration ( dfle, MILD_DIS) records the length of time an individual has ever been in the mild disability state. Consider a person who has survived to age 75, his disability status entered the mild state at age 20, exited the mild state at 25, returned to it at aged 60, and stayed in this state until the time of his death. The value of duration is 0 until he turned 20, 1 when he is 21, 2 when he is 22, and so on until his 25th birthday. At that point durationwould keep the same value, 5, until age 60 where it would be incremented by 1 until the year of his death. • duration_trigger(state, value, elapsed_time )This function is a logical state informing if the duration of a specific state at a specific value reached a specified time period.e.g. logical worked6months = duration_trigger(employed, TRUE, 0.5 ) states the value of the derived state worked6months is TRUE if the individual has been working for at least 6 months, FALSE in any other case. It also implicitly creates an event with the waiting time being the specified time. In the above example, the waiting time would be 0.5.
duration_counter(state, value, size of time interval); • or • duration_counter(state, value, size of time interval, maximum value); • This function is like duration_trigger(), except that it counts the number of intervals of specified size that have elapsed since a particular state reached a particular value. • e.g. int curtate_age = duration_counter(alive, TRUE, 1) • will count the number of years elapsed since the person is alive, i.e. the person’s integerized age. Implicit events will also be created at each birthday. • Due to the creation of implicit events, using duration_counter() can be expensive, since it may continue to be updated (perhaps monthly) long after its usefulness is at an end (e.g. after retirement, or beyond the largest value needed by a time function). For that reason, it is possible to use an optional fourth argument: the maximum count it’s allowed to reach. Once it reaches that maximum, Modgen will cease updating the value. • e.g. int curtate_age_below_50 = duration_counter(alive, TRUE, 1, 50) • will count the number of years elapsed since the person is alive as long as that number is lower than or equal to 50. At any point during a person’s life, curtate_age_below_50 would be either the age (integer) of the person, or 50. • weighted_cumulation(state1,state2)“state1” is the state whose cumulation is observed. Whenever the value of “state1” changes the difference is mutiplied by the value of “state2” and added to the derived state. The new state is useful for creating a constant dollar version of some state cumulated in current dollars. • weighted_duration ( variable, state, weighting variable ) • or • weighted_duration (weighting variable)This function uses the values of the weighting variable, which is always a rate variable (i.e. earnings rates, wage rates, etc.) to the sum of this variable over the duration of time the variable has, so far, been in the state. This function, essentially, converts a rate variable into a accumulating variable. If the variable and state are missing from the specification, then the value of the function is the sum of the weighting variable to the current point in the actor’s lifetime.eg. weighted_duration ( dfle, MILD_DIS, earnings_rate) records the total earnings of an actor while it has, so far, been in the mild disability state. Consider a person who survived to age 75, and his disability status entered the mild state at age 60, left it at aged 65, and his annual earnings are $10,000. The value of weighted_duration is, at age 60, is 10000*1, at aged 61 is 10000*2, and so on to age 65 where the value of this function is 10000*5 = 50000. This value is maintained for the duration of the actor’s lifetime.