⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 slogit_p.ado

📁 是一个经济学管理应用软件 很难找的 但是经济学学生又必须用到
💻 ADO
字号:
*! version 1.0.9  07jun2005
/* predict for slogit */
program define slogit_p
        version 9
	if "`e(cmd)'" != "slogit" {
		di as error "{p}stereotype logistic regression " ///
	"estimates from {help slogit##|_new:slogit} not found{p_end}"
		exit 301
	}

	syntax [anything] [if] [in] [, SCores * ]
	if `"`scores'"' != "" {
		global STEREO_nreg	`e(k_indvars)'
		global STEREO_dim	`e(k_dim)'
		global STEREO_nlev	`e(k_out)'
		tempname levels
		matrix `levels' = e(outcomes)
		forval i = 1/`e(k_out)' {
			if (`i' == e(i_base)) continue
			local valist `"`valist' `i'"'
		}
		global STEREO_levels	`valist' `e(i_base)'
		global STEREO_base	`e(i_base)'
		local dl : word count `valist'
		// identify the score variables
		forvalues dm = 1/$STEREO_dim {
			local dbv `"`dbv' dbv`dm'"'
			forval i = 1/`dl' {
				local dpv `"`dpv' dpv`dm'`i'"'
			}
		}
		forval i = 1/`dl' {
			local dtv `"`dtv' dtv`i'"'
		}
		global STEREO_dv `dbv' `dpv' `dtv'
		/* create a proper factor variable for the response */
		marksample touse, novarlist
		markout `touse' `e(indvars)'
		tempvar fdepvar
		qui egen `fdepvar' = group(`e(depvar)') if `touse'
		global STEREO_resp `"`fdepvar'"'

		cap noi ml_score `0'
		local rc = _rc
		macro drop STEREO_*
		exit `rc'
	}

        syntax anything(name=vlist id="varlist") [if] [in] ///
		[, Outcome(string) XB STDP Pr INDex SEIndex]

        local nopt : word count `xb' `stdp' `pr' `index' `seindex'
        if `nopt' > 1 {
                di as error "{p}only one of pr, xb, index, stdp, or " ///
		 "seindex can be specified{p_end}"
                exit 198
        }
	marksample touse, novarlist
	markout `touse' `e(indvars)'

	local type "`xb'`stdp'`pr'`index'`seindex'"        

	if "`type'"=="xb" | "`type'"=="index" ///
	 | "`type'"=="stdp" | "`type'"=="seindex" {
        	syntax newvarlist [if] [in] [, * ]
		local nvar : word count `varlist'
		if `"`outcome'"' == "" {
	                di as error "{p}must specify outcome() option with " ///
			 "`type' option{p_end}"
        	        exit 198
		}
		if `nvar' > 1 {
			di as error "{p}only one new variable can be " ///
 			 "specified with `type' option{p_end}"
			exit 103
		}
		if index("`vlist'","*") {
			di as err "{p}`vlist' may not be " ///
 			 "specified with `type' option{p_end}"
			exit 198
		}
        }
	else {
		if "`type'" == "" {
			di in gr "(option pr assumed; predicted probabilities)"
		}
		local type "pr"
		cap _stubstar2names `vlist', nvars(`e(k_out)') singleok outcome
		local rc = _rc
		if `rc' == 0 {
			local varlist `s(varlist)'
			local typlist `s(typlist)'
			local nvar : word count `varlist'
			if ("`outcome'"!="" & `nvar'>1) local rc = 103
		}
		if `rc' {
			if `rc'==102 | `rc'==103 {
				di as error "{p}must specify " e(k_out) " new variable names, "   ///
				 "or one new variable name with the outcome() option when using " ///
				 "the pr option{p_end}"
				exit 198
			}
			error `rc'
		}
		if `nvar'==1 & "`outcome'"=="" {
			di as error "{p}must specify outcome() when one new variable " ///
			 "name is given with the pr option{p_end}"
			exit 198
		}
	}

	Outcome `outcome'
	local lev `s(outcome)'	
	tokenize `typlist'

	if "`type'"=="xb" | "`type'"=="index" {
		tempvar xb
		qui Xbeta `lev' `xb' `1' `touse'
		gen `1' `varlist' = `xb'
		label var `varlist' `"Linear prediction, `e(depvar)'=`=abbrev("`e(out`lev')'",17)'"'
	}
	else if "`type'" == "pr" {
		qui Predict `"`varlist'"' `1' `touse' `lev'
	}
	else { /* if "`type'"=="stdp" | "`type'"=="seindex" */
		tempvar var 
		local type `1'
		tempname b theta phi V X

		local covar `"`e(indvars)'"'
		local dim  = e(k_dim)
		matrix `b' = e(b)
		scalar `phi' = 0.0

		tempvar zero one
		qui gen double `zero' = 0.0 if `touse'
		qui gen double `one' = 1.0 if `touse'
		forvalues dm = 1/`dim' {
			tempvar xb`dm' 
			qui _predict `type' `xb`dm'' if `touse', xb equation(dim`dm')
			qui replace `xb`dm'' = -`xb`dm'' if `touse'

			if `lev' != e(i_base) {
				local k = colnumb(`b',"phi`dm'_`lev':")
				scalar `phi' = `b'[1,`k']
			}
			if abs(`phi') < c(epsdouble) {
				foreach vari of local covar {
					local blist `"`blist' `zero'"'
				}
			}
			else {
				foreach vari of local covar {
					tempvar x`vari'`dm'
					qui gen `type' `x`vari'`dm'' = -`phi'*`vari'
					local blist `"`blist' `x`vari'`dm''"'
				}
			}
			forvalues i = 1/`e(k_out)' {
				if `i' == e(i_base) {
					continue
				}
				if `lev' == `i' {
					local plist `"`plist' `xb`dm''"'
					if `dm' == 1 {
						local tlist `"`tlist' `one'"'
					}
				}
				else {
					local plist `"`plist' `zero'"'
					if `dm' == 1 {
						local tlist `"`tlist' `zero'"'
					}
				}
			}
		}	
		local nb = e(k)
		qui gen `type' `var' = .
		mata: QuadProd("`blist'`plist'`tlist'", "`var'", "`touse'")
		gen `type' `varlist' = `var'
		label var `varlist' `"Standard error of the linear prediction, `e(depvar)'=`=abbrev("`e(out`lev')'",17)'"'
	}
	sret clear
end

program Outcome, sclass
	local o = trim(`"`0'"')

	if "`o'" == "" {
		sreturn local outcome
		exit
	}

	if substr(`"`o'"',1,1) == "#" {
		local i = substr(`"`o'"',2,.)
		cap confirm integer number `i'
		if _rc > 0 {
			di as error "the outcome index must follow the # in outcome(`o')"
			exit 198
		}
		if `i' < 1 | `i' > e(k_out) {
			di as error "{p}the outcome index specified with # must " ///
			 "be an integer between 1 and `=e(k_out)' inclusive{p_end}"
			exit 198
		}
		sreturn local outcome = `i'
		exit
	}
	cap confirm number `o'
	if _rc == 0 {
	       	forvalues i = 1/`e(k_out)' {
			local j = el(e(outcomes),`i',1)
			if `j' == `o' {
				sreturn local outcome = `i'
				continue, break	
			}
		}
	}
	if "`s(outcome)'" == "" {
       		forvalues i = 1/`e(k_out)' {
			if `"`e(out`i')'"' == `"`o'"' {
				sreturn local outcome = `i'
				continue, break	
			}
		}
	}
	if "`s(outcome)'" == "" {
		di as error "{p}`o' is not one of the outcomes{p_end}"
		exit 322
	}
end
 
program Xbeta
	args lev xb type touse

	tempname bij b

	tempvar tx
	if `lev' == e(i_base) {
		cap confirm new variable `xb'
		if _rc == 0 {
			qui gen `type' `xb' = 0.0 if `touse'
		}
		else {
	       	        qui replace `xb' = 0.0 if `touse'
		}
		exit
        }
	
	matrix `b' = e(b)
	local k = colnumb(`b',"theta`lev':")
	scalar `bij' = el(`b',1,`k')
	cap confirm new variable `xb'
	if _rc == 0 {
		qui gen `type' `xb' = `bij' if `touse'
	}
	else {
		qui replace `xb' = `bij' if `touse'
	}

	forvalues dm = 1/`e(k_dim)' {
		tempvar xb`dm'
		local k = colnumb(`b',"phi`dm'_`lev':")
		scalar `bij' = el(`b',1,`k')
		qui _predict `type' `xb`dm'' if `touse', xb equation("dim`dm'")
		qui replace `xb' = `xb' - `bij'*`xb`dm'' if `touse'
	}	
end

program Predict
        args varlist type touse lev

        tempvar denom
        qui gen `type' `denom' = 0.0 if `touse'
        local nvar : word count `varlist'
        if `nvar' == 1 {
                tempvar vari
		tempvar vark
        }
                                                                                          
        forvalues i = 1/`e(k_out)' {
                if `nvar' > 1 {
                        tempvar var`i'
			local vari `var`i''
                }
                Xbeta `i' `vari' `type' `touse'
                replace `vari' = exp(`vari') if `touse'
                qui replace `denom' = `denom' + `vari' if `touse'
                if `nvar'==1 {
			if `i'==`lev' {
	                        qui gen `type' `vark' = `vari' if `touse'
			}
			drop `vari'
                }
        }
        if `nvar' > 1 {
                /* predict all levels */
		local i = 0
                foreach vari of local varlist {
			local `++i'
                        qui gen `type' `vari' = `var`i''/`denom' if `touse'
                        label var `vari' `"Pr(`e(depvar)'=`=abbrev("`e(out`i')'",17)')"'
                }
        }
        else {
                qui gen `type' `varlist' = `vark'/`denom' if `touse'
                label var `varlist' `"Pr(`e(depvar)'=`=abbrev("`e(out`lev')'",17)')"'
        }
end

mata function QuadProd(string scalar svar, string scalar sv, string scalar stou)
{
	real vector x
	real matrix V
	scalar i, n, iv, ix, itou

	ix = st_varindex(tokens(svar))
	iv = st_varindex(sv)
	itou = st_varindex(stou)
	V = st_matrix("e(V)")
	n = st_nobs()
	for (i=1; i<=n; i++) {
		if ( st_data(i,itou) ) {
			x = st_data(i,ix)
			st_store(i, iv, sqrt(x*V*x'))
		}
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -