热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

matlabfmincon优化,求教Matlab用fmincon做优化计算

matlabfmincon优化,求教Matlab用fmincon做优化计算本人利用fmincon做优化计算,其程序如下:1,主程序clearallx0[0.1,0.3,0.2,0.

本人利用fmincon做优化计算,其程序如下:

1,主程序

clear all

x0=[0.1,0.3,0.2,0.3,0.1,45,0.214,0.05,0,0.45,0.15,0,0.4,0.12,0,0,0,0,0,0,0,0,0,0,0,0];

A=[ 1 -1 -1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0; 1 1 -1 -1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0; 1 -1 1 -1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0; -2 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0; 0 -2 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0; 0 0 -2 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0];

b=[0;0;0;0;0;0];

Aeq=[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0; 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1; 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 2 3 4 5 6 7 8 9 10; 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 6 12 20 30 42 56 72 90];

beq=[0;0;0;0];

[x,fval,exitflag]=fmincon(@myfun,x0,A,b,Aeq,beq);

2,优化程序

function c=myfun(x)

% Parameters of the four-bar linkage(m,rad)

l1=x(1);l2=x(2);l3=x(3);l4=x(4);L=x(5); beta=x(6)/180*pi;

m1x=x(7);r1x=x(8);phi1x=x(9);m2x=x(10);r2x=x(11);phi2x=x(12); m3x=x(13);r3x=x(14);phi3x=x(15);

% orignal linkage

m1o=0.20;r1o=0.05;phi1o=0; m2o=0.5;r2o=0.15; phi2o=0;m3o=0.4;r3o=0.12; phi3o=0;I1o=0.00017;I2o=0.00375;I3o=0.00192;

m1=m1o+m1x;  m2=m2o+m2x;  m3=m3o+m3x;

r1=sqrt((m1o*r1o)^2+(m1x*r1x)^2-2*m1o*r1o*m1x*r1x*cos(pi-(phi1x-phi1o)))/m1;

r2=sqrt((m2o*r2o)^2+(m2x*r2x)^2-2*m2o*r2o*m2x*r2x*cos(pi-(phi2x-phi2o)))/m2;

r3=sqrt((m3o*r3o)^2+(m3x*r3x)^2-2*m3o*r3o*m3x*r3x*cos(pi-(phi3x-phi3o)))/m3;

phi1=atan((m1o*r1o*sin(phi1o)+m1x*r1x*sin(phi1x))/(m1o*r1o*cos(phi1o)+m1x*r1x*cos(phi1x)));

phi2=atan((m2o*r2o*sin(phi2o)+m2x*r2x*sin(phi2x))/(m2o*r2o*cos(phi2o)+m2x*r2x*cos(phi2x)));

phi3=atan((m3o*r3o*sin(phi3o)+m3x*r3x*sin(phi3x))/(m3o*r3o*cos(phi3o)+m3x*r3x*cos(phi3x)));

v1=r1x^2+r1^2-2*r1x*r1*cos(phi1x-phi1); u1=r1o^2+r1^2-2*r1o*r1*cos(phi1-phi1o);

v2=r2x^2+r2^2-2*r2x*r2*cos(phi2x-phi2); u2=r2o^2+r2^2-2*r2o*r2*cos(phi2-phi2o);

v3=r3x^2+r3^2-2*r3x*r3*cos(phi3x-phi3); u3=r3o^2+r3^2-2*r3o*r3*cos(phi3-phi3o);

I1=I1o+m1x*v1^2+m1x*u1^2;    I2=I2o+m2x*v2^2+m2x*u2^2;    I3=I3o+m3x*v3^2+m3x*u3^2;

%Parameters of the angle path planning

f=[];g=[];h=[];

%varied input speed(rad,rad/s,rad/s^2)

for t=0:0.01:1;

q1=x(16)+x(17)*t+x(18)*t^2+x(19)*t^3+x(20)*t^4+x(21)*t^5+x(22)*t^6+x(23)*t^7+x(24)*t^8+x(25)*t^9+x(26)*t^10;

omega1=x(17)+2*x(18)*t+3*x(19)*t^2+4*x(20)*t^3+5*x(21)*t^4+6*x(22)*t^5+7*x(23)*t^6+8*x(24)*t^7+9*x(25)*t^8+10*x(26)*t^9;

alpha1=2*x(18)+6*x(19)*t+12*x(20)*t^2+20*x(21)*t^3+30*x(22)*t^4+42*x(23)*t^5+56*x(24)*t^6+72*x(25)*t^7+90*x(26)*t^8;

% the angle of the coupler and crank(m,rad)

d=sqrt(l4^2+l1^2-2*l4*l1*cos(q1));

theted=atan((-l1.*sin(q1))/(l4-l1*cos(q1)));

q2=acos((l2^2+d.^2-l3^2)/(2*d*l2))+theted;

A=2*l4*l3-2*l1*l3*cos(q1);B=-2*l1*l3*sin(q1);C=l4^2+l1^2+l3^2-l2^2-2*l4*l1*cos(-q1);

q3=2*atan((-B-sqrt(B^2-C^2+A^2))/(C-A));

% the calculation of velocity

h1=-(l1*csc(q2-q3)*sin(q1-q3))/l2;

h2=-(l1*csc(q2-q3)*sin(q1-q2))/l3;

omega2=h1*omega1;

omega3=h2*omega1;

u=l1*cos(q1)+L*cos(q2+beta);

v=l1*sin(q1)+L*sin(q2+beta);

g=[g;u];

h=[h;v];

v1x=-r1*omega1*sin(q1+phi1);

v1y=r1*omega1*cos(q1+phi1);

v1=sqrt(v1x^2+v1y^2);

v2x=-l1*omega1*sin(q1)-r2*omega2*sin(q2+phi2);

v2y=l1*omega1*cos(q1)+r2*omega2*cos(q2+phi2);

v2=sqrt(v2x^2+v2y^2);

v3x=-r3*omega3*sin(q3+phi3);

v3y=r3*omega3*cos(q3+phi3);

v3=sqrt(v3x^2+v3y^2);

% the calculation of acceleration

h3=-((l1*cos(q1-q3)+l2*h1^2*cos(q2-q3)-l3*h2^2)*csc(q2-q3))/l2;

h4=((-l1*cos(q1-q2)-l2*h1^2+l3*h2^2*cos(q2-q3))*csc(q2-q3))/l3;

alpha2=h3*omega1^2+h1*alpha1;

alpha3=h4*omega1^2+h2*alpha1;

a1x=-r1*alpha1*sin(q1+phi1)-r1*omega1^2*cos(q1+phi1);

a1y=r1*alpha1*cos(q1+phi1)-r1*omega1^2*sin(q1+phi1);

a1=sqrt(a1x^2+a1y^2);

a2x=-l1*alpha1*sin(q1)-l1*omega1^2*cos(q1)-r2*alpha2*sin(q2+phi2)-r2*omega2^2*cos(q2+phi2);

a2y=l1*alpha1*cos(q1)-l1*omega1^2*sin(q1)+r2*alpha2*cos(q2+phi2)-r2*omega2^2*sin(q2+phi2);

a2=sqrt(a2x^2+a2y^2);

a3x=-r3*alpha3*sin(q3+phi3)-r3*omega3^2*cos(q3+phi3);

a3y=r3*alpha3*cos(q3+phi3)-r3*omega3^2*sin(q3+phi3);

a3=sqrt(a3x^2+a3y^2);

% the calculation of each joint’s force

r1x1=l1*cos(q1)-r1*cos(q1+phi1); r1y1=l1*sin(q1)-r1*sin(q1+phi1);

r2x1=l2*cos(q2)-r2*cos(q2+phi2); r2y1=l2*sin(q2)-r2*sin(q2+phi2);

r3x1=l3*cos(q3)-r3*cos(q3+phi3); r3y1=l3*sin(q3)-r3*sin(q3+phi3);

r2x=r2*cos(q2+phi2); r2y=r2*sin(q2+phi2);

Lx=L*cos(beta+q2); Ly=L*sin(beta+q2);

A=[1,0,1,0,0,0,0,0,0;

0,1,0,1,0,0,0,0,0;

-1,0,0,0,1,0,0,0,0;

0,-1,0,0,0,1,0,0,0;

0,0,0,0,-1,0,1,0,0;

0,0,0,0,0,-1,0,1,0;

-r1y1,r1x1,r1*sin(q1+phi1),-r1*cos(q1+phi1),0,0,0,0,1;

-r2*sin(q2+phi2),r2*cos(q2+phi2),0,0,-r2y1,r2x1,0,0,0;

0,0,0,0,r3y1,-r3x1,r3*sin(q3+phi3),-r3*cos(q3+phi3),0];

B=[m1*a1x;

m1*a1y;

m2*a2x;

m2*a2y;

m3*a3x;

m3*a3y;

I1*alpha1;

I2*alpha2;

I3*alpha3];

X=A\B;

f=[f;X’];

end

%把所有的Fsh,MshA,MshD和TIN都加起来

F41x=f(:,3);F41y=f(:,4);F43x=f(:,7);F43y=f(:,8);TIN=f(:,9);

Fsh=sqrt((F41x+F43x).^2+(F41y+F43y).^2);

MshA=-(F43y*l4+TIN);

MshD=(F41y*l4-TIN);

Fsh=sqrt(sum(Fsh.^2)./101);

%TIN=sqrt(sum(TIN.^2)./101);

MshA=sqrt(sum(MshA.^2)./101);

MshD=sqrt(sum(MshD.^2)./101);

%objective function

c1=sqrt(1/6*(g(14)-0.103)^2+(h(14)-0.220)^2+(g(22)-0.072)^2+(h(22)-0.242)^2+(g(34)+0.004)^2+(h(34)-0.231)^2+(g(51)+0.082)^2+(h(51)-0.149)^2+(g(59)+0.091)^2+(h(59)-0.1)^2+(g(93)-0.036)^2+(h(93)-0.090)^2);

c2=1/3*Fsh+1/3*MshA+1/3*MshD;

c=0.5*c1+0.5*c2;

可是最后出现了:

Warning: Large-scale (trust region) method does not currently solve this type of problem,

using medium-scale (line search) instead.

> In fmincon at 317

In main at 12

Optimization terminated: magnitude of directional derivative in search

direction less than 2*options.TolFun and maximum constraint violation

is less than options.TolCon.

No active inequalities.

望高手们予以解答,不甚感激啊!

[本帖最后由 DHU 于 2011-3-17 21:44 编辑]


推荐阅读
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • 恶意软件分析的最佳编程语言及其应用
    本文介绍了学习恶意软件分析和逆向工程领域时最适合的编程语言,并重点讨论了Python的优点。Python是一种解释型、多用途的语言,具有可读性高、可快速开发、易于学习的特点。作者分享了在本地恶意软件分析中使用Python的经验,包括快速复制恶意软件组件以更好地理解其工作。此外,作者还提到了Python的跨平台优势,使得在不同操作系统上运行代码变得更加方便。 ... [详细]
  • 本文介绍了贝叶斯垃圾邮件分类的机器学习代码,代码来源于https://www.cnblogs.com/huangyc/p/10327209.html,并对代码进行了简介。朴素贝叶斯分类器训练函数包括求p(Ci)和基于词汇表的p(w|Ci)。 ... [详细]
  • 深入理解Java虚拟机的并发编程与性能优化
    本文主要介绍了Java内存模型与线程的相关概念,探讨了并发编程在服务端应用中的重要性。同时,介绍了Java语言和虚拟机提供的工具,帮助开发人员处理并发方面的问题,提高程序的并发能力和性能优化。文章指出,充分利用计算机处理器的能力和协调线程之间的并发操作是提高服务端程序性能的关键。 ... [详细]
  • 摘要1:ElasticSearch比较两个时间的大小_gaojie_csdn的博客-CSDN博客_es时间比较摘要2:zlasticsearch脚本教 ... [详细]
  • 本文介绍了在MySQL8.0中如何查看性能并解析SQL执行顺序。首先介绍了查询性能工具的开启方法,然后详细解析了SQL执行顺序中的每个步骤,包括from、on、join、where、group by、having、select distinct、union、order by和limit。同时还介绍了虚拟表的概念和生成过程。通过本文的解析,读者可以更好地理解MySQL8.0中的性能查看和SQL执行顺序。 ... [详细]
  • 本文介绍了在处理不规则数据时如何使用Python自动提取文本中的时间日期,包括使用dateutil.parser模块统一日期字符串格式和使用datefinder模块提取日期。同时,还介绍了一段使用正则表达式的代码,可以支持中文日期和一些特殊的时间识别,例如'2012年12月12日'、'3小时前'、'在2012/12/13哈哈'等。 ... [详细]
  • 学习Java异常处理之throws之抛出并捕获异常(9)
    任务描述本关任务:在main方法之外创建任意一个方法接收给定的两个字符串,把第二个字符串的长度减1生成一个整数值,输出第一个字符串长度是 ... [详细]
  • VueCLI多页分目录打包的步骤记录
    本文介绍了使用VueCLI进行多页分目录打包的步骤,包括页面目录结构、安装依赖、获取Vue CLI需要的多页对象等内容。同时还提供了自定义不同模块页面标题的方法。 ... [详细]
  • Android自定义控件绘图篇之Paint函数大汇总
    本文介绍了Android自定义控件绘图篇中的Paint函数大汇总,包括重置画笔、设置颜色、设置透明度、设置样式、设置宽度、设置抗锯齿等功能。通过学习这些函数,可以更好地掌握Paint的用法。 ... [详细]
  • HashMap的相关问题及其底层数据结构和操作流程
    本文介绍了关于HashMap的相关问题,包括其底层数据结构、JDK1.7和JDK1.8的差异、红黑树的使用、扩容和树化的条件、退化为链表的情况、索引的计算方法、hashcode和hash()方法的作用、数组容量的选择、Put方法的流程以及并发问题下的操作。文章还提到了扩容死链和数据错乱的问题,并探讨了key的设计要求。对于对Java面试中的HashMap问题感兴趣的读者,本文将为您提供一些有用的技术和经验。 ... [详细]
  • java drools5_Java Drools5.1 规则流基础【示例】(中)
    五、规则文件及规则流EduInfoRule.drl:packagemyrules;importsample.Employ;ruleBachelorruleflow-group ... [详细]
author-avatar
手机用户2502907463
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有