Set rop to the absolute value of op rounded in the direction rnd.
Namespace:
Math.Mpfr.Native
Assembly:
Math.Mpfr.Native (in Math.Mpfr.Native.dll) Version: 1.0.0.0 (1.0.0.0)
Syntaxpublic static int mpfr_abs(
mpfr_t rop,
mpfr_t op,
mpfr_rnd_t rnd
)
Public Shared Function mpfr_abs (
rop As mpfr_t,
op As mpfr_t,
rnd As mpfr_rnd_t
) As Integer
public:
static int mpfr_abs(
mpfr_t^ rop,
mpfr_t^ op,
mpfr_rnd_t rnd
)
static member mpfr_abs :
rop : mpfr_t *
op : mpfr_t *
rnd : mpfr_rnd_t -> int
Parameters
- rop
- Type: Math.Mpfr.Nativempfr_t
The result floating-point number. - op
- Type: Math.Mpfr.Nativempfr_t
The operand floating-point number. - rnd
- Type: Math.Mpfr.Nativempfr_rnd_t
The rounding direction.
Return Value
Type:
Int32Return 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
Just changes or adjusts the sign if rop and op are the same variable,
otherwise a rounding might occur if the precision of rop is less than that of op.
The sign rule also applies to NaN in order to mimic the IEEE 754 negate and abs operations, i.e.,
for mpfr_neg(mpfr_t, mpfr_t, mpfr_rnd_t), the sign is reversed, and for mpfr_abs(mpfr_t, mpfr_t, mpfr_rnd_t), the sign is set
to positive. But contrary to IEEE 754, the NaN flag is set as usual.
Examples
mpfr_t op = new mpfr_t();
mpfr_lib.mpfr_init2(op, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_si(op, -10, mpfr_rnd_t.MPFR_RNDN) == 0);
mpfr_t rop = new mpfr_t();
mpfr_lib.mpfr_init2(rop, 64U);
Assert.IsTrue(mpfr_lib.mpfr_abs(rop, op, mpfr_rnd_t.MPFR_RNDN) == 0);
Assert.IsTrue(mpfr_lib.mpfr_cmp_si(rop, 10) == 0);
mpfr_lib.mpfr_clears(rop, op, null);
Dim op As mpfr_t = New mpfr_t()
mpfr_lib.mpfr_init2(op, 64U)
Assert.IsTrue(mpfr_lib.mpfr_set_si(op, -10, mpfr_rnd_t.MPFR_RNDN) = 0)
Dim rop As mpfr_t = New mpfr_t()
mpfr_lib.mpfr_init2(rop, 64U)
Assert.IsTrue(mpfr_lib.mpfr_abs(rop, op, mpfr_rnd_t.MPFR_RNDN) = 0)
Assert.IsTrue(mpfr_lib.mpfr_cmp_si(rop, 10) = 0)
mpfr_lib.mpfr_clears(rop, op, Nothing)
No code example is currently available or this language may not be supported.
No code example is currently available or this language may not be supported.
See Also