Click or drag to resize
mpfr_libmpfr_cmp Method
Compare op1 and op2.

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_cmp(
	mpfr_t op1,
	mpfr_t op2
)

Parameters

op1
Type: Math.Mpfr.Nativempfr_t
The first operand floating-point number.
op2
Type: Math.Mpfr.Nativempfr_t
The second operand floating-point number.

Return Value

Type: Int32
Return a positive value if op1 > op2, zero if op1 = op2, and a negative value if op1 < op2.
Remarks

Both op1 and op2 are considered to their full own precision, which may differ. If one of the operands is NaN, set the erange flag and return zero.

Note: These functions may be useful to distinguish the three possible cases. If you need to distinguish two cases only, it is recommended to use the predicate functions (e.g., mpfr_equal_p for the equality) described below; they behave like the IEEE 754 comparisons, in particular when one or both arguments are NaN. But only floating-point numbers can be compared (you may need to do a conversion first).

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

// Create and initialize a new floating-point number op2.
mpfr_t op2 = new mpfr_t();
mpfr_lib.mpfr_init2(op2, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_si(op2, 128, mpfr_rnd_t.MPFR_RNDN) == 0);

// Assert that op1 > op2.
Assert.IsTrue(mpfr_lib.mpfr_cmp(op1, op2) > 0);

// Release unmanaged memory allocated for op1 and op2.
mpfr_lib.mpfr_clears(op1, op2, null);
See Also