-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathproblem.jl
41 lines (40 loc) · 1.32 KB
/
problem.jl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
struct RP{P}
net::P
obj_cost::Vector{Float64}
x0::Vector{Float64}
xg::Vector{Float64}
u_lim::Vector{Float64}
end
function RP(net, obj_cost, x0, xg; u_lim=[2,4])
RP(net, float.(obj_cost), float.(x0), float.(xg), float.(u_lim))
end
struct TP{P,Q}
net::P
obj_cost::Vector{Float64}
T::Int
tf::Float64
dt::Float64
x0::Vector{Float64}
Xref::Vector{Vector{Q}}
times::Vector{Float64}
u_lim::Vector{Float64}
end
function TP(net, obj_cost, tf, x0, Xref; u_lim=[2,4])
T = length(Xref)
TP(net, float.(obj_cost), T, float(tf), float(tf)/T, x0, Xref, Vector(range(0, tf, length=T)), float.(u_lim))
end
function TP(net, obj_cost, tf, Xref; u_lim=[2,4])
T = length(Xref)
TP(net, float.(obj_cost), T, float(tf), float(tf)/T, Xref[1], Xref, Vector(range(0, tf, length=T)), float.(u_lim))
end
function costs(tp, X; norm=1, cost=nothing)
if norm == 1
isnothing(cost) && return [sum(abs.(X[i] - tp.Xref[i]).*tp.obj_cost) for i = 1:tp.T]
return [sum(abs.(X[i] - tp.Xref[i]).*cost) for i = 1:tp.T]
end
if norm == 2
isnothing(cost) && return [sqrt(dot((X[i] - tp.Xref[i]), (X[i] - tp.Xref[i]).*tp.obj_cost)) for i = 1:tp.T]
return [sqrt(dot((X[i] - tp.Xref[i]), (X[i] - tp.Xref[i]).*cost)) for i = 1:tp.T]
end
return [nothing for i = 1:tp.T]
end