我目前正在.ado 文件中编写一个小的 Stata 程序。在这个 .ado 文件中,我想使用 Mata 来使用 optimize() 函数。当我键入end
以退出 MATA 时,.ado 文件将其读取为程序的结尾(我认为)。我该怎么做?我对 Stata 和 Mata 都很陌生,尤其是同时使用它们。这是我的代码示例:
program define test
args epv prev0 prev1 sample_size bin_prev rep
local prevdiff=`prev1'-`prev0'
local t=-log(1-`prev0')
local eventprob=`epv'/`sample_size'
local lambda_c=0.5
local lambda_0=1
local lambda_1=-log(1-`prev0'-`prevdiff')/`t'
mata
mata clear
void cens_func(todo, x, y, g, H)
{
y = "some function of x and the locals"
}
S = optimize_init()
optimize_init_evaluator(S, &cens_func())
optimize_init_which(S, "min")
optimize_init_params(S, 1)
temp=optimize(S)
st_local("lambda_c",strofreal(temp))
end
some Stata code here
end
提前致谢。