我正在尝试在python中实现math.frexp
函数。如果您感到困惑,请参阅here。显然,我正在研究可汗学院的this课程。
但是,它是PJS,不支持DataView
或ArrayBuffer
。有人可以帮我这个实现吗?
以下是当前代码(因DataView
/ ArrayBuffer
而被注释掉)。我在互联网上找到了这个。
var frexp = function(value) {
if (value === 0){
return [value, 0];
}
var data = new DataView(new ArrayBuffer(8));//Does not support DataView and ArrayBuffer objects.
data.setFloat64(0, value);
var bits = (data.getUint32(0) >>> 20) & 0x7FF;
if (bits === 0) {
data.setFloat64(0, value * Math.pow(2, 64));
bits = ((data.getUint32(0) >>> 20) & 0x7FF) - 64;
}
var exponent = bits - 1022,
mantissa = value * Math.pow(2, -exponent);
return [mantissa, exponent];
};
答案 0 :(得分:0)
它没有读取字节
那么高效exponent = Math.trunc( 1023+Math.log( Math.abs(value) )/Math.LN2 ) - 1022;
mantissa = value * Math.pow(2,-exponent);
应返回一对2^(e-1) <= val < 2^e
,因此0.5 <= m < 1
。在ECMA 6中,商可以由Math.log2
替换。
对数的浮点评估可能导致二元幂的模糊结果。如果e=exponent
太小,可能会给出错误的结果。因此添加行
if (Math.abs(mantissa) >=1 ) { exponent +=1; mantissa /=2; }