source: proiecte/pmake3d/make3d_original/Make3dSingleImageStanford_version0.1/third_party/opt/yalmip/dev/regress_dppwa3d.m @ 37

Last change on this file since 37 was 37, checked in by (none), 14 years ago

Added original make3d

File size: 3.0 KB
Line 
1yalmip('clear')
2mpt_init('lpsolver','clp')
3
4% Prediction horizon
5N = 4;
6
7pwa3d
8sysStruct.xmin = sysStruct.ymin;
9sysStruct.xmax = sysStruct.ymax;
10probStruct.R = 1;
11probStruct.N=N-1;
12probStruct.norm = 1;
13probStruct.subopt_lev=0;
14probStruct.P_N = zeros(3);
15if 0
16    ctrl=mpt_control(sysStruct,probStruct)
17end
18nx = 3;
19nu = 1;
20
21% States x(k), ..., x(k+N)
22x = sdpvar(repmat(nx,1,N),repmat(1,1,N));
23
24% Inputs u(k), ..., u(k+N) (last one not used)
25u = sdpvar(repmat(nu,1,N),repmat(1,1,N));
26
27% Binary for PWA selection
28d = binvar(2,1);
29
30% Value functions
31J = cell(1,N);
32
33tic
34% Initialize value function at stage N
35J{N} = 0;
36sysStruct.xmin = sysStruct.ymin;
37sysStruct.xmax = sysStruct.ymax;
38for k = N-1:-1:1
39    % Feasible region
40    t = sdpvar(nx+nu,1);
41%     bounds(x{k},sysStruct.xmin,sysStruct.xmax);
42%     bounds(u{k},sysStruct.umin,sysStruct.umax);
43%     bounds(x{k+1},sysStruct.xmin,sysStruct.ymax);
44%     bounds(t,0,600);
45
46    F =     set(sysStruct.umin < u{k}     < sysStruct.umax);
47    F = F + set(sysStruct.xmin < x{k}     < sysStruct.xmax);
48    F = F + set(sysStruct.xmin < x{k+1}   < sysStruct.xmax);
49    F = F + set(sysStruct.ymin < sysStruct.C{1}*x{k}   < sysStruct.ymax);
50    F = F + set(sysStruct.ymin < sysStruct.C{1}*x{k+1} < sysStruct.ymax);
51
52    F = F + set(-t < [x{k};u{k}] < t) ;
53    F = F + set(0 < t < 600);
54    % PWA Dynamics
55    for i = 1:length(sysStruct.A)
56        F = F + set(implies(d(i),x{k+1} == sysStruct.A{i}*x{k}+sysStruct.B{i}*u{k}+sysStruct.f{i}));
57        F = F + set(implies(d(i),sysStruct.guardX{i}*x{k} <= sysStruct.guardC{i}));
58    end
59    F = F + set(sum(d) == 1);
60
61    % Compute value function for one step backwards
62    [mpsol{k},sol{k},Uz{k},J{k}] = solvemp(F,sum(t) + J{k+1},[],x{k},u{k});
63end
64toc
65break
66
67mpsol{1} = mpt_removeOverlaps(mpsol{1})
68
69[pass,tol] = mpt_isPWAbigger(mpsol{1},ctrl)
70
71
72
73break
74
75% On-line solution
76nx = 3;
77nu = 1;
78J{N} = 0;
79sysStruct.xmin = sysStruct.ymin;
80sysStruct.xmax = sysStruct.ymax;
81F = set([]);
82obj = 0;
83dd = [];
84for k = N-1:-1:1
85    % Feasible region
86 %   t = sdpvar(nx+nu,1);
87    d = binvar(2,1);dd = [dd;d];
88 %   obj = obj + sum(t);
89    bounds(x{k},sysStruct.xmin,sysStruct.xmax);
90    bounds(u{k},sysStruct.umin,sysStruct.umax);
91    bounds(x{k+1},sysStruct.xmin,sysStruct.ymax);
92%   bounds(t,0,60);
93
94    F = F + set(sysStruct.umin < u{k}     < sysStruct.umax);
95    F = F + set(sysStruct.xmin < x{k}     < sysStruct.xmax);
96    F = F + set(sysStruct.xmin < x{k+1}   < sysStruct.xmax);
97    F = F + set(sysStruct.ymin < sysStruct.C{1}*x{k}   < sysStruct.ymax);
98    F = F + set(sysStruct.ymin < sysStruct.C{1}*x{k+1} < sysStruct.ymax);
99
100    F = F + set(-t < [x{k};u{k}] < t) ;
101
102    % PWA Dynamics
103    for i = 1:length(sysStruct.A)
104        F = F + set(implies(d(i),x{k+1} == sysStruct.A{i}*x{k}+sysStruct.B{i}*u{k}+sysStruct.f{i}));
105     
106        F = F + set(implies(d(i),sysStruct.guardX{i}*x{k} <= sysStruct.guardC{i}));
107    end
108    F = F + set(sum(d) == 1);
109%    obj = obj + x{k}'*x{k}+u{k}'*u{k};
110    obj = obj + sum(t);
111end
112[mpsol{k},sol{k},Uz{k}] = solvemp(F,obj,[],x{k},u{k});
113sol = solvesdp(F+set(x{k}==[1.2;1.1;1.1]),obj)
114
115
116
117
Note: See TracBrowser for help on using the repository browser.