点到平面的最短距离
此示例演示如何使用面向问题的方法来制定和解决最小二乘优化问题。
我们将使用[跳转的功能。jl]图书馆(https://github.com/jump-dev/JuMP ...jl)用于优化问题的制定和非线性优化的库Ipopt.jl。
安装库
如果您的环境中未安装最新版本的软件包 JuMP,取消注释并运行下面的单元格:
In [ ]:
Pkg.add(["Ipopt", "JuMP"])
In [ ]:
#Pkg.add("JuMP");
要在安装完成后启动新版本的库,请单击"个人帐户"按钮:
然后点击"停止"按钮:
通过单击"Start Engee"按钮重新启动会话:
任务说明
任务的目标是找到距离原点的最短距离(点 )到飞机上 .
因此,任务是最小化功能:
受限制:
功能 是目标函数,并且 是相等约束。
更复杂的任务可能包含其他相等约束、不等式约束和上限或下限约束。
连接图书馆
连接库 JuMP:
In [ ]:
using JuMP;
连接非线性求解器的库 Ipopt:
In [ ]:
using Ipopt;
创建优化任务
使用函数创建优化任务 Model() 并在括号中指定求解器的名称。:
In [ ]:
plane_prob = Model(Ipopt.Optimizer)
Out[0]:
创建变量 x 包含三个值, – , 和 :
In [ ]:
@variable(plane_prob, x[1:3]);
创建一个目标函数来解决最小化问题:
In [ ]:
@objective(plane_prob, Min, sum(x[i]^2 for i in 1:3))
Out[0]:
设置求解优化问题的条件 . 您可以使用该功能 dot() 为两个向量的标量积,或者用传统的方式写出方程:
In [ ]:
v = [1, 2, 4]
@constraint(plane_prob, dot(x, v) == 7)
Out[0]:
任务语句完成。 您可以查看并检查问题。:
In [ ]:
println(plane_prob)
解决问题
解决优化问题:
In [ ]:
optimize!(plane_prob)
保存值 x 在变量中:
In [ ]:
sol = value.(x);
打印优化结果。 您可以使用该功能 round 四舍五入过于精确的值:
In [ ]:
println("Оптимизированные значения x = ", round.(sol, digits=4))
因此,从点的最短距离是 上飞机 位于点 . 现在我们可以计算两点之间的距离。:
In [ ]:
origin = [0, 0, 0]
distance = sqrt(sum((sol .- origin).^2))
println("Расстояние ", round(distance, digits=4))
您已找到原点和指定平面之间的最短距离。
结论
在这个例子中,我们解决了从原点(点)找到最短距离的问题 )到飞机上 使用最小二乘法(OLS),使用面向问题的方法。