Click or drag to resize
mpfr_libmpfr_setsign Method
Set the value of rop from op, rounded toward the given direction rnd, then set (resp. clear) its sign bit if s is non-zero (resp. zero), even when op is a NaN.

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

Parameters

rop
Type: Math.Mpfr.Nativempfr_t
The result floating-point number.
op
Type: Math.Mpfr.Nativempfr_t
The operand floating-point number.
s
Type: SystemInt32
The sign bit.
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.
Examples
// Create, initialize, and set a new integer op to 200.
mpfr_t op = new mpfr_t();
mpfr_lib.mpfr_init2(op, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_ui(op, 200U, mpfr_rnd_t.MPFR_RNDN) == 0);

// Create, initialize, and set a new floating-point number rop to op.
mpfr_t rop = new mpfr_t();
mpfr_lib.mpfr_init(rop);

// Set rop = -op.
Assert.IsTrue(mpfr_lib.mpfr_setsign(rop, op, 1, mpfr_rnd_t.MPFR_RNDN) == 0);

// Assert that rop is -200.
Assert.IsTrue(rop.ToString() == "-0.20000000000000000e3");

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