📄 xtrefe_p.ado
字号:
*! version 1.0.3 11may2005
program define xtrefe_p, sort /* predict after xtreg, fe */
version 6, missing
/* Step 1:
place command-unique options in local myopts
Note that standard options are
LR:
Index XB Cooksd Hat
REsiduals RSTAndard RSTUdent
STDF STDP STDR noOFFset
SE:
Index XB STDP noOFFset
*/
local myopts "UE E U XBU"
/* Cooksd Hat REsiduals RSTAndard RSTUdent STDF STDR
|---------------- not allowed ------------------|
These will get rejected by _pred_se. */
/* note that UE is full sample, rest are estimation subsample only */
/* default is XB */
/* Step 2:
call _propts, exit if done,
else collect what was returned.
*/
_pred_se "`myopts'" `0'
if `s(done)' { exit }
local vtyp `s(typ)'
local varn `s(varn)'
local 0 `"`s(rest)'"'
/* Step 3:
Parse your syntax.
*/
syntax [if] [in] [, `myopts' noOFFset]
/* Step 4:
Concatenate switch options together
*/
local type "`e'`u'`ue'`xbu'"
/* Step 5:
quickly process default case if you can
Do not forget -nooffset- option.
*/
if "`type'"=="" {
di in gr "(option xb assumed; fitted values)"
_predict `vtyp' `varn' `if' `in', xb `offset'
label var `varn' "Xb"
exit
}
/* Step 6:
mark sample (this is not e(sample)).
*/
marksample touse
/* Step 7:
handle options that take argument one at a time.
Comment if restricted to e(sample).
Be careful in coding that number of missing values
created is shown.
Do all intermediate calculations in double.
*/
/* Step 8:
handle switch options that can be used in-sample or
out-of-sample one at a time.
Be careful in coding that number of missing values
created is shown.
Do all intermediate calculations in double.
*/
if "`type'" =="ue" {
tempvar xb
quietly _predict double `xb' if `touse', xb `offset'
gen `vtyp' `varn' = `e(depvar)' - `xb' if `touse'
label var `varn' "u[`e(ivar)'] + e[`e(ivar)',t]"
exit
}
/* Step 9:
handle switch options that can be used in-sample only.
Same comments as for step 8.
*/
qui replace `touse'=0 if !e(sample)
if "`type'"=="e" {
tempvar xb u
quietly {
_predict double `xb' if `touse', xb `offset'
predict double `u' if `touse', u `offset'
}
gen `vtyp' `varn' = `e(depvar)' - `xb' - `u' if `touse'
label var `varn' "e[`e(ivar)',t]"
exit
}
/* for the remaining, we also need to know the full estimation
subsample
*/
tempvar smpl
qui gen byte `smpl' = e(sample)
if "`type'"=="u" | "`type'"=="xbu" {
sort `e(ivar)' `smpl'
tempvar xb u
quietly {
_predict double `xb' if `smpl', xb `offset'
by `e(ivar)' `smpl': /*
*/ gen double `u' = sum(`e(depvar)')/_n - /*
*/ sum(`xb')/_n if `smpl'
by `e(ivar)' `smpl': replace `u' = `u'[_N] /* sic */
}
if "`type'"=="u" {
gen `vtyp' `varn' = `u' if `touse'
label var `varn' "u[`e(ivar)']"
}
else {
gen `vtyp' `varn' = `xb' + `u' if `touse'
label var `varn' "Xb + u[`e(ivar)']"
}
exit
}
error 198
end
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -