simul_confusion/Modules/ado/personal/r/raschpce.ado

228 lines
6.3 KiB
Plaintext

program define raschpce,rclass
syntax varlist [if] [in] [, rsm]
preserve
if "`if'"!=""|"`in'"!="" {
di "if:`if' in: `in'"
keep `if' `in'
}
tokenize `varlist'
local nbitems:word count `varlist'
local lines=1
local summ=0
local modamax=0
forvalues i=1/`nbitems' {
qui su ``i''
local moda`i'=r(max)
local lines=`lines'*(`moda`i''+1)
local summ=`summ'+`moda`i''
if `modamax'<`moda`i'' {
local modamax `moda`i''
}
}
local col=1+`nbitems'
*di "matrix table=J(`lines',`col',.)"
*matrix table=J(`lines',`col',.)
local line=1
/*forvalues i=1/`nbitems' {
forvalues j=`=`i'+1'/`nbitems' {
forvalues mi=0/`moda`i'' {
forvalues mj=0/`moda`j'' {
matrix table[`line',`i']=`mi'
matrix table[`line',`j']=`mj'
qui count if ``i''==`mi'&``j''==`mj'
matrix table[`line',`=`nbitems'+1']=r(N)
local ++line
}
}
}
}
*/
local line=1
forvalues i=1/`nbitems' {
forvalues j=`=`i'+1'/`nbitems' {
forvalues mi=0/`moda`i'' {
forvalues mj=0/`moda`j'' {
qui count if ``i''==`mi'&``j''==`mj'
local table_`line'_`=`nbitems'+1'=r(N)
local ++line
}
}
}
}
qui drop _all
set obs `=`line'-1'
local line=1
forvalues i=1/`nbitems' {
qui gen table`i'=.
}
qui gen table`=`nbitems'+1'=.
*set trace on
forvalues i=1/`nbitems' {
forvalues j=`=`i'+1'/`nbitems' {
forvalues mi=0/`moda`i'' {
forvalues mj=0/`moda`j'' {
qui replace table`i'=`mi' in `line'
qui replace table`j'=`mj' in `line'
qui replace table`=`nbitems'+1'=`table_`line'_`=`nbitems'+1'' in `line'
local ++line
}
}
}
}
*qui svmat table
local ti
local vi
forvalues i=1/`nbitems' {
rename table`i' ``i''
}
rename table`=`nbitems'+1' freq
local s="0"
local max=0
forvalues i=1/`nbitems' {
local max=`max'+`moda`i''
local bi`i'm0=0
local s="`s'+vi`i'mi`moda`i''"
forvalues j=`=`i'+1'/`nbitems' {
qui gen ti`i'j`j'=``i''+``j''
qui replace ti`i'j`j'=0 if ti`i'j`j'==.
local ti "`ti' i.ti`i'j`j'"
}
forvalues mi=1/`moda`i'' {
qui gen vi`i'mi`mi'=``i''==`mi'
local vi "`vi' vi`i'mi`mi'"
}
}
local s="(`s')/`max'"
count
if "`rsm'"=="" {
*edit
qui xi:poisson freq `vi' `ti', nocons iterate(30)
local ll=e(ll)
*set trace on
*lincom -(vi1mi1-(vi1mi3+vi2mi3+vi3mi3+vi4mi3+vi5mi3)/15)
*lincom -(vi1mi2-(vi1mi3+vi2mi3+vi3mi3+vi4mi3+vi5mi3)/15-vi1mi1)
*lincom -(vi1mi3-(vi1mi3+vi2mi3+vi3mi3+vi4mi3+vi5mi3)/15-vi1mi2)
*lincom -.5*(vi1mi1-(vi1mi2+vi2mi2+vi3mi2+vi4mi2+vi5mi2+vi6mi2+vi7mi2)/14)-.5*(vi1mi2-(vi1mi2+vi2mi2+vi3mi2+vi4mi2+vi5mi2+vi6mi2+vi7mi2)/14-vi1mi1)
qui matrix b=e(b)
local col=1
forvalues i=1/`nbitems' {
forvalues mi=1/`moda`i'' {
local bi`i'm`mi'=b[1,`col']
local ++col
}
}
*local s=`s'/`max'
*set trace on
forvalues i=1/`nbitems' {
local location`i'="0"
forvalues mi=1/`moda`i'' {
local delta`i'm`mi'=-(`bi`i'm`mi''-`mi'*`s'-`bi`i'm`=`mi'-1'')
if (`mi'==1) {
qui di "-(vi`i'mi`mi'-`s')"
local tdelta`i'_1 "-(vi`i'mi`mi'-`s')"
qui lincom -(vi`i'mi`mi'-`s')
local location`i' "`location`i''-(vi`i'mi`mi'-`s')"
}
else {
/*QUESTION : DOIT-ON MULTIPLIER `s' par `mi'*/
qui di " vi`i'mi`=`mi'-1'-vi`i'mi`mi'+`s'"
local tdelta`i'_`mi' " vi`i'mi`=`mi'-1'-vi`i'mi`mi'+`s'"
qui lincom vi`i'mi`=`mi'-1'-vi`i'mi`mi'+`s'
local location`i' "`location`i''+vi`i'mi`=`mi'-1'-vi`i'mi`mi'+`s'"
}
local delta`i'_`mi'=r(estimate)
local sedelta`i'_`mi'=r(se)
}
qui lincom (`location`i'')/`moda`i''
local delta`i'=r(estimate)
local sedelta`i'=r(se)
}
forvalues i=1/`nbitems' {
forvalues mi=1/`moda`i'' {
di "delta`i'_`mi' : `delta`i'_`mi'' (`sedelta`i'_`mi'')"
}
di "delta`i' : `delta`i'' (`sedelta`i'')"
}
}
else {
qui gen vmi2=vi1mi2+vi2mi2+vi3mi2
drop vi1mi2 vi2mi2 vi3mi2
edit
qui xi:poisson freq vi1mi1 vi2mi1 vi3mi1 vmi2 `ti', nocons
local ll=e(ll)
*set trace on
*lincom -(vi1mi1-(vi1mi3+vi2mi3+vi3mi3+vi4mi3+vi5mi3)/15)
*lincom -(vi1mi2-(vi1mi3+vi2mi3+vi3mi3+vi4mi3+vi5mi3)/15-vi1mi1)
*lincom -(vi1mi3-(vi1mi3+vi2mi3+vi3mi3+vi4mi3+vi5mi3)/15-vi1mi2)
*lincom -.5*(vi1mi1-(vi1mi2+vi2mi2+vi3mi2+vi4mi2+vi5mi2+vi6mi2+vi7mi2)/14)-.5*(vi1mi2-(vi1mi2+vi2mi2+vi3mi2+vi4mi2+vi5mi2+vi6mi2+vi7mi2)/14-vi1mi1)
forvalues i=1/`nbitems' {
local location`i'="0"
forvalues mi=1/`moda`i'' {
* local delta`i'm`mi'=-(`bi`i'm`mi''-`mi'*`s'-`bi`i'm`=`mi'-1'')
if (`mi'==1) {
qui di "-(vi`i'mi1-vi2)"
local tdelta`i'_1 "-(vi`i'mi1-vi2)"
qui lincom -(vi`i'mi1-vi2)
local location`i' "`location`i''-(vi`i'mi1)"
}
else {
/*QUESTION : DOIT-ON MULTIPLIER `s' par `mi'*/
qui di " vi`i'mi`=`mi'-1'"
local tdelta`i'_`mi' " vi`i'mi`=`mi'-1'"
qui lincom vi`i'mi`=`mi'-1'
local location`i' "`location`i''+vi`i'mi`=`mi'-1'"
}
local delta`i'_`mi'=r(estimate)
local sedelta`i'_`mi'=r(se)
}
qui lincom (`location`i'')/`moda`i''
local delta`i'=r(estimate)
local sedelta`i'=r(se)
}
forvalues i=1/`nbitems' {
forvalues mi=1/`moda`i'' {
di "delta`i'_`mi' : `delta`i'_`mi'' (`sedelta`i'_`mi'')"
}
di "delta`i' : `delta`i'' (`sedelta`i'')"
}
}
*set trace on
matrix delta=J(`nbitems',`modamax',.)
matrix sedelta=J(`nbitems',`modamax',.)
forvalues i=1/`nbitems' {
forvalues mi=1/`moda`i'' {
matrix delta[`i',`mi']=`delta`i'_`mi''
matrix sedelta[`i',`mi']=`sedelta`i'_`mi''
}
}
*set trace on
matrix b=delta
matrix list delta
*matrix delta=delta'
*matrix sedelta=sedelta'
return matrix b=delta
return matrix sedelta=sedelta
return scalar ll=`ll'
restore
*set trace on
matrix list b
*pcm item*, fixed(b)
end