Set rop to the arithmetic-geometric mean of op1 and 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_agm(
mpfr_t rop,
mpfr_t op1,
mpfr_t op2,
mpfr_rnd_t rnd
)
Public Shared Function mpfr_agm (
rop As mpfr_t,
op1 As mpfr_t,
op2 As mpfr_t,
rnd As mpfr_rnd_t
) As Integer
public:
static int mpfr_agm(
mpfr_t^ rop,
mpfr_t^ op1,
mpfr_t^ op2,
mpfr_rnd_t rnd
)
static member mpfr_agm :
rop : mpfr_t *
op1 : mpfr_t *
op2 : 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. - 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
The arithmetic-geometric mean is the common limit of the sequences u(n) and v(n), where u(0) = op1, v(0) = op2,
u(n + 1) is the arithmetic mean of u(n) and v(n), and v(n + 1) is the geometric mean of u(n) and v(n).
If any operand is negative and the other one is not zero, set rop to NaN.
If any operand is zero and the other one is finite (resp. infinite), set rop to +0 (resp. NaN).
Examples
mpfr_t op1 = new mpfr_t();
mpfr_lib.mpfr_init2(op1, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_si(op1, 24, mpfr_rnd_t.MPFR_RNDN) == 0);
mpfr_t op2 = new mpfr_t();
mpfr_lib.mpfr_init2(op2, 64U);
Assert.IsTrue(mpfr_lib.mpfr_init_set_si(op2, 6, mpfr_rnd_t.MPFR_RNDN) == 0);
mpfr_t rop = new mpfr_t();
mpfr_lib.mpfr_init2(rop, 64U);
Assert.IsTrue(mpfr_lib.mpfr_agm(rop, op1, op2, mpfr_rnd_t.MPFR_RNDN) == -1);
Assert.IsTrue(mpfr_lib.mpfr_get_d(rop, mpfr_rnd_t.MPFR_RNDN) == 13.458171481725615420766813156);
mpfr_lib.mpfr_clears(rop, op1, op2, null);
Dim op1 As mpfr_t = New mpfr_t()
mpfr_lib.mpfr_init2(op1, 64U)
Assert.IsTrue(mpfr_lib.mpfr_set_si(op1, 24, 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_init_set_si(op2, 6, 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_agm(rop, op1, op2, mpfr_rnd_t.MPFR_RNDN) = -1)
Assert.IsTrue(mpfr_lib.mpfr_get_d(rop, mpfr_rnd_t.MPFR_RNDN) = 13.458171481725615420766813156)
mpfr_lib.mpfr_clears(rop, op1, op2, 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