/********************************************************************************/ /* 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