積和式
在線性代數中,積和式(英語:permanent)是一個由方塊矩陣計算得到的標量,記作。積和式的定義與行列式類似,只是在求和時不添加正負號。當矩陣包含若干變量時,積和式也可以看作是一個關於這些變量的多項式。積和式在計算機科學,特別是計算複雜性理論中有重要的地位,因為理論上的一個重要難題——計算一個二分圖(bipartite graph)上完美匹配(perfect matching)的數目——等價於求某個矩陣的積和式。
定義
編輯一個 矩陣 的積和式定義為
其中 為 階對稱群_(n次對稱群),即包含所有 元排列的集合。在 的特殊情形下,
從定義不難驗證,積和式是多線性多項式,且置換 中行(或列)後保持不變。與行列式類似,積和式也可以用拉普拉斯展開式展開。
作為比較,同一個矩陣 的行列式定義為
其中 為符號差。可以看出,兩者形式上的區別僅在於某些項前面的符號有所不同。儘管如此,它們在性質上卻有諸多不同。比如,置換 中兩行(或列)後行列式的符號會改變,而正是這一性質使我們得以利用高斯消元法高效求出行列式的值。
與組合問題的聯繫
編輯積和式的定義可以從如下兩方面理解,一是用於計算二分圖上完美匹配的個數,二是用於計算一個圖上的圈覆蓋的個數。
與二分圖完美匹配的關係
編輯二分圖上的完美匹配是算法理論和計算複雜性理論中的重要問題。設二分圖 ,其中 是左邊結點的集合, 是右邊結點的集合, 為邊的集合。如果雙射 滿足 均為 中的邊,那麼我們稱其為 的一個完美匹配。
對包括二分圖在內的任意圖 ,我們定義其鄰接矩陣 如下:若 則 ,否則 。不難驗證, 的值即是 中完美匹配的個數,因為乘積項與雙射之間一一對應,而不滿足條件的雙射所對應的乘積項為零。這樣,我們就將積和式的值與二分圖完美匹配的個數建立了聯繫。
與圖的圈覆蓋的關係
編輯設有向圖 , 為結點集, 為邊集。 的一個圈覆蓋定義為 中一組不相交的圈的集合,且這些圈覆蓋了 。由於一個置換可以做環狀分解,可以看出一個置換與一個可能的圈覆蓋是一一對應的。特別地, 的鄰接矩陣 的積和式即是 中圈覆蓋的數目。
積和式的計算複雜性
編輯Valient首先證明了積和式的求值問題是#P完全的,即便矩陣各項的值僅能取0或1[1]。也就是說,任何#P複雜性類中的計數問題都能多項式歸約到積和式的求值問題。而戶田定理(Toda's theorem)告訴我們 ,因此假若能在確定性多項式時間內解決積和式求值問題,那麼也能在確定性多項式時間內解決一切屬於多項式譜系( )的判定問題,進而導致 ;計算機科學家普遍相信這是不可能的。可見計算積和式的複雜性遠比計算行列式高;後者易用高斯消元等算法在確定性多項式時間內解決。
雖然精確計算積和式很困難,但是的確存在近似計算積和式的高效算法。Jerrum,Sinclair和Vigoda設計出了一種多項式時間內的隨機算法,能以任意精度(FPRAS)近似計算非負矩陣的積和式[2]。
參考文獻
編輯- ^ Valiant, L.G. The complexity of computing the permanent. Theoretical Computer Science. 1979, 8 (2): 189–201 [2020-10-21]. doi:10.1016/0304-3975(79)90044-6. (原始內容存檔於2021-03-08) (英語).
- ^ Jerrum, Mark; Sinclair, Alistair; Vigoda, Eric. A polynomial-time approximation algorithm for the permanent of a matrix with non-negative entries. Proceedings of the thirty-third annual ACM symposium on Theory of computing - STOC '01 (Hersonissos, Greece: ACM Press). 2001: 712–721. ISBN 978-1-58113-349-3. doi:10.1145/380752.380877 (英語).