検索
Close this search box.
凸関数・凹関数

エピグラフ・ハイポグラフを用いた1変数の凸関数・凹関数の判定

メール
Xで共有

エピグラフを用いた1変数の凸関数の判定

区間上に定義された関数\(f:\mathbb{R} \supset I\rightarrow \mathbb{R} \)が凸関数であることは、\begin{equation*}\forall x_{1},x_{2}\in I,\ \forall \lambda \in \left[ 0,1\right] :\lambda
f\left( x_{1}\right) +\left( 1-\lambda \right) f\left( x_{2}\right) \geq
f\left( \lambda x_{1}+\left( 1-\lambda \right) x_{2}\right)
\end{equation*}が成り立つこととして定義されますが、定義にもとづいて関数が凸であることを示す作業は煩雑になりがちです。これまで明らかにしたように、関数\(f\)が微分可能である場合、導関数\(f^{\prime }\)が単調増加関数であることと\(f\)が凸関数であることは必要十分です。さらに、関数\(f\)が2階微分可能である場合、2階導関数\(f^{\prime\prime }\)が非負の値のみをとることと\(f\)が凸関数であることは必要十分です。では、関数\(f\)が微分可能であるとは限らない場合、\(f\)が凸関数であることを容易に判定する方法はあるのでしょうか。

区間上に定義された関数\(f:\mathbb{R} \supset I\rightarrow \mathbb{R} \)のグラフは、\begin{equation*}G\left( f\right) =\left\{ \left( x,y\right) \in I\times \mathbb{R} \ |\ y=f\left( x\right) \right\}
\end{equation*}と定義される\(\mathbb{R} ^{2}\)の部分集合であるため、空間\(\mathbb{R} ^{2}\)は曲線である\(G\left( f\right) \)を境に、その上部の領域と下部の領域に分割されます。特に、\(G\left( f\right) \)を含めてそれよりも上部の領域であるような\(\mathbb{R} ^{2}\)の部分集合を、\begin{equation*}\mathrm{epi}\left( f\right) =\left\{ \left( x,y\right) \in I\times \mathbb{R} \ |\ y\geq f\left( x\right) \right\}
\end{equation*}で表記し、これを関数\(f\)のエピグラフ(epigraph)と呼びます。定義より以下の関係\begin{equation*}G\left( f\right) \subset \mathrm{epi}\left( f\right)
\end{equation*}が成り立ちます。

例(関数のエピグラフ)
関数\(f:\mathbb{R} \supset I\rightarrow \mathbb{R} \)のグラフ\(G\left( f\right) \)が下図において曲線として描かれています。\(f\)のエピグラフ\(\mathrm{epi}\left( f\right) \)は\(f\)のグラフである曲線と、それより上方の領域を併せたグレーの領域に相当します。

図:エピグラフ
図:エピグラフ

上の例中の関数\(f\)は下に凸なグラフを持つため、これは凸関数です。さらに、\(f\)が下に凸なグラフを持つことは、グラフの上部の領域に相当する\(f\)のエピグラフが凸集合であることと必要十分であることが図から読み取れます。実際、これは正しい主張です。

命題(エピグラフを用いた凸関数の判定)
区間上に定義された関数\(f:\mathbb{R} \supset I\rightarrow \mathbb{R} \)のエピグラフ\(\mathrm{epi}\left(f\right) \)が凸集合であることと、\(f\)が凸関数であることは必要十分である。
証明

プレミアム会員専用コンテンツです
ログイン】【会員登録

例(エピグラフと凸関数)
関数\(f:\mathbb{R} \rightarrow \mathbb{R} \)はそれぞれの\(x\in \mathbb{R} \)に対して、\begin{equation*}f\left( x\right) =\left\{
\begin{array}{cc}
x & \left( if\ x\geq 0\right) \\
-x & \left( if\ x<0\right)
\end{array}\right.
\end{equation*}を定めるものとします。\(f\)は明らかに微分可能ではありません。\(f\)のエピグラフは、\begin{equation*}\mathrm{epi}\left( f\right) =\left\{ \left( x,y\right) \in \mathbb{R} ^{2}\ |\ x\geq 0\wedge y\geq x\right\} \cup \left\{ \left( x,y\right) \in \mathbb{R} ^{2}\ |\ x<0\wedge y\geq -x\right\}
\end{equation*}であり、これは下図のグレーの領域に相当します。これは明らかに凸集合であるため、\(f\)は凸関数です。

図:エピグラフ
図:エピグラフ

 

ハイポグラフを用いた1変数の凹関数の判定

区間上に定義された関数\(f:\mathbb{R} \supset I\rightarrow \mathbb{R} \)が凹関数であることは、\begin{equation*}\forall x_{1},x_{2}\in I,\ \forall \lambda \in \left[ 0,1\right] :\lambda
f\left( x_{1}\right) +\left( 1-\lambda \right) f\left( x_{2}\right) \leq
f\left( \lambda x_{1}+\left( 1-\lambda \right) x_{2}\right)
\end{equation*}が成り立つこととして定義されますが、定義にもとづいて関数が凹であることを示す作業は煩雑になりがちです。これまで明らかにしたように、関数\(f\)が微分可能である場合、導関数\(f^{\prime }\)が単調減少関数であることと\(f\)が凹関数であることは必要十分です。さらに、関数\(f\)が2階微分可能である場合、2階導関数\(f^{\prime\prime }\)が非正の値のみをとることと\(f\)が凹関数であることは必要十分です。では、関数\(f\)が微分可能であるとは限らない場合、\(f\)が凹関数であることを容易に判定する方法はあるのでしょうか。

区間上に定義された関数\(f:\mathbb{R} \supset I\rightarrow \mathbb{R} \)のグラフは、\begin{equation*}G\left( f\right) =\left\{ \left( x,y\right) \in I\times \mathbb{R} \ |\ y=f\left( x\right) \right\}
\end{equation*}と定義される\(\mathbb{R} ^{2}\)の部分集合であるため、空間\(\mathbb{R} ^{2}\)は曲線である\(G\left( f\right) \)を境に、その上部の領域と下部の領域に分割されます。特に、\(G\left( f\right) \)を含めてそれよりも下部の領域であるような\(\mathbb{R} ^{2}\)の部分集合を、\begin{equation*}\mathrm{hyp}\left( f\right) =\left\{ \left( x,y\right) \in I\times \mathbb{R} \ |\ y\leq f\left( x\right) \right\}
\end{equation*}で表記し、これを関数\(f\)のハイポグラフ(hypograph)と呼びます。定義より以下の関係\begin{equation*}G\left( f\right) \subset \mathrm{hyp}\left( f\right)
\end{equation*}が成り立ちます。

例(関数のハイポグラフ)
関数\(f:\mathbb{R} \supset I\rightarrow \mathbb{R} \)のグラフ\(G\left( f\right) \)が下図において曲線として描かれています。\(f\)のハイポグラフ\(\mathrm{hyp}\left(f\right) \)は\(f\)のグラフである曲線と、それより下方の領域を併せたグレーの領域に相当します。

図:ハイポグラフ
図:ハイポグラフ

上の例中の関数\(f\)は上に凸なグラフを持つため、これは凹関数です。さらに、\(f\)が上に凸なグラフを持つことは、グラフの下部の領域に相当する\(f\)のハイポグラフが凸集合であることと必要十分であることが図から読み取れます。実際、これは正しい主張です。

命題(ハイポグラフを用いた凹関数の判定)
区間上に定義された関数\(f:\mathbb{R} \supset I\rightarrow \mathbb{R} \)のハイポグラフ\(\mathrm{hyp}\left( f\right) \)が凸集合であることと、\(f\)が凹関数であることは必要十分である。
証明

プレミアム会員専用コンテンツです
ログイン】【会員登録

例(ハイポグラフと凹関数)
関数\(f:\mathbb{R} \rightarrow \mathbb{R} \)はそれぞれの\(x\in \mathbb{R} \)に対して、\begin{equation*}f\left( x\right) =\left\{
\begin{array}{cc}
-x & \left( if\ x\geq 0\right) \\
x & \left( if\ x<0\right)
\end{array}\right.
\end{equation*}を定めるものとします。\(f\)は明らかに微分可能ではありません。\(f\)のハイポグラフは、\begin{equation*}\mathrm{hyp}\left( f\right) =\left\{ \left( x,y\right) \in \mathbb{R} ^{2}\ |\ x\geq 0\wedge y\leq -x\right\} \cup \left\{ \left( x,y\right) \in \mathbb{R} ^{2}\ |\ x<0\wedge y\leq x\right\}
\end{equation*}であり、これは下図のグレーの領域に相当します。これは明らかに凸集合であるため、\(f\)は凹関数です。

図:ハイポグラフ
図:ハイポグラフ

 

エピグラフを用いた1変数の拡大実数値凸関数の判定

拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ +\infty \right\} \)が凸関数であることは、\begin{equation*}\forall x_{1},x_{2}\in \mathbb{R} ,\ \forall \lambda \in \left[ 0,1\right] :\lambda f\left( x_{1}\right)
+\left( 1-\lambda \right) f\left( x_{2}\right) \geq f\left( \lambda
x_{1}+\left( 1-\lambda \right) x_{2}\right)
\end{equation*}が成り立つこととして定義されます。拡大実数値をとる凸関数に関しても、それをエピグラフを用いて表現できます。

拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ +\infty \right\} \)に対して、そのエピグラフを、\begin{equation*}\mathrm{epi}\left( f\right) =\left\{ \left( x,y\right) \in \mathbb{R} ^{2}\ |\ y\geq f\left( x\right) \right\}
\end{equation*}と定義します。\(f\)は拡大実数を値としてとり得る一方で、エピグラフの定義において\(y\)は実数だけを値としてとり得る状況を想定していることに注意してください。言い換えると、\(x\)がとり得る値の範囲を\(f\)の有効領域\begin{equation*}\mathrm{dom}\left( f\right) =\left\{ x\in \mathbb{R} \ |\ f\left( x\right) <+\infty \right\}
\end{equation*}に制限した上でエピグラフを定義するということです。

拡大実数値関数\(f\)に関しても、\(f\)のエピグラフが\(\mathbb{R} ^{2}\)上の凸集合であることと\(f\)が凸関数であることは必要十分です。

命題(拡大実数値凸関数とエピグラフ)
拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ +\infty \right\} \)のエピグラフ\(\mathrm{epi}\left( f\right) \)が凸集合であることと、\(f\)が凸関数であることは必要十分である。
証明

プレミアム会員専用コンテンツです
ログイン】【会員登録

例(拡大実数値凸関数とエピグラフ)
拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ +\infty \right\} \)はそれぞれの\(x\in \mathbb{R} \)に対して、\begin{equation*}f\left( x\right) =\left\{
\begin{array}{cl}
\frac{1}{x} & \left( if\ 0<x<+\infty \right) \\
+\infty & \left( if\ -\infty <x\leq 0\right)
\end{array}\right.
\end{equation*}を定めるものとします。\(f\)のエピグラフは、\begin{eqnarray*}\mathrm{epi}\left( f\right) &=&\left\{ \left( x,y\right) \in \mathbb{R} ^{2}\ |\ y\geq f\left( x\right) \right\} \\
&=&\left\{ \left( x,y\right) \in \left( 0,+\infty \right) \times \mathbb{R} \ |\ y\geq \frac{1}{x}\right\} \cup \left\{ \left( x,y\right) \in (-\infty
,0]\times \mathbb{R} \ |\ y\geq +\infty \right\} \\
&=&\left\{ \left( x,y\right) \in \left( 0,+\infty \right) \times \mathbb{R} \ |\ y\geq \frac{1}{x}\right\} \cup \phi \\
&=&\left\{ \left( x,y\right) \in \left( 0,+\infty \right) \times \mathbb{R} \ |\ y\geq \frac{1}{x}\right\}
\end{eqnarray*}ですが、これは凸集合であるため\(f\)は凸関数です。

 

ハイポグラフを用いた1変数の拡大実数値凹関数の判定

拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ -\infty \right\} \)が凹関数であることは、\begin{equation*}\forall x_{1},x_{2}\in \mathbb{R} ,\ \forall \lambda \in \left[ 0,1\right] :\lambda f\left( x_{1}\right)
+\left( 1-\lambda \right) f\left( x_{2}\right) \leq f\left( \lambda
x_{1}+\left( 1-\lambda \right) x_{2}\right)
\end{equation*}が成り立つこととして定義されます。拡大実数値をとる凹関数に関しても、それをハイポグラフを用いて表現できます。

拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ -\infty \right\} \)に対して、そのハイポグラフを、\begin{equation*}\mathrm{hyp}\left( f\right) =\left\{ \left( x,y\right) \in \mathbb{R} ^{2}\ |\ y\leq f\left( x\right) \right\}
\end{equation*}と定義します。\(f\)は拡大実数を値としてとり得る一方で、ハイポグラフの定義において\(y\)は実数だけを値としてとり得る状況を想定していることに注意してください。言い換えると、\(x\)がとり得る値の範囲を\(f\)の有効領域\begin{equation*}\mathrm{dom}\left( f\right) =\left\{ x\in \mathbb{R} \ |\ f\left( x\right) >-\infty \right\}
\end{equation*}に制限した上でハイポグラフを定義するということです。

拡大実数値関数\(f\)に関しても、\(f\)のハイポグラフが\(\mathbb{R} ^{2}\)上の凸集合であることと\(f\)が凹関数であることは必要十分です。

命題(拡大実数値凹関数とハイポグラフ)
拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ -\infty \right\} \)のハイポグラフ\(\mathrm{hyp}\left( f\right) \)が凸集合であることと、\(f\)が凹関数であることは必要十分である。
証明

プレミアム会員専用コンテンツです
ログイン】【会員登録

例(拡大実数値凹関数とハイポグラフ)
拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ -\infty \right\} \)はそれぞれの\(x\in \mathbb{R} \)に対して、\begin{equation*}f\left( x\right) =\left\{
\begin{array}{cl}
\frac{1}{x} & \left( if\ -\infty <x<0\right) \\
-\infty & \left( if\ 0\leq x<+\infty \right)
\end{array}\right.
\end{equation*}を定めるものとします。\(f\)のハイポグラフは、\begin{eqnarray*}\mathrm{hyp}\left( f\right) &=&\left\{ \left( x,y\right) \in \mathbb{R} ^{2}\ |\ y\leq f\left( x\right) \right\} \\
&=&\left\{ \left( x,y\right) \in \left( -\infty ,0\right) \times \mathbb{R} \ |\ y\leq \frac{1}{x}\right\} \cup \left\{ \left( x,y\right) \in \lbrack
0,+\infty )\times \mathbb{R} \ |\ y\leq -\infty \right\} \\
&=&\left\{ \left( x,y\right) \in \left( -\infty ,0\right) \times \mathbb{R} \ |\ y\leq \frac{1}{x}\right\} \cup \phi \\
&=&\left\{ \left( x,y\right) \in \left( -\infty ,0\right) \times \mathbb{R} \ |\ y\leq \frac{1}{x}\right\}
\end{eqnarray*}ですが、これは凸集合であるため\(f\)は凹関数です。

 

演習問題

問題(エピグラフと凸関数)
関数\(f:\mathbb{R} \rightarrow \mathbb{R} \)はそれぞれの\(x\in \mathbb{R} \)に対して、\begin{equation*}f\left( x\right) =x^{2}
\end{equation*}を定めるものとします。\(f\)が凸関数であることをエピグラフを用いて示してください。
解答を見る

プレミアム会員専用コンテンツです
ログイン】【会員登録

問題(エピグラフと凸関数)
関数\(f:\mathbb{R} _{+}\rightarrow \mathbb{R} \)はそれぞれの\(x\in \mathbb{R} _{+}\)に対して、\begin{equation*}f\left( x\right) =\sqrt{x}
\end{equation*}を定めるものとします。\(f\)が凹関数であることをハイポグラフを用いて示してください。
解答を見る

プレミアム会員専用コンテンツです
ログイン】【会員登録

問題(凸関数や凹関数ではない関数)
関数\(f:\mathbb{R} \rightarrow \mathbb{R} \)はそれぞれの\(x\in \mathbb{R} \)に対して、\begin{equation*}f\left( x\right) =\sin \left( x\right)
\end{equation*}を定めるものとします。\(f\)が凸関数や凹関数ではないことをエピグラフとハイポグラフを用いて示してください。
解答を見る

プレミアム会員専用コンテンツです
ログイン】【会員登録

問題(エピグラフと凸関数)
拡大実数値関数\(f:\mathbb{R} \rightarrow \mathbb{R} \cup \left\{ +\infty \right\} \)はそれぞれの\(x\in \mathbb{R} \)に対して、\begin{equation*}f\left( x\right) =\left\{
\begin{array}{cl}
2x+1 & \left( if\ 0\leq x\leq 3\right) \\
+\infty & \left( otherwise\right)
\end{array}\right.
\end{equation*}を定めるものとします。\(f\)が凸関数であることをエピグラフを用いて示してください。
解答を見る

プレミアム会員専用コンテンツです
ログイン】【会員登録

関連知識

メール
Xで共有

質問とコメント

プレミアム会員専用コンテンツです

会員登録

有料のプレミアム会員であれば、質問やコメントの投稿と閲覧、プレミアムコンテンツ(命題の証明や演習問題とその解答)へのアクセスなどが可能になります。

WIISでは、年齢・性別・学歴・職業・社会的立場などにかかわらず、すべてのユーザーが「学ぶ人」として対等であると考えています。ここは、知識を競う場所ではなく、互いに尊重し合いながら理解を深めていく場です。安心して思考し、質問し、考え続けられる環境を、みなさんと一緒につくっていきたいと考えています。

誤字脱字、リンク切れ、内容の誤りを発見した場合にはコメントに投稿するのではなく、以下のフォームからご連絡をお願い致します。

プレミアム会員専用コンテンツです
ログイン】【会員登録