Click or drag to resize
mpfr_libmpfr_custom_get_size Method
Return the needed size in bytes to store the significand of a floating-point number of precision prec.

Namespace:  Math.Mpfr.Native
Assembly:  Math.Mpfr.Native (in Math.Mpfr.Native.dll) Version: 1.0.0.0 (1.0.0.0)
Syntax
public static size_t mpfr_custom_get_size(
	uint prec
)

Parameters

prec
Type: SystemUInt32
The precision in bits.

Return Value

Type: size_t
Return the needed size in bytes to store the significand of a floating-point number of precision prec.
Examples
// Initialize a custom, 64-bit significand floating-point number, and set it to 0.
size_t size = mpfr_lib.mpfr_custom_get_size(64U);
void_ptr significand = gmp_lib.allocate(size);
gmp_lib.ZeroMemory(significand.ToIntPtr(), (int)size);
mpfr_t x = new mpfr_t();
mpfr_lib.mpfr_custom_init_set(x, mpfr_kind_t.MPFR_ZERO_KIND, 0, 64U, significand);

// Set x = 16.
Assert.IsTrue(mpfr_lib.mpfr_set_si(x, 16, mpfr_rnd_t.MPFR_RNDN) == 0);

// Assert exponent of x.
Assert.IsTrue(mpfr_lib.mpfr_custom_get_exp(x) == 5);

// Assert significand of x.
Byte[] result = new byte[] { 0, 0, 0, 0, 0, 0, 0, 0x80 };
byte[] sp = new byte[8];
Marshal.Copy(significand.ToIntPtr(), sp, 0, 8);
Assert.IsTrue(sp.SequenceEqual(result));

// Release unmanaged memory allocated for x and significand.
mpfr_lib.mpfr_custom_clear(x);
gmp_lib.free(significand);
See Also