simul_confusion/Modules/ado/personal/p/pcmtest.ado

1503 lines
43 KiB
Plaintext

/********************************************************************************/
/* v1.1 : Modified for being used after irt pcm and irt rsm */
/********************************************************************************/
* Needed modules :
* gausshermite (http://www.freeirt.org)
* gllamm version 2.3.14 (ssc describe gllamm)
program define pcmtest, rclass
version 11.0
syntax [, APproximation NEw Group(string) NFit(string) Power(string) Alpha(string) GRAPHics FILEgraph(string) Sitest]
preserve
qui{
tempfile bddtravail
save `bddtravail', replace
tempname x w val freq
capture local cmdavant=e(cmd)
if _rc!=0 | "`cmdavant'"!="pcmodel"{
capture local cmdavant=e(model1)
local condition ="`cmdavant'"=="pcm" | "`cmdavant'"=="rsm"
if _rc!=0 | `condition'!=1{
noi di in red "Please use pcmtest only after pcmodel, irt pcm or irt rsm"
error 100
}
else{
local testIrtPcm=1
}
if "`cmdavant'"=="rsm"{
local RSMtest=1
}
}
if "`graphics'"!=""{
if "`filegraph'"!=""{
local ReplaceGr2=0
local ReplaceGr=strpos("`filegraph'",",")
if `ReplaceGr'!=0{
local ReplaceGr=strpos(reverse("`filegraph'"),",")
local ReplaceGr2=strpos( substr("`filegraph'", strpos("`filegraph'",","), .), "r")!=0
local filegraphOld="`filegraph'"
local filegraph=rtrim(reverse(substr(reverse("`filegraph'"),`=`ReplaceGr'+1',.)))
}
if `ReplaceGr2'==0{
capture graph use "`filegraph'_LT_Sc", nodraw
if _rc==0{
noi di in red "`filegraph'_LT_Sc already exists (use option replace for replacing it)"
error 100
}
capture graph use "`filegraph'_MAP", nodraw
if _rc==0{
noi di in red "`filegraph'_MAP already exists (use option replace for replacing it)"
error 100
}
capture graph use "`filegraph'_Score_Distrib", nodraw
if _rc==0{
noi di in red "`filegraph'_Score_Distrib already exists (use option replace for replacing it)"
error 100
}
capture graph use "`filegraph'_Contrib", nodraw
if _rc==0{
noi di in red "`filegraph'_Contrib already exists (use option replace for replacing it)"
error 100
}
}
capture save "`filegraph'", replace
if _rc!=0{
noi di in red "Invalid path specification"
error 603
}
else{
erase "`filegraph'.dta"
}
}
}
/***************************/
/* Récuperation de toutes */
/* les matrices estimées */
/***************************/
local itest=e(itest)
if `itest'==0{
noi di in red "No tests of fit if the items difficulties are fixed (i.e. not estimated) "
error 100
}
local Elll=e(ll)
local Ecn=e(cn)
local EN=e(N)
local ENit=e(Nit)
local dataR1m=e(dataR1m)
local mugauss=e(mugauss)
local sdgauss=e(sdgauss)
local ordre=e(order)
local ENqual=e(Ncat)
local ENquant=e(Ncont)
local convergeance=e(converged)
local Esigma=e(sigma)
local EVarsigma=e(Varsigma)
local ENumFit=e(NumFit)
local Eitems=e(items)
local IF=e(if)
local IN=e(in)
if "`IF'"!="" & "`IF'"!="."{
local if "`IF'"
}
if "`IN'"!="" & "`IN'"!="."{
local in "`IN'"
}
tempname EglobalFit EitemFit Etheta EVartheta Edelta EVardelta
matrix `EglobalFit'=e(globalFit)
matrix `EitemFit'=e(itemFit)
matrix `Etheta'=e(theta)
matrix `EVartheta'=e(Vartheta)
matrix `Edelta'=e(delta)
matrix `EVardelta'=e(Vardelta)
local rsm=e(rsm)
if "`rsm'"!="."{
local RSMtest2=1
}
else if "`RSMtest'"=="1"{
local RSMtest2=1
}
else{
local RSMtest2=0
}
/* irt pcm et irt rsm */
if "`testIrtPcm'"=="1"{
local EN=e(N)
local mugauss=0
local if strpos(,s2)
local IFif=e(cmdline)
local PosIf=strpos("`IFif'"," if ")
local PosIn=strpos("`IFif'"," in ")
if strpos("`IFif'",",")==0{
local posComma="."
}
else{
local posComma=strpos("`IFif'",",")
}
if `PosIf'!=0 & `PosIn'!=0{
if `PosIf'<`PosIn'{
local if "`=substr("`IFif'",`=`PosIf'+4',`=`PosIn'-`PosIf'-4')'"
local in "`=substr("`IFif'",`=`PosIn'+4',`=`posComma'-`PosIn'-4')'"
}
else{
local in "`=substr("`IFif'",`=`PosIn'+4',`=`PosIf'-`PosIn'-4')'"
local if "`=substr("`IFif'",`=`PosIf'+4',`=`posComma'-`PosIf'-4')'"
}
}
else{
local if "`=substr("`IFif'",`=`PosIf'+4',`=`posComma'-`PosIf'-4')'"
local in "`=substr("`IFif'",`=`PosIn'+4',`=`posComma'-`PosIn'-4')'"
}
if `PosIf'==0{
local if=""
}
if `PosIn'==0{
local in=""
}
local itPcm=e(n_cuts1)
tempname Edelta DifComPcm tempmatdif EglobalFit EitemFit Etheta EVartheta EVardelta
matrix `DifComPcm'=e(b)
local nbcolMD=0
local plus=0
matrix `Edelta'=(.)
foreach i in `itPcm'{
local sum=0
forvalues it=2/`i'{
local tempmatdifnnn=`DifComPcm'[1,`=2*`it'+`plus'']-`DifComPcm'[1,`=2*`=`it'-1'+`plus'']
matrix `tempmatdif'=(`=-`tempmatdifnnn'')
matrix `Edelta'=`Edelta',`tempmatdif'
}
local plus=`plus'+2*`i'
}
matrix `Edelta'=`Edelta'[....,2...]
local sdgauss=`DifComPcm'[1,3]
local Eitems=e(items1)
}
qui capture matrix list r(globalFitTot)
if _rc!=0{
local testafaire=1
}
else{
local testafaire=0
}
if "`new'"!=""{
local testafaire=1
}
if "`nfit'"!=""{
local numFit=`nfit'
}
else{
local numFit=.
}
local varlist `Eitems'
local nbit: word count `varlist'
local nbitsuf=1
if `nbit'<2{
noi di in red "No tests of fit if the number of items is less than 2"
error 100
}
if `nbit'==2{
noi di in gr "Only the R1m test is performed if the number of items is equal to 2"
local nbitsuf=0
}
tokenize `varlist'
qui{
marksample touse,novarlist
keep if `touse'
local ordre=0
forvalues i=1/`nbit'{
tempname rep__`i'
tab ``i'', matrow(`rep__`i'')
local ordre=`ordre'+`=rowsof(`rep__`i'')'-1
forvalues j=1/`=rowsof(`rep__`i'')'{
replace ``i''=`j'-1 if ``i''==`rep__`i''[`j',1]
}
}
if `RSMtest2'==1{
local ordre=`=rowsof(`rep__1')'-2+`nbit'
}
q memory
}
tempfile bddini datatest bdd_b bdd_se bdd_seg bdd_P bdd_R1 bdd_G
save `bdd_b', replace
save `datatest', replace
/*************************************/
/* test R1m */
/*************************************/
noi di in gr "Performing R1m test"
qui{
q memory
local matsizeini=r(matsize)
set matsize `matsizeini'
tempfile matU matU1 matU2
tempname dm cell row
egen `dm'=rowmiss(`varlist')
replace `dm'=`dm'>0
tab `dm',matcell(`cell') matrow(`row')
local nbmissing=`cell'[2,1]
local percentmissing=`cell'[2,1]/(`cell'[1,1]+`cell'[2,1])
if `nbmissing'==.{
local nbmissing=0
local percentmissing=0
}
keep if `dm'==0
local NbIdFit=_N
if `numFit'==.{
local propFit=1
local propFitPb=0
}
else if `numFit'>`NbIdFit'{
local propFit=1
local propFitPb=1
}
else{
local propFit=`numFit'/`NbIdFit'
local propFitPb=2
}
drop `dm'
keep `varlist'
forvalues i=1/`nbit'{
rename ``i'' pre_``i''
}
forvalues i=1/`nbit'{
gen it`i'=pre_``i''
drop pre_``i''
}
local nbscore=1
forvalues i=1/`nbit'{
qui tab it`i'
local nbmoda_`i'=r(r)
local nbscore=`nbscore'+`nbmoda_`i''-1
}
local score "it1"
forvalues i=2/`nbit'{
local score "`score'+it`i'"
}
gen score=`score'
save `bdd_se', replace
local N=_N
/* autogroup */
if "`group'"==""{
su score, d
local list `=r(p25)'
if `=r(p25)'!=`=r(p50)'{
local list "`list' `=r(p50)'"
}
if `=r(p50)'!=`=r(p75)'{
local list "`list' `=r(p75)'"
}
if `=r(p75)'!=`=`nbscore'-1'{
local list "`list' `=`nbscore'-1'"
}
if wordcount("`list'")==1{
noi di in red "Problem with Autogroup option: creating groups from the score quartiles is not possible"
}
tab score, matcell(`freq') matrow(`val')
local nbgroup=wordcount("`list'")
}
else{
tab score, matcell(`freq') matrow(`val')
local list "`group'"
local nbgroup=wordcount("`list'")
if real(word("`list'",`nbgroup'))<`=`nbscore'-1'{
local list "`group' `=`nbscore'-1'"
local nbgroup=wordcount("`list'")
}
}
local nbmodagpe=0
forvalues i=1/`nbit'{
local nbmodagpe=`nbmodagpe'+`nbmoda_`i''
}
gen g=.
local liminf1=-1
forvalues i=1/`nbgroup'{
local limsup`i'=real("`=word("`list'",`i')'")
if `i'>1{
local liminf`i'=real("`=word("`list'",`=`i'-1')'")
}
replace g=`i' if score<=`limsup`i'' & score>`liminf`i''
}
forvalues i=1/`nbgroup'{
su score if g==`i'
local N`i'=r(N)
}
save `bdd_se', replace
save `bdd_seg', replace
use `bdd_se', replace
local count=0
forvalues i=1/`nbit'{
forvalues j=1/`nbmoda_`i''{
if `j'==1{
local diffest`i'_`j'=0
}
else{
local count=`count'+1
local diffest`i'_`j'=round(`Edelta'[1,`count'],0.001)+`diffest`i'_`=`j'-1''
}
local num`i'_`j' "exp(`=`j'-1'*x-`diffest`i'_`j'')"
if `j'==1{
local denom`i' "1"
}
else{
local denom`i' "`denom`i''+`num`i'_`j''"
}
}
forvalues j=1/`nbmoda_`i''{
local PCM`i'_`j' "(`num`i'_`j'')/(`denom`i'')"
}
}
local nbcomb=1
forvalues i=1/`nbit'{
local nbcomb=`nbcomb'*`nbmoda_`i''
}
clear
set obs `=int(`nbcomb'+0.1)'
local facteur=1
gen score=0
local order "score"
forvalues i=1/`nbit'{
gen it`i'=floor(mod(_n/`facteur',`nbmoda_`i''))
local facteur=`facteur'*`nbmoda_`i''
replace score=score+it`i'
tab it`i', gen(i`i'c)
local order "`order' it`i'"
}
order `order', first
sort score
tab score, gen(score)
local nbscore=r(r)
gen P=1
local gdN=_N
/*************************************/
/* */
/* Calcul de la probabilité de */
/* chaque patern de réponses */
/* */
/*************************************/
if "`approximation'"==""{
local percentcount=0
noi di ""
noi di in ye "`gdN'" in gr " response pattern probabilities to compute"
noi di in gr "Percentage of completion"
noi di in gr "----|---10%---|---20%---|---30%---|---40%---|---50%"
_dots 0, title(Loop computation of theorical probabilities of each response pattern) reps(100)
forvalues l=1/`gdN'{
local exp ""
forvalues i=1/`nbit'{
forvalues m=1/`nbmoda_`i''{
if i`i'c`m'[`l']==1{
if "`exp'"==""{
local exp "`PCM`i'_`m''"
}
else{
local exp "`exp'*`PCM`i'_`m''"
}
}
}
}
gausshermite `exp' , sigma(`sdgauss') mu(`mugauss') display
replace P=round(r(int),0.000001) if _n==`l'
local percentcountplus=floor(`l'*100/`gdN')
forvalues percen=`=`percentcount'+1'/`percentcountplus'{
nois _dots `percen' 0
}
local percentcount=`percentcountplus'
}
}
else{
noi di in gr "Response pattern probabilities computation"
replace P=0
sort score it*
save `bdd_P', replace
local NbCol=1
local compteur=1
forvalues i=1/`nbit'{
tempname Dit`i'
matrix `Dit`i''=`Edelta'[1,`compteur'..`=`compteur'+`nbmoda_`i''-2']
if colsof(`Dit`i'')>`NbCol'{
local NbCol=colsof(`Dit`i'')
}
local compteur=`compteur'+`nbmoda_`i''-1
}
clear
noi di in gr "----|---25%---|---50%---|---75%---|---100%
qui _dots 0, title(Title) reps(40)
set obs 1000000
gen id=_n
gen theta=`mugauss'+invnormal(uniform())*`sdgauss'
forvalues i=1/`nbit'{
gen denom`i'=1
gen num`i'_0=1
forvalues j=1/`=`nbmoda_`i''-1'{
gen num`i'_`j'=exp(ln(num`i'_`=`j'-1') + theta-`Dit`i''[1,`j'])
replace denom`i'=denom`i'+num`i'_`j'
}
forvalues j=0/`=`nbmoda_`i''-1'{
gen p`i'_`j'=num`i'_`j'/denom`i'
}
drop denom`i'
drop num`i'_*
forvalues j=1/`=`nbmoda_`i''-1'{
replace p`i'_`j'=p`i'_`j'+p`i'_`=`j'-1'
}
gen it`i'=0
gen random`i'=runiform()
forvalues j=1/`=`nbmoda_`i''-1'{
replace it`i'=`j' if random`i'>=p`i'_`=`j'-1' & random`i'<p`i'_`j'
}
drop random* p`i'_*
forvalues j=1/`=round(`=40/`nbit'')'{
nois _dots `j' 0
}
}
egen score=rowtotal(it*)
keep it* score
contract score it*, f(P)
replace P=round(P/1000000,0.000001)
sort score it*
merge score it* using `bdd_P'
drop _merge
order `order', first
order P, last
}
noi di in gr ""
save `bdd_R1', replace
local dataR1m "`bdd_R1'"
tab score
local Pscoresl=r(r)
tempname Pscores
matrix `Pscores'=J(`Pscoresl',2,.)
forvalues i=1/`Pscoresl'{
su P if score==`=`i'-1'
matrix `Pscores'[`i',2]=r(sum)
matrix `Pscores'[`i',1]=`i'-1
}
save `matU2', replace
local sort "score"
forvalues i=1/`nbit'{
local sort "`sort' it`i'"
forvalues j=1/`nbmoda_`i''{
replace i`i'c`j'=i`i'c`j'*P
}
}
forvalues i=1/`nbscore'{
replace score`i'=score`i'*P
}
save `matU1', replace
/* Matrices U */
noi di "U matrix computation"
local order ""
forvalues i=1/`=wordcount("`list'")'{
tempfile b`i'_1
local nbscoreg`i'= `nbscore'
forvalues j=0/`=`nbscore'-1'{
if `j'>`limsup`i'' | `j'<=`liminf`i''{
local nbscoreg`i'=`nbscoreg`i''-1
capture drop s`=`j'+1'g`i'
}
}
local order "`order' *g`i'"
use `matU1', replace
keep if score<=`limsup`i'' & score>`liminf`i''
gen g=`i'
forvalues a=1/`nbit'{
forvalues b=1/`nbmoda_`a''{
capture rename i`a'c`b' i`a'c`b'g`i'
}
}
forvalues a=1/`nbscore'{
capture rename score`a' s`a'g`i'
forvalues j=1/`=wordcount("`list'")'{
if `=`a'-1'>`limsup`i'' | `=`a'-1' <= `liminf`i''{
capture drop s`a'g`j'
}
}
}
tempfile bloc`i'
sort `sort'
save `b`i'_1', replace
}
local order ""
forvalues i=1/`=wordcount("`list'")'{
tempfile b`i'_2
local order "`order' *g`i'"
use `matU2', replace
keep if score<=`limsup`i'' & score>`liminf`i''
gen g=`i'
forvalues a=1/`nbit'{
forvalues b=1/`nbmoda_`a''{
capture rename i`a'c`b' i`a'c`b'g`i'b
}
}
forvalues a=1/`nbscore'{
capture rename score`a' s`a'g`i'b
forvalues j=1/`=wordcount("`list'")'{
if `=`a'-1'>`limsup`i'' | `=`a'-1' <= `liminf`i''{
capture drop s`a'g`j'
}
}
}
sort `sort'
save `b`i'_2', replace
describe
local mat_`i'=r(k)-3-`nbit'
}
noi di "W matrix computation"
/* Matrice W */
local nbscoreg0=0
forvalues g=1/`nbgroup'{
tempname W_`g'i W_`g'
tempfile b`g'_2b
qui q memory
if `mat_`g''>r(matsize) & `mat_`g''<=r(m_matsize){
set matsize `mat_`g''
}
if `mat_`g''>r(m_matsize){
noi di in red "Error, not enough memory to allocate to the W matrix computation"
}
matrix `W_`g''=J(`mat_`g'',`mat_`g'',.)
use `b`g'_2', replace
local count=1
forvalues i=1/`nbit'{
forvalues j=1/`nbmoda_`i''{
rename i`i'c`j'g`g'b v`count'b
local count=`count'+1
}
}
forvalues s=1/`=`nbscore'+1'{
capture rename s`s'g`g'b v`count'b
if _rc ==0{
local count=`count'+1
}
}
local Ncol_`g'_=`count'-1
save `b`g'_2b', replace
use `b`g'_1', replace
local count=1
forvalues i=1/`nbit'{
forvalues j=1/`nbmoda_`i''{
rename i`i'c`j'g`g' v`count'
local count=`count'+1
}
}
forvalues s=1/`=`nbscore'+1'{
capture rename s`s'g`g' v`count'
if _rc ==0{
local count=`count'+1
}
}
local Ncol_`g'__=`count'-1
forvalues i=1/`=`count'-1'{
replace v`i'=P if round(v`i',0.000001)!=round(0,0.000001)
}
local countW_`g'=`count'-1
merge `sort' using `b`g'_2b'
drop _merge
forvalues i=1/`mat_`g''{
forvalues j=1/`mat_`g''{
gen prod=v`i'*v`j'b
qui su prod
matrix `W_`g''[`i',`j']=r(sum)
drop prod
}
}
capture matrix `W_`g'i'=invsym(`W_`g'')
if _rc!=0{
capture matrix `W_`g'i'=inv(`W_`g'')
}
if _rc!=0{
noi di in red "Error while computing the Wg matrix"
}
tempname A rank_
mata: `A'=J(1,1,.)
mata: `A'[1,1]=rank(st_matrix("`W_`g''"))
mata: st_matrix("`rank_'",`A')
local rank`g'=`rank_'[1,1]
}
/* Matrice poid */
forvalues g=1/`nbgroup'{
tempfile bddSe`g' b`g'_2bi
use `bdd_seg', replace
keep if g==`g'
gen Pd=1
contract `sort', f(nb)
sort `sort'
save `bddSe`g'', replace
use `b`g'_2b', replace
sort `sort'
merge `sort' using `bddSe`g''
drop _merge
replace nb=0 if nb==.
gen nbth=P*`N'
gen Di=(nb-nbth)/sqrt(`N')
sort `sort'
save `b`g'_2bi', replace
if `countW_`g''>10{
set matsize `countW_`g''
}
else{
set matsize 10
}
tempname deviation_`g'
matrix `deviation_`g''=J(`countW_`g'',1,.)
use `b`g'_2bi', replace
gen Pobs=nb/`N'
gen Diff=Pobs-P
forvalues j=1/`countW_`g''{
replace v`j'b=v`j'b*Diff
su v`j'b
matrix `deviation_`g''[`j', 1]=r(sum)*sqrt(`N')
}
}
local sum=0
local ddl=0
local rank ""
qui q memory
if `matsizeini'>r(matsize) & 10000 > r(m_matsize){
set matsize `matsizeini'
}
else{
set matsize 10000
}
tempname graphContribPond
matrix `graphContribPond'=J(`nbgroup',2,.)
forvalues g=1/`nbgroup'{
tempname G_`g'
capture matrix `G_`g''=`deviation_`g'''*`W_`g'i'*`deviation_`g''
if _rc!=0{
noi di in red "Error, not enought memory to allocate to the W matrix computation
}
local sum=`sum'+`G_`g''[1,1]
local ddl=`ddl'+`rank`g''
local rank "`rank'`rank`g'' "
matrix `graphContribPond'[`g',1]=`g'
matrix `graphContribPond'[`g',2]=`G_`g''[1,1]
}
local ddl=`ddl'-`ordre'-1
set matsize `matsizeini'
}
local R1m_group "`list'"
local R1m_Rank `rank'
local R1M_ddl=`ddl'
local R1M_stat=`sum'*`propFit'
local R1M_p=`=1-chi2(`ddl', `R1M_stat')'
/*************************************/
/* tests Si */
/*************************************/
if `nbitsuf'==1 & "`sitest'"!=""{
qui{
local countbase=0
forvalues ii=1/`nbit'{
forvalues j=1/`nbmoda_`ii''{
local countbase=`countbase'+1
}
}
forvalues s=1/`nbscore'{
local countbase=`countbase'+1
}
tempname DGibase
matrix `DGibase'=J(6,`countbase',.)
use `bdd_seg', replace
local countbase=0
forvalues ii=1/`nbit'{
tab it`ii', gen(i`ii'c)
forvalues j=1/`nbmoda_`ii''{
local countbase=`countbase'+1
matrix `DGibase'[2,`countbase']=`ii'
matrix `DGibase'[3,`countbase']=`j'
su i`ii'c`j'
matrix `DGibase'[4,`countbase']=r(sum)
}
drop i`ii'c*
}
tab score, gen(s)
forvalues s=1/`nbscore'{
capture su s`s'
if _rc!=0{
gen s`s'=0
}
}
forvalues s=1/`nbscore'{
local countbase=`countbase'+1
matrix `DGibase'[2,`countbase']=`s'
su s`s'
matrix `DGibase'[4,`countbase']=r(sum)
}
use `matU2', replace
local countbase=0
forvalues ii=1/`nbit'{
forvalues j=1/`nbmoda_`ii''{
local countbase=`countbase'+1
su P if i`ii'c`j'==1
matrix `DGibase'[5,`countbase']=r(sum)*`N'
matrix `DGibase'[6,`countbase']=(`DGibase'[4,`countbase']-`DGibase'[5,`countbase'])/sqrt(`N')
}
}
forvalues s=1/`nbscore'{
local countbase=`countbase'+1
su P if score`s'==1
matrix `DGibase'[5,`countbase']=r(sum)*`N'
matrix `DGibase'[6,`countbase']=(`DGibase'[4,`countbase']-`DGibase'[5,`countbase'])/sqrt(`N')
}
local colbase=`countbase'
}
forvalues i=1/`nbit'{
tempfile mU2_`i' mU_`i'
noi di in gr "Performing Si test for the `i'th item"
qui{
use `matU2', replace
gen g=.
local liminf1=-1
forvalues g=1/`nbgroup'{
replace g=`g' if score<=`limsup`g'' & score>`liminf`g''
}
forvalues g=1/`nbgroup'{
forvalues j=1/`nbmoda_`i''{
gen testi`i'c`j'g`g'=0
replace testi`i'c`j'g`g'=i`i'c`j' if g==`g'
}
}
local count=1
forvalues ii=1/`nbit'{
forvalues j=1/`nbmoda_`ii''{
rename i`ii'c`j' v`count'b
local count=`count'+1
}
}
forvalues s=1/`=`nbscore'+1'{
capture rename score`s' v`count'b
if _rc ==0{
local count=`count'+1
}
}
forvalues g=1/`nbgroup'{
forvalues j=1/`nbmoda_`i''{
rename testi`i'c`j'g`g' v`count'b
local count=`count'+1
}
}
local nbarrive`i'=`count'-1
sort `sort'
save `mU2_`i'', replace
use `matU1', replace
gen g=.
local liminf1=-1
forvalues g=1/`nbgroup'{
replace g=`g' if score<=`limsup`g'' & score>`liminf`g''
}
forvalues g=1/`nbgroup'{
forvalues j=1/`nbmoda_`i''{
gen testi`i'c`j'g`g'=0
replace testi`i'c`j'g`g'=i`i'c`j' if g==`g'
}
}
local count=1
forvalues ii=1/`nbit'{
forvalues j=1/`nbmoda_`ii''{
rename i`ii'c`j' v`count'
local count=`count'+1
}
}
forvalues s=1/`=`nbscore'+1'{
capture rename score`s' v`count'
if _rc ==0{
local count=`count'+1
}
}
forvalues g=1/`nbgroup'{
forvalues j=1/`nbmoda_`i''{
rename testi`i'c`j'g`g' v`count'
local count=`count'+1
}
}
sort `sort'
merge `sort' using `mU2_`i''
drop _merge
if `nbarrive`i''>r(matsize) & `nbarrive`i''<=r(m_matsize){
set matsize `nbarrive`i''
}
if `nbarrive`i''>r(m_matsize){
noi di in red "Error, not enought memory to allocate to the W matrix computation"
}
tempname i`i'W
matrix `i`i'W'=J(`nbarrive`i'',`nbarrive`i'',0)
if `=`nbarrive`i''*`nbarrive`i'''>3000{
noi di in gr "----|---25%---|---50%---|---75%---|---100%
qui _dots 0, title(Loop computation of theorical probabilities of each response pattern) reps(40)
local percentcount=0
local countS=1
}
forvalues ii=1/`nbarrive`i''{
su v`ii'
if r(max)>=0.000001{
forvalues j=1/`nbarrive`i''{
gen prod=v`ii'*v`j'b
qui su prod
matrix `i`i'W'[`ii',`j']=r(sum)
drop prod
if `=`nbarrive`i''*`nbarrive`i'''>3000{
local percentcountplus=floor(`countS'*40/`=`nbarrive`i''*`nbarrive`i''')
forvalues percen=`=`percentcount'+1'/`percentcountplus'{
nois _dots `percen' 0
}
local percentcount=`percentcountplus'
local countS=`countS'+1
}
}
}
else{
if `=`nbarrive`i''*`nbarrive`i'''>3000{
local percentcountplus=floor((`countS'+`nbarrive`i''-1)*40/`=`nbarrive`i''*`nbarrive`i''')
forvalues percen=`=`percentcount'+1'/`percentcountplus'{
nois _dots `percen' 0
}
local percentcount=`percentcountplus'
local countS=`countS'+`nbarrive`i''
}
}
}
if `=`nbarrive`i''*`nbarrive`i'''>3000{
noi di ""
}
tempname i`i'Wi
capture matrix `i`i'Wi'=invsym(`i`i'W')
if _rc!=0{
capture matrix `i`i'Wi'=inv(`i`i'W')
}
if _rc!=0{
noi di in red "Error while computing the Wg matrix"
}
tempname A rank_
mata: `A'=J(1,1,.)
mata: `A'[1,1]=rank(st_matrix("`i`i'W'"))
mata: st_matrix("`rank_'",`A')
local i`i'rank=`rank_'[1,1]
tempname plus`i' DGi_`i' DGi`i'_a DGi`i'_b DGi_`i'_v2
matrix `plus`i''=J(6,`=`nbarrive`i''-`colbase'',.)
matrix `DGi_`i''=`DGibase',`plus`i''
matrix `DGi`i'_a'=J(1,`=colsof(`DGibase')',0)
matrix `DGi`i'_b'=J(1,`=`nbarrive`i''-`colbase'',.)
matrix `DGi_`i'_v2'=`DGi`i'_a',`DGi`i'_b'
save `mU_`i'', replace
local count=`colbase'
use `bdd_seg', replace
tab it`i', gen(i`i'c)
forvalues g=1/`nbgroup'{
forvalues j=1/`nbmoda_`i''{
local count=`count'+1
matrix `DGi_`i''[2,`count']=`i'
matrix `DGi_`i''[3,`count']=`j'
matrix `DGi_`i''[1,`count']=`g'
su i`i'c`j' if g==`g'
matrix `DGi_`i''[4,`count']=r(sum)
}
}
use `mU_`i'', replace
forvalues t=`=`colbase'+1'/`nbarrive`i''{
su P if v`t'b==1
matrix `DGi_`i''[5,`t']=r(sum)*`N'
matrix `DGi_`i''[6,`t']=(`DGi_`i''[4,`t']-`DGi_`i''[5,`t'])/sqrt(`N')
matrix `DGi_`i'_v2'[1,`t']=(`DGi_`i''[4,`t']-`DGi_`i''[5,`t'])/sqrt(`N')
}
set matsize `matsizeini'
tempname tDGi_`i' tDGi_`i'_v2 G G_v2
matrix `tDGi_`i''=`DGi_`i''[6,1..`=colsof(`DGi_`i'')']'
matrix `tDGi_`i'_v2'=`DGi_`i'_v2''
matrix `G'=`tDGi_`i'''*`i`i'Wi'*`tDGi_`i''
matrix `G_v2'=`tDGi_`i'_v2''*`i`i'Wi'*`tDGi_`i'_v2'
local sum=`G'[1,1]
local sum_v2=`G_v2'[1,1]
local rank "`i`i'rank'"
local ddl=(`nbgroup'-1)*(`nbmoda_`i''-1)
}
local S`i'_rank=`rank'
local S`i'_ddl=`ddl'
local S`i'_stat=`sum'*`propFit'
local S`i'_p=`=1-chi2(`S`i'_ddl', `S`i'_stat')'
}
}
/* Graphs : */
if "`graphics'"!=""{
noi di ""
noi di ""
noi di in gr "Graphics:"
tempfile graph
qui{
local debut=1
local fin=1
forvalues i=1/`nbit'{
local fin=`fin'+`nbmoda_`i''-2
tempname it`i'
matrix `it`i''=`Edelta'[1,`debut'..`fin']
local fin=`fin'+1
local debut=`debut'+`nbmoda_`i''-1
}
clear
use `bdd_se', replace
local scmin=1
local scmax=-1
forvalues i=1/`nbit'{
local scmax=`scmax'+`nbmoda_`i''-1
}
gen select=score<=`scmin'
su score if select==1
local scorereel_scmin=r(mean)
replace select=score>=`scmax'
su score if select==1
local scorereel_scmax=r(mean)
replace score=`scmin' if score<`scmin'
replace score=`scmax' if score>`scmax'
tab score, matcell(matname)
local tottab=r(N)
clear
set obs 2000
gen theta=_n/100-10
gen scoreth=0
forvalues i=1/`nbit'{
tempname D`i'
matrix `D`i''=J(1,`nbmoda_`i'',0)
gen eV`i'_0=1
gen SeV`i'=1
forvalues j=1/`=`nbmoda_`i''-1'{
matrix `D`i''[1,`=`j'+1']=`it`i''[1,`j']+`D`i''[1,`j']
gen eV`i'_`j'=exp(`j'*theta-`D`i''[1,`=`j'+1'])
replace SeV`i'=SeV`i'+eV`i'_`j'
}
gen p`i'_0=eV`i'_0/SeV`i'
forvalues j=1/`=`nbmoda_`i''-1'{
gen p`i'_`j'=eV`i'_`j'/SeV`i'
replace scoreth=scoreth+(eV`i'_`j'/SeV`i')*`j'
}
}
drop e* S* p*
su scoreth
local scmin=ceil(r(min))
local scmax=floor(r(max))
gen sc=abs(scoreth-`scorereel_scmin')
sort sc
local valini_`scmin'=theta[1]
drop sc
gen sc=abs(scoreth-`scorereel_scmax')
sort sc
local valini_`scmax'=theta[1]
drop sc
tempname scoretheta
matrix `scoretheta'=J(2,`scmax',.)
forvalues i=`=`scmin'+1'/`=`scmax'-1'{
matrix `scoretheta'[1,`i']=`i'
gen sc=abs(scoreth-`i')
sort sc
local valini_`i'=theta[1]
drop sc
}
matrix `scoretheta'[1,1]=`scorereel_scmin'
matrix `scoretheta'[1,`scmax']=`scorereel_scmax'
forvalues i=1/`scmax'{
matrix `scoretheta'[2,`i']=`valini_`i''
}
tempfile graphscthscobstheta
save `graphscthscobstheta', replace
clear
use `bdd_se', replace
gen select=score<=`scmin'
su score if select==1
local scorereel_scmin=r(mean)
replace select=score>=`scmax'
su score if select==1
local scorereel_scmax=r(mean)
replace score=`scmin' if score<`scmin'
replace score=`scmax' if score>`scmax'
drop g
forvalues i=1/`nbit'{
gen rep`i' = it`i'
drop it`i'
}
contract rep1-rep`nbit' score, f(wt2)
gen id=_n
reshape long rep, i(id) j(it)
drop if rep==.
gen obs=_n
forvalues i=1/`nbit'{
expand `nbmoda_`i'' if it==`i'
}
by obs, sort: gen `x'=_n-1
gen choix=rep==`x'
rename it item
tab item, gen(it)
forvalues i=1/`nbit'{
forvalues g=1/`=`nbmoda_`i''-1'{
gen d_i`i'_m`g'=(-1)*it`i'*(`x'>=`g')
}
}
gen difficulties=0
forvalues i=1/`nbit'{
forvalues g=1/`=`nbmoda_`i''-1'{
replace difficulties=difficulties+`it`i''[1,`g']*d_i`i'_m`g'
}
}
tab score, gen(score__) matrow(nom)
local nbmodscore=r(r)
forvalues k=1/`nbmodscore'{
replace score__`k'=`x' if score__`k'==1
local ident=nom[`k',1]
if `k'==1{
local ident1=`ident'
}
rename score__`k' score_`ident'
}
eq slope: `x'
noi di in gr "Performing graphics"
use `graphscthscobstheta', replace
gen sc=abs(scoreth-`scorereel_scmin')
sort sc
local limginf=theta[1]-1.5
drop sc
gen sc=abs(scoreth-`scorereel_scmax')
sort sc
local limgsup=theta[1]+1.5
drop sc
drop if theta<`limginf' | theta>`limgsup'
capture graph drop Obs_vs_Exp_LT
capture graph drop MAP
capture graph drop Score_Distrib
capture graph drop Contrib
twoway (line scoreth theta, sort) , ytitle(Score) xtitle(Latent trait) title("Expected scores depending on individual latent traits", size(medium)) scheme(s2mono) graphregion(fcolor(white) ifcolor(white)) name("LT_Sc", replace)
tempfile gEO
graph save `gEO', replace
if "`filegraph'"!=""{
graph save "`filegraph'_LT_Sc", replace
}
clear
set obs `=int(`=rowsof(matname)+colsof(`Edelta')'+0.1)'
gen theta=.
gen diff=0
gen freq=.
forvalues i=1/`=rowsof(matname)'{
replace theta=`scoretheta'[2,`i'] if _n==`i'
replace freq=matname[`i',1]/`tottab' if _n==`i'
}
su freq
local tadatzouinzou=-r(max)/8
forvalues i=1/`=colsof(`Edelta')'{
replace theta=`Edelta'[1,`i'] if _n==`i'+`=rowsof(matname)'
replace freq=`tadatzouinzou' if _n==`i'+`=rowsof(matname)'
replace diff=1 if _n==`i'+`=rowsof(matname)'
}
sort diff theta
bysort diff: replace freq=freq-(`tadatzouinzou'/5) if theta<theta[_n-1]+0.08 & diff==1 & _n!=1
replace theta=round(theta,0.01)
compress
sort theta
save `graph', replace
su theta
local mininf=round(`=r(min)-(r(max)-r(min))/4',0.01)
local maxinf=round(`=r(max)+(r(max)-r(min))/4',0.01)
clear
set obs `=int(`=(`maxinf'-`mininf')*100'+0.1)'
gen theta=round(_n/100+`mininf',0.01)
compress
sort theta
merge theta using `graph'
drop _merge
forvalues i=1/`nbit'{
tempname D`i'
matrix `D`i''=J(1,`nbmoda_`i'',0)
gen eV`i'_0=1
gen SeV`i'=1
forvalues j=1/`=`nbmoda_`i''-1'{
matrix `D`i''[1,`=`j'+1']=`it`i''[1,`j']+`D`i''[1,`j']
gen eV`i'_`j'=exp(`j'*theta-`D`i''[1,`=`j'+1'])
replace SeV`i'=SeV`i'+eV`i'_`j'
}
gen p`i'_0=eV`i'_0/SeV`i'
forvalues j=1/`=`nbmoda_`i''-1'{
gen p`i'_`j'=eV`i'_`j'/SeV`i' + p`i'_`=`j'-1'
}
drop eV* SeV*
}
gen L=1
forvalues i=1/`nbit'{
forvalues j=0/`=`nbmoda_`i''-1'{
replace L=L*p`i'_`j'
}
}
sort theta
replace L=ln(L)
gen d1=.
replace d1=(L-L[_n-1])/(theta-theta[_n-1]) if _n>1
gen d2=.
replace d2=(d1-d1[_n-1])/(theta-theta[_n-1]) if _n>1
replace d2=-d2
su freq
local freqmin=r(min)
local freqmax=r(max)
su d2
local d2max=r(max)
local d2min=`d2max'*`freqmax'/`freqmin'
label variable freq "Freq. (%)"
label variable d2 "Information"
sort theta
twoway (spike freq theta if diff==0, lwidth(thick) horizontal xscale(alt axis(1)) ) (scatter theta freq if diff==1,mcolor(black) msymbol(plus)) (line theta d2, xaxis(2) xscale(alt axis(2))) , yscale(noline) ylabel(#5, angle(horizontal)) xscale(range(`freqmin' `freqmax') axis(1)) xscale(reverse range(`d2min' `d2max') axis(2)) yscale(range(`mininf' `maxinf')) xline(0) xlabel(0 (0.05) `freqmax') title(, size(medium)) legend(order(1 "Persons" 2 "Thresholds location" 3 "Information curve") cols(1) size(small)) scheme(s2mono) graphregion(fcolor(white) ifcolor(white)) ytitle(Latent trait) title(MAP) name("MAP", replace)
tempfile gMAP
graph save `gMAP', replace
if "`filegraph'"!=""{
graph save "`filegraph'_MAP", replace
}
clear
use "`dataR1m'"
keep score P
collapse (sum) P, by(score)
sort score
save `bdd_G', replace
clear
use "`datatest'"
keep `varlist'
tempname dm SumScore
egen `dm'=rowmiss(`varlist')
replace `dm'=`dm'>0
keep if `dm'==0
tempname SumScore
egen `SumScore'=rowtotal(`varlist')
gen Pobs=1
rename `SumScore' score
keep Pobs score
local tot=_N
collapse (sum) Pobs, by(score)
replace Pobs=Pobs/`tot'
sort score
merge 1:1 score using `bdd_G'
gen g=.
drop _merge
sort g
save `bdd_G', replace
clear
svmat `graphContribPond'
rename `graphContribPond'1 g
rename `graphContribPond'2 Contrib
sort g
merge g using `bdd_G'
su Contrib
replace Contrib=Contrib/r(sum)
capture label drop g
local liminf1=-1
forvalues i=1/`nbgroup'{
local limsup`i'=real("`=word("`list'",`i')'")
if `i'>1{
local liminf`i'=real("`=word("`list'",`=`i'-1')'")
}
replace g=`i' if score<=`limsup`i'' & score>`liminf`i''
if `i'==1{
label define g `i' "[0;`limsup`i'']"
}
else if `i' == `nbgroup'{
label define g `i' "]`liminf`i'';`=`nbscore'-1']", a
}
else{
label define g `i' "]`liminf`i'';`limsup`i'']", a
}
}
label values g g
gen nb=P*`EN'
su score [iweight=nb]
local MoyThScore=r(mean)
local SdThScore=r(sd)
gen nbObs=Pobs*`EN'
su score [iweight=nbObs]
local MoyObsScore=r(mean)
local SdObdcore=r(sd)
drop _merge
tempfile BDD
sort score
save `BDD', replace
clear
set obs `=(`=r(max)'+2)*100'
gen score=(_n/100)-1
gen p=normalden(score,`MoyThScore',`SdThScore')
gen pobs=normalden(score,`MoyObsScore',`SdObdcore')
sort score
merge score using `BDD'
gen score1=score if Pobs!=.
gen scorep=score1-0.15
gen scorep2=score1+0.15
twoway (bar Pobs scorep, horizontal barwidth(0.3)) (bar P scorep2, horizontal barwidth(0.3)) (line score p, lpattern(solid)lcolor(black)) (line score pobs, lpattern(vshortdash) lcolor(gs12)), yscale(reverse) scheme(s2mono) xtitle(%) xscale(range(0 0.01)) xlabel(#5) legend(order(1 "% observed" 3 "" 2 "% expected" 4 "") cols(2) size(small)) title("Observed and expected" "scores distribution", size(medium)) graphregion(fcolor(white)) name("Score_Distrib", replace)
tempfile gTS
graph save `gTS', replace
if "`filegraph'"!=""{
graph save "`filegraph'_totscore", replace
}
graph hbar (sum) Pobs P Contrib, over(g) yvaroptions(relabel(1 "% observed" 2 "% expected" 3 "% R1m contribution") label(labcolor(none) labsize(zero))) title("Groups contribution to" "the R1m statistic", size(medium)) legend(cols(1) size(small)) ytitle("%") scheme(s2mono) graphregion(fcolor(white)) bar(3, fcolor(black)) bar(1, fcolor(gs8)) bar(2, fcolor(gs13)) name("Contrib", replace)
tempfile gSG
graph save `gSG', replace
if "`filegraph'"!=""{
graph save "`filegraph'_scoregp", replace
}
}
}
tempname globalFit itemFit
matrix `globalFit'=(`R1M_stat',`R1M_ddl',`R1M_p')
if `nbitsuf'==1 & "`sitest'"!=""{
matrix itemFit=J(`nbit',3,.)
forvalues i=1/`nbit'{
matrix itemFit[`i',1]=`S`i'_stat'
matrix itemFit[`i',2]=`S`i'_ddl'
matrix itemFit[`i',3]=`S`i'_p'
}
}
if "`alpha'"==""{
local alpha=0.05
}
tempname g it r Power bB cC Discriminant
matrix `g'=`globalFit'
if `nbitsuf'==1 & "`sitest'"!=""{
matrix `it'=itemFit
}
if "`nfit'"==""{
local `r'=1
}
else{
local `r'=`NbIdFit'/`nfit'
}
local `g'_t=`g'[1,1]*``r''
if `g'[1,2]<=200{
local `Power'_t_R1m= 1-nchi2(`g'[1,2],``g'_t',invchi2tail(`g'[1,2],`alpha'))
}
else{
local `Power'_t_R1m=1-(normal((invchi2tail(`g'[1,2],`alpha')-(`g'[1,2]+``g'_t'))/sqrt(2*(`g'[1,2]+2*``g'_t'))))
}
if `nbitsuf'==1 & "`sitest'"!=""{
forvalues i=1/`nbit'{
local `it'_`i'_t=`it'[`i',1]*``r''
if `it'[`i',2]>200 | ``it'_`i'_t'>1000{
local `Power'_t_S`i'=1-(normal((invchi2tail(`it'[`i',2],`alpha')-(`it'[`i',2]+``it'_`i'_t'))/sqrt(2*(`it'[`i',2]+2*``it'_`i'_t'))))
}
else{
local `Power'_t_S`i'= 1-nchi2(`it'[`i',2],``it'_`i'_t',invchi2tail(`it'[`i',2],`alpha'))
}
}
}
if "`nfit'"!=""{
local `r'_2=``r''*`nfit'/`NbIdFit'
local `g'_newN=`g'[1,1]*``r'_2'
if `g'[1,2]<=200{
local `Power'_newN_R1m= 1-nchi2(`g'[1,2],``g'_newN',invchi2tail(`g'[1,2],`alpha'))
}
else{
local `Power'_newN_R1m=1-(normal((invchi2tail(`g'[1,2],`alpha')-(`g'[1,2]+``g'_newN'))/sqrt(2*(`g'[1,2]+2*``g'_newN'))))
}
if `nbitsuf'==1 & "`sitest'"!=""{
forvalues i=1/`nbit'{
local `it'_`i'_newN=`it'[`i',1]*``r'_2'
if `it'[`i',2]>200 | ``it'_`i'_newN'>1000{
local `Power'_newN_S`i'=1-(normal((invchi2tail(`it'[`i',2],`alpha')-(`it'[`i',2]+``it'_`i'_newN'))/sqrt(2*(`it'[`i',2]+2*``it'_`i'_newN'))))
}
else{
local `Power'_newN_S`i'= 1-nchi2(`it'[`i',2],``it'_`i'_newN',invchi2tail(`it'[`i',2],`alpha'))
}
}
}
}
if "`power'"!=""{
if `g'[1,2]<=200{
local `g'_newP=npnchi2(`=`g'[1,2]',`=invchi2tail(`=`g'[1,2]',`alpha')',`=1-`power'')
}
else{
local `bB'=2*`=`g'[1,2]'-2*`=invchi2tail(`=`g'[1,2]',`alpha')'-4*(invnormal(`=1-0.8'))^2
local `cC'=(`=invchi2tail(`=`g'[1,2]',`alpha')')^2-2*`=`g'[1,2]'*`=invchi2tail(`=`g'[1,2]',`alpha')'+(`=`g'[1,2]')^2-2*`=`g'[1,2]'*(invnormal(`=1-0.8'))^2
local `Discriminant'=(``bB'')^2-4*``cC''
local `g'_newP=(sqrt(``Discriminant'')-``bB'')/2
}
local `r'_3=``g'_newP'/``g'_t'
if `nbitsuf'==1 & "`sitest'"!=""{
forvalues i=1/`nbit'{
local `it'_`i'_newP=``it'_`i'_t'*``r'_3'
if `it'[`i',2]>200 | ``it'_`i'_newP'>1000{
local `Power'_newP_S`i'=1-(normal((invchi2tail(`it'[`i',2],`alpha')-(`it'[`i',2]+``it'_`i'_newP'))/sqrt(2*(`it'[`i',2]+2*``it'_`i'_newP'))))
}
else{
local `Power'_newP_S`i'= 1-nchi2(`it'[`i',2],``it'_`i'_newP',invchi2tail(`it'[`i',2],`alpha'))
}
}
}
}
}
/*************************************/
/* print */
/*************************************/
di ""
di ""
di in gr "Global tests of the fit : test R1m"
di in gr " groups : " in ye "`R1m_group'"
di in gr " Number of individuals with missing data : " in ye "`nbmissing' " in gr "(" in ye "`=round(`=`percentmissing'*100',0.01)'%" in gr ")"
di ""
if "`nfit'"!="" & "`power'"!=""{
di in gr "{hline 90}"
di _col(30) in gr "N = " in ye %6.0f `NbIdFit' _col(53) in gr "N = " in ye %6.0f `nfit' _col(76) in gr "N = " in ye %6.0f `=ceil(`NbIdFit'*``r'_3')'
di _col(16) in gr "df" _col(26) in gr "R1m" _col(32) in gr "p-val" _col(39) in gr "Power" _col(49) in gr "R1m" _col(55) in gr "p-val" _col(62) in gr "Power" _col(72) in gr "R1m" _col(78) in gr "p-val" _col(85) in gr "Power"
di in gr "{hline 90}"
di _col(3) in gr "R1m" _col(14) in ye %4.0f `R1M_ddl' _col(23) in ye %6.1f ``g'_t' _col(32) in ye %5.4f `=1-chi2(`=`g'[1,2]', ``g'_t')' _col(39) in ye %5.4f ``Power'_t_R1m' _col(46) in ye %6.1f ``g'_newN' _col(55) in ye %5.4f `=1-chi2(`=`g'[1,2]', ``g'_newN')' _col(62) in ye %5.4f ``Power'_newN_R1m' _col(69) in ye %6.1f ``g'_newP' _col(78) in ye %5.4f `=1-chi2(`=`g'[1,2]', ``g'_newP')' _col(85) in ye %5.4f `power'
di in gr "{hline 90}"
di in gr ""
if `nbitsuf'==1 & "`sitest'"!=""{
di in gr "Items specific tests of the fit : tests Si"
di in gr ""
di in gr "{hline 90}"
di _col(30) in gr "N = " in ye %6.0f `NbIdFit' _col(53) in gr "N = " in ye %6.0f `nfit' _col(76) in gr "N = " in ye %6.0f `=ceil(`NbIdFit'*``r'_3')'
di _col(1) in gr "Item" _col(16) in gr "df" _col(27) in gr "Si" _col(32) in gr "p-val" _col(39) in gr "Power" _col(50) in gr "Si" _col(55) in gr "p-val" _col(62) in gr "Power" _col(73) in gr "Si" _col(78) in gr "p-val" _col(85) in gr "Power"
di in gr "{hline 90}"
forvalues i=1/`nbit'{
di _col(1) in gr "``i'' :" _col(14) in ye %4.0f `S`i'_ddl' _col(23) in ye %6.1f ``it'_`i'_t' _col(32) in ye %5.4f `=1-chi2(`=`it'[`i',2]', ``it'_`i'_t')' _col(39) in ye %5.4f ``Power'_t_S`i'' _col(46) in ye %6.1f ``it'_`i'_newN' _col(55) in ye %5.4f `=1-chi2(`=`it'[`i',2]', ``it'_`i'_newN')' _col(62) in ye %5.4f ``Power'_newN_S`i'' _col(69) in ye %6.1f ``it'_`i'_newP' _col(78) in ye %5.4f `=1-chi2(`=`it'[`i',2]', ``it'_`i'_newP')' _col(85) in ye %5.4f ``Power'_newP_S`i''
di in gr "{hline 90}"
}
}
}
else if "`nfit'"!=""{
di in gr "{hline 67}"
di _col(30) in gr "N = " in ye %6.0f `NbIdFit' _col(53) in gr "N = " in ye %6.0f `nfit'
di _col(16) in gr "df" _col(26) in gr "R1m" _col(32) in gr "p-val" _col(39) in gr "Power" _col(49) in gr "R1m" _col(55) in gr "p-val" _col(62) in gr "Power"
di in gr "{hline 67}"
di _col(3) in gr "R1m" _col(14) in ye %4.0f `R1M_ddl' _col(23) in ye %6.1f ``g'_t' _col(32) in ye %5.4f `=1-chi2(`=`g'[1,2]', ``g'_t')' _col(39) in ye %5.4f ``Power'_t_R1m' _col(46) in ye %6.1f ``g'_newN' _col(55) in ye %5.4f `=1-chi2(`=`g'[1,2]', ``g'_newN')' _col(62) in ye %5.4f ``Power'_newN_R1m'
di in gr "{hline 67}"
di in gr ""
if `nbitsuf'==1 & "`sitest'"!=""{
di in gr "Items specific tests of the fit : tests Si"
di in gr ""
di in gr "{hline 67}"
di _col(30) in gr "N = " in ye %6.0f `NbIdFit' _col(53) in gr "N = " in ye %6.0f `nfit'
di _col(1) in gr "Item" _col(17) in gr "df" _col(26) in gr "Si" _col(32) in gr "p-val" _col(39) in gr "Power" _col(50) in gr "Si" _col(55) in gr "p-val" _col(62) in gr "Power"
di in gr "{hline 67}"
forvalues i=1/`nbit'{
di _col(1) in gr "``i'' :" _col(14) in ye %4.0f `S`i'_ddl' _col(23) in ye %6.1f ``it'_`i'_t' _col(32) in ye %5.4f `=1-chi2(`=`it'[`i',2]', ``it'_`i'_t')' _col(39) in ye %5.4f ``Power'_t_S`i'' _col(46) in ye %6.1f ``it'_`i'_newN' _col(55) in ye %5.4f `=1-chi2(`=`it'[`i',2]', ``it'_`i'_newN')' _col(62) in ye %5.4f ``Power'_newN_S`i''
di in gr "{hline 90}"
}
}
}
else if "`power'"!=""{
di in gr "{hline 67}"
di _col(30) in gr "N = " in ye %6.0f `NbIdFit' _col(53) in gr "N = " in ye %6.0f `=ceil(`NbIdFit'*``r'_3')'
di _col(16) in gr "df" _col(26) in gr "R1m" _col(32) in gr "p-val" _col(39) in gr "Power" _col(49) in gr "R1m" _col(55) in gr "p-val" _col(62) in gr "Power"
di in gr "{hline 67}"
di _col(3) in gr "R1m" _col(14) in ye %4.0f `R1M_ddl' _col(23) in ye %6.1f ``g'_t' _col(32) in ye %5.4f `=1-chi2(`=`g'[1,2]', ``g'_t')' _col(39) in ye %5.4f ``Power'_t_R1m' _col(46) in ye %6.1f ``g'_newP' _col(55) in ye %5.4f `=1-chi2(`=`g'[1,2]', ``g'_newP')' _col(62) in ye %5.4f `power'
di in gr "{hline 67}"
di in gr ""
if `nbitsuf'==1 & "`sitest'"!=""{
di in gr "Items specific tests of the fit : tests Si"
di in gr ""
di in gr "{hline 67}"
di _col(30) in gr "N = " in ye %6.0f `NbIdFit' _col(53) in gr "N = " in ye %6.0f `=ceil(`NbIdFit'*``r'_3')'
di _col(1) in gr "Item" _col(16) in gr "df" _col(27) in gr "Si" _col(32) in gr "p-val" _col(39) in gr "Power" _col(50) in gr "Si" _col(55) in gr "p-val" _col(62) in gr "Power"
di in gr "{hline 67}"
forvalues i=1/`nbit'{
di _col(1) in gr "``i'' :" _col(14) in ye %4.0f `S`i'_ddl' _col(23) in ye %6.1f ``it'_`i'_t' _col(32) in ye %5.4f `=1-chi2(`=`it'[`i',2]', ``it'_`i'_t')' _col(39) in ye %5.4f ``Power'_t_S`i'' _col(46) in ye %6.1f ``it'_`i'_newP' _col(55) in ye %5.4f `=1-chi2(`=`it'[`i',2]', ``it'_`i'_newP')' _col(62) in ye %5.4f ``Power'_newP_S`i''
di in gr "{hline 67}"
}
}
}
else{
di in gr "{hline 44}"
di _col(30) in gr "N = " in ye %6.0f `NbIdFit'
di _col(16) in gr "df" _col(26) in gr "R1m" _col(32) in gr "p-val" _col(39) in gr "Power"
di in gr "{hline 44}"
di _col(3) in gr "R1m" _col(14) in ye %4.0f `R1M_ddl' _col(23) in ye %6.1f ``g'_t' _col(32) in ye %5.4f `=1-chi2(`=`g'[1,2]', ``g'_t')' _col(39) in ye %5.4f ``Power'_t_R1m'
di in gr "{hline 44}"
di in gr ""
if `nbitsuf'==1 & "`sitest'"!=""{
di in gr "Items specific tests of the fit : tests Si"
di in gr ""
di in gr "{hline 44}"
di _col(30) in gr "N = " in ye %6.0f `NbIdFit'
di _col(1) in gr "Item" _col(16) in gr "df" _col(27) in gr "Si" _col(32) in gr "p-val" _col(39) in gr "Power"
di in gr "{hline 44}"
forvalues i=1/`nbit'{
di _col(1) in gr "``i'' :" _col(14) in ye %4.0f `S`i'_ddl' _col(23) in ye %6.1f ``it'_`i'_t' _col(32) in ye %5.4f `=1-chi2(`=`it'[`i',2]', ``it'_`i'_t')' _col(39) in ye %5.4f ``Power'_t_S`i''
di in gr "{hline 44}"
}
}
}
/*************************************/
/* ereturn */
/*************************************/
return clear
if "`nfit'"!=""{
return scalar NumFit=`nfit'
tempname globalFitNu itemFitNu
matrix `globalFitNu'=(``g'_newN',`R1M_ddl',`=1-chi2(`=`g'[1,2]', ``g'_newN')',``Power'_newN_R1m',`nfit')
if `nbitsuf'==1 & "`sitest'"!=""{
matrix `itemFitNu'=J(`nbit',5,.)
forvalues i=1/`nbit'{
matrix `itemFitNu'[`i',1]=``it'_`i'_newN'
matrix `itemFitNu'[`i',2]=`S`i'_ddl'
matrix `itemFitNu'[`i',3]=`=1-chi2(`=`it'[`i',2]', ``it'_`i'_newN')'
matrix `itemFitNu'[`i',4]=``Power'_newN_S`i''
matrix `itemFitNu'[`i',5]=`nfit'
}
}
matrix coln `globalFitNu'=R1m df alpha power N
matrix rown `globalFitNu'=Global
if `nbitsuf'==1 & "`sitest'"!=""{
matrix coln `itemFitNu'=Si df alpha power N
return matrix itemFitNu=`itemFitNu'
}
return matrix globalFitNu=`globalFitNu'
}
if "`power'"!=""{
return scalar PowFit=`power'
tempname globalFitPo itemFitPo
matrix `globalFitPo'=(``g'_newP',`R1M_ddl',`=1-chi2(`=`g'[1,2]', ``g'_newP')',`power',`=ceil(`NbIdFit'*``r'_3')')
if `nbitsuf'==1 & "`sitest'"!=""{
matrix `itemFitPo'=J(`nbit',5,.)
forvalues i=1/`nbit'{
matrix `itemFitPo'[`i',1]=``it'_`i'_newP'
matrix `itemFitPo'[`i',2]=`S`i'_ddl'
matrix `itemFitPo'[`i',3]=`=1-chi2(`=`it'[`i',2]', ``it'_`i'_newP')'
matrix `itemFitPo'[`i',4]=``Power'_newP_S`i''
matrix `itemFitPo'[`i',5]=`=ceil(`NbIdFit'*``r'_3')'
}
}
matrix coln `globalFitPo'=R1m df alpha power N
matrix rown `globalFitPo'=Global
if `nbitsuf'==1 & "`sitest'"!=""{
matrix coln `itemFitPo'=Si df alpha power N
return matrix itemFitPo=`itemFitPo'
}
return matrix globalFitPo=`globalFitPo'
}
tempname globalFitTot itemFitTot
matrix `globalFitTot'=(``g'_t',`R1M_ddl',`=1-chi2(`=`g'[1,2]', ``g'_t')',``Power'_t_R1m',`NbIdFit')
if `nbitsuf'==1 & "`sitest'"!=""{
matrix `itemFitTot'=J(`nbit',5,.)
forvalues i=1/`nbit'{
matrix `itemFitTot'[`i',1]=``it'_`i'_t'
matrix `itemFitTot'[`i',2]=`S`i'_ddl'
matrix `itemFitTot'[`i',3]=`=1-chi2(`=`it'[`i',2]', ``it'_`i'_t')'
matrix `itemFitTot'[`i',4]=``Power'_t_S`i''
matrix `itemFitTot'[`i',5]=`NbIdFit'
}
}
matrix coln `globalFitTot'=R1m df alpha power N
matrix rown `globalFitTot'=Global
if `nbitsuf'==1 & "`sitest'"!=""{
matrix coln `itemFitTot'=Si df alpha power N
return matrix itemFitTot=`itemFitTot'
}
return matrix globalFitTot=`globalFitTot'
use `bddtravail', replace
restore
end