Hello,
I want the solution (x,y) of my optimization problem to belong to a specific region of the search-space as depicted below. This region can have an arbitrary shape.
1st case: The red region is known, by knowing the equation of each red line (segment). Is it possible to create a set of inequalities?
2nd case: The red region is known, by knowing the coordinates of all points of its perimeter. Is it possible to create a set of inequalities?
Thanks in advance.

 채택된 답변

Matt J
Matt J 2020년 12월 22일
편집: Matt J 2020년 12월 22일

1 개 추천

Assuming the region is convex, the answer is yes in both cases. Otherwise, the answer is no - inequalitites will not be enough to specify a nonconvex polygon.

댓글 수: 4

Alan Weiss
Alan Weiss 2020년 12월 22일
To expand on Matt's answer, for convex regions you would generally use a set of linear inequality constraints.
Alan Weiss
MATLAB mathematical toolbox documentation
John Kioulaxidis
John Kioulaxidis 2020년 12월 22일
편집: John Kioulaxidis 2020년 12월 22일
Thank both of you for the answers. Indeed, let's assume it is a convex region.
1st case: The (line) equations of the sides of the region are known. I guess it is easy then to procceed according to linear inequality constraints
2nd case: To better explain, let's assume that my convex region is in fact a grid of points with known coordinates. I dont know which points define the boundaries of the region or any any line equations. How is it possible to define this region by linear inequalities?
For the second case, you can use vert2lconin
[A,b]=vert2lcon(V);
Although the instructions assume the rows of V are the vertices of the polygon, it will actually work if there are additional points as well.
John Kioulaxidis
John Kioulaxidis 2020년 12월 23일
Wow this function is what I needed. Thanks

댓글을 달려면 로그인하십시오.

추가 답변 (1개)

Bruno Luong
Bruno Luong 2020년 12월 22일
편집: Bruno Luong 2020년 12월 22일

0 개 추천

% Your points that define the domain
xg = randn(10,1);
yg = randn(10,1);
% The domain is concerted to the set defined by inequalities { xy : A*xy <= b }
xyg = [xg(:) yg(:)];
K = convhull(xyg);
xyh = xyg(K,:);
dxy = diff(xyh,1,1);
A = [dxy(:,2),-dxy(:,1)];
b = sum(A.*xyh(1:end-1,:),2);
% Check with grid points
close all
xi = linspace(min(xg),max(xg),30);
yi = linspace(min(yg),max(yg),30);
[X,Y] = ndgrid(xi,yi);
xy = [X(:),Y(:)]';
in = all(A*xy <= b,1); % inequalities
plot(xg,yg,'+',...
xyh(:,1),xyh(:,2),'-k',...
X(in),Y(in),'or', ...
X(~in),Y(~in),'.y');

댓글 수: 1

John Kioulaxidis
John Kioulaxidis 2020년 12월 23일
Thank you for the answer. Function convhull seems quite interesting..

댓글을 달려면 로그인하십시오.

카테고리

질문:

2020년 12월 21일

댓글:

2020년 12월 23일

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by