// least_positive_float().
// General includes.
#include "cl_sysdep.h"
CL_PROVIDE(cl_F_leastpos)
// Specification.
#include "cln/float.h"
// Implementation.
#include "cl_F.h"
#include "cl_SF.h"
#include "cl_FF.h"
#include "cl_DF.h"
#include "cl_LF.h"
#include "cl_LF_impl.h"
namespace cln {
// Exponent so klein wie möglich, Mantisse 10...0, Vorzeichen +.
static const cl_SF least_positive_SF =
make_SF(0,SF_exp_low,bit(SF_mant_len));
static const cl_FF least_positive_FF =
encode_FF(0,FF_exp_low-FF_exp_mid,bit(FF_mant_len));
static const cl_DF least_positive_DF =
#if (cl_word_size==64)
encode_DF(0,DF_exp_low-DF_exp_mid,bit(DF_mant_len));
#else
encode_DF(0,DF_exp_low-DF_exp_mid,bit(DF_mant_len-32),0);
#endif
inline const cl_LF least_positive_LF (uintC len)
{
var Lfloat erg = allocate_lfloat(len,LF_exp_low,0);
#if CL_DS_BIG_ENDIAN_P
TheLfloat(erg)->data[0] = bit(intDsize-1);
clear_loop_up(&TheLfloat(erg)->data[1],len-1);
#else
var uintD* ptr = clear_loop_up(&TheLfloat(erg)->data[0],len-1);
*ptr = bit(intDsize-1);
#endif
return erg;
}
const cl_F least_positive_float (float_format_t f)
{
floatformatcase((uintL)f
, return least_positive_SF;
, return least_positive_FF;
, return least_positive_DF;
, return least_positive_LF(len);
);
}
} // namespace cln
CL_PROVIDE_END(cl_F_leastpos)
syntax highlighted by Code2HTML, v. 0.9.1