文档详情

ANSYS高级分析:优化设计(三)-优化算法.doc

发布:2017-07-18约3.44千字共3页下载文档
文本预览下载声明
理解ANSYS优化模块的计算机程序的算法是很有必要的,也只有这样才能弄清楚ANSYS优化设计的来龙去脉,本篇主要讲述了ANSYS优化设计时最常用的优化技术,但因为ANSYS能够兼容使用者自己开发的优化算法,所以ANSYS优化技术有其广阔的提升和发展空间。 1、引言 ??? ANSYS程序最常见的优化算法有零阶方法,一阶方法,随机搜索法,等步长搜索法,乘子计算法和最优梯度法。本篇仅作简单描述,更多的细节参见ANSYS Theory Reference? chapter 20。要想深刻的了解这些算法,需要具有一定数学知识,并有一定的兴趣爱好才能精下心了好好的理解和学习这一部分的理论性内容,但这也是快速提升自己水平的好途径。 2、优化算法简介 2.1 零介方法 ??? 零阶方法之所以称为零阶方法是由于它只用到因变量而不用到它的偏导数。在零阶方法中有两个重要的概念: ??? 1)目标函数和状态变量的逼近方法; ??? 2)由约束的优化问题转换为非约束的优化问题。 ??? 逼近方法是指程序用曲线拟合来建立目标函数和设计变量之间的关系。这是通过用几个设计变量序列计算目标函数然后求得各数据点间最小平方实现的。该结果曲线(或平面)叫做逼近。每次优化循环生成一个新的数据点,目标函数就完成一次更新。实际上是逼近被求解最小值而并非目标函数。状态变量也是同样处理的。每个状态变量都生成一个逼近并在每次循环后更新。用户可以控制优化近似的逼近曲线。可以指定线性拟合,平方拟合或平方差拟合。缺省情况下,用平方差拟合目标函数,用平方拟合状态变量。用下列方法实现该控制功能: ??? Command: OPEQN ??? GUI: Main MenuDesign OptMethod/Tool ??? 转换为非约束问题的原因是状态变量和设计变量的数值范围约束了设计,优化问题就成为约束的优化问题。ANSYS程序将其转化为非约束问题,因为后者的最小化方法比前者更有效率。转换的实现方法是通过对目标函数逼近加罚函数的方法计入所加约束的。 ??? 收敛检查:前面的或最佳设计是合理的而且满足下列条件之一时,问题就是收敛的: ??? 1)目标函数值由最佳合理设计到当前设计的变化应小于目标函数允差。 ??? 2)最后两个设计之间的差值应小于目标函数允差。 ??? 3)从当前设计到最佳合理设计所有设计变量的变化值应小于各自的允差。 ??? 4)最后两个设计所有设计变量的变化值应小于各自的允差。 ??? 但收敛并不代表实际的最小值已经得到了,只说明以上四个准则之一满足了。因此,用户必须确定当前设计优化的结果是否足够。如果不足的话,就要另外做附加的优化分析。 ??? 对于零阶方法,优化处理器开始通过随机搜索建立状态变量和目标函数的逼近。由于是随机搜索,收敛的速度可能很慢。用户有时可以通过给出多个合理的起始设计来加速收敛。只简单的运行一系列的随机搜索并删除所有不合理的设计。也可以运行多次单独的循环,并在每次运行前指定新的设计变量序列来生成起始设计序列。 2.2 一阶方法 ??? 一阶方法同零阶方法一样,一阶方法通过对目标函数添加罚函数将问题转换为非约束的。但是,与零阶方法不同的是,一阶方法将真实的有限元结果最小化,而不是对逼近数值进行操作。 ??? 一阶方法使用因变量对设计变量的偏导数。在每次迭代中,梯度计算(用最大斜度法或共轭方向法)确定搜索方向,并用线搜索法对非约束问题进行最小化。因此,每次迭代都有一系列的子迭代(其中包括搜索方向和梯度计算)组成。这就使得一次优化迭代有多次分析循环。 ??? OPFRST命令(Main MenuDesign OptMethod/Tool)有两个输入域可以用来改善一阶方法的收敛。用户可以指定计算梯度的设计变量范围变化程度,也可以指定线搜索步长的范围。一般来说,这两个输入值的缺省数值就足够了。见ANSYS Theory Reference。 ??? 一阶方法在收敛或中断时结束。当当前的设计序列相对于前面的和最佳序列满足下面任意一种情况时,问题就称为收敛: ??? 1)目标函数值由最佳合理设计到当前设计的变化应小于目标函数允差。 ??? 2)从当前设计到前面设计目标函数的变化值应小于允差。 ??? 3)同时要求最后的迭代使用最大斜度搜索,否则要进行附加的迭代。 ??? 与零阶方法相比,一阶方法计算量大且结果精确。但是,精确度高并不能保证最佳求解。一阶方法可能在不合理的设计序列上收敛。这时可能是找到了一个局部最小值,或是不存在合理设计空间。如果出现这种情况,可以使用零阶方法,因其可以更好的研究整个设计空间。也可以先运行随机搜索确定合理设计空间(如果存在的话),然后以合理设计序列为起点重新运行一阶方法。一阶方法更容易获得局部最小值。(见后面“局部和全局最小值”的说
显示全部
相似文档