JavaScript/Math/log2
表示
< JavaScript | Math
Math.log2(x)
は、引数 x
の2を底とする対数(二進対数)を返します。これは、x
の値に対応する2を底とする対数を返します[1]。
- 引数
x
がNaN
の場合、NaN
を返します。 - 引数
x
が+0
の場合、-Infinity
を返します。 - 引数
x
が-0
の場合、-Infinity
を返します。 - 引数
x
が1
の場合、+0
を返します。 - 引数
x
がInfinity
の場合、Infinity
を返します。 - 引数
x
が負の値の場合、NaN
を返します。
例
[編集]2を底とする対数を計算するプログラム
[編集]以下のプログラムは、ユーザーが入力した値の2を底とする対数を計算します。
constf=p=>{for(;;){a=prompt(`${p}は何ですか?`);if(!isNaN(a)&&a>0)returna;alert(`${p}に、入力ミスがあります。 "${a}"`);}}for(;;){constx=f("値");constlog2=Math.log2(x);if(!isNaN(log2)){alert(`${x} の2を底とする対数は ${log2.toFixed(3)} です。`);break;}alert("入力が大きすぎます。");}
このプログラムでは、Math.log2
を使用して値の2を底とする対数を計算しています。ユーザーが入力した値が NaN
や Infinity
の場合、適切に処理されます。
2を底とする対数関数のグラフを描画するプログラム
[編集]以下のプログラムは、2を底とする対数関数のグラフを描画します。
constcanvas=document.createElement('canvas');document.body.appendChild(canvas);constctx=canvas.getContext('2d');canvas.width=800;canvas.height=400;constxScale=canvas.width/10;constyScale=canvas.height/5;ctx.beginPath();ctx.moveTo(0,canvas.height);for(letx=0.1;x<=10;x+=0.1){consty=Math.log2(x);constcanvasX=x*xScale;constcanvasY=canvas.height-y*yScale;ctx.lineTo(canvasX,canvasY);}ctx.strokeStyle='blue';ctx.lineWidth=2;ctx.stroke();
このプログラムでは、Math.log2
を使用して2を底とする対数関数のグラフを描画しています。xScale
と yScale
は、グラフのスケーリングを調整するための変数です。
注意点
[編集]- 引数の範囲:
Math.log2
の引数x
は、正の値でなければなりません。この範囲外の値を指定すると、NaN
が返されます。 - 戻り値の範囲:
Math.log2
の戻り値は、-Infinity
からInfinity
の範囲です。 - 精度: 浮動小数点演算の特性上、
Math.log2
の結果には微小な誤差が含まれることがあります。
脚註
[編集]- ^これは、数学的には として定義されます。