0

我是matlab的新手,如果问题很愚蠢,我深表歉意。我正在使用该fmincon 函数来推导mxn矩阵 (X) 的元素,该矩阵将在非负性约束下最大化以下目标函数,并且:

总和(x_{ij})< 100

{f(x(1,1))+(f(x(1,2))+...+f(x(1,n))} + Beta*{f(x(2,1))+ (f(x(2,2))+...+f(x(2,n))}+...+(Beta^(m-1))*{f(x(m,1)) +(f(x(m,2))+...+f(x(m,n))}

在哪里

f(xij)=zeta*[((alpha*pf*(xij^delta))-(pw*xij))^gamma]

在我曾经这样做的代码fmincon中使用了,因为目标函数是非线性的:

function optim = optim(m,n)
A= ones(1,m*n);
b = 100;
z = zeros(m,n);
in = inf(m,n);
X = ones(m,n);

[x, bestval] = fmincon(@myfun2,X,A,b,[],[],z,in,[])

  function f = myfun2(x)
  Alpha = 5;
  %kappa = 5;
  zeta = 5;
  beta = 0.90909;
  delta = 0.4;
  gamma = 0.4;
  pf = 1;
  pw = 1;

  for i= 1:m
     f=0;
     sum(i)=0;
        for j=1:n
        sum(i) = sum(i) +((beta^(i-1))*(-1)*(zeta)*(((Alpha*pf.*((x(i,j)).^delta))- 
                 (pw.*x(i,j)))^gamma));

         end
     f = f+sum(i)
   end

 end
end

当代码针对 5x5 矩阵 (optim(5,5)) 运行时,得到的解是 x =

1.5439    1.5439    1.5439    1.5439    1.5439
1.5439    1.5439    1.5439    1.5439    1.5439
1.5439    1.5439    1.5439    1.5439    1.5439
1.5439    1.5439    1.5439    1.5439    1.5439
3.1748    3.1748    3.1748    3.1748    3.1748


bestval =

-31.8780 

但这不是全局最小值 - 正如边际条件指定的全局最小值(对于第一行):

f'(x11)=...=f'(x1n)

每行以此类推。我们还将为每一列:

f'(x11)=beta*f'(x21)=...=(beta^m-1)*f'(xm1)

对于第一列,依此类推。结果矩阵不满足这些条件。我已经查看了堆栈溢出中的相关问题以及文档,但我不知道如何获得更好的结果。代码有问题吗?可以调整代码以获得更好的结果吗?

我可以将边际条件设为停止条件吗?我该如何去做。或者我可以以某种方式使用雅可比吗?任何帮助,将不胜感激。谢谢你。

4

1 回答 1

0

没有任何优化技术可以保证返回全局最小值。如果 Hessian 是正定的,则​​某些算法可以保证找到局部最小值,但是如果局部最小值是全局最小值,则没有数学方法可以仅从函数值及其 n 次导数中确定。

现在至于您的终止条件。您可以将选项结构传递给 fmincon,该结构具有控制 fmincon 操作的参数。您可以选择最适合您的问题的不同算法。我会阅读有关此选项结构的文档,看看是否有任何内容适合您尝试做的事情。

http://www.mathworks.com/help/optim/ug/optimoptions.html

于 2015-05-03T21:02:40.650 回答