数学における最適化技術
定義
- 関数の関数値を最小にするを見つける問題を最適化問題optimization Problemと呼び、その問題を解くアルゴリズムを最適化技法と呼ぶ。最適化問題で与えられた関数は特に目的関数objective functionと言う。
- 全てのに対してを満たすを全域最適解global Optimizerと呼ぶ。
- 全てのに対してを満たすの近傍が存在する場合、そのを局所最適解local Optimizerと呼ぶ。
これらの定義では、不等式の向きが逆でも、つまり最大化について説明されても、それらは総じて最適化と呼ばれる。
説明
最適化技法を使用する人々は「利益を最大化」または「コストを最小化」と言うことができるが、数学者にとっては最大か最小かは重要な問題ではない。最小化が最適化とほぼ同義とされる理由は、最小化問題で使用されるアルゴリズムが、を単に乗じることで最大化問題にも適用できるからであり、数学的に非常に重要な関数であるメトリックやノルムが以上の実数の集合を値域に持つから、つまり最小値が存在するという理由からである。
近年、ディープラーニングが流行しているが、目的関数(またはコスト関数、損失関数)は通常、スムーズであると想定されているが、必ずそうであるとは限らない。したがって、それを克服するためのアルゴリズムとメソッドも研究されてきた。目的関数の定義域が必ずしもでなければならないわけではない。
全域最適解
最適解の存在性は、数々の条件によって示すことができるかもしれないが、局所最適解が全域最適解であることを示す定理はない。理想的には誰もが最適解を見つけたいと思うが、実際に見つけた解が最適解であることを心から期待することはほとんどない。最適化問題は多くあるが、すべての問題にピッタリ合う「最適化された」最適化技法はないため、数多くの改善アルゴリズムが開発されてきた。
最適解の厳密さと孤立性
通常は以下の定義は無意味であるが、一応言及しておく。
- 全てのに対してを満たすの近傍が存在する場合、そのを厳密な局所最適解strict Local Optimizerと呼ぶ。
- 全てのに対してを満たすの唯一の近傍が存在する場合、そのを孤立した局所最適解isolated Local Optimizerと呼ぶ。