階数因数分解(かいすういんすうぶんかい、英: rank factorization)あるいは階数分解(rank decomposition)とは、数学の線型代数学の分野において、階数が  のある与えられた  行列  のある  行列  と  行列  の積としての表示  のことを言う。
全ての有限次元行列には階数因数分解が存在する: を、列階数が  であるような  行列とする。すなわち、 には  個の線型独立な列が含まれる。あるいは同じ意味であるが、 の列空間の次元は  である。 を、 の列空間の任意の基底とし、それらを列ベクトルとして  行列  を構成する。したがって、 の全ての列ベクトルは、 の列の線型結合である。正確に言うと、 を第  列が  であるような  行列とすれば、
となる。ただし  は、基底  に関する  のスカラー係数である。このことは、 を -成分とする行列  によって  が得られることを意味する。
rank(A) = rank(AT)
階数因数分解から直ちに従う帰結として、 の階数はその転置行列  の階数と等しい、というものがある。すると  の列は  の行であることから、 の列階数と行階数は等しいことが分かる。
証明:これが真であることを示すために、はじめに行列の「階数」とはその「列階数」を意味するものであると定義しておく。 より、 が従う。行列乗算の定義から、この等式は  の各列が  の列の線型結合であることを意味する。したがって、 の列空間は  の列空間に含まれるものであることが分かり、したがって rank() ≤ rank() が成立する。今  は × 行列であるので、 には  個の列が存在し、したがって rank() ≤  = rank() が成立する。これより rank( ≤ rank() が示された。続いて、その逆の不等式が成立することを示すために、 に対して上述の結果を適用する。 =  なので、rank() = rank( ≤ rank() と書くことが出来る。このことから rank( ≤ rank() が示される。したがって、rank( ≤ rank() かつ rank() ≤ rank() であることから、rank() = rank() が示された。
行階段形からの階数因数分解
実際、特定の階数因数分解を次の手順で構成することが出来る: の行既約階段形  は計算することで得られる。このとき、上述の行列  は  から全ての非ピボット列を除くことで得られ、 は  から全てのゼロ行を除くことで得られる。
例
行列
を考える。 は既約階段形である。このとき、 は、 の唯一つの非ピボット列である第三列を除くことで得られ、 は最後のゼロ行を除くことで得られる。すなわち、
が得られる。次の関係式が、直ちに確かめられる:
証明
 を、ブロック区分けの形式で  が成立するような  置換行列とする。ただし  はその列が  の  個のピボット列であるものとする。 の全ての列は  の列の線形結合であり、したがって  が成立するような行列  が存在する。ただし  の列は、それら各線形結合の係数を含むものである。すると、 単位行列  によって  と書くことが出来る。続いて、 を証明する。
 を、基本行列の積であるような行列  を左から掛けることによって、行既約階段形へと変換する。すなわち、 が得られる。ただし  である。すると、 と書くことが出来、したがって  ということが分かる。これはすなわち、 に対して行ったものと同様の置換を列に対して行うことで得られる、行既約階段形に含まれる非ゼロの  個の行である。したがって、 が得られ、 が可逆であることから  が得られる。以上で証明は完成された。
参考文献




