数値解析における二分法(にぶんほう、Bisection method)は、解を含む区間の中間点を求める操作を繰り返すことによって方程式を解く求根アルゴリズム。反復法の一種。ここでは、formula_1となるformula_2を求める方法について説明する。formula_2はformula_5とformula_6の間に存在するので、formula_5とformula_6の間隔を繰り返し1/2に狭めていき、formula_9をformula_2に近づけていくわけである。方程式が連続であり、なおかつ関数値の符号が異なる初期条件を与えることができれば必ず収束する。関数が単調増加あるいは単調減少であれば、区間上限を十分に大きく、区間下限を十分に小さくすることで適切な初期条件となる。また、繰り返しの回数によってあらかじめ解の精度を次式で予測することができる。一方、ニュートン法などと比較して収束は遅い。perlによるプログラムの例を示す。関数値&F($x1)と&F($x2)の符号が異なるような区間下限を$x1に、区間上限を$x2に設定する。続いて中間点$xmと中間点における関数値&F($xm)の符号を計算し、区間下限における関数値と同符号であれば区間下限を中間点で置き換え、そうでなければ区間上限を中間点で置き換える。この記述例においては初期区間幅が6、繰り返し回数が50回であることから、formula_27より、おおむね15桁の精度が得られることが予測できる。以下に実行結果例を示す。結果は予測される解(x=円周率)に対しておおむね15桁の精度で一致している。
出典:wikipedia
LINEスタンプ制作に興味がある場合は、
下記よりスタンプファクトリーのホームページをご覧ください。