Click or drag to resize
mpfr_libmpfr_reldiff Method
Compute the relative difference between op1 and op2 and store the result in rop.

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 mpfr_reldiff(
	mpfr_t rop,
	mpfr_t op1,
	mpfr_t op2,
	mpfr_rnd_t rnd
)

Parameters

rop
Type: Math.Mpfr.Nativempfr_t
The result floating-point number.
op1
Type: Math.Mpfr.Nativempfr_t
The first operand floating-point number.
op2
Type: Math.Mpfr.Nativempfr_t
The second operand floating-point number.
rnd
Type: Math.Mpfr.Nativempfr_rnd_t
The rounding direction.
Remarks

This function does not guarantee the correct rounding on the relative difference; it just computes |op1 - op2| / op1, using the precision of rop and the rounding mode rnd for all operations.

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

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

// Create and initialize a new floating-point number rop.
mpfr_t rop = new mpfr_t();
mpfr_lib.mpfr_init2(rop, 64U);

// Set rop = |op1 - op2| / op1.
mpfr_lib.mpfr_reldiff(rop, op1, op2, mpfr_rnd_t.MPFR_RNDN);

// Assert that the value of z is 22.
Assert.IsTrue(mpfr_lib.mpfr_get_d(rop, mpfr_rnd_t.MPFR_RNDN) == 22.0);

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