Click or drag to resize
mpfr_libmpfr_custom_get_significand Method
Return a pointer to the significand used by a mpfr_t initialized with mpfr_custom_init_set.

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 void_ptr mpfr_custom_get_significand(
	mpfr_t x
)

Parameters

x
Type: Math.Mpfr.Nativempfr_t
The operand floating-point number.

Return Value

Type: void_ptr
Return a pointer to the significand used by a mpfr_t initialized with mpfr_custom_init_set.
Remarks

The behavior of this function for any mpfr_t not initialized with mpfr_custom_init_set is undefined.

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 = x + 1.
Assert.IsTrue(mpfr_lib.mpfr_add_si(x, x, 1, mpfr_rnd_t.MPFR_RNDN) == 0);

// 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