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

📄 op_inv.ado

📁 是一个经济学管理应用软件 很难找的 但是经济学学生又必须用到
💻 ADO
字号:
*! version 1.0.4  23sep2004
program define op_inv
	version 6, missing
	syntax varlist(ts min=2 max=2) if, Generate(string) [Dynamic(string)]
	confirm new var `generate'
	tempvar touse X
	mark `touse' `if'

	if "`dynamic'" != "" {
		local dynamic = `dynamic'
		capture confirm integer number `dynamic'
		if _rc { 
			di in red "option dynamic() misspecified"
			exit 198
		}
	}
	else	local dynamic .

	tokenize `varlist'
	local i = index("`1'",".")
	if `i'==0 { 
		qui gen double `generate' = `2' if `touse'
		exit 
	}
	local ops = substr("`1'",1,`i'-1)
	local base = substr("`1'",`i'+1,.)

	if "`dynamic'"=="" { 
		local dynamic "static"
	}

	qui gen double `X' = `2' if `touse'
	rmOPLIST `dynamic' "`ops'" `base' `X' `touse'
	qui replace `X' = . if !`touse'
	rename `X' `generat'
end


program define rmD 
	args dyn R Y0 X touse
	quietly { 
		gen double `R' = `Y0'
		replace `R' = cond(l.`_dta[_TStvar]'>=`dyn', l.`R', l.`Y0') /*
				*/ + `X' if `touse'
	}
end

program define rmS
	args dyn snum R Y0 X touse
	quietly { 
		gen double `R' = `Y0'
		replace `R' = cond(l`snum'.`_dta[_TStvar]'>=`dyn', /*
			*/ l`snum'.`R', l`snum'.`Y0') + `X' if `touse'
	}
end

program define rmDS
	args dyn op R Y0 X touse
	if lower("`op'") == "d" { 
		rmD `dyn' `R' `Y0' `X' `touse'
	}
	else { 
		local pnum = substr("`op'",2,.)
		if "`pnum'" == "" {
			local pnum 1
		}
		rmS `dyn' "`pnum'" `R' `Y0' `X' `touse'
	}
end

program define OpSplit, sclass
	args ops
	sret clear 
	if "`ops'" == "" { exit }
	local opltr = substr("`ops'",1,1)

	local id = index(substr("`ops'",2,.),"D")
	local is = index(substr("`ops'",2,.),"S")
	if `id'==0 & `is'==0 { 
		local id = length("`ops'")
	}
	else if `id'==0 { 
		local id `is'
	}
	local num = substr("`ops'",2,`id'-1)
	local rest = substr("`ops'",`id'+1,.)

	if "`num'"=="" { 
		sret local lhs `opltr'
		sret local rhs = substr("`ops'",2,.)
		exit
	}
	if "`opltr'"=="D" { 
		local num = `num' - 1
		if `num'>0 { 
			local rest  D`num'`rest'
		}
		sret local lhs `opltr'
		sret local rhs `rest'
	}
	else {
		sret local lhs S`num'
		sret local rhs `rest'
	}
end

program define rmOPLIST 
	args dyn oplist Y0 X touse
	tempvar curY R

	LagSplit `oplist' 
	local lagop `s(lhs)'
	local oplist `s(rhs)'

	if "`lagop'"!="" { 
		/* I know X is tempvar */
		tempvar oldX
		quietly { 
			rename `X' `oldX' 
			gen double `X' = `lagop'.`oldX'
			drop `oldX'
		}
	}
			

	while "`oplist'"!="" {
		OpSplit `oplist'
		local oplist `s(rhs)'
		local op `s(lhs)'
		if "`oplist'"=="" { 
			quietly gen double `curY' = `Y0'
		}
		else 	quietly gen double `curY' = `oplist'.`Y0'
		rmDS `dyn' `op' `R' `curY' `X' `touse'
		drop `X' `curY'
		rename `R' `X'
	}
end



program define LagSplit, sclass
	args ops
	sret clear 
	if "`ops'" == "" { exit }
	local opltr = substr("`ops'",1,1)
	if "`opltr'" != "F" & "`opltr'" != "L" { 
		sret local rhs "`ops'"
		exit
	}

	local id = index(substr("`ops'",2,.),"D")
	local is = index(substr("`ops'",2,.),"S")
	if `id'==0 & `is'==0 { 
		local id = length("`ops'")
	}
	else if `id'==0 { 
		local id `is'
	}
	local num = substr("`ops'",2,`id'-1)
	local rest = substr("`ops'",`id'+1,.)

	sret local lhs = cond("`opltr'"=="F", "L", "F") 
	if "`num'"=="" { 
		sret local rhs = substr("`ops'",2,.)
		exit
	}
	else {
		sret local lhs `s(lhs)'`num'
		sret local rhs `rest'
	}
end
exit

⌨️ 快捷键说明

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