Я пытаюсь использовать функцию fseminf в среде оптимизации MATLAB:
clc;
clear;
close;
% Define function
global g f S
f= @(x) -x(1);
g= @(x,s) x(1)-x(2).*s(1)-x(3).*(-sqrt((2.25-10.*sqrt(12).*...
(s(1)-1.175).^2)./(5.*sqrt(24)))+1.2);
lb=[-Inf,0,0];
ub=[Inf,1,1];
S=[0.9220144,1.42985];
x0= [0.5,0.5,0.5]'; % initial condition
A= [];
b=[];
Aeq= [0,1,1];
beq= [1];
[x,fval,exitflag,output,lambda] = fseminf(f,x0,1,@seminfcon2,A,b,Aeq,beq,lb,ub);
seminfcon2 определяется следующим образом:
function [c, ceq, K1, s] = seminfcon2(x,s)
global S g
% No finite nonlinear inequality and equality constraints
c = [];
ceq = [];
% Sample set
if isnan(s(1,1))
s(1,1)=0.001;
s(1,2)=0;
end
t = S(1):s(1):S(2);
K1 = g(x,t);
Вот детали, дело в том, что это не работает должным образом, я получаю решение, которое не удовлетворяет ограничениям. В нем говорится:
Найден локальный минимум, который удовлетворяет ограничениям.
завершено, потому что целевая функция не уменьшается в
↵ возможные направления, в пределах значения допуска оптимальности.
Я знаю, что ограничения не выполняются, потому что
- Я нарисовал область ограничения
- мои другие алгоритмы дают хороший результат
Мой вопрос к людям, которые знают, как работает функция fseminf
. Возможно ли, что этот алгоритм не может выполнить оптимизацию для моего примера? Чтобы добавить, fseminf
отлично работает с моими другими примерами.
РЕДАКТИРОВАТЬ
- Решение, найденное алгоритмом:
(1.1633, 0, 1.0000)
- тогда как другие мои алгоритмы дали:
(0.99069, 0.55395, 0.44605)