目次 | Experiment |
Simulations非線形力学 |
---|
前回では線形系での安定性解析の方法と,固定点の分類などについて学習しました.
今回は,この議論を非線形系に適用することを考えていきます.
はじめに,復習です.前回確認した,任意の線形系
の安定性解析の手順は,
でした.固有値と固定点の種類の対応については
こうでしたね.描かれる相図は
です.
ただしこれは,あくまで系が線形であった場合のことです.非線形な場合,このように単純な図は描けず,非線形な項の影響で局所局所で異なる振る舞いを示すようになります.
例としては,以下の相図です.
見るからに複雑ですね.前回やったような,固有ベクトルを2本引いて,その値のバランスからなんとなく周りの曲線軌道を引く,なんてやりかたは通用しなそうです.
ですが,まぁ上の図をちゃんと出せているように非線形の場合でも相図を描き,安定性を議論することは可能です.今回はその方法を確認します.
さて,結論から言うと非線形系を非線形のままに安定性解析はできません.そのため,線形化という作業を行う必要があります.
考え方としては,非線形系は複雑ではあるけれども,固定点周りのごく狭い範囲では線形系に近似ができるのではないか,という発想に基づきます.この発想の厳密な話はHeartman-Grobmanの定理によりますが,ここでは細かいことは省きます.
たとえば,先程の相図についても固定点(0,0)周りを拡大すると
となります.これは線形な場合のセンターに似ています.このように,固定点周りで固有ベクトルを求めた場合,あまり離れすぎない(微小範囲)場合には線形な議論が近似的に成り立ちそうなことが分かります.
そこで,「(各固定点周りの)微小範囲での線形近似」 を行う,という方針が立ちます.
まずは,系を
として固定点をで表します.さらに,固定点からの微小な摂動を
で表すとします.ここで,がどのように変化するか (成長するか減衰するか) を調べます.まずはこれらの微分方程式を考えます.これで安定性の議論ができます.まずはについて考えます.すると なので
となります.方程式が出てきました.次は,これを線形近似するためにテイラー展開を使います.テイラー展開について復習すると
#####(1実変数)関数のテイラー展開
点を含む実数の閉区間上で無限階微分可能な関数が与えられたとき,
の形に関数を展開する操作
です.今回はの部分,つまり点からの微小ずれをとします.するとなのでとも置き換えられます.さらに今考えているのは固定点周りでの話なので,とすると,1変数()についてだけについては
のようになります.ただし,今回はこれの多変数バージョン
を使います.今考えている問題に適用すると
となります.今は線形近似をしていますし,は十分に小さい () としているので,2次以上の項は無視します.また,第1項の は定義より なので,結局
と求まります.
についても同様にして,
と求めることができます.よって,摂動()は
に従って発展することが分かります.この時の係数行列
は,点()でのヤコビ行列とよばれる行列です.さて,この一連の流れを通して,
非線形系を線形化した線形系
が得られました.これ以降は,前回確認した線形系の安定性解析を適用することが出来ます.
これです.
まとめると,非線形系の安定性解析の手順は,
となります.ヤコビ行列を求めるところだけが線形系の場合との違いですね.
さっそく,例題を解いてみます.
系,の固定点をすべて求め,線形化を用いてそれらを分類せよ.また,対応する相図を作図せよ
はじめに,固定点を求めます.
を解くと,固定点はと分かります.
次に,それぞれの点においてヤコビ行列
を求めます.固定点 (-1,0) のもとでは,となるので,固定点 (-1, 0) はサドル点です.同様に, 固定点(1,0) もサドル点になります.
また, (この場合x軸) が正の値, (この場合y軸) が負の値なので,どちらも不安定多様体は軸,安定多様体は軸に平行な直線 (線形化が可能な範囲内では) になることも分かります.
次に固定点 ですが,こちらは となるので,安定なスパイラルか安定なノードです.面倒ですがを計算してあげると,ですね.よって固定点は安定ノードと分かります.
あとは,これらに矛盾しないような相図を描いてみましょう.
こんな感じになるはずです.
では,数値計算による答えを見てみましょう.
合っていますね.数値計算だとベクトルの長さまで簡単に再現できるのが強いですね...
系,の固定点をすべて求め,線形化を用いてそれらを分類せよ.また,対応する相図を作図せよ
固定点を求めます.
を解くと,固定点はと分かります.
次に,それぞれの点においてヤコビ行列
を求めます.さらにそこでの固有値も求めます.固定点 (0,0) のもとで固有値,固有ベクトルを求めると,
,と求まります.
従ってとなるので,固定点 (0, 0) はサドル点です.右肩下がり方向には不安定,右肩上がり方向には安定多様体があります.
次に固定点 について考えます.同様に固有値,固有ベクトルを求めると,
なので, ,
と,複素数が出てきます.固有値の実部が0なので,固定点 はセンターになります.同様に固定点 (0,-1) もセンターになります.
問題は,回転の方向がどちら (時計回りか反時計回り) になるかです.これは固有値とかから読み取る方法がちょっと分からなかったのですが,系を見ればすぐ分かります.
です.求めたセンターの近くの の組を与えた時にどう動くかを考えます. センター であれば,たとえば です.式に代入すると,
です. が正 ( は0),ということは右向きに力が働いています.センターのすぐ上で右向きに力が働くということは,時計回りですね.
同様に も見ると,
左向きに力が向いています.センターの下で左向きの力ということは,やはり時計回りです.以上の情報を元に相図を描いてみます.
この絵のポイントは,上下のセンターたちが中央のサドルに引き寄せられるために若干ゆがむことと,固定点達から離れたところでは上下のセンターがつながって大きな円を描こうとすること,しかしそれもやはりサドルの影響で歪んで...という構造をとることです.
では,数値計算による答えを見てみましょう.
大体いいですね.
あと2問置いておきます.実際に解いてみてください(いい感じの数字と見た目になる組み合わせ探すの結構大変...)
答え合わせ用の自作プログラムも置いておきます.
(Pythonです...意気揚々とJulia環境構築したはいいけど,よく分からんくて結局Python使っています...すみません...)
# 微分方程式を定義
xdot = "y + y**2"
ydot = "x -x**3"
import sympy
import numpy as np
import matplotlib.pyplot as plt
x =sympy.Symbol('x')
y = sympy.Symbol('y')
u = eval(xdot)
v = eval(ydot)
# Find fixed points
points = np.array([])
fixed = sympy.solve([u, v])
for i in range(len(fixed)):
value = np.array([fixed[i][x],fixed[i][y]])
points = np.append(points, value)
fixed_points = points.reshape(len(points)//2, 2)
# define Jacobian matrix
Jacobian = sympy.Matrix([[u.diff(x), u.diff(y)], [v.diff(x), v.diff(y)]])
plt.figure(figsize = (10,5))
for point in fixed_points:
# find eigenvalues around each fixed point
Jacobian_point = Jacobian.subs([(x,point[0]), (y,point[1])])
eigenvalues = Jacobian_point.eigenvals()
eigen= list(eigenvalues.keys())
#if np.all(re(list(eigenvalues.keys())) < 0):
for i in range(len(eigen)):
#if ((re(eigen[0]) < 0) and (re(eigen[1]) < 0)) or ((eigen[0] + eigen[1] ==0) and (eigen[0] * eigen[1] >0)): # Stable fixed points or center
if (re(eigen[i]) < 0): # Stable fixed points or center
plt.plot(point[0], point[1], 'ko', markersize=10) # black circle
else:
plt.plot(point[0], point[1], 'wo', mec='k', markersize=10, markeredgewidth=2) # Unstable fixed points
eigen_sum = np.sum(eigen)
eigen_multipl = np.prod(eigen)
if (eigen_sum ==0) and (eigen_multipl >0):
plt.plot(point[0], point[1], 'ko', markersize=10) # black circle
y, x= np.mgrid[-2:2:20j,-2:2:20j]
# define the system of ODEs
u = eval(xdot)
v = eval(ydot)
# plot the vector field
strm = plt.streamplot(x, y, u, v,color=np.sqrt(u**2+v**2),cmap='plasma', linewidth=2, arrowsize = 1.5)
# plot the nullclines
#plt.contour(x, y, u, levels=[0], linewidths=2, colors='r')
#plt.contour(x, y, v, levels=[0], linewidths=2, colors='b')
plt.title('Phase portrait of the system')
plt.colorbar(strm.lines)
plt.xlabel("x", fontsize=20, style="italic")
plt.ylabel("y", fontsize=20, style="italic")
plt.grid(True)
plt.savefig("../figures/answer.png")
系,の固定点をすべて求め,線形化を用いてそれらを分類せよ.また,対応する相図を作図せよ
固定点 :,不安定ノード
固定点 :,安定ノード
固定点 :,サドル
なんかおもしろ三角
系,の固定点をすべて求め,線形化を用いてそれらを分類せよ.また,対応する相図を作図せよ
固定点 :, サドル
固定点 :, センター(時計回り)
固定点 :, センター (反時計回り)
固定点 :, サドル
固定点 :, サドル
固定点 :, センター (時計回り)
きもかわいい
以上の議論は次元の場合ですが,これを次元に拡張します.やることは一緒で,固有値と固有ベクトルを求め,固有値から安定性について議論します.
ただしその判断基準は固有値2個ではなくn個なので,
#####固有値の安定性
となります.ここで,の実部を取り出している理由は,場合によっては固有値が複素数になることもあるからです.しかしその場合でも,安定かどうかに影響するのは結局軸方向での拡大率なので,実部だけ見るということになります.
3次元以上になると相図を描くのが難しくなりますが,とはいえ議論は同じです.固有ベクトルと固有値を比較することで,これまで通りの議論が可能です.
次回,リミットサイクルや分岐などといった本格的な非線形力学系のトピックに踏み込みます(時期未定)
【ホーム】