
matlab 非线性优化问题
非线性函数:function[c,ceq]=ss(x)i=1;forl=0.313:0.057/9:0.37m(i)=333.984*sin(x(11))*((2*x(1...
非线性函数 :function [c,ceq]=ss(x)i=1;for l=0.313:0.057/9:0.37 m(i)=333.984*sin(x(11))*((2*x(12)*l-l^2)^2)/(l^2-3*x(12)*l+3*x(12)^2)-1.47*x(i)*((0.0006342*l/(34.08*l+0.005))^0.4)*((1/(19.6*x(12)*(2*x(12)-l)*sin(x(11))/(l^2-3*x(12)*l+3*x(12)^2))^0.2)+(1/((7.92232*x(12)*(2*x(12)-l)*sin(x(11))/(l^2-3*x(12)*l+3*x(12)^2))^0.2))); i=i+1;endc=[];ceq=m';主函数:clear;clc;fun='x(1)+x(2)+x(3)+x(4)+x(5)+x(6)+x(7)+x(8)+x(9)+x(10)';x0=[5;5;5;5;5;5;5;5;5;5;0.5;0.25];A=[];b=[];Aeq=[];beq=[];lb=[0;0;0;0;0;0;0;0;0;0;0;0.185];%l的变化导致a的范围缩小ub=[11.3;11.3;11.3;11.3;11.3;11.3;11.3;11.3;11.3;11.3;0.898;0.313];[x,fval,exitflag]=fmincon(fun,x0,A,b,Aeq,beq,lb,ub,@ss)运行结果:
展开
2个回答
展开全部
方法/步骤
此题的问题描如下图。由于本经验主要是谈非线性约束下的最优化问题,对于其他线性约束就不再考虑。
然后启动matlab。新建一个函数文件,用来写目标函数。
在编辑器窗口中写入我们要求的目标函数,并保存,注意使函数名与文件名相同。
然后再新建一个函数文件,用来编写非线性约束条件。步骤及其注意事项同上。额外需要注意的是,需要将两个函数文件放在同一个文件夹中。
最后,在命令行窗口处写入fmincon命令。此处需要注意的是,对于没有的线性约束条件的位置药用空矩阵代替,并且初始条件需要满足非线性约束条件(本例中写的是[1,2])。
敲下键盘上的enter建,结果得出。可以发现exitflag=1是大于0的,所以结果正确。
此题的问题描如下图。由于本经验主要是谈非线性约束下的最优化问题,对于其他线性约束就不再考虑。
然后启动matlab。新建一个函数文件,用来写目标函数。
在编辑器窗口中写入我们要求的目标函数,并保存,注意使函数名与文件名相同。
然后再新建一个函数文件,用来编写非线性约束条件。步骤及其注意事项同上。额外需要注意的是,需要将两个函数文件放在同一个文件夹中。
最后,在命令行窗口处写入fmincon命令。此处需要注意的是,对于没有的线性约束条件的位置药用空矩阵代替,并且初始条件需要满足非线性约束条件(本例中写的是[1,2])。
敲下键盘上的enter建,结果得出。可以发现exitflag=1是大于0的,所以结果正确。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?

2025-02-09 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准...
点击进入详情页
本回答由Sievers分析仪提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询