コンテンツにスキップ

JavaScript/Math/log2

出典: フリー教科書『ウィキブックス(Wikibooks)』

Math.log2(x) は、引数 x の2を底とする対数(二進対数)を返します。これは、x の値に対応する2を底とする対数を返します[1]

  • 引数 xNaN の場合、NaN を返します。
  • 引数 x+0 の場合、-Infinity を返します。
  • 引数 x-0 の場合、-Infinity を返します。
  • 引数 x1 の場合、+0 を返します。
  • 引数 xInfinity の場合、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を底とする対数を計算しています。ユーザーが入力した値が NaNInfinity の場合、適切に処理されます。

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を底とする対数関数のグラフを描画しています。xScaleyScale は、グラフのスケーリングを調整するための変数です。

注意点

[編集]
  • 引数の範囲: Math.log2 の引数 x は、正の値でなければなりません。この範囲外の値を指定すると、NaN が返されます。
  • 戻り値の範囲: Math.log2 の戻り値は、-Infinity から Infinity の範囲です。
  • 精度: 浮動小数点演算の特性上、Math.log2 の結果には微小な誤差が含まれることがあります。

脚註

[編集]
  1. ^これは、数学的には として定義されます。

外部リンク

[編集]


close