source: proiecte/pmake3d/make3d_original/Make3dSingleImageStanford_version0.1/third_party/opt/yalmip/dev/tests-mbg/robust/test_robust_2.m @ 37

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

Added original make3d

File size: 1.1 KB
Line 
1function test_robust_2
2
3yalmip('clear')
4
5Anominal = [0 1 0;0 0 1;0 0 0];
6B = [0;0;1];
7Q = eye(3)
8R = 1;
9
10alpha = sdpvar(1)
11A = double2sdpvar(Anominal);
12A(1,3) = alpha;
13
14%We have now created a parameterized system, and can proceed as before.
15Y = sdpvar(3,3);
16L = sdpvar(1,3);
17
18F = set(Y >=0);
19F = F + set([-A*Y-B*L + (-A*Y-B*L)' Y L';Y inv(Q) zeros(3,1);L zeros(1,3) inv(R)] > 0)
20
21F = F + set(-0.1 <= alpha <= 0.1);
22
23sol = solverobust(F,-trace(Y),[],alpha)
24
25K = double(L)*inv(double(Y))
26
27mbg_asserttolequal(sol.problem, 0, 1e-5);
28mbg_asserttolequal(K -   [-1.3674   -2.9158   -2.6670], 0, 1e-3);
29
30
31alpha = sdpvar(1)
32A = double2sdpvar(Anominal);
33A(1,3) = alpha;
34
35L0 = sdpvar(1,3);
36L1 = sdpvar(1,3);
37L = L0 + alpha*L1;
38
39Y0 = sdpvar(3,3);
40Y1 = sdpvar(3,3);
41Y = Y0 + alpha*Y1;
42
43F = set(Y >=0);
44F = F + set([-A*Y-B*L + (-A*Y-B*L)' Y L';Y inv(Q) zeros(3,1);L zeros(1,3) inv(R)] > 0)
45F = F + set(-0.1 <= alpha <= 0.1);
46sol = solverobust(F,-trace(Y),[],alpha)
47
48mbg_asserttolequal(sol.problem, 0, 1e-5);
49Y0 = double(Y0);
50Y1 = double(Y1);
51mbg_asserttolequal(max([trace(Y0-0.1*trace(Y1)) trace(Y0+0.1*trace(Y1))]),2.3319, 1e-3);
Note: See TracBrowser for help on using the repository browser.