Set rop to (op1 * op2) - op3 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_fms(
mpfr_t rop,
mpfr_t op1,
mpfr_t op2,
mpfr_t op3,
mpfr_rnd_t rnd
)
Public Shared Function mpfr_fms (
rop As mpfr_t,
op1 As mpfr_t,
op2 As mpfr_t,
op3 As mpfr_t,
rnd As mpfr_rnd_t
) As Integer
public:
static int mpfr_fms(
mpfr_t^ rop,
mpfr_t^ op1,
mpfr_t^ op2,
mpfr_t^ op3,
mpfr_rnd_t rnd
)
static member mpfr_fms :
rop : mpfr_t *
op1 : mpfr_t *
op2 : mpfr_t *
op3 : mpfr_t *
rnd : mpfr_rnd_t -> int
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. - op3
- Type: Math.Mpfr.Nativempfr_t
The third 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
Concerning special values (signed zeros, infinities, NaN), these functions behave like a multiplication followed by a separate subtraction.
That is, the fused operation matters only for rounding.
Examples
mpfr_t op1 = new mpfr_t();
mpfr_lib.mpfr_init2(op1, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_si(op1, -210, mpfr_rnd_t.MPFR_RNDN) == 0);
mpfr_t op2 = new mpfr_t();
mpfr_lib.mpfr_init2(op2, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_si(op2, 10, mpfr_rnd_t.MPFR_RNDN) == 0);
mpfr_t op3 = new mpfr_t();
mpfr_lib.mpfr_init2(op3, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_si(op3, 10, mpfr_rnd_t.MPFR_RNDN) == 0);
mpfr_t rop = new mpfr_t();
mpfr_lib.mpfr_init2(rop, 64U);
Assert.IsTrue(mpfr_lib.mpfr_fms(rop, op1, op2, op3, mpfr_rnd_t.MPFR_RNDN) == 0);
Assert.IsTrue(mpfr_lib.mpfr_get_d(rop, mpfr_rnd_t.MPFR_RNDN) == -2110.0);
mpfr_lib.mpfr_clears(rop, op1, op2, op3, null);
Dim op1 As mpfr_t = New mpfr_t()
mpfr_lib.mpfr_init2(op1, 64U)
Assert.IsTrue(mpfr_lib.mpfr_set_si(op1, -210, mpfr_rnd_t.MPFR_RNDN) = 0)
Dim op2 As mpfr_t = New mpfr_t()
mpfr_lib.mpfr_init2(op2, 64U)
Assert.IsTrue(mpfr_lib.mpfr_set_si(op2, 10, mpfr_rnd_t.MPFR_RNDN) = 0)
Dim op3 As mpfr_t = New mpfr_t()
mpfr_lib.mpfr_init2(op3, 64U)
Assert.IsTrue(mpfr_lib.mpfr_set_si(op3, 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_fms(rop, op1, op2, op3, mpfr_rnd_t.MPFR_RNDN) = 0)
Assert.IsTrue(mpfr_lib.mpfr_get_d(rop, mpfr_rnd_t.MPFR_RNDN) = -2110.0)
mpfr_lib.mpfr_clears(rop, op1, op2, op3, 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