优化设计上机指导书.doc
《优化设计上机指导书.doc》由会员分享,可在线阅读,更多相关《优化设计上机指导书.doc(48页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-date优化设计上机指导书2012前言上机指导书适用专业: 机械工程 课程代码: 8201581 编写单位: 机械工程学院 编 写 人: 杨昌明 审 核 人: 审 批 人: 目 录 实验一 (实验代码1) 1实验二 (实验代码2) 9注释 14主要参考文献 15MATLAB Optimization Toolbox应用基础专题 单变量函数最小值问题(一维问题)一、上机目的:1
2、、掌握一维搜索方法的基本概念、算法等知识点; 2、熟悉Matlab软件环境及有关语句和函数的使用方法。二、原理和方法:函数fminbnd是用来寻找单变量函数在固定区间内的最小值点及最小值。MATLAB各工具箱的每个函数,包括优化工具箱函数,都有多种不同的调用格式。其调用格式可使用在线帮助系统查询。函数fminbnd最常用的调用格式为:x, fval = fminbnd(fun, x1, x2)%返回函数fun在区间x1x x, fval = fminbnd(sin, 0, 2*pi)%符号“”表明目标函数为MATLAB自定义的正弦函数sin.m。x = 4.7124 %最小值点赋值给x。fva
3、l = -1.0000 %最小值赋值给fval。3、如果目标函数并不是MATLAB自定义的函数,需要首先定义一个函数M文件,以该文件的名称来代替上述命令行中的“sin”部分。如希望求出在0,1内的最小值及最小值点,首先编写目标函数的M文件opt1.m,如下:function f = myfun(x)%编写函数M文件时,上句代码中的“myfun”并不一定与文件名相同。f = (x3+cos(x)+x*log(x)/exp(x) 然后调用fminbnd函数,在命令窗口中输入: x, fval=fminbnd(opt1, 0, 1) x = 0.5223fval = 0.3974%注意此处使用“op
4、t1”而不是“myfun”。4、如果目标函数的表达式较为简单,也可以使用表达式的字符串而不必编写目标函数。如上例也可以使用x, fval=fminbnd(x3+cos(x)+x*log(x)/exp(x),0,1)实现。注:在MATLAB软件中,function为关键字,%为注释符号,为命令窗口中的提示符。专题 线性方程组的应用一、上机目的:1、了解线性规划问题及可行解、最优解的概念 ; 2、掌握Matlab软件关于求解线性规划的语句和方法。二、原理和方法:在工程实践中,很多重要的实际问题都是线性的(至少能够用线性函数很好的近似表示),所以我们一般把这些问题化为线性的目标函数和约束条件进行分析
5、,通常将目标函数和约束都是线性表达式的规划问题称为线性规划。其一般形式是: 矩阵形式表示为:线性规划的可行解是满足约束条件的解;线性规划的最优解是使目标函数达到最优的可行解。一般求解线性规划的常用方法是单纯形法和改进的单纯形法,这类方法的基本思路是先求得一个可行解,检验是否为最优解;若不是,可用迭代的方法找到另一个更优的可行解,经过有限次迭代后,可以找到可行解中的最优解或者判定无最优解。三、上机内容与步骤:在Matlab优化工具箱中,linprog函数是使用单纯形法求解下述线性规划问题的函数。命令格式为:其中:A为不等式约束条件矩阵,b, c分别为目标函数的系数向量和不等式约束条件中最右边的数
6、值向量;也可设置解向量的上界vlb和下界vub,即解向量必须满足vlb=x=vub;还可预先设置初始解向量x0。如没有不等式约束,而只有等式约束条件时,A= ,b= ;aeq与beq分别为等式约束矩阵;输出的结果:x表示最优解向量;fval表示最优值。某一线性规划问题,如下: 考虑到linprog函数只解决形式如下的线性规划。所以先要将线性规划变换为如下形式:建立M文件如下(如以文件名optest保存):c = -3;1;1;A = 1 -2 1; 4 -1 -2;b = 11;-3;aeq = 2 0 -1;beq = -1;vlb = 0;0;0;x,fval = linprog(c, A
7、, b, aeq, beq, vlb) 则在命令窗口中输入:optest,可得到计算结果:x1 = 4,x2 = 1,x3 = 9,fval = 2。专题 无约束规划计算方法一、上机目的1、了解无约束规划问题的求解原理与方法 ; 2、会用Matlab软件求解无约束规划问题。 二、原理和方法无约束规划问题的解法一般按目标函数的形式分为两大类:一类是一元函数的一维搜索法,如黄金分割法、插值法等;另一类是求解多元函数的下降迭代法。三、上机内容与步骤在Matlab软件中,求解无约束规划的常用命令是: x=fminunc(fun, x0) 其中,fun函数应预先定义到M文件中。 问题如下:初始点x0 =
8、 -2 4首先建立函数文件fun02.mfunction f = fun02(x)f = 3/2*x(1)2 + 1/2*x(2)2 - x(1)*x(2) - 2*x(1)在命令窗口输入: x0=-2;4x=fminunc(fun02,x0)计算结果:极小值为-1,最优点:x1=1,x2=1。专题 约束非线性规划计算方法 一、上机目的1、了解约束非线性规划问题的求解原理与方法; 2、会用Matlab软件求解约束非线性规划问题。 二、原理和方法对于约束非线性规划,随着目标函数和约束条件的不同,解法也不同,一般来说,有两类方法:(1)、将约束问题转化为无约束问题的求解方法;(2)、用线性规划来逼
9、近非线性规划;三、上机内容与步骤约束非线性规划的一般形式为:其中,f(x)为多元实值函数;g(x)为向量函数,并且f(x),g(x)中至少有一个函数是非线性函数的(否则成为线性规划问题)。在Matlab优化工具箱中,fmincon函数是用SQP算法来解决一般的约束非线性规划的函数,其命令格式为:x = fmincon(fun, x0, A, b)x = fmincon(fun, x0, A, b, Aeq, beq)x = fmincon(fun, x0, A, b, Aeq, beq, lb, ub)x = fmincon(fun, x0, A, b, Aeq, beq, lb,ub, no
10、nlcon)对于如下约束非线性规划问题:建立一个M文件 fun05.m,代码如下:function y=fun05(x)y=(x(1)-1)2+(x(2)-2)2+(x(3)-3)2+(x(4)-4)2;存储为fun05.m文件.在命令窗口输入:x0 = 1;1;1;1; A= 1 1 1 1;3 3 2 1;B = 5;10; Aeq = ; Beq = ;Lb = 0;0;0;0;x, g = fmincon(fun05,x0,A,B,Aeq,Beq,Lb)计算结果为:X = 0.0000 0.6667 1.6665 2.6668g = 6.3333实验一 齿轮传动系统优化设计一、 上机目
11、的和任务 1、 机械优化设计是一门实践性很强的课程,通过实际上机计算达到以下目的:1)加深对机械优化设计方法的基本理论和算法的理解。 2)培养学生独立编制计算机程序的能力。3)掌握常用优化方法程序的使用方法。4)培养学生灵活运用优化设计方法解决工程实际问题的能力。二、 上机内容某二级斜齿圆柱齿轮减速器(如图1所示),高速级输入功率 =6.2KW,转速=1450r/min;总传动比i=31.5,齿轮宽度系数=0.4,齿轮材料和热处理:大齿轮45号钢正火187207HB,小齿轮45号钢调质228255HB,工作寿命10年以上。要求按照总中心距 最小来确定齿轮传动方案。图1 传动系统简图三、 上机步
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 优化 设计 上机 指导书
限制150内