mpfr_libmpfr_div_q Method |
Set rop to op1 / op2 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_div_q(
mpfr_t rop,
mpfr_t op1,
mpq_t op2,
mpfr_rnd_t rnd
)
Public Shared Function mpfr_div_q (
rop As mpfr_t,
op1 As mpfr_t,
op2 As mpq_t,
rnd As mpfr_rnd_t
) As Integer
public:
static int mpfr_div_q(
mpfr_t^ rop,
mpfr_t^ op1,
mpq_t^ op2,
mpfr_rnd_t rnd
)
static member mpfr_div_q :
rop : mpfr_t *
op1 : mpfr_t *
op2 : mpq_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.Gmp.Nativempq_t
The second 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
When a result is zero, its sign is the product of the signs of the operands.
For types having no signed zeros, 0 is considered positive; but note that if
op1 is non-zero and op2 is zero, the result might change from
±Inf to NaN in future MPFR versions if there is an opposite decision on the IEEE 754 side.
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);
mpq_t op2 = new mpq_t();
gmp_lib.mpq_init(op2);
gmp_lib.mpq_set_si(op2, 10, 1);
mpfr_t rop = new mpfr_t();
mpfr_lib.mpfr_init2(rop, 64U);
Assert.IsTrue(mpfr_lib.mpfr_div_q(rop, op1, op2, mpfr_rnd_t.MPFR_RNDN) == 0);
Assert.IsTrue(mpfr_lib.mpfr_get_d(rop, mpfr_rnd_t.MPFR_RNDN) == -21.0);
mpfr_lib.mpfr_clears(rop, op1, null);
gmp_lib.mpq_clear(op2);
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 mpq_t = New mpq_t()
gmp_lib.mpq_init(op2)
gmp_lib.mpq_set_si(op2, 10, 1)
Dim rop As mpfr_t = New mpfr_t()
mpfr_lib.mpfr_init2(rop, 64U)
Assert.IsTrue(mpfr_lib.mpfr_div_q(rop, op1, op2, mpfr_rnd_t.MPFR_RNDN) = 0)
Assert.IsTrue(mpfr_lib.mpfr_get_d(rop, mpfr_rnd_t.MPFR_RNDN) = -21.0)
mpfr_lib.mpfr_clears(rop, op1, Nothing)
gmp_lib.mpq_clear(op2)
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