JavaScript でルートを見つける方法
数学では、ルートを見つけることはよくある問題です。方程式の解法や画像処理など、多くの実践的な問題を解決するのに役立ちます。コンピューター サイエンスでは、JavaScript 言語は根探索問題などの数学的問題に適しています。この記事では、JavaScript でルートを見つける方法を学びます。
1. ルートシークとは何か
まず、ルートシークとは何かを明確にする必要があります。数学では、方程式の根は、方程式を真にする未知数の値です。たとえば、二次方程式 ax^2 bx c=0 の場合、x の値はその根です。コンピューターサイエンスでは、方程式の根を解くために数値反復法をよく使用します。
2. 根を解く数値反復法
数値反復法は、数学の問題を近似的に解くために使用できる数値解析手法です。一定の精度または指定された終了条件に達するまで、一定のルールに従って問題の解を徐々に近似します。
根探索問題では、数値反復法が広く使用されています。その基本的な考え方は、初期値から開始し、一定の精度に達するまで反復式に従って徐々に目標値に近づけることです。
数値反復法の手順は次のとおりです。
根を求める問題では、反復公式の選択が非常に重要です。反復計算式が異なると、収束速度と精度も異なる場合があります。一般的に使用される 2 つの反復公式を以下に紹介します。
3. 二分法による根探索
二分法は、根探索問題における最も単純な数値反復法の 1 つです。その基本的な考え方は、決定する区間を継続的に 2 つに分割し、2 つのサブ区間の関数の値に基づいて次の区間を決定することです。このプロセスは、間隔の長さが指定された精度未満になるまで繰り返されます。
JavaScript では、二分根探索コードは次のとおりです。
function bisection(func, a, b, tol) { if (func(a) * func(b) >= 0) { throw "Error: f(a) and f(b) do not have opposite signs."; } let c = a; while ((b-a)/2 > tol) { c = (a+b)/2; if (func(c) === 0.0) { return c; } else if (func(c)*func(a) < 0) { b = c; } else { a = c; } } return c; }
パラメータの説明:
4. 根を求めるニュートン法
ニュートン法は、非線形方程式を解くための数値反復法です。その基本的な考え方は、関数の局所線形近似を使用して反復計算を実行することです。各反復で、ニュートン法は現在の点の接線と x 軸の交点を次の反復点として取得し、一定の精度が達成されるまでこのプロセスを繰り返します。
JavaScript では、ニュートン法のルートを見つけるためのコードは次のとおりです。
function newton(func, derivFunc, x0, tol) { let x1 = x0 - func(x0) / derivFunc(x0); while (Math.abs(x1 - x0) > tol) { x0 = x1; x1 = x0 - func(x0) / derivFunc(x0); } return x1; }
パラメーターの説明:
以上がJavaScript でルートを見つける方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。