Optimize the Max Min over two sets for the given function
6 次查看(过去 30 天)
显示 更早的评论
Hello Guys,
I have two matricis
and
whose rows represents the extreme points and all the rows of
are also the rows of
i.e.,
, and
. I want to compute the square root of
.
data:image/s3,"s3://crabby-images/2fafd/2fafd43a04ad360802a0795332255caea3b5760b" alt=""
data:image/s3,"s3://crabby-images/fc614/fc6147cfd9cb1537074eb52bd0c7f11bcac1eab7" alt=""
data:image/s3,"s3://crabby-images/99eb8/99eb801de7042f6fa5f0650e19b18673ada6f017" alt=""
data:image/s3,"s3://crabby-images/0d2d6/0d2d655129b984bff3666d7636f87ab8dcfd42da" alt=""
data:image/s3,"s3://crabby-images/8176d/8176df75477be4e75520eafc2a47f2395c0c4227" alt=""
data:image/s3,"s3://crabby-images/a9317/a9317cec8aa2e2fe565074ebcda03e95a48a4ec7" alt=""
data:image/s3,"s3://crabby-images/38847/388478b44f2c8079a9b4c8e427e7a49504528d15" alt=""
I want to solve the following problem.
Since
is convex, and convexity is also preserved under minimization, so the function
data:image/s3,"s3://crabby-images/e3b4d/e3b4d7fa169ea83669d233052acfd101eb9a132d" alt=""
data:image/s3,"s3://crabby-images/972c4/972c44a74731766fe9d3ca3b61a74797cb2aad79" alt=""
data:image/s3,"s3://crabby-images/e8d40/e8d40ce0ece734831b2d728fd51b67d865c3c3ec" alt=""
data:image/s3,"s3://crabby-images/9b4d8/9b4d86606a43fff2486ff7c1f884a4453e519f17" alt=""
data:image/s3,"s3://crabby-images/09dfc/09dfcf1023473836f848a7ce985fa520d3c14b1d" alt=""
data:image/s3,"s3://crabby-images/0eb48/0eb481b2244619f197bc67a4f54e9b3bf91d7f60" alt=""
data:image/s3,"s3://crabby-images/04a8f/04a8f6cf4388f295c15979a9e3b2746b01694909" alt=""
which is attained at
. Thus, we can compute the square root of
data:image/s3,"s3://crabby-images/2bb8f/2bb8f8270ef6f5306fcf3ed95d6bd22dd99dbfd0" alt=""
data:image/s3,"s3://crabby-images/c9cab/c9cab8e7aa4336f8436365d34bf20f3ae8cc27a8" alt=""
I hope the question is clear.
Thanks!
5 个评论
回答(4 个)
Torsten
2018-12-19
编辑:Torsten
2018-12-19
max: eps
s.c.
[norm(a_j - sum_{i=1}^{i=k} lambda_i*b_i,2)]^2 >= eps (j=1,...,m)
sum_{i=1}^{i=k} lambda_i = 1
lambda_i >=0
where the a_j are the row vectors of the matrix A and the b_j are the row vectors of the matrix B.
Use "fmincon" to solve for the lambda_i and eps.
Or use "fminimax".
Best wishes
Torsten.
Bruno Luong
2018-12-21
编辑:Bruno Luong
2018-12-21
Not sure why this bla-bla about convex that makes your statement confusing. There is no continuous variable in the quantity f2 = max min | a-b |^2. It is straightforward calculation:
A=[2, 3; 1, 4; 3,1];
B=[1,2; 2,4];
n = size(A,2);
AA = reshape(A,[],1,n);
BB = reshape(B,1,[],n);
d2 = sum((AA-BB).^2,3);
f2 = max(min(d2,[],2),[],1)
8 个评论
Bruno Luong
2018-12-23
编辑:Bruno Luong
2018-12-23
This answer is not longer valid since Sutan has editted and modified his question.
Bruno Luong
2018-12-23
编辑:Bruno Luong
2019-1-15
For ant row a_j, the inner equation
argmin_lambda || sum (lambda_i * b_i - a_j) ||^2
lambda >= 0
sum(lambda_i) = 1
can be solved using QUADPROG.
Then loop on j to find the max.
Example:
A = [1 2 4; 2 3 4; 1 2 3];
B = [1 2 4; 1 2 3];
[m,n] = size(A);
k = size(B,1);
H = B*B';
lb = zeros(1,k);
ub = inf(1,k);
f = nan(1,m);
lambda = nan(k,m);
Aeq = ones(1,k);
beq = 1;
C = -A*B';
for j=1:m
[x,fx] = quadprog(H, C(j,:), [], [], Aeq, beq, lb, ub);
lambda(:,j) = x;
f(j) = norm(B'*x - A(j,:)')^2; % == 2*fx + norm(A(j,:))^2
end
fmax = max(f)
4 个评论
Sultan
2019-1-15
编辑:Sultan
2019-1-16
6 个评论
Bruno Luong
2019-1-16
@Sultan: "I have optimal value 1.414213580747754"
I suspect that is the 2-norm value at the solution and not the square of the norm as defined in your question.
@Torten: Not pseudocode, but CVX:
Thanks
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!