Click or drag to resize
mpfr_libmpfr_set_flt Method
Set the value of rop from op rounded toward the given direction rnd.

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 int mpfr_set_flt(
	mpfr_t rop,
	float op,
	mpfr_rnd_t rnd
)

Parameters

rop
Type: Math.Mpfr.Nativempfr_t
The result floating-point number.
op
Type: SystemSingle
The operand floating-point number.
rnd
Type: Math.Mpfr.Nativempfr_rnd_t
The rounding direction.

Return Value

Type: Int32
Return zero, a positive, or a negative value if rop is respectively equal to, greater than, or lower than the exact result. See GNU MPFR - Rounding Modes for details.
Remarks

If the system does not support the IEEE 754 standard, mpfr_set_flt might not preserve the signed zeros.

Note: If you want to store a floating-point constant to a mpfr_t, you should use mpfr_set_str (or one of the MPFR constant functions, such as mpfr_const_pi for Pi) instead of mpfr_set_flt. Otherwise the floating-point constant will be first converted into a reduced-precision (e.g., 53-bit) binary number before MPFR can work with it.

This function assigns new values to already initialized floats (see GNU MPFR - Initialization Functions).

Examples
// Create, initialize, and set a new floating-point number rop to 10.0.
mpfr_t rop = new mpfr_t();
mpfr_lib.mpfr_init2(rop, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_flt(rop, (float)10.0, mpfr_rnd_t.MPFR_RNDN) == 0);

// Assert that rop is 10.
Assert.IsTrue(mpfr_lib.mpfr_get_si(rop, mpfr_rnd_t.MPFR_RNDN) == 10);

// Release unmanaged memory allocated for rop.
mpfr_lib.mpfr_clear(rop);
See Also