変分法1 では,関数 によって決まる汎関数 の停留値問題を解くためには,オイラー方程式を解けば良いのだということを勉強しました.
ここでは,オイラー方程式の,さらに発展的な形について勉強します.もし,なんだかちょっと難しいぞ,と感じる人は,もう一度 変分法1 を復習して下さい.
色々な関数形が出てきますが,その全てを理解する必要はありません.全部読むのは長くて大変ですから,必要なときに必要な部分だけ,この記事を参考書代わりに読んで頂ければ十分だと思います.次のセクションが目次を兼ねています.
汎関数 を決める関数として, 変分法1 では という形のものしか考えませんでした.しかし,言うまでもなく世の中には,もっと色々な形の関数があります.これよりももっと簡単な形の関数もあれば,もっと複雑なものもあるわけです.次に挙げるような関数に対して,オイラー方程式( 変分法1 で導いたオイラー方程式と区別するために,これらを変形オイラー方程式と呼びます)を導くのがこの記事の目的です.
1.〜3.は, が,特に簡単な関数形をしている場合です.4.は, 以外にも変数を含む場合です. も の関数であることに注意して下さい.これは一般に 個の変数を含む場合に容易に拡張できますので,本文の方でその場合にも触れます.5.は が の二次導関数まで含む場合です.5.の場合を更に一般の高次導関数まで拡張したものが6.です.5.と6.は本質的に同じ問題ですが,少し計算が長くなるので別にしました.1.〜6.に出てくる や は の関数でしたから,基本変数は だけでした.7.として,独立に動ける基本変数が のように複数個あり,それらの関数である と,その偏導関数 . が に含まれる場合を考えます.
以下に,この7つのタイプの変分問題について,順番に変形オイラー方程式を導いていきます.本文では一応導出の過程も全て述べますが,これらを覚える必要は全くありません.最後に幾つかの例題を載せておきますので,出来れば答えを見ないでチャレンジしてみてください.
これは関数 に が含まれていない簡単な形です. が零になりますので,オイラー方程式(0)は次式のようになります.
両辺を で積分して次のような形になります.これが1番目の形の変形オイラー方程式です.
とても計算が簡単だったので,なにもわざわざ勿体ぶって公式などと呼ぶ必要はないと感じた読者の方が多いと思います.しかし,実際に変分法の問題を解くときには少しでも簡単な形から始めるということが,とても重要なのです.オイラー方程式は二階微分方程式ですが,式(1)は一階微分方程式の形をしています. が少し複雑な形をしている場合,無駄な微分の手間を一回省くというのは非常に大きな節約になります.
まず の全微分を考えます.
少し式変形をして,次のような形にまとめます.
一方,オイラー方程式(0)の両辺に を掛けたものを考えます.
式 (2)(3)を連立して を消去します.
この公式は1868年にベルトラミによって導かれたので,特にベルトラミの公式という名前がついています.この公式が使える問題の中で有名なものに, 最速降下曲線 を求めるというものがあります.
関数 に が含まれていない場合です. の項を落とすと,オイラー方程式(0)は次のような形になります.
これは直ちに積分できて, が言えるでしょう.変分問題としては,全然面白くない形の関数でした.
関数 が, 以外にも変数を含む場合です.汎関数は次式(6)のように表されます.
ここで, も も の関数であることに注意しましょう.関数形の微小な変形を,任意関数 , と任意の微小量 を使って,次のように表現することにします.
式(7)には が含まれていませんし,式(8)には が含まれていません.そこで,式(7)(8)をそれぞれ別の変分問題だと考えることができます.これは 変分法1 で求めた形のオイラー方程式に帰着する形ですから,結果が次の式(9)(10)のように書けます.オイラー方程式が二本出てきたということです.これらを連立することで変分問題が解けます.
変数がたくさんある場合には,変数の数だけオイラー方程式が出てきます.一般に,関数 が 個の変数を含み, と表わされる場合,この に関する変分問題は次のように, 次連立オイラー方程式を解くという問題に帰着します.
関数 が の二次導関数までを含む場合です.基本的には 変分法1 で行った計算と同じですので,そのときの手順も思い出しながら計算を追ってみて下さい.
汎関数の形は式(12)のように書けることでしょう.また, の関数形の微小な変化は,任意の関数 と任意の微小量 を用いて式(13)のように書けます.
式(12)で表される汎関数 に対し, が次式のようになるというは大丈夫でしょうか.一行目では の全微分を考えています.一行目に出てきた などを式(13)を用いて変形したのが二行目です.
次に,式(14)の二行目の第三項を 部分積分 します.
積分の中から が外に出せました.もう一回頑張って,積分の中の第二項・第三項を部分積分しましょう.今度は をなくすのが目標です.
境界条件より,最初の括弧は全て零になります. は任意の関数だということでしたから,結局,上式が成り立つためには,次式(15)が成り立つことが必要十分条件となります.これが求める変形オイラー方程式です.オイラー方程式(0)と比べてみてください.
5.の場合の拡張として, が の 次導関数まで含む場合を考えましょう.5.で行った計算と同じようにして, 回部分積分を繰り返しと,次のような変形オイラー方程式が得られます.
今まで見てきた関数では, や は の関数でしたから,結局,一番基本的な変数は だけでした.ここでは,そのような基本変数が二個ある場合を考えます.このとき汎関数は次式のように書けます.重積分になっているところがポイントです.
式中, というのは, の による偏微分という意味だとします.例によって, の微小な変化を,任意の微小量 と,任意の関数 によって,次のように表しましょう.
次に, を考えます. の偏導関数が二種類出てくるのがポイントです.
右辺の括弧内の,第二項,第三項をそれぞれ と で部分積分します.
部分積分した前へ出した部分は,境界条件によって零になります.また は任意の関数だということでしたので,結局,上式が成り立つための必要十分条件は,次式(17)が成り立つことです.
オイラー方程式(0)と見比べてみて下さい.
二点 , を結ぶ最短経路を求めて下さい.
解答
この答えが直線であることは直感的に明らかですが,変分法を使って解くのが練習です.二点を結ぶ任意の曲線の長さ は,次のように書けますね.
求めたいのは の最小値ですから, を汎関数にとり,さっそく変分法で解きましょう.
この問題では となっていますね.これは を含まない形ですから,変形オイラー方程式(2)が使える形です.求める変形オイラー方程式は次のようになります.
これを一回積分すれば, となります.もう一度積分して次の答えが得られます.
積分定数 , は,この直線が二点 , を通るという条件から決まります.予想通り, , を通る直線が,最短経路だということになりました.
高さの異なる二点を坂道で結び,玉を転がすとき,玉が一番速く転がる坂の形(曲線)を考えてください.重力は一様だとします.
この問題の解答は, 最速降下曲線 をご覧下さい.
(ヒント:式(4)が使える問題です.)
密度が一様な紐を吊り下げたとき,ポテンシャルエネルギーが最小になるような紐の垂れ方(曲線)を考えて下さい.重力は一様だとします.
解答
紐の微小部分が持つ位置エネルギーを全て合わせたものを,紐全体のポテンシャルエネルギー だとします.紐の微小部分 が持つ位置エネルギーは,その微小部分の高さを だとして と表わされますので, は次のように,積分で表すことができます.
ここで の最小値を求めたいのですから, として,変分問題を解きましょう.
この問題では となっていて, が を含まない形ですから,変形オイラー方程式(4)が使える形です.解くべき式は次のようになります.
これを積分して,次の答えを得ます.
これは双曲線関数(ハイパーボリックコサイン)と呼ばれる曲線です. [*]
[*] | 余談ですが,西洋の大きな建築物は,たいてい石で出来ています. 石を削るのはなかなか大変なことですから,自然と,予め地上で石を設計図通りに切っておいて, 上で積み上げるという方式が取られることになります. 設計図として簡単に書けるのは,定規とコンパスだけで作図できる図形ですから, 古い西洋建築に見られる曲線というのは,大方,円弧なのです. ヨーロッパに旅行に行く機会があれば,どこの街にも古い教会などがありますから, 是非窓枠や屋根の曲線を眺めて見てください.ほとんど全て円弧の一部のはずです. さて,たった今求めた双曲線関数ですが,これは という関数ですので, ちょっと定規とコンパスだけで作図するのは無理そうです. 西洋で双曲線関数を始めて建築に取り入れたのは,スペインのアントニ・ガウディで,19世紀末の話です. ところが,わが日本では,神社の屋根の微妙な反り返りなどがほとんど全て双曲線関数になっているのです! 日本では設計図を描いてから木を削るのではなく,大工さんが鎖を垂らして曲線を決めていくので, 自然と双曲線関数になってしまうのでした.こんど神社に行くようなことがあれば,是非屋根をながめて見て下さい. 西洋で,ようやくここ100年そこそこになって使われ始めた曲線が, 日本では何百年も伝統的に使われているとは,なんだか嬉しい話です. |