3. 最適化問題

2020/1/4公開

S\mathcal{S}を空でない任意の集合とする。S\mathcal{S}上の目的関数(objective function)と呼ばれる関数f ⁣:SR ⁣:xf(x)f \colon \mathcal{S} \to \mathbb{R} \colon x \mapsto f(x)を最小化(または最大化)する点xx ^ \astを求める問題をS\mathcal{S}上の最適化問題(optimization problem)という。この問題の解xx ^ \astは問題の最適解(optimal solution)という。

特に関数ffS\mathcal{S}上の連続関数であるとき、その最適化問題は連続最適化問題(continuous optimization problem)と呼ばれる。

関数ffの最小値(minimum value)、最大値(maximum value)はそれぞれ

minxSf(x),maxxSf(x)\underset{ x \in \mathcal{S} }{\operatorname{min}} \, f(x) \, , \,\, \underset{ x \in \mathcal{S} }{\operatorname{max}} \, f(x)

と表記される。

最適解xx ^ \astは一般にひとつとは限らない。そこで関数ffの最小値を与える最適解の集合を

argminxSf(x)\underset{x \in \mathcal{S}}{\operatorname{arg} \operatorname{min}} \, f(x)

と表記する。最適解の集合は空集合になることもあるし、最適解が無数に存在することもある。argmin\operatorname{arg}\operatorname{min}は「argument of minimum(最小値を与える引数)」の略である。この最適解の集合を求める問題をS\mathcal{S}上の最小化問題(minimization problem)という。同様に、関数ffの最大値を与える最適解の集合を

argmaxxSf(x)\underset{x \in \mathcal{S}}{\operatorname{arg} \operatorname{max}} \, f(x)

と表記する。argmax\operatorname{arg}\operatorname{max}は「argument of minimum(最大値を与える引数)」の略である。この集合を求める問題をS\mathcal{S}上の最大化問題(maximization problem)という。

関数ffの符号を反転すれば最小化問題と最大化問題は入れ替えることができるので、最適化問題ではどちらか一方を考えれば十分であり、大抵は最小化問題として扱うことが多い。

最適化問題には制約条件(constraint、束縛条件ということもある)を課す場合がある。たとえば正定値対称行列AAの最大の固有値に対応する固有ベクトルを求めるには、レイリー商

f(x)=xTAxf(x) = x ^ \mathrm{T} A x

の最大化問題を考えることになる。しかしこの目的関数はxxのノルムを大きくしていけばいくらでも大きな値をとるので、その最適解はx=+\| x \| = +\inftyとなるような点xxの集合という無意味な解になる。実際、固有ベクトルにはノルムの自由度が存在して、重要なのはその方向だけなので、x=1\| x \| = 1の範囲で解を探せば十分である。この最大化問題は

argmaxxRnxTAxs.t.x=1\underset{x \in \mathbb{R} ^ n}{\operatorname{arg} \operatorname{max}} \, x ^ \mathrm{T} A x\quad \operatorname{s.t.} \|x\| = 1

と書く。「s.t.\operatorname{s.t.}」は「such that(〜を満たすような)」または「subject to(〜の条件下で)」の略である。どちらと読むかはその人の好みでよい。

制約条件のついた最適化問題を制約付き最適化問題(constrained optimization problem)という。g(x)=cg(x) = cの形で書かれる制約条件を等式制約(equality constraint)といい、h(x)ch(x) \leq cの形で書かれる制約条件を不等式制約(inequality constraint)という。h(x)<ch(x) < cの形で不等式制約を設けると目的関数の最大値や最小値の存在を保証するのが難しくなるので、この形は連続最適化の文脈ではほとんど見かけない。

等式制約と不等式制約は同時に課してもよいし、また同時にいくつ課してもよい。したがって制約付き最適化問題は一般に

argmaxxRnf(x)s.t.Ei{gi(x)=ci},Ej{hj(x)dj}\underset{x \in \mathbb{R} ^ n}{\operatorname{arg} \operatorname{max}} \, f(x) \quad \operatorname{s.t.} \underset{i}{{\sf E}} \left\{ g _ i (x) = c _ i \right\}, \underset{j}{{\sf E}} \left\{ h _ j (x) \leq d _ j \right\}

という形で表される。ただしE{\sf E}は「列挙」を意味する記号で

Ei{gi(x)=ci}g1(x)=c1,g2(x)=c2,,gn(x)=cn\underset{i}{{\sf E}} \left\{ g _ i (x) = c _ i \right\} \equiv g _ 1(x) = c _ 1, g _ 2(x) = c _ 2, \ldots, g _ n(x) = c _ n

と定義する。詳しくは

page数学記号記法一覧

を参照のこと。

制約付き最適化問題に対して、制約条件のない最適化問題は制約なし最適化問題(unconstrained optimization problem)という。

Last updated