Next: 2 二分法
Up: 6 方程式の数値解法
Previous: 6 方程式の数値解法
Subsections
Newton-Raphson法は、関数
が単調連続で変曲点がなく、且つ導関数
が
数値的に求められる時に利用できる数値解法で、収束が速く、広く用いられている。
いま、曲線上の点
での接線と
-軸との交点を
とすると、
data:image/s3,"s3://crabby-images/c8e5d/c8e5d2e718934691b88b7f76f709b38913bc5193" alt="\begin{displaymath}
f'(x_n)=-{{f(x_n)}\over{x_{n+1}-x_n}}
\end{displaymath}" |
(1) |
だから、
解の適当な推定値から始めて、反復公式
data:image/s3,"s3://crabby-images/2a55c/2a55c94005f5b2df78c9634f5e3e58c1eb65e549" alt="\begin{displaymath}
x_{n+1}=x_n-{{f(x_n)}\over{f'(x_n)}} \qquad (n=0, 1, 2, \cdots) .
\end{displaymath}" |
(2) |
を繰り返すと、
漸近的に解に達する。
Figure 6.1:
Newton-Raphson法の概念図。
data:image/s3,"s3://crabby-images/6c632/6c632050ef6e1fe0b75af4dccf9bc00faca83a49" alt="\begin{figure}\begin{center}
\leavevmode
\epsfig{file=/usr2/makino/papers/Keisan-TenmongakuI/newton.eps,angle=270,width=10.cm}\end{center}\end{figure}" |
収束の判定条件としては、ある
に対して、
- 二つの近似解間の差
- 二つの近似解間の相対差
- 二つの近似解関数値間の差
等が考えられるが、1と2の条件では、
の値が大きいと、真の解に未だ
充分近くないのに満たされてしまう場合があるので、3の条件を判定条件として用いる
方が誤った解を出してしまう危険性がすくない。
以下の外部関数rtnewtは、関数
をfuncdとして、
となる解を
Newton-Raphson法で解くプログラム例である
。収束判定条件は上記1を使っている。
function rtnewt(funcd,x1,x2,xacc)
Implicit NONE
Integer JMAX
Real rtnewt,x1,x2,xacc
external funcd
Parameter (JMAX=20) !Set to maximum number of iterations.
! Using the Newton-Raphson method, find the root of a function known to
! lie in the interval [x1,x2]. The root 'rtnewt' will be refined until
! its accuracy is known within +-'xacc'. 'funcd' is a user-supplied
! subroutine that returns both the function value and the first
! derivative of the function at the point x.
Integer j
Real df,dx,f
rtnewt=.5*(x1+x2) !Initial guess.
do j=1,JMAX
call funcd(rtnewt,f,df)
dx=f/df
rtnewt=rtnewt-dx
if((x1-rtnewt)*(rtnewt-x2).lt.0.)
* pause 'rtnewt jumped out of brackets'
if(abs(dx).lt.xacc) return !Convergence.
end do
pause 'rtnewt exceeded maximum iterations'
end
上記サンプルプログラムで、external funcdという行がある。これは、
EXTERNAL文と呼ばれる宣言文である。FUNCTION文の引数は、通常はその関数の独立変
数であるが、今の場合、funcdは、解きたい関数名である。そして、
この関数は、別にサブルーチンで与える。そこで、
FUNCTION文の引数が、外部手続きサブルーチンの名である事を宣言しておくのである。
Newton-Raphson法で、
data:image/s3,"s3://crabby-images/ede2f/ede2f5ffd1f069096dc06fd804f61df32e2b8706" alt="\begin{displaymath}
f(x)=2x+\sin{x}-2\pi=0
\end{displaymath}" |
(3) |
を解け。
CfA カタログを使って、銀河の天球上の
赤経・赤緯座標、銀経・銀緯座標、の二次元マップを、
Mollwide画法で描いて見よう。
Mollwide図法では経度・緯度
-
を次の様に
-
座標に変換する。
data:image/s3,"s3://crabby-images/595e5/595e56d06e91a3df7b29656777bba8cc5e69bb1f" alt="\begin{displaymath}
x=(\sqrt{8}/\pi) (\lambda-\lambda_0)\cos\theta,
\end{displaymath}" |
(4) |
data:image/s3,"s3://crabby-images/0a48d/0a48d3ee35dcc9acd63219b80739fb729c9367eb" alt="\begin{displaymath}
y=\sqrt{2}\sin\theta.
\end{displaymath}" |
(5) |
但し、
は地図上の中心経度であり、
は
data:image/s3,"s3://crabby-images/c0813/c08135f5361040893ea8778259b7cd3ec10410d2" alt="\begin{displaymath}
2\theta+\sin 2\theta = \pi\sin\phi
\end{displaymath}" |
(6) |
で定義する
。
(経度
はファイルGALAXY.DATから読み取った値を直接使用するのではない。
適切な変換をしてから使用する。
図6.2、6.3の
-軸を見て、良く考えよう。)
与えられた緯度
から上の式に基づいて
を求めるには、
先ず適当な推定値
を用意して、
Newton-Raphson法により、上の式を満たすように逐次修正して行けば良い。
修正値
は、(6.2)式を使って、
data:image/s3,"s3://crabby-images/341ea/341eae3b7bc03330e6fb60c9f5cb1a4593a35a09" alt="\begin{displaymath}
\Delta \theta=-(2\theta+\sin2\theta-\pi\sin\phi)/2(1+\cos2\theta)
\end{displaymath}" |
(7) |
で求め、これを
に加えたものを改めて
として、
修正値
が予め定めておいた限界値以下になるまで、
上のプロセスを繰り返す。
Figure 6.2:
銀河の天球上の分布。赤経、赤緯座標で図示。
data:image/s3,"s3://crabby-images/1623b/1623b062c98e26386121da2d6d20eb1b200138af" alt="\begin{figure}\begin{center}
\leavevmode
\centerline{\epsfig{file=mollwide_galaxy_eq.ps,angle=270,width=10.cm}}\end{center}\end{figure}" |
赤経(
)・赤緯(
)と銀経(
)・銀緯(
)の変換は、
銀河の北極の赤経・赤緯を
,
とし、
data:image/s3,"s3://crabby-images/4b0e7/4b0e76cc1aa9f0d375299d43efbaf56e91b7c813" alt="\begin{displaymath}
\Omega=90^\circ + \alpha_0
\end{displaymath}" |
(8) |
data:image/s3,"s3://crabby-images/1ac68/1ac6849f2f9bbaf3e6505fd957c4c73d37e5bf24" alt="\begin{displaymath}
i = 90^\circ - \delta_0
\end{displaymath}" |
(9) |
data:image/s3,"s3://crabby-images/39a2b/39a2bf86a39d7e4dfd5364f41499f71446588ec1" alt="\begin{displaymath}
\alpha' \equiv \alpha - \Omega
\end{displaymath}" |
(10) |
として、
data:image/s3,"s3://crabby-images/77bdd/77bdda2ba422b5247e25b76b94b8a39deb077b03" alt="\begin{displaymath}
\cos b \cos l = \cos\delta\cos\alpha'
\end{displaymath}" |
(11) |
data:image/s3,"s3://crabby-images/b2e88/b2e884452fbd50bb90e4c651a3f29861e03e2ccc" alt="\begin{displaymath}
\sin b = \cos i \sin\delta - \sin i \cos\delta\sin\alpha'
\end{displaymath}" |
(12) |
data:image/s3,"s3://crabby-images/a5e83/a5e83b9a563ef7863875d2a0d328ab9a936836c5" alt="\begin{displaymath}
\cos b \sin l = \sin i \sin\delta + \cos i \cos\delta\sin\alpha'
\end{displaymath}" |
(13) |
で与えられる。但し、
。
Figure 6.3:
銀河の天球上の分布。銀経、銀緯座標で図示。
data:image/s3,"s3://crabby-images/9c8f5/9c8f5b65a2c199594495ff20da98088a5455db3c" alt="\begin{figure}\begin{center}
\leavevmode
\centerline{\epsfig{file=mollwide_galaxy_gal.ps,angle=270,width=10.cm}}\end{center}\end{figure}" |
Next: 2 二分法
Up: 6 方程式の数値解法
Previous: 6 方程式の数値解法
Jun Makino
平成15年5月29日