單體法

本頁使用了標題或全文手工轉換
維基百科,自由的百科全書

單體法(simplex algorithm)在數學最佳化領域中常用於線性規劃問題的數值求解,由喬治·伯納德·丹齊格發明。

下山單體法(Nelder-Mead method)與單體法名稱相似,但二者關聯不大。該方法由Nelder和Mead於1965年發明,是用於最佳化多維無約束問題的一種數值方法,屬於更普遍的搜索算法的類別。這兩種方法都使用了單體的概念。單體 維中的 頂點凸包,是一個多胞體:直線上的一個線段,平面上的一個三角形,三維空間中的一個四面體等等,都是單體。

標準形式[編輯]

假設有n個變量和m個約束。線性規劃的標準形式如下:

所有其他形式的線性規劃方程組都可以按照下列方式轉化成標準形式:

  • 目標函數並非最大化:將所有取負。
  • 約束條件中存在大於或等於約束:將約束兩邊取負。
  • 約束條件中存在等式:將其拆分為兩個不等式(一個大於等於,一個小於等於)
  • 有的變量沒有非負約束:加入新變量並用替換原來的變量

鬆弛形式[編輯]

可以將標準形式的線性規劃轉化為鬆弛形式,以方便運算。 在原來n個變量,m個約束的線性規劃中,加入m個新的變量,將原來的不等式化為等式:

當然,此時依然成立。

我們將這些變量稱為非基變量,它們構成的集合記為N。將 這些變量稱為基變量,它們構成的集合記為B。簡單地理解,非基變量能夠由基變量唯一確定。

在這樣的定義下,線性規劃的鬆弛形式可以寫為如下形式:

因此,線性規劃的鬆弛形式可以由唯一確定,是長度為n的向量是長度為m的向量是m*(n+m)的矩陣整數集合,分別表示非基變量集合以及基變量集合。

轉軸操作[編輯]

轉軸操作是單體法中的核心操作,其作用是將一個基變量與一個非基變量進行互換。可以將轉軸操作理解為從單體上的一個頂點走向另一個頂點。

設變量屬於B(基變量),變量屬於N(非基變量),執行轉軸操作pivot(d,e)之後,將變為非基變量,相應地將變為基變量。

具體地說,一開始我們有

移項,得

如果,我們有

將此式代入其他的約束等式以及目標函數,我們就實現了在基變量和非基變量上的互換。

方法步驟[編輯]

單體法的一般解題步驟可歸納如下:

  1. 把線性規劃問題的約束方程組表達成典範型方程組,找出基本可行解作為初始基本可行解。
  2. 若基本可行解不存在,即約束條件有矛盾,則問題無解。
  3. 若基本可行解存在,從初始基本可行解作為起點,根據最優性條件和可行性條件,引入非基變量取代某一基變量,找出目標函數值更優的另一基本可行解。
  4. 按步驟3進行疊代,直到對應檢驗數滿足最優性條件(這時目標函數值不能再改善),即得到問題的最優解。
  5. 若疊代過程中發現問題的目標函數值無界,則終止疊代。

最佳化過程[編輯]

如果b向量所有元素非負,則顯然我們只需要令所有的變量等於0,就可以得到一個可行解。在這種情況下,通過下述最佳化過程,我們可以得到該線性規劃的最優解,或者指出該線性規劃的最優解為無窮大(不存在)。

  1. 任取一個非基變量,使得
  2. 選取一個基變量,使得,且最小化
  3. 執行轉軸操作pivot(d, e),並轉到第一步繼續算法。

根據的最小性不難證明pivot(d, e)不會破壞b的非負性。因此將所有變量取0值仍然是可行解。同時,根據,我們發現v一定是不降的。這就達到了更新解的目的。

不難發現,算法終止有兩種情況:

  1. 對於所有的非基變量,c均非正。
  2. 對於某一個e,所有的均非正。

可以證明,對於第一種情況,我們已經得到了該線性規劃的最優解。當前的v即為答案。嚴格證明比較複雜,但是直觀上是很容易理解的。因為所有的非基變量都是非負的,而所有的c都是非正的,因此只要某個非基變量不為0,就會使得目標函數更小。

對於第二種情況來說,很容易證明此時線性規劃的最優解是無窮大。只要讓其他所有變量均為0,變量為正無窮。由於所有的都非正,因此非基變量的非負性得到保證。同時由於,目標函數值為正無窮。

實例[編輯]

例:解最佳化問題:

列單體表(即矩陣):

b
2 1 1 0 12
1 2 0 1 9
c 1 1 0 0 0

從c所在行的正數中最大的一個所對應的變量作為基變量,因為這裏兩者相等,不妨選為

所在列的正系數除b所在列的數並比較大小,有,故取離開基變量。

然後對該矩陣進行轉軸操作,使所在列變為單位向量:

b
1 1/2 1/2 0 6
0 3/2 -1/2 1 3
c 0 1/2 -1/2 0 -6

令c所在行其餘最大的正數所在列的變量進入基變量,並且根據,令離開基變量。

繼續進行行轉換,得到

b
1 0 2/3 -1/3 5
0 1 -1/3 2/3 2
c 0 0 -1/3 -1/3 -7

由於c所在行的所有數均非正,問題結束。最優解為,最優值為

初始化過程[編輯]

如果b向量並不全為非負,則我們需要通過初始化過程來找到一個可行解,然後才可以使用最佳化過程進行最佳化。當然,此時原線性規劃不一定存在可行解。

具體的方法是,加入一個新的非基變量,並在原線性規劃的基礎上構造一個新的輔助的線性規劃。

注意這裏N集合併不包含

然後,選擇一個基變量使得最小,執行轉軸操作pivot(d, 0)。不難證明該操作過後所有的b值全部非負。然後,使用前文中所述的最佳化過程求解該輔助線性規劃。

由於非負,因此該線性規劃的答案非正。如果答案為負數,則說明原線性規劃不可能讓所有的基變量都非負,因此原線性規劃無可行解。否則,只要令所有變量為0,並去掉變量,就可以得到可行解。

在從輔助線性規劃轉化到原來的線性規劃的過程中,如果已經是非基變量,則可以將其從約束條件和目標函數中直接去掉。否則,需要任取一個非基變量執行pivot(0, e),將變為非基變量。由於此時是基變量且,故一定成立,因此這個轉軸操作不會破壞b向量的非負性。

效率分析[編輯]

在採用Bland's法則選擇用於轉軸操作的d和e(相同值的情況下取字典序最小)之後,可以證明單體法一定能夠在有限步之後終止,但是最壞情況算法的時間複雜度指數函數級別的,而且可以構造出讓單體法的時間複雜度達到指數級別的具體實例。不過實踐證明在絕大多數情況下單體法的效率非常令人滿意。

單體法的最壞時間複雜度為指數級別,並不意味着線性規劃不存在多項式級別的算法。橢球算法內點算法均為解決線性規劃的多項式時間算法。

參考[編輯]

參看[編輯]

外部連結[編輯]