热门问题
时间线
聊天
视角
非线性规划
来自维基百科,自由的百科全书
Remove ads
在数学中,非线性规划是求解由一系列未知实函数组成的组方程和不等式(统称为约束)定义的最佳化問題,伴随着一个要被最大化或最小化的目标函数,只是一些约束或目标函数是非線性的。[1]它是最优化处理非线性问题的一个子领域。
适用性
从一系列运输方法中选择优化运输成本的一个或多个表现规模经济的连通性和容量约束不同的非凸问题。例如从管道、铁路油槽车、罐车、河驳船或沿海油船中选择或组合的石油产品运输。由于经济批量大小,除了平滑变化之外,成本函数可以有不连续性。
现代工程实践涉及到大量的数值优化。除了在很少一部分重要情形(如无源电路)中,工程问题是非线性的,它们通常是非常复杂。
在实验科学中,一些简单的数据分析(如已知位置和形状但未知幅度的峰的总和的光谱的拟合)可以用线性方法来完成,但一般来说这些问题也是非线性的。通常研究的是含有变量参数的系统的理论模型以及含有未知参数的试验模型。可以试着用数值寻找最优值。这种情况下,除了最优值本身通常还需要对结果的精度进行量度。
定义
令 n、m、p为正整数。令 X 为 Rn 的一个子集,令 f、gi 和 hj 为 X 的实值函数,对每个 i 属于 {1, …, m} 及每个 j 属于 {1, …, p}。
非线性最小化问题等效为下面形式的最佳化問題
非线性最大化问题定义方式类似。
Remove ads
约束集的可能类型
约束集的性质有若干可能性,也被称为可行集或可行域。
無解問題(infeasible problem)是指沒有一組變數可以滿足所有的約束,也就是約束之間有互相矛盾的情形,沒有解存在。
有解問題(feasible problem)是指至少有一組變數可以滿足所有的約束條件。
无界限問題(unbounded problem)是一個有解問題,其變數沒有上限限制,因此沒有最佳解,因為總會有一組變數使得目標函數比其他組的變數有更好的結果。
求解問題的方案分析
- 若目標函數f(x)為線性,約束的空间為多胞形,对应线性规划問題,采用著名的线性规划法求解。
- 若目標函數為凹函数(最大化)或是凸函数(最小化),且約束為凸集,对应凸規劃問題,常采用凸優化求解。若目標函數是凹函数和凸函数的比值(最大化問題)及約束為凸集,对应分數規劃的方式轉換為凸集的求解問題。
- 許多方式可以解非凸集的問題。其一個方式是用線性規劃問題的特殊公式;另一種方式則是用分支定界法:將問題分為幾個可以用凸集法(最小化問題)求解或是線性近似的子集合,較小區域內的總成本會有一下限。在隨後的分區後,在一些點上其成成本會等於所有近似解的下限,此解即為實際解。此解雖然不一定唯一,不過是為最佳解。若已確認可能的最佳解和已找到的解之間的誤差在容許值內,可以提早結束此演算法。這些點稱為ε-最佳。若要在有限內結束,一般就需要在ε-最佳點結束。尤其在大型的、困難的問題,或是問題有不確定的成本或價值,但不確定以由適當的信賴性估測所估測時,更需要在ε-最佳點結束的技巧。
- 在可微函数及約束規范的條件下,卡羅需-庫恩-塔克條件(KKT條件)是有最佳解的必要條件。在凸集的條件下,這也是充份條件。若其中有些函數是不可微分的,也可以用次导数條件的卡羅需-庫恩-塔克條件。[2]
Remove ads
例子

可以用下列约束来定义一个简单问题
- x1 ≥ 0
- x2 ≥ 0
- x12 + x22 ≥ 1
- x12 + x22 ≤ 2
需要最大化的目标函数为
- f(x) = x1 + x2

用下面这些约束就可以定义另一个简单的问题
- x12 − x22 + x32 ≤ 2
- x12 + x22 + x32 ≤ 10
需要最大化的目标函数为
- f(x) = x1x2 + x2x3
应用
参见
参考文献
延伸阅读
外部链接
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads