问题描述
代码是用Julia 1+编写的。
using JuMP,Gurobi,Ipopt
#parameters--------------------------------------------------------
sig=0.86;
#---------------------------------------------------------------------------
ALT= Model(optimizer_with_attributes(Juniper.Optimizer,"nl_solver"=>optimizer_with_attributes(Ipopt.Optimizer,"print_level" => 0),"mip_solver"=>optimizer_with_attributes(Gurobi.Optimizer,"logLevel" => 0)))
# variables-----------------------------------------------------------------
f(x) = cdf(normal(0,1),x);
JuMP.register(ALT,:f,1,f; autodiff = true);
@variable(ALT,h >= 0);
@variable(ALT,L >= 0);
@variable(ALT,n,Int);
#-------------------------------------------------------------------
@NLexpression(ALT,k7,1-f(L-sig*sqrt(n))+f(-L-sig*sqrt(n)));
#constraints--------------------------------------------------------
@NLconstraint(ALT,f(-L) <= 1/400);
#-------------------------------------------------------------------
@NLobjective(ALT,Min,1/k7)
optimize!(ALT)
但是发生了此错误
错误:您已注册功能吗?然后,请同时为Juniper注册该功能,请参见: https://lanl-ansi.github.io/Juniper.jl/stable/options/#registered_functions%3A%3AUnion%7BNothing%2CVector%7BRegisteredFunction%7D%7D-%5Bnothing%5D-1
然后将代码更改如下
using JuMP,f; autodiff = true);
Juniper.register(ALT,1/k7)
optimize!(ALT)
但是再次发生此错误 错误:MethodError:没有方法匹配寄存器(:: Model,:: Symbol,:: Int64,:: typeof(f); autodiff = true) 您能帮我解决这些错误吗?谢谢
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)