-
Notifications
You must be signed in to change notification settings - Fork 0
/
#Interior_Point_Main_Function_Changed.jl
89 lines (66 loc) · 2.4 KB
/
#Interior_Point_Main_Function_Changed.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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
using MatrixDepot
using SparseArrays
using LinearAlgebra
using JuMP
include("3_backtracking_line_search.jl")
include("2_Newton.jl")
include("1_Starting_Point_Generator.jl")
function interior_point_method(A, b, c; max_iter=1000, tol=1e-8)
m, n = size(A)
# Compute the starting point
# To make s > 0 (slack variable)
x, lambda, s = starting_point(A, b, c)
println(x)
# Backtracking line search parameters
alpha = 0.01 # approaching variable
beta = 0.5 # to reduce alpha
iter_count = 0
for iter = 1:max_iter
# Increment the iteration count
iter_count += 1
# Compute the residuals
r_p = A * x - b #primal
r_d = A' * lambda + s - c #dual
r_g = x .* s #complementary gap
# Check the stopping criterion
du_tol = r_g/n
re_tol = norm([A'*lambda + s - c; A*s - b; x.*s])/norm([b; c]) #########
println(du_tol)
println(re_tol)
if du_tol < tol && re_tol < tol
println(du_tol)
println(re_tol)
break
end
# Compute the search direction
dx, dlambda, ds = compute_newton_direction(A, x, s, r_p, r_d, r_g)
# Perform backtracking line search
t = backtracking_line_search(A, b, c, x, lambda, s, dx, dlambda, ds, alpha, beta)
# What about get output r_p_new, r_d_new ?? --> Test !!
# Update the iterates
x .+= t .* dx
lambda .+= t .* dlambda
s .+= t .* ds
if iter_count == 1000
println(du_tol)
println(re_tol)
end
end
return x, lambda, s, iter_count
end
#Download the Sparse from MatrixDepot
#If you are putting the matrix, erase MatrixName, put LPnetlib/lp_afiro, LPnetlib/lp_brandy,
#LPnetlib/lp_fit1d, LPnetlib/lp_adlittle, LPnetlib/lp_agg, LPnetlib/lp_ganges, LPnetlib/lp_stocfor1, LPnetlib/lp_25fv47, LPnetlib/lpi_chemcom
md = mdopen("LPnetlib/lp_afiro")
println("lp_afiro")
#converting the LP problem min c^T*x s.t. Ax = b, lo <= x <= hi
#to an lp in standard form min c^T*x s.t. Ax = b, x >= 0
A = md.A
b = md.b
c = md.c
# Solve the linear programming problem
x, lambda, s, iter_count = interior_point_method(A, b, c)
# Print the solution and iteration count
Op_value = c'*x
println("Optimal value = ", Op_value)
println("Total iterations = ", iter_count)