我正在维护一个程序,该程序从PDP-11(模拟!)程序中获取数据,并将其放入现代的基于Windows的系统中。我们遇到了一些数据值报告为“1.#QNAN”和“1.#QNB”的问题。客户最近透露,在PDP-11程序中,坏数据值由两个16位字表示,所有位都设置除了第一个。我认为我们尝试将这些转换为IEEE浮点数时,会出现错误。
我找到了下面的代码,用于将PDP-11值转换为IEEE。我对浮点数表示的复杂性不太了解,但这似乎对我来说有点简单!这确实可靠地将PDP-11浮点数转换为IEEE吗?
// ---------------------------------------------------------------- cnvPDPfloat
// CNVPDPFLOAT
// ----------------------------------------------------------------------------
//
// Converts PDP11 float (two 16-bit words) into IEEE float
//
// PDP11 and IEEE floats have same layout so can be mapped onto eachother.
// But PDP11 exponent must have 2 subtracted for IEEE. Or just divide by 4.
//
float cnvPDPfloat( PDP11Float input )
{
union
{
unsigned long pdp11;
float ieee;
} uFloat;
uFloat.pdp11 = (input.word[0] << 16) + input.word[1];
return (uFloat.ieee / (float) 4.0);
}
艾利斯特。