16 const cl_DF scale_float (const cl_DF& x, const cl_I& delta)
19 // x=0.0 -> x als Ergebnis
20 // delta muß ein Fixnum betragsmäßig <= DF_exp_high-DF_exp_low sein.
21 // Neues DF mit um delta vergrößertem Exponenten bilden.
25 #if (cl_word_size==64)
27 DF_decode(x, { return x; }, sign=,exp=,mant=);
31 DF_decode2(x, { return x; }, sign=,exp=,manthi=,mantlo=);
37 && ((udelta = FN_to_L(delta)) <= (uintL)(DF_exp_high-DF_exp_low))
40 #if (cl_word_size==64)
41 return encode_DF(sign,exp,mant);
43 return encode_DF(sign,exp,manthi,mantlo);
47 { cl_error_floating_point_overflow(); }
53 && ((udelta = -FN_to_L(delta)) <= (uintL)(DF_exp_high-DF_exp_low))
54 && ((cl_value_len+1<intLsize) || !(udelta==0))
57 #if (cl_word_size==64)
58 return encode_DF(sign,exp,mant);
60 return encode_DF(sign,exp,manthi,mantlo);
64 if (underflow_allowed())
65 { cl_error_floating_point_underflow(); }