劣モジュラ関数

提供: testwiki
ナビゲーションに移動 検索に移動

劣モジュラ関数(れつモジュラかんすう、テンプレート:Lang-en-short)とは、数学において集合関数の一種で、簡単にいうと、関数に渡される集合に1つ要素が加わった場合に増える関数の値が、もとの集合が大きくなるにつれ小さくなるような関数を指す。集合関数であることを明示して劣モジュラ集合関数ということもある。劣モジュラ関数の概念は一般のベクトル値関数における凸関数の概念と類似した性質を持つため、近似アルゴリズムやゲーム理論機械学習などの幅広い応用を持つ。

定義

台集合 テンプレート:Math の冪集合 テンプレート:Math 上の関数 テンプレート:Math で 次を満たす関数を劣モジュラ関数と呼ぶ。

劣モジュラ性
任意の集合対 テンプレート:Math に対して、テンプレート:Math

この不等式を劣モジュラ不等式と呼ぶ。 なお、不等号の向きを逆にした不等式を優モジュラ不等式と呼び、それを満たす集合関数を優モジュラ関数と呼ぶ。

また、上記の不等式と以下の 2 つの不等式は同値である。

  1. 任意の集合対 X,YΩ,XY と任意の xΩY に対して、f(X{x})f(X)f(Y{x})f(Y)
  2. 任意の集合 XΩx1,x2ΩX,x1x2 に対して、 f(X{x1})+f(X{x2})f(X{x1,x2})+f(X)

非負の劣モジュラ関数は劣加法的であるが、劣加法的関数が必ずしも劣モジュラとは限らない。

劣モジュラ関数の例

ここでは劣モジュラ関数の例として、単調関数、非単調関数、対称関数、及び非対称関数について述べる。 以下、Ω を劣モジュラ関数の台集合とする。

単調関数

劣モジュラ関数 f が全ての ST に対して f(S)f(T) を満たすとき単調と呼ぶ。以下、単調関数の例である。

線形関数
f(S)=iSwiという形で表せる全ての集合関数。

この場合、i,wi0なら単調。

バジェット加法型関数
f(S)=min(B,iSwi) という形で表せる関数のうち、wi0,B0を満たす関数。
被覆関数
集合Ω={E1,E2,,En}が何らかの元集合Ωの部分集合族であるとする。これに対して、f(S)=|EiSEi| for SΩ という形で表せる関数。
エントロピー関数(Ωは確率変数の集合)
任意の SΩ に対して、Sエントロピーを返すような関数 H(S)
マトロイド階数関数(Ωマトロイドの台集合)
マトロイドの階数関数は劣モジュラ関数。

非単調関数

単調関数でない劣モジュラ関数。

対称な劣モジュラ関数

任意の SΩ に対して f(S)=f(ΩS) を満たす劣モジュラ関数を対称であるという。 以下、対称な劣モジュラ関数の例である。

カット関数(Ω はグラフの頂点集合)
任意の SΩに対して、f(S) が、e=(u,v),uS,vΩS を満たす辺 e の数を返す関数となるとき f をカット関数と呼ぶ。

上記の条件を満たす辺重みの合計を返すような関数として定義する場合がある。 辺重み無しの場合を上記で考える場合、重み 1: 辺が存在する、重み 0: 辺が存在することを表す。

相互情報量(Ω は確率変数の集合)
任意の SΩ に対して、f(S)=I(S;ΩS)I(S;Ω)は相互情報量)となる関数。

非対称な劣モジュラ関数

単調でも対称でもない劣モジュラ関数。 以下、非対称な劣モジュラ関数の例である。

有向グラフのカット関数(Ω は有向グラフの頂点集合)
この集合 Ω に対して定義されたカット関数は非対称な劣モジュラ関数である。

出る辺に関するカット関数と、入る辺に関するカット関数は対称でないことからこのことが分かる。

連続関数への拡張

劣モジュラ関数の連続化として、ロバース拡張や多重線形拡張がある。 テンプレート:節スタブ

ロバース拡張

ベクトル 𝐱={x1,x2,,xn} であって、各要素が 0xi1 となるものに対し、fL(𝐱)=𝔼(f({i:xiλ})) で定義される関数を集合関数 f のロバース拡張(Lovász extension)という。この関数は閉区間 [0,1] 上の一様分布から λ 以上のものを選んだ時の期待値を返すような関数になっており、この関数は凸関数になる。

一般化

参考文献

関連項目