当我运行下面的代码时,fminbox或Optim.autodiff函数似乎创建了一个Array {Dual {Float64},1}类型的向量,因为我得到错误“fbellmanind没有方法匹配。 ..Array {双{Float64},1}”。我已经指定函数fbellmanind接受Array {Any,1}但没有运气。有任何想法吗?Fminbox约束优化Julia
function fbargsolve(x::Vector)
fbellmanind(probc,EV,V,Ind,x,V0,VUnemp0,Vnp,Vp,q,obj,assets,EmpState,i)
fbellmanfirm(probc,poachedwage,minw,x,jfirm1,jfirm0,Ind,i)
@inbounds for ia in 1:na
Vnp[ia]=V[ia]
Indnp[ia]=Ind[ia]
firmratio[ia]=jfirm1[ia]/jfirmres[ia]
hhratio[ia]=((Vnp[ia]-VUnemp0[ia])/(Vp[ia]-VUnemp0[ia]))
end
Crit_bwr=vnormdiff(firmratio,hhratio,Inf)
return Crit_bwr
end
f=fbargsolve
df = Optim.autodiff(f, Float64, na)
x0=vec(bargwage0)
l=vec(max(reswage,minw))
u=vec(poachedwage*ones(na))
sol=fminbox(df,x0,l,u)
注意'阵{T,1} <:数组{任何,1}'其中'T <:任何'。 – Gnimuc