Arbitrary precision complex balls using Arb#
This is a binding to the Arb library; it may be useful to refer to its documentation for more details.
Parts of the documentation for this module are copied or adapted from Arb’s own documentation, licenced under the GNU General Public License version 2, or later.
Data Structure#
A ComplexBall
represents a complex number with error bounds. It wraps
an Arb object of type acb_t
, which consists of a pair of real number balls
representing the real and imaginary part with separate error bounds. (See the
documentation of sage.rings.real_arb
for more information.)
A ComplexBall
thus represents a rectangle \([m_1-r_1, m_1+r_1] +
[m_2-r_2, m_2+r_2] i\) in the complex plane. This is used in Arb instead of a
disk or square representation (consisting of a complex floating-point midpoint
with a single radius), since it allows implementing many operations more
conveniently by splitting into ball operations on the real and imaginary parts.
It also allows tracking when complex numbers have an exact (for example exactly
zero) real part and an inexact imaginary part, or vice versa.
The parents of complex balls are instances of ComplexBallField
.
The name CBF
is bound to the complex ball field with the default precision
of 53 bits:
sage: CBF is ComplexBallField() is ComplexBallField(53)
True
Comparison#
Warning
In accordance with the semantics of Arb, identical ComplexBall
objects are understood to give permission for algebraic simplification.
This assumption is made to improve performance. For example, setting z =
x*x
sets \(z\) to a ball enclosing the set \(\{t^2 : t \in x\}\) and not the
(generally larger) set \(\{tu : t \in x, u \in x\}\).
Two elements are equal if and only if they are exact and equal (in spite of the above warning, inexact balls are not considered equal to themselves):
sage: a = CBF(1, 2)
sage: b = CBF(1, 2)
sage: a is b
False
sage: a == a
True
sage: a == b
True
sage: a = CBF(1/3, 1/5)
sage: b = CBF(1/3, 1/5)
sage: a.is_exact()
False
sage: b.is_exact()
False
sage: a is b
False
sage: a == a
False
sage: a == b
False
A ball is non-zero in the sense of usual comparison if and only if it does not contain zero:
sage: a = CBF(RIF(-0.5, 0.5))
sage: a != 0
False
sage: b = CBF(1/3, 1/5)
sage: b != 0
True
However, bool(b)
returns False
for a ball b
only if b
is exactly
zero:
sage: bool(a)
True
sage: bool(b)
True
sage: bool(CBF.zero())
False
Coercion#
Automatic coercions work as expected:
sage: bpol = 1/3*CBF(i) + AA(sqrt(2)) + (polygen(RealBallField(20), 'x') + QQbar(i))
sage: bpol
x + [1.41421 +/- ...e-6] + [1.33333 +/- ...e-6]*I
sage: bpol.parent()
Univariate Polynomial Ring in x over Complex ball field with 20 bits of precision
sage: bpol/3
([0.333333 +/- ...e-7])*x + [0.47140 +/- ...e-6] + [0.44444 +/- ...e-6]*I
Classes and Methods#
- class sage.rings.complex_arb.ComplexBall#
Bases:
RingElement
Hold one
acb_t
of the Arb libraryEXAMPLES:
sage: a = ComplexBallField()(1, 1) sage: a 1.000000000000000 + 1.000000000000000*I
- Chi()#
Return the hyperbolic cosine integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Chi() [0.882172180555936 +/- ...e-16] + [1.28354719327494 +/- ...e-15]*I sage: CBF(0).Chi() nan + nan*I
- Ci()#
Return the cosine integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Ci() [0.882172180555936 +/- ...e-16] + [0.287249133519956 +/- ...e-16]*I sage: CBF(0).Ci() nan + nan*I
- Ei()#
Return the exponential integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Ei() [1.76462598556385 +/- ...e-15] + [2.38776985151052 +/- ...e-15]*I sage: CBF(0).Ei() nan
- Li()#
Offset logarithmic integral.
EXAMPLES:
sage: CBF(0).Li() [-1.045163780117493 +/- ...e-16] sage: li(0).n() 0.000000000000000 sage: Li(0).n() -1.04516378011749
- Shi()#
Return the hyperbolic sine integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Shi() [0.88245380500792 +/- ...e-15] + [1.10422265823558 +/- ...e-15]*I sage: CBF(0).Shi() 0
- Si()#
Return the sine integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Si() [1.10422265823558 +/- ...e-15] + [0.88245380500792 +/- ...e-15]*I sage: CBF(0).Si() 0
- above_abs()#
Return an upper bound for the absolute value of this complex ball.
OUTPUT:
A ball with zero radius
EXAMPLES:
sage: b = ComplexBallField(8)(1+i).above_abs() sage: b [1.4 +/- 0.0219] sage: b.is_exact() True sage: QQ(b)*128 182
See also
- accuracy()#
Return the effective relative accuracy of this ball measured in bits.
This is computed as if calling
accuracy()
on the real ball whose midpoint is the larger out of the real and imaginary midpoints of this complex ball, and whose radius is the larger out of the real and imaginary radii of this complex ball.EXAMPLES:
sage: CBF(exp(I*pi/3)).accuracy() 51 sage: CBF(I/2).accuracy() == CBF.base().maximal_accuracy() True sage: CBF('nan', 'inf').accuracy() == -CBF.base().maximal_accuracy() True
See also
- add_error(ampl)#
Increase the radii of the real and imaginary parts by (an upper bound on)
ampl
.If
ampl
is negative, the radii remain unchanged.INPUT:
ampl
- A real ball (or an object that can be coerced to a real ball).
OUTPUT:
A new complex ball.
EXAMPLES:
sage: CBF(1+i).add_error(10^-16) [1.000000000000000 +/- ...e-16] + [1.000000000000000 +/- ...e-16]*I
- agm1()#
Return the arithmetic-geometric mean of 1 and
self
.The arithmetic-geometric mean is defined such that the function is continuous in the complex plane except for a branch cut along the negative half axis (where it is continuous from above). This corresponds to always choosing an “optimal” branch for the square root in the arithmetic-geometric mean iteration.
EXAMPLES:
sage: CBF(0, -1).agm1() [0.599070117367796 +/- 3.9...e-16] + [-0.599070117367796 +/- 5.5...e-16]*I
- airy()#
Return the Airy functions Ai, Ai’, Bi, Bi’ with argument
self
, evaluated simultaneously.EXAMPLES:
sage: CBF(10*pi).airy() ([1.2408955946101e-52 +/- ...e-66], [-6.965048886977e-52 +/- ...e-65], [2.2882956833435e+50 +/- ...e+36], [1.2807602335816e+51 +/- ...e+37]) sage: ai, aip, bi, bip = CBF(1,2).airy() sage: (ai * bip - bi * aip) * CBF(pi) [1.0000000000000 +/- ...e-15] + [+/- ...e-16]*I
- airy_ai()#
Return the Airy function Ai with argument
self
.EXAMPLES:
sage: CBF(1,2).airy_ai() [-0.2193862549814276 +/- ...e-17] + [-0.1753859114081094 +/- ...e-17]*I
- airy_ai_prime()#
Return the Airy function derivative Ai’ with argument
self
.EXAMPLES:
sage: CBF(1,2).airy_ai_prime() [0.1704449781789148 +/- ...e-17] + [0.387622439413295 +/- ...e-16]*I
- airy_bi()#
Return the Airy function Bi with argument
self
.EXAMPLES:
sage: CBF(1,2).airy_bi() [0.0488220324530612 +/- ...e-17] + [0.1332740579917484 +/- ...e-17]*I
- airy_bi_prime()#
Return the Airy function derivative Bi’ with argument
self
.EXAMPLES:
sage: CBF(1,2).airy_bi_prime() [-0.857239258605362 +/- ...e-16] + [0.4955063363095674 +/- ...e-17]*I
- arccos(analytic=False)#
Return the arccosine of this ball.
INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(1+i).arccos() [0.90455689430238 +/- ...e-15] + [-1.06127506190504 +/- ...e-15]*I sage: CBF(-1).arccos() [3.141592653589793 +/- ...e-16] sage: CBF(-1).arccos(analytic=True) nan + nan*I
- arccosh(analytic=False)#
Return the hyperbolic arccosine of this ball.
INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(1+i).arccosh() [1.061275061905035 +/- ...e-16] + [0.904556894302381 +/- ...e-16]*I sage: CBF(-2).arccosh() [1.316957896924817 +/- ...e-16] + [3.141592653589793 +/- ...e-16]*I sage: CBF(-2).arccosh(analytic=True) nan + nan*I
- arcsin(analytic=False)#
Return the arcsine of this ball.
INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(1+i).arcsin() [0.66623943249252 +/- ...e-15] + [1.06127506190504 +/- ...e-15]*I sage: CBF(1, RIF(0,1/1000)).arcsin() [1.6 +/- 0.0619] + [+/- 0.0322]*I sage: CBF(1, RIF(0,1/1000)).arcsin(analytic=True) nan + nan*I
- arcsinh(analytic=False)#
Return the hyperbolic arcsine of this ball.
INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(1+i).arcsinh() [1.06127506190504 +/- ...e-15] + [0.66623943249252 +/- ...e-15]*I sage: CBF(2*i).arcsinh() [1.31695789692482 +/- ...e-15] + [1.570796326794897 +/- ...e-16]*I sage: CBF(2*i).arcsinh(analytic=True) nan + nan*I
- arctan(analytic=False)#
Return the arctangent of this ball.
INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(1+i).arctan() [1.017221967897851 +/- ...e-16] + [0.4023594781085251 +/- ...e-17]*I sage: CBF(i).arctan() nan + nan*I sage: CBF(2*i).arctan() [1.570796326794897 +/- ...e-16] + [0.549306144334055 +/- ...e-16]*I sage: CBF(2*i).arctan(analytic=True) nan + nan*I
- arctanh(analytic=False)#
Return the hyperbolic arctangent of this ball.
INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(1+i).arctanh() [0.4023594781085251 +/- ...e-17] + [1.017221967897851 +/- ...e-16]*I sage: CBF(-2).arctanh() [-0.549306144334055 +/- ...e-16] + [1.570796326794897 +/- ...e-16]*I sage: CBF(-2).arctanh(analytic=True) nan + nan*I
- arg()#
Return the argument of this complex ball.
EXAMPLES:
sage: CBF(1 + i).arg() [0.7853981633974483 +/- ...e-17] sage: CBF(-1).arg() [3.141592653589793 +/- ...e-16] sage: CBF(-1).arg().parent() Real ball field with 53 bits of precision
- barnes_g()#
Return the Barnes G-function of
self
.EXAMPLES:
sage: CBF(-4).barnes_g() 0 sage: CBF(8).barnes_g() 24883200.00000000 sage: CBF(500,10).barnes_g() [4.54078781e+254873 +/- ...e+254864] + [8.65835455e+254873 +/- ...e+254864]*I
- below_abs(test_zero=False)#
Return a lower bound for the absolute value of this complex ball.
INPUT:
test_zero
(boolean, defaultFalse
) – ifTrue
, make sure that the returned lower bound is positive, raising an error if the ball contains zero.
OUTPUT:
A ball with zero radius
EXAMPLES:
sage: b = ComplexBallField(8)(1+i).below_abs() sage: b [1.4 +/- 0.0141] sage: b.is_exact() True sage: QQ(b)*128 181 sage: (CBF(1/3) - 1/3).below_abs() 0 sage: (CBF(1/3) - 1/3).below_abs(test_zero=True) Traceback (most recent call last): ... ValueError: ball contains zero
See also
- bessel_I(nu)#
Return the modified Bessel function of the first kind with argument
self
and indexnu
.EXAMPLES:
sage: CBF(1, 1).bessel_I(1) [0.365028028827088 +/- ...e-16] + [0.614160334922903 +/- ...e-16]*I sage: CBF(100, -100).bessel_I(1/3) [5.4362189595644e+41 +/- ...e+27] + [7.1989436985321e+41 +/- ...e+27]*I
- bessel_J(nu)#
Return the Bessel function of the first kind with argument
self
and indexnu
.EXAMPLES:
sage: CBF(1, 1).bessel_J(1) [0.614160334922903 +/- ...e-16] + [0.365028028827088 +/- ...e-16]*I sage: CBF(100, -100).bessel_J(1/3) [1.108431870251e+41 +/- ...e+28] + [-8.952577603125e+41 +/- ...e+28]*I
- bessel_J_Y(nu)#
Return the Bessel function of the first and second kind with argument
self
and indexnu
, computed simultaneously.EXAMPLES:
sage: J, Y = CBF(1, 1).bessel_J_Y(1) sage: J - CBF(1, 1).bessel_J(1) [+/- ...e-16] + [+/- ...e-16]*I sage: Y - CBF(1, 1).bessel_Y(1) [+/- ...e-14] + [+/- ...e-14]*I
- bessel_K(nu)#
Return the modified Bessel function of the second kind with argument
self
and indexnu
.EXAMPLES:
sage: CBF(1, 1).bessel_K(0) [0.08019772694652 +/- ...e-15] + [-0.357277459285330 +/- ...e-16]*I sage: CBF(1, 1).bessel_K(1) [0.02456830552374 +/- ...e-15] + [-0.45971947380119 +/- ...e-15]*I sage: CBF(100, 100).bessel_K(QQbar(i)) [3.8693896656383e-45 +/- ...e-59] + [5.507100423418e-46 +/- ...e-59]*I
- bessel_Y(nu)#
Return the Bessel function of the second kind with argument
self
and indexnu
.EXAMPLES:
sage: CBF(1, 1).bessel_Y(1) [-0.6576945355913 +/- ...e-14] + [0.6298010039929 +/- ...e-14]*I sage: CBF(100, -100).bessel_Y(1/3) [-8.952577603125e+41 +/- ...e+28] + [-1.108431870251e+41 +/- ...e+28]*I
- chebyshev_T(n)#
Return the Chebyshev function of the first kind of order
n
evaluated atself
.EXAMPLES:
sage: CBF(1/3).chebyshev_T(20) [0.8710045668809 +/- ...e-14] sage: CBF(1/3).chebyshev_T(CBF(5,1)) [1.84296854518763 +/- ...e-15] + [0.20053614301799 +/- ...e-15]*I
- chebyshev_U(n)#
Return the Chebyshev function of the second kind of order
n
evaluated atself
.EXAMPLES:
sage: CBF(1/3).chebyshev_U(20) [0.6973126541184 +/- ...e-14] sage: CBF(1/3).chebyshev_U(CBF(5,1)) [1.75884964893425 +/- ...e-15] + [0.7497317165104 +/- ...e-14]*I
- chi(*args, **kwds)#
Deprecated: Use
Chi()
instead. See trac ticket #32869 for details.
- ci(*args, **kwds)#
Deprecated: Use
Ci()
instead. See trac ticket #32869 for details.
- conjugate()#
Return the complex conjugate of this ball.
EXAMPLES:
sage: CBF(-2 + I/3).conjugate() -2.000000000000000 + [-0.3333333333333333 +/- ...e-17]*I
- contains_exact(other)#
Return
True
iffother
is contained inself
.Use
other in self
for a test that works for a wider range of inputs but may return false negatives.INPUT:
other
–ComplexBall
,Integer
, orRational
EXAMPLES:
sage: CBF(RealBallField(100)(1/3), 0).contains_exact(1/3) True sage: CBF(1).contains_exact(1) True sage: CBF(1).contains_exact(CBF(1)) True sage: CBF(sqrt(2)).contains_exact(sqrt(2)) Traceback (most recent call last): ... TypeError: unsupported type: <class 'sage.symbolic.expression.Expression'>
- contains_integer()#
Return
True
iff this ball contains any integer.EXAMPLES:
sage: CBF(3, RBF(0.1)).contains_integer() False sage: CBF(3, RBF(0.1,0.1)).contains_integer() True
- contains_zero()#
Return
True
iff this ball contains zero.EXAMPLES:
sage: CBF(0).contains_zero() True sage: CBF(RIF(-1,1)).contains_zero() True sage: CBF(i).contains_zero() False
- cos()#
Return the cosine of this ball.
EXAMPLES:
sage: CBF(i*pi).cos() [11.59195327552152 +/- ...e-15]
- cos_integral()#
Return the cosine integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Ci() [0.882172180555936 +/- ...e-16] + [0.287249133519956 +/- ...e-16]*I sage: CBF(0).Ci() nan + nan*I
- cosh()#
Return the hyperbolic cosine of this ball.
EXAMPLES:
sage: CBF(1, 1).cosh() [0.833730025131149 +/- ...e-16] + [0.988897705762865 +/- ...e-16]*I
- cosh_integral()#
Return the hyperbolic cosine integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Chi() [0.882172180555936 +/- ...e-16] + [1.28354719327494 +/- ...e-15]*I sage: CBF(0).Chi() nan + nan*I
- cot()#
Return the cotangent of this ball.
EXAMPLES:
sage: CBF(pi, 1/10).cot() [+/- ...e-14] + [-10.03331113225399 +/- ...e-15]*I sage: CBF(pi).cot() nan
- coth()#
Return the hyperbolic cotangent of this ball.
EXAMPLES:
sage: CBF(1, 1).coth() [0.868014142895925 +/- ...e-16] + [-0.2176215618544027 +/- ...e-17]*I sage: CBF(0, pi).coth() nan*I
- csc()#
Return the cosecant of this ball.
EXAMPLES:
sage: CBF(1, 1).csc() [0.621518017170428 +/- ...e-16] + [-0.303931001628426 +/- ...e-16]*I
- csch()#
Return the hyperbolic cosecant of this ball.
EXAMPLES:
sage: CBF(1, 1).csch() [0.303931001628426 +/- ...e-16] + [-0.621518017170428 +/- ...e-16]*I sage: CBF(i*pi).csch() nan*I
- cube()#
Return the cube of this ball.
The result is computed efficiently using two real squarings, two real multiplications, and scalar operations.
EXAMPLES:
sage: CBF(1, 1).cube() -2.000000000000000 + 2.000000000000000*I
- diameter()#
Return the diameter of this ball.
EXAMPLES:
sage: CBF(1 + i).diameter() 0.00000000 sage: CBF(i/3).diameter() 2.2204460e-16 sage: CBF(i/3).diameter().parent() Real Field with 30 bits of precision sage: CBF(CIF(RIF(1.02, 1.04), RIF(2.1, 2.2))).diameter() 0.20000000
- ei(*args, **kwds)#
Deprecated: Use
Ei()
instead. See trac ticket #32869 for details.
- eisenstein(n)#
Return the first
n
entries in the sequence of Eisenstein series \(G_4(\tau), G_6(\tau), G_8(\tau), \ldots\) where tau is given byself
. The output is a list.EXAMPLES:
sage: a, b, c, d = 2, 5, 1, 3 sage: tau = CBF(1,3) sage: tau.eisenstein(4) [[2.1646498507193 +/- ...e-14], [2.0346794456073 +/- ...e-14], [2.0081609898081 +/- ...e-14], [2.0019857082706 +/- ...e-14]] sage: ((a*tau+b)/(c*tau+d)).eisenstein(3)[2] [331011.2004330 +/- ...e-8] + [-711178.1655746 +/- ...e-8]*I sage: (c*tau+d)^8 * tau.eisenstein(3)[2] [331011.20043304 +/- ...e-9] + [-711178.1655746 +/- ...e-8]*I
- elliptic_e()#
Return the complete elliptic integral of the second kind evaluated at m given by
self
.EXAMPLES:
sage: CBF(2,3).elliptic_e() [1.472797144959 +/- ...e-13] + [-1.231604783936 +/- ...e-14]*I
- elliptic_e_inc(m)#
Return the incomplete elliptic integral of the second kind evaluated at m.
See
elliptic_e()
for the corresponding complete integralINPUT:
m
- complex ball
EXAMPLES:
sage: CBF(1,2).elliptic_e_inc(CBF(0,1)) [1.906576998914 +/- ...e-13] + [3.6896645289411 +/- ...e-14]*I
At parameter \(\pi/2\) it is a complete integral:
sage: phi = CBF(1,1) sage: (CBF.pi()/2).elliptic_e_inc(phi) [1.2838409578982 +/- ...e-14] + [-0.5317843366915 +/- ...e-14]*I sage: phi.elliptic_e() [1.2838409578982 +/- 5...e-14] + [-0.5317843366915 +/- 3...e-14]*I sage: phi = CBF(2, 3/7) sage: (CBF.pi()/2).elliptic_e_inc(phi) [0.787564350925 +/- ...e-13] + [-0.686896129145 +/- ...e-13]*I sage: phi.elliptic_e() [0.7875643509254 +/- ...e-14] + [-0.686896129145 +/- ...e-13]*I
- elliptic_f(m)#
Return the incomplete elliptic integral of the first kind evaluated at m.
See
elliptic_k()
for the corresponding complete integralINPUT:
m
- complex ball
EXAMPLES:
sage: CBF(1,2).elliptic_f(CBF(0,1)) [0.6821522911854 +/- ...e-14] + [1.2482780628143 +/- ...e-14]*I
At parameter \(\pi/2\) it is a complete integral:
sage: phi = CBF(1,1) sage: (CBF.pi()/2).elliptic_f(phi) [1.5092369540513 +/- ...e-14] + [0.6251464152027 +/- ...e-15]*I sage: phi.elliptic_k() [1.50923695405127 +/- ...e-15] + [0.62514641520270 +/- ...e-15]*I sage: phi = CBF(2, 3/7) sage: (CBF.pi()/2).elliptic_f(phi) [1.3393589639094 +/- ...e-14] + [1.1104369690719 +/- ...e-14]*I sage: phi.elliptic_k() [1.33935896390938 +/- ...e-15] + [1.11043696907194 +/- ...e-15]*I
- elliptic_invariants()#
Return the lattice invariants
(g2, g3)
.EXAMPLES:
sage: CBF(0,1).elliptic_invariants() ([189.07272012923 +/- ...e-12], [+/- ...e-12]) sage: CBF(sqrt(2)/2, sqrt(2)/2).elliptic_invariants() ([+/- ...e-12] + [-332.5338031465...]*I, [1254.46842157...] + [1254.46842157...]*I)
- elliptic_k()#
Return the complete elliptic integral of the first kind evaluated at m given by
self
.EXAMPLES:
sage: CBF(2,3).elliptic_k() [1.04291329192852 +/- ...e-15] + [0.62968247230864 +/- ...e-15]*I
- elliptic_p(tau, n=None)#
Return the Weierstrass elliptic function with lattice parameter
tau
, evaluated atself
. The function is doubly periodic inself
with periods 1 andtau
, which should lie in the upper half plane.If
n
is given, return a list containing the firstn
terms in the Taylor expansion atself
. In particular, withn
= 2, compute the Weierstrass elliptic function together with its derivative, which generate the field of elliptic functions with periods 1 andtau
.EXAMPLES:
sage: tau = CBF(1,4) sage: z = CBF(sqrt(2), sqrt(3)) sage: z.elliptic_p(tau) [-3.28920996772709 +/- ...e-15] + [-0.0003673767302933 +/- ...e-17]*I sage: (z + tau).elliptic_p(tau) [-3.28920996772709 +/- ...e-15] + [-0.000367376730293 +/- ...e-16]*I sage: (z + 1).elliptic_p(tau) [-3.28920996772709 +/- ...e-15] + [-0.0003673767302933 +/- ...e-17]*I sage: z.elliptic_p(tau, 3) [[-3.28920996772709 +/- ...e-15] + [-0.0003673767302933 +/- ...e-17]*I, [0.002473055794309 +/- ...e-16] + [0.003859554040267 +/- ...e-16]*I, [-0.01299087561709 +/- ...e-15] + [0.00725027521915 +/- ...e-15]*I] sage: (z + 3 + 4*tau).elliptic_p(tau, 3) [[-3.28920996772709 +/- ...e-15] + [-0.00036737673029 +/- ...e-15]*I, [0.0024730557943 +/- ...e-14] + [0.0038595540403 +/- ...e-14]*I, [-0.01299087562 +/- ...e-12] + [0.00725027522 +/- ...e-12]*I]
- elliptic_pi(m)#
Return the complete elliptic integral of the third kind evaluated at m given by
self
.EXAMPLES:
sage: CBF(2,3).elliptic_pi(CBF(1,1)) [0.2702999736198...] + [0.715676058329...]*I
- elliptic_pi_inc(phi, m)#
Return the Legendre incomplete elliptic integral of the third kind.
See:
elliptic_pi()
for the complete integral.INPUT:
phi
- complex ballm
- complex ball
EXAMPLES:
sage: CBF(1,2).elliptic_pi_inc(CBF(0,1), CBF(2,-3)) [0.05738864021418 +/- ...e-15] + [0.55557494549951 +/- ...e-15]*I
At parameter \(\pi/2\) it is a complete integral:
sage: n = CBF(1,1) sage: m = CBF(-2/3, 3/5) sage: n.elliptic_pi_inc(CBF.pi()/2, m) # arb216 [0.8934793755173 +/- ...e-14] + [0.95707868710750 +/- ...e-15]*I sage: n.elliptic_pi_inc(CBF.pi()/2, m) # arb218 - this is a regression, see :trac:28623 nan + nan*I sage: n.elliptic_pi(m) [0.8934793755173...] + [0.957078687107...]*I sage: n = CBF(2, 3/7) sage: m = CBF(-1/3, 2/9) sage: n.elliptic_pi_inc(CBF.pi()/2, m) # arb216 [0.2969588746419 +/- ...e-14] + [1.3188795332738 +/- ...e-14]*I sage: n.elliptic_pi_inc(CBF.pi()/2, m) # arb218 - this is a regression, see :trac:28623 nan + nan*I sage: n.elliptic_pi(m) [0.296958874641...] + [1.318879533273...]*I
- elliptic_rf(y, z)#
Return the Carlson symmetric elliptic integral of the first kind evaluated at
(self, y, z)
.INPUT:
y
- complex ballz
- complex ball
EXAMPLES:
sage: CBF(0,1).elliptic_rf(CBF(-1/2,1), CBF(-1,-1)) [1.469800396738515 +/- ...e-16] + [-0.2358791199824196 +/- ...e-17]*I
- elliptic_rg(y, z)#
Return the Carlson symmetric elliptic integral of the second kind evaluated at
(self, y, z)
.INPUT:
y
- complex ballz
- complex ball
EXAMPLES:
sage: CBF(0,1).elliptic_rg(CBF(-1/2,1), CBF(-1,-1)) [0.1586786770922370 +/- ...e-17] + [0.2239733128130531 +/- ...e-17]*I
- elliptic_rj(y, z, p)#
Return the Carlson symmetric elliptic integral of the third kind evaluated at
(self, y, z)
.INPUT:
y
- complex ballz
- complex ballp
- complex bamm
EXAMPLES:
sage: CBF(0,1).elliptic_rj(CBF(-1/2,1), CBF(-1,-1), CBF(2)) [1.00438675628573...] + [-0.24516268343916...]*I
- elliptic_roots()#
Return the lattice roots
(e1, e2, e3)
of \(4 z^3 - g_2 z - g_3\).EXAMPLES:
sage: e1, e2, e3 = CBF(0,1).elliptic_roots() sage: e1, e2, e3 ([6.8751858180204 +/- ...e-14], [+/- ...e-14], [-6.8751858180204 +/- ...e-14]) sage: g2, g3 = CBF(0,1).elliptic_invariants() sage: 4 * e1^3 - g2 * e1 - g3 [+/- ...e-11]
- elliptic_sigma(tau)#
Return the value of the Weierstrass sigma function at
(self, tau)
EXAMPLES:
- ``tau`` - a complex ball with positive imaginary part
EXAMPLES:
sage: CBF(1,1).elliptic_sigma(CBF(1,3)) [-0.543073363596 +/- ...e-13] + [3.6357291186244 +/- ...e-14]*I
- elliptic_zeta(tau)#
Return the value of the Weierstrass zeta function at
(self, tau)
EXAMPLES:
- ``tau`` - a complex ball with positive imaginary part
EXAMPLES:
sage: CBF(1,1).elliptic_zeta(CBF(1,3)) [3.2898676194970 +/- ...e-14] + [0.1365414361782 +/- ...e-14]*I
- erf()#
Return the error function with argument
self
.EXAMPLES:
sage: CBF(1, 1).erf() [1.316151281697947 +/- ...e-16] + [0.1904534692378347 +/- ...e-17]*I
- erfc()#
Compute the complementary error function with argument
self
.EXAMPLES:
sage: CBF(20).erfc() # abs tol 1e-190 [5.39586561160790e-176 +/- 6.73e-191] sage: CBF(100, 100).erfc() [0.00065234366376858 +/- ...e-18] + [-0.00393572636292141 +/- ...e-18]*I
- exp()#
Return the exponential of this ball.
See also
EXAMPLES:
sage: CBF(i*pi).exp() [-1.00000000000000 +/- ...e-16] + [+/- ...e-16]*I
- exp_integral_e(s)#
Return the image of this ball by the generalized exponential integral with index
s
.EXAMPLES:
sage: CBF(1+i).exp_integral_e(1) [0.00028162445198 +/- ...e-15] + [-0.17932453503936 +/- ...e-15]*I sage: CBF(1+i).exp_integral_e(QQbar(i)) [-0.10396361883964 +/- ...e-15] + [-0.16268401277783 +/- ...e-15]*I
- exppii()#
Return
exp(pi*i*self)
.EXAMPLES:
sage: CBF(1/2).exppii() 1.000000000000000*I sage: CBF(0, -1/pi).exppii() [2.71828182845904 +/- ...e-15]
- gamma(z=None)#
Return the image of this ball by the Euler Gamma function (if
z = None
) or the incomplete Gamma function (otherwise).EXAMPLES:
sage: CBF(1, 1).gamma() # abs tol 1e-15 [0.498015668118356 +/- 1.26e-16] + [-0.1549498283018107 +/- 8.43e-17]*I sage: CBF(-1).gamma() nan sage: CBF(1, 1).gamma(0) # abs tol 1e-15 [0.498015668118356 +/- 1.26e-16] + [-0.1549498283018107 +/- 8.43e-17]*I sage: CBF(1, 1).gamma(100) [-3.6143867454139e-45 +/- ...e-59] + [-3.7022961377791e-44 +/- ...e-58]*I sage: CBF(1, 1).gamma(CLF(i)) # abs tol 1e-14 [0.328866841935004 +/- 7.07e-16] + [-0.189749450456210 +/- 9.05e-16]*I
- gamma_inc(z=None)#
Return the image of this ball by the Euler Gamma function (if
z = None
) or the incomplete Gamma function (otherwise).EXAMPLES:
sage: CBF(1, 1).gamma() # abs tol 1e-15 [0.498015668118356 +/- 1.26e-16] + [-0.1549498283018107 +/- 8.43e-17]*I sage: CBF(-1).gamma() nan sage: CBF(1, 1).gamma(0) # abs tol 1e-15 [0.498015668118356 +/- 1.26e-16] + [-0.1549498283018107 +/- 8.43e-17]*I sage: CBF(1, 1).gamma(100) [-3.6143867454139e-45 +/- ...e-59] + [-3.7022961377791e-44 +/- ...e-58]*I sage: CBF(1, 1).gamma(CLF(i)) # abs tol 1e-14 [0.328866841935004 +/- 7.07e-16] + [-0.189749450456210 +/- 9.05e-16]*I
- gegenbauer_C(n, m)#
Return the Gegenbauer polynomial (or function) \(C_n^m(z)\) evaluated at
self
.EXAMPLES:
sage: CBF(-10).gegenbauer_C(7, 1/2) [-263813415.6250000 +/- ...e-8]
- hermite_H(n)#
Return the Hermite function (or polynomial) of order
n
evaluated atself
.EXAMPLES:
sage: CBF(10).hermite_H(1) 20.00000000000000 sage: CBF(10).hermite_H(30) [8.0574670961707e+37 +/- ...e+23]
- hypergeometric(a, b, regularized=False)#
Return the generalized hypergeometric function of
self
.INPUT:
a
– upper parameters, list of complex numbers that coerce into this ball’s parent;b
– lower parameters, list of complex numbers that coerce into this ball’s parent.regularized
– if True, the regularized generalized hypergeometric function is computed.
OUTPUT:
The generalized hypergeometric function defined by
\[{}_pF_q(a_1,\ldots,a_p;b_1,\ldots,b_q;z) = \sum_{k=0}^\infty \frac{(a_1)_k\dots(a_p)_k}{(b_1)_k\dots(b_q)_k} \frac {z^k} {k!}\]extended using analytic continuation or regularization when the sum does not converge.
The regularized generalized hypergeometric function
\[{}_pF_q(a_1,\ldots,a_p;b_1,\ldots,b_q;z) = \sum_{k=0}^\infty \frac{(a_1)_k\dots(a_p)_k}{\Gamma(b_1+k)\dots\Gamma(b_q+k)} \frac {z^k} {k!}\]is well-defined even when the lower parameters are nonpositive integers. Currently, this is only supported for some \(p\) and \(q\).
EXAMPLES:
sage: CBF(1, pi/2).hypergeometric([], []) [+/- ...e-16] + [2.71828182845904 +/- ...e-15]*I sage: CBF(1, pi).hypergeometric([1/4], [1/4]) [-2.7182818284590 +/- ...e-14] + [+/- ...e-14]*I sage: CBF(1000, 1000).hypergeometric([10], [AA(sqrt(2))]) [9.79300951360e+454 +/- ...e+442] + [5.522579106816e+455 +/- ...e+442]*I sage: CBF(1000, 1000).hypergeometric([100], [AA(sqrt(2))]) [1.27967355557e+590 +/- ...e+578] + [-9.32333491987e+590 +/- ...e+578]*I sage: CBF(0, 1).hypergeometric([], [1/2, 1/3, 1/4]) [-3.7991962344383 +/- ...e-14] + [23.878097177805 +/- ...e-13]*I sage: CBF(0).hypergeometric([1], []) 1.000000000000000 sage: CBF(1, 1).hypergeometric([1], []) 1.000000000000000*I sage: CBF(2+3*I).hypergeometric([1/4,1/3],[1/2]) # abs tol 1e-14 [0.7871684267473 +/- 6.79e-14] + [0.2749254173721 +/- 8.82e-14]*I sage: CBF(2+3*I).hypergeometric([1/4,1/3],[1/2],regularized=True) [0.4441122268685 +/- 3...e-14] + [0.1551100567338 +/- 5...e-14]*I sage: CBF(5).hypergeometric([2,3], [-5]) nan + nan*I sage: CBF(5).hypergeometric([2,3], [-5], regularized=True) [5106.925964355 +/- ...e-10] sage: CBF(2016).hypergeometric([], [2/3]) # abs tol 1e+26 [2.0256426923278e+38 +/- 9.59e+24] sage: CBF(-2016).hypergeometric([], [2/3], regularized=True) [-0.0005428550847 +/- ...e-14] sage: CBF(-7).hypergeometric([4], []) 0.0002441406250000000 sage: CBF(0, 3).hypergeometric([CBF(1,1)], [-4], regularized=True) [239.514000752841 +/- ...e-13] + [105.175157349015 +/- ...e-13]*I
- hypergeometric_U(a, b)#
Return the Tricomi confluent hypergeometric function U(a, b, self) of this ball.
EXAMPLES:
sage: CBF(1000, 1000).hypergeometric_U(RLF(pi), -100) [-7.261605907166e-11 +/- ...e-24] + [-7.928136216391e-11 +/- ...e-24]*I sage: CBF(1000, 1000).hypergeometric_U(0, -100) 1.000000000000000
- identical(other)#
Return whether
self
andother
represent the same ball.INPUT:
other
– aComplexBall
.
OUTPUT:
Return True iff
self
andother
are equal as sets, i.e. if their real and imaginary parts each have the same midpoint and radius.Note that this is not the same thing as testing whether both
self
andother
certainly represent the complex real number, unless eitherself
orother
is exact (and neither contains NaN). To test whether both operands might represent the same mathematical quantity, useoverlaps()
orin
, depending on the circumstance.EXAMPLES:
sage: CBF(1, 1/3).identical(1 + CBF(0, 1)/3) True sage: CBF(1, 1).identical(1 + CBF(0, 1/3)*3) False
- imag()#
Return the imaginary part of this ball.
OUTPUT:
A
RealBall
.EXAMPLES:
sage: a = CBF(1/3, 1/5) sage: a.imag() [0.2000000000000000 +/- ...e-17] sage: a.imag().parent() Real ball field with 53 bits of precision
- is_NaN()#
Return
True
iff either the real or the imaginary part is not-a-number.EXAMPLES:
sage: CBF(NaN).is_NaN() True sage: CBF(-5).gamma().is_NaN() True sage: CBF(oo).is_NaN() False sage: CBF(42+I).is_NaN() False
- is_exact()#
Return
True
iff the radius of this ball is zero.EXAMPLES:
sage: CBF(1).is_exact() True sage: CBF(1/3, 1/3).is_exact() False
- is_nonzero()#
Return
True
iff zero is not contained in the interval represented by this ball.Note
This method is not the negation of
is_zero()
: it only returnsTrue
if zero is known not to be contained in the ball.Use
bool(b)
(or, equivalently,not b.is_zero()
) to check if a ballb
may represent a nonzero number (for instance, to determine the “degree” of a polynomial with ball coefficients).EXAMPLES:
sage: CBF(pi, 1/3).is_nonzero() True sage: CBF(RIF(-0.5, 0.5), 1/3).is_nonzero() True sage: CBF(1/3, RIF(-0.5, 0.5)).is_nonzero() True sage: CBF(RIF(-0.5, 0.5), RIF(-0.5, 0.5)).is_nonzero() False
See also
- is_real()#
Return
True
iff the imaginary part of this ball is exactly zero.EXAMPLES:
sage: CBF(1/3, 0).is_real() True sage: (CBF(i/3) - CBF(1, 1/3)).is_real() False sage: CBF('inf').is_real() True
- is_zero()#
Return
True
iff the midpoint and radius of this ball are both zero.EXAMPLES:
sage: CBF(0).is_zero() True sage: CBF(RIF(-0.5, 0.5)).is_zero() False
See also
- jacobi_P(n, a, b)#
Return the Jacobi polynomial (or function) \(P_n^{(a,b)}(z)\) evaluated at
self
.EXAMPLES:
sage: CBF(5,-6).jacobi_P(8, CBF(1,2), CBF(2,3)) [-920983000.45982 +/- ...e-6] + [6069919969.92857 +/- ...e-6]*I
- jacobi_theta(tau)#
Return the four Jacobi theta functions evaluated at the argument
self
(representing \(z\)) and the parametertau
which should lie in the upper half plane.The following definitions are used:
\[ \begin{align}\begin{aligned}\theta_1(z,\tau) = 2 q_{1/4} \sum_{n=0}^{\infty} (-1)^n q^{n(n+1)} \sin((2n+1) \pi z)\\\theta_2(z,\tau) = 2 q_{1/4} \sum_{n=0}^{\infty} q^{n(n+1)} \cos((2n+1) \pi z)\\\theta_3(z,\tau) = 1 + 2 \sum_{n=1}^{\infty} q^{n^2} \cos(2n \pi z)\\\theta_4(z,\tau) = 1 + 2 \sum_{n=1}^{\infty} (-1)^n q^{n^2} \cos(2n \pi z)\end{aligned}\end{align} \]where \(q = \exp(\pi i \tau)\) and \(q_{1/4} = \exp(\pi i \tau / 4)\). Note that \(z\) is multiplied by \(\pi\); some authors omit this factor.
EXAMPLES:
sage: CBF(3,-1/2).jacobi_theta(CBF(1/4,2)) ([-0.186580562274757 +/- ...e-16] + [0.93841744788594 +/- ...e-15]*I, [-1.02315311037951 +/- ...e-15] + [-0.203600094532010 +/- ...e-16]*I, [1.030613911309632 +/- ...e-16] + [0.030613917822067 +/- ...e-16]*I, [0.969386075665498 +/- ...e-16] + [-0.030613917822067 +/- ...e-16]*I) sage: CBF(3,-1/2).jacobi_theta(CBF(1/4,-2)) (nan + nan*I, nan + nan*I, nan + nan*I, nan + nan*I) sage: CBF(0).jacobi_theta(CBF(0,1)) (0, [0.913579138156117 +/- ...e-16], [1.086434811213308 +/- ...e-16], [0.913579138156117 +/- ...e-16])
- laguerre_L(n, m=0)#
Return the Laguerre polynomial (or function) \(L_n^m(z)\) evaluated at
self
.EXAMPLES:
sage: CBF(10).laguerre_L(3) [-45.6666666666666 +/- ...e-14] sage: CBF(10).laguerre_L(3, 2) [-6.666666666667 +/- ...e-13] sage: CBF(5,7).laguerre_L(CBF(2,3), CBF(1,-2)) # abs tol 1e-9 [5515.3150302713 +/- 5.02e-11] + [-12386.9428452714 +/- 6.21e-11]*I
- lambert_w(branch=0)#
Return the image of this ball by the specified branch of the Lambert W function.
EXAMPLES:
sage: CBF(1 + I).lambert_w() [0.6569660692304...] + [0.3254503394134...]*I sage: CBF(1 + I).lambert_w(2) [-2.1208839379437...] + [11.600137110774...]*I sage: CBF(1 + I).lambert_w(2^100) [-70.806021532123...] + [7.9648836259913...]*I
- legendre_P(n, m=0, type=2)#
Return the Legendre function of the first kind \(P_n^m(z)\) evaluated at
self
.The
type
parameter can be either 2 or 3. This selects between different branch cut conventions. The definitions of the “type 2” and “type 3” functions are the same as those used by Mathematica and mpmath.EXAMPLES:
sage: CBF(1/2).legendre_P(5) [0.0898437500000000 +/- 7...e-17] sage: CBF(1,2).legendre_P(CBF(2,3), CBF(0,1)) [0.10996180744364 +/- ...e-15] + [0.14312767804055 +/- ...e-15]*I sage: CBF(-10).legendre_P(5, 325/100) [-22104403.487377 +/- ...e-7] + [53364750.687392 +/- ...e-7]*I sage: CBF(-10).legendre_P(5, 325/100, type=3) [-57761589.914581 +/- ...e-7] + [+/- ...e-7]*I
- legendre_Q(n, m=0, type=2)#
Return the Legendre function of the second kind \(Q_n^m(z)\) evaluated at
self
.The
type
parameter can be either 2 or 3. This selects between different branch cut conventions. The definitions of the “type 2” and “type 3” functions are the same as those used by Mathematica and mpmath.EXAMPLES:
sage: CBF(1/2).legendre_Q(5) [0.55508089057168 +/- ...e-15] sage: CBF(1,2).legendre_Q(CBF(2,3), CBF(0,1)) [0.167678710 +/- ...e-10] + [-0.161558598 +/- ...e-10]*I sage: CBF(-10).legendre_Q(5, 325/100) [-83825154.36008 +/- ...e-6] + [-34721515.80396 +/- ...e-6]*I sage: CBF(-10).legendre_Q(5, 325/100, type=3) [-4.797306921692e-6 +/- ...e-19] + [-4.797306921692e-6 +/- ...e-19]*I
- li(offset=False)#
Return the logarithmic integral with argument
self
.If
offset
is True, return the offset logarithmic integral.EXAMPLES:
sage: CBF(1, 1).li() [0.61391166922120 +/- ...e-15] + [2.05958421419258 +/- ...e-15]*I sage: CBF(0).li() 0 sage: CBF(0).li(offset=True) [-1.045163780117493 +/- ...e-16] sage: li(0).n() 0.000000000000000 sage: Li(0).n() -1.04516378011749
- log(base=None, analytic=False)#
General logarithm (principal branch).
INPUT:
base
(optional, complex ball or number) – ifNone
, return the principal branch of the natural logarithmln(self)
, otherwise, return the general logarithmln(self)/ln(base)
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut (with respect toself
)
EXAMPLES:
sage: CBF(2*i).log() [0.693147180559945 +/- ...e-16] + [1.570796326794897 +/- ...e-16]*I sage: CBF(-1).log() [3.141592653589793 +/- ...e-16]*I sage: CBF(2*i).log(2) [1.000000000000000 +/- ...e-16] + [2.26618007091360 +/- ...e-15]*I sage: CBF(2*i).log(CBF(i)) [1.000000000000000 +/- ...e-16] + [-0.441271200305303 +/- ...e-16]*I sage: CBF('inf').log() [+/- inf] sage: CBF(2).log(0) nan + nan*I sage: CBF(-1).log(2) [4.53236014182719 +/- ...e-15]*I sage: CBF(-1).log(2, analytic=True) nan + nan*I sage: CBF(-1, RBF(0, rad=.1r)).log(analytic=False) [+/- ...e-3] + [+/- 3.15]*I
- log1p(analytic=False)#
Return
log(1 + self)
, computed accurately whenself
is close to zero.INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: eps = RBF(1e-50) sage: CBF(1+eps, eps).log() [+/- ...e-16] + [1.000000000000000e-50 +/- ...e-66]*I sage: CBF(eps, eps).log1p() [1.000000000000000e-50 +/- ...e-68] + [1.00000000000000e-50 +/- ...e-66]*I sage: CBF(-3/2).log1p(analytic=True) nan + nan*I
- log_barnes_g()#
Return the logarithmic Barnes G-function of
self
.EXAMPLES:
sage: CBF(10^100).log_barnes_g() [1.14379254649702e+202 +/- ...e+187] sage: CBF(0,1000).log_barnes_g() [-2702305.04929258 +/- ...e-9] + [-790386.325561423 +/- ...e-10]*I
- log_gamma(analytic=False)#
Return the image of this ball by the logarithmic Gamma function.
The branch cut of the logarithmic gamma function is placed on the negative half-axis, which means that
log_gamma(z) + log z = log_gamma(z+1)
holds for all \(z\), whereaslog_gamma(z) != log(gamma(z))
in general.INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(1000, 1000).log_gamma() [5466.22252162990 +/- ...e-12] + [7039.33429191119 +/- ...e-12]*I sage: CBF(-1/2).log_gamma() [1.265512123484645 +/- ...e-16] + [-3.141592653589793 +/- ...e-16]*I sage: CBF(-1).log_gamma() nan + ...*I sage: CBF(-3/2).log_gamma() # abs tol 1e-14 [0.860047015376481 +/- 3.82e-16] + [-6.283185307179586 +/- 6.77e-16]*I sage: CBF(-3/2).log_gamma(analytic=True) nan + nan*I
- log_integral(offset=False)#
Return the logarithmic integral with argument
self
.If
offset
is True, return the offset logarithmic integral.EXAMPLES:
sage: CBF(1, 1).li() [0.61391166922120 +/- ...e-15] + [2.05958421419258 +/- ...e-15]*I sage: CBF(0).li() 0 sage: CBF(0).li(offset=True) [-1.045163780117493 +/- ...e-16] sage: li(0).n() 0.000000000000000 sage: Li(0).n() -1.04516378011749
- log_integral_offset()#
Offset logarithmic integral.
EXAMPLES:
sage: CBF(0).Li() [-1.045163780117493 +/- ...e-16] sage: li(0).n() 0.000000000000000 sage: Li(0).n() -1.04516378011749
- mid()#
Return the midpoint of this ball.
OUTPUT:
ComplexNumber
, floating-point complex number formed by the centers of the real and imaginary parts of this ball.EXAMPLES:
sage: CBF(1/3, 1).mid() 0.333333333333333 + 1.00000000000000*I sage: CBF(1/3, 1).mid().parent() Complex Field with 53 bits of precision sage: CBF('inf', 'nan').mid() +infinity + NaN*I sage: CBF('nan', 'inf').mid() NaN + +infinity*I sage: CBF('nan').mid() NaN sage: CBF('inf').mid() +infinity sage: CBF(0, 'inf').mid() +infinity*I
See also
- modular_delta()#
Return the modular discriminant with tau given by
self
.EXAMPLES:
sage: CBF(0,1).modular_delta() [0.0017853698506421 +/- ...e-17] sage: a, b, c, d = 2, 5, 1, 3 sage: tau = CBF(1,3) sage: ((a*tau+b)/(c*tau+d)).modular_delta() [0.20921376655 +/- ...e-12] + [1.57611925523 +/- ...e-12]*I sage: (c*tau+d)^12 * tau.modular_delta() [0.20921376654986 +/- ...e-15] + [1.5761192552253 +/- ...e-14]*I
- modular_eta()#
Return the Dedekind eta function with tau given by
self
.EXAMPLES:
sage: CBF(0,1).modular_eta() [0.768225422326057 +/- ...e-16] sage: CBF(12,1).modular_eta() [-0.768225422326057 +/- ...e-16]
- modular_j()#
Return the modular j-invariant with tau given by
self
.EXAMPLES:
sage: CBF(0,1).modular_j() [1728.0000000000 +/- ...e-11]
- modular_lambda()#
Return the modular lambda function with tau given by
self
.EXAMPLES:
sage: tau = CBF(sqrt(2),pi) sage: tau.modular_lambda() [-0.00022005123884157 +/- ...e-18] + [-0.00079787346459944 +/- ...e-18]*I sage: (tau + 2).modular_lambda() [-0.00022005123884157 +/- ...e-18] + [-0.00079787346459944 +/- ...e-18]*I sage: (tau / (1 - 2*tau)).modular_lambda() [-0.00022005123884 +/- ...e-15] + [-0.00079787346460 +/- ...e-15]*I
- nbits()#
Return the minimum precision sufficient to represent this ball exactly.
More precisely, the output is the number of bits needed to represent the absolute value of the mantissa of both the real and the imaginary part of the midpoint.
EXAMPLES:
sage: CBF(17, 1023).nbits() 10 sage: CBF(1/3, NaN).nbits() 53 sage: CBF(NaN).nbits() 0
- overlaps(other)#
Return True iff
self
andother
have some point in common.INPUT:
other
– aComplexBall
.
EXAMPLES:
sage: CBF(1, 1).overlaps(1 + CBF(0, 1/3)*3) True sage: CBF(1, 1).overlaps(CBF(1, 'nan')) True sage: CBF(1, 1).overlaps(CBF(0, 'nan')) False
- polylog(s)#
Return the polylogarithm \(\operatorname{Li}_s(\mathrm{self})\).
EXAMPLES:
sage: CBF(2).polylog(1) [+/- ...e-15] + [-3.14159265358979 +/- ...e-15]*I sage: CBF(1, 1).polylog(CBF(1, 1)) [0.3708160030469 +/- ...e-14] + [2.7238016577979 +/- ...e-14]*I
- pow(expo, analytic=False)#
Raise this ball to the power of
expo
.INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the exponent is not an integer and the base ball touches the branch cut of the logarithm
EXAMPLES:
sage: CBF(-1).pow(CBF(i)) [0.0432139182637723 +/- ...e-17] sage: CBF(-1).pow(CBF(i), analytic=True) nan + nan*I sage: CBF(-10).pow(-2) [0.0100000000000000 +/- ...e-18] sage: CBF(-10).pow(-2, analytic=True) [0.0100000000000000 +/- ...e-18]
- psi(n=None)#
Compute the digamma function with argument
self
.If
n
is provided, compute the polygamma function of ordern
and argumentself
.EXAMPLES:
sage: CBF(1, 1).psi() [0.0946503206224770 +/- ...e-17] + [1.076674047468581 +/- ...e-16]*I sage: CBF(-1).psi() nan sage: CBF(1,1).psi(10) [56514.8269344249 +/- ...e-11] + [56215.1218005823 +/- ...e-11]*I
- rad()#
Return an upper bound for the error radius of this ball.
OUTPUT:
A
RealNumber
of the same precision as the radii of real balls.Warning
Unlike a
RealBall
, aComplexBall
is not defined by its midpoint and radius. (Instances ofComplexBall
are actually rectangles, not balls.)EXAMPLES:
sage: CBF(1 + i).rad() 0.00000000 sage: CBF(i/3).rad() 1.1102230e-16 sage: CBF(i/3).rad().parent() Real Field with 30 bits of precision
See also
- real()#
Return the real part of this ball.
OUTPUT:
A
RealBall
.EXAMPLES:
sage: a = CBF(1/3, 1/5) sage: a.real() [0.3333333333333333 +/- ...e-17] sage: a.real().parent() Real ball field with 53 bits of precision
- rgamma()#
Compute the reciprocal gamma function with argument
self
.EXAMPLES:
sage: CBF(6).rgamma() [0.00833333333333333 +/- ...e-18] sage: CBF(-1).rgamma() 0
- rising_factorial(n)#
Return the
n
-th rising factorial of this ball.The \(n\)-th rising factorial of \(x\) is equal to \(x (x+1) \cdots (x+n-1)\).
For complex \(n\), it is a quotient of gamma functions.
EXAMPLES:
sage: CBF(1).rising_factorial(5) 120.0000000000000 sage: CBF(1/3, 1/2).rising_factorial(300) [-3.87949484514e+612 +/- 5...e+600] + [-3.52042209763e+612 +/- 5...e+600]*I sage: CBF(1).rising_factorial(-1) nan sage: CBF(1).rising_factorial(2**64) [+/- ...e+347382171326740403407] sage: ComplexBallField(128)(1).rising_factorial(2**64) [2.343691126796861348e+347382171305201285713 +/- ...e+347382171305201285694] sage: CBF(1/2).rising_factorial(CBF(2,3)) # abs tol 1e-15 [-0.123060451458124 +/- 3.06e-16] + [0.0406412631676552 +/- 7.57e-17]*I
- round()#
Return a copy of this ball rounded to the precision of the parent.
EXAMPLES:
It is possible to create balls whose midpoint is more precise that their parent’s nominal precision (see
real_arb
for more information):sage: b = CBF(exp(I*pi/3).n(100)) sage: b.mid() 0.50000000000000000000000000000 + 0.86602540378443864676372317075*I
The
round()
method rounds such a ball to its parent’s precision:sage: b.round().mid() 0.500000000000000 + 0.866025403784439*I
See also
- rsqrt(analytic=False)#
Return the reciprocal square root of
self
.If either the real or imaginary part is exactly zero, only a single real reciprocal square root is needed.
INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(-2).rsqrt() [-0.707106781186547 +/- ...e-16]*I sage: CBF(-2).rsqrt(analytic=True) nan + nan*I sage: CBF(0, 1/2).rsqrt() 1.000000000000000 - 1.000000000000000*I sage: CBF(0).rsqrt() nan + nan*I
- sec()#
Return the secant of this ball.
EXAMPLES:
sage: CBF(1, 1).sec() [0.498337030555187 +/- ...e-16] + [0.591083841721045 +/- ...e-16]*I
- sech()#
Return the hyperbolic secant of this ball.
EXAMPLES:
sage: CBF(pi/2, 1/10).sech() [0.397174529918189 +/- ...e-16] + [-0.0365488656274242 +/- ...e-17]*I
- shi(*args, **kwds)#
Deprecated: Use
Shi()
instead. See trac ticket #32869 for details.
- si(*args, **kwds)#
Deprecated: Use
Si()
instead. See trac ticket #32869 for details.
- sin()#
Return the sine of this ball.
EXAMPLES:
sage: CBF(i*pi).sin() [11.54873935725775 +/- ...e-15]*I
- sin_integral()#
Return the sine integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Si() [1.10422265823558 +/- ...e-15] + [0.88245380500792 +/- ...e-15]*I sage: CBF(0).Si() 0
- sinh()#
Return the hyperbolic sine of this ball.
EXAMPLES:
sage: CBF(1, 1).sinh() [0.634963914784736 +/- ...e-16] + [1.298457581415977 +/- ...e-16]*I
- sinh_integral()#
Return the hyperbolic sine integral with argument
self
.EXAMPLES:
sage: CBF(1, 1).Shi() [0.88245380500792 +/- ...e-15] + [1.10422265823558 +/- ...e-15]*I sage: CBF(0).Shi() 0
- spherical_harmonic(phi, n, m)#
Return the spherical harmonic \(Y_n^m(\theta,\phi)\) evaluated at \(\theta\) given by
self
. In the current implementation,n
andm
must be small integers.EXAMPLES:
sage: CBF(1+I).spherical_harmonic(1/2, -3, -2) [0.80370071745224 +/- ...e-15] + [-0.07282031864711 +/- ...e-15]*I
- sqrt(analytic=False)#
Return the square root of this ball.
If either the real or imaginary part is exactly zero, only a single real square root is needed.
INPUT:
analytic
(optional, boolean) – ifTrue
, return an indeterminate (not-a-number) value when the input ball touches the branch cut
EXAMPLES:
sage: CBF(-2).sqrt() [1.414213562373095 +/- ...e-16]*I sage: CBF(-2).sqrt(analytic=True) nan + nan*I
- squash()#
Return an exact ball with the same midpoint as this ball.
OUTPUT:
A
ComplexBall
.EXAMPLES:
sage: mid = CBF(1/3, 1/10).squash() sage: mid [0.3333333333333333 +/- ...e-17] + [0.09999999999999999 +/- ...e-18]*I sage: mid.parent() Complex ball field with 53 bits of precision sage: mid.is_exact() True
See also
- tan()#
Return the tangent of this ball.
EXAMPLES:
sage: CBF(pi/2, 1/10).tan() [+/- ...e-14] + [10.03331113225399 +/- ...e-15]*I sage: CBF(pi/2).tan() nan
- tanh()#
Return the hyperbolic tangent of this ball.
EXAMPLES:
sage: CBF(1, 1).tanh() [1.083923327338694 +/- ...e-16] + [0.2717525853195117 +/- ...e-17]*I sage: CBF(0, pi/2).tanh() nan*I
- trim()#
Return a trimmed copy of this ball.
Return a copy of this ball with both the real and imaginary parts trimmed (see
trim()
).EXAMPLES:
sage: b = CBF(1/3, RBF(1/3, rad=.01)) sage: b.mid() 0.333333333333333 + 0.333333333333333*I sage: b.trim().mid() 0.333333333333333 + 0.333333015441895*I
See also
- union(other)#
Return a ball containing the convex hull of
self
andother
.EXAMPLES:
sage: b = CBF(1 + i).union(0) sage: b.real().endpoints() (-9.31322574615479e-10, 1.00000000093133)
- zeta(a=None)#
Return the image of this ball by the Hurwitz zeta function.
For
a = None
, this computes the Riemann zeta function.EXAMPLES:
sage: CBF(1, 1).zeta() [0.5821580597520036 +/- ...e-17] + [-0.9268485643308071 +/- ...e-17]*I sage: CBF(1, 1).zeta(1) [0.5821580597520036 +/- ...e-17] + [-0.9268485643308071 +/- ...e-17]*I sage: CBF(1, 1).zeta(1/2) [1.497919876084167 +/- ...e-16] + [0.2448655353684164 +/- ...e-17]*I sage: CBF(1, 1).zeta(CBF(1, 1)) [-0.3593983122202835 +/- ...e-17] + [-2.875283329756940 +/- ...e-16]*I sage: CBF(1, 1).zeta(-1) nan + nan*I
- zetaderiv(k)#
Return the image of this ball by the k-th derivative of the Riemann zeta function.
For a more flexible interface, see the low-level method
_zeta_series
of polynomials with complex ball coefficients.EXAMPLES:
sage: CBF(1/2, 3).zetaderiv(1) [0.191759884092721...] + [-0.073135728865928...]*I sage: CBF(2).zetaderiv(3) [-6.0001458028430...]
- class sage.rings.complex_arb.ComplexBallField(precision=53)#
Bases:
UniqueRepresentation
,ComplexBallField
An approximation of the field of complex numbers using pairs of mid-rad intervals.
INPUT:
precision
– an integer \(\ge 2\).
EXAMPLES:
sage: CBF(1) 1.000000000000000
- Element#
alias of
ComplexBall
- characteristic()#
Complex ball fields have characteristic zero.
EXAMPLES:
sage: ComplexBallField().characteristic() 0
- complex_field()#
Return the complex ball field with the same precision, i.e.
self
EXAMPLES:
sage: CBF.complex_field() is CBF True
- construction()#
Return the construction of a complex ball field as the algebraic closure of the real ball field with the same precision.
EXAMPLES:
sage: functor, base = CBF.construction() sage: functor, base (AlgebraicClosureFunctor, Real ball field with 53 bits of precision) sage: functor(base) is CBF True
- gen(i)#
For i = 0, return the imaginary unit in this complex ball field.
EXAMPLES:
sage: CBF.0 1.000000000000000*I sage: CBF.gen(1) Traceback (most recent call last): ... ValueError: only one generator
- gens()#
Return the tuple of generators of this complex ball field, i.e.
(i,)
.EXAMPLES:
sage: CBF.gens() (1.000000000000000*I,) sage: CBF.gens_dict() {'1.000000000000000*I': 1.000000000000000*I}
- integral(func, a, b, params=None, rel_tol=None, abs_tol=None, deg_limit=None, eval_limit=None, depth_limit=None, use_heap=None, verbose=None)#
Compute a rigorous enclosure of the integral of
func
on the interval [a
,b
].INPUT:
func
– a callable object accepting two parameters, a complex ballx
and a boolean flaganalytic
, and returning an element of this ball field (or some value that coerces into this ball field), such that:func(x, False)
evaluates the integrand \(f\) on the ballx
. There are no restrictions on the behavior of \(f\) onx
; in particular, it can be discontinuous.func(x, True)
evaluates \(f(x)\) if \(f\) is analytic on the wholex
, and returns some non-finite ball (e.g.,self(NaN)
) otherwise.
(The
analytic
flag only needs to be checked for integrands that are non-analytic but bounded in some regions, typically complex functions with branch cuts, like \(\sqrt{z}\). In particular, it can be ignored for meromorphic functions.)a
,b
– integration bounds. The bounds can be real or complex balls, or elements of any parent that coerces into this ball field, e.g. rational or algebraic numbers.rel_tol
(optional, default \(2^{-p}\) where \(p\) is the precision of the ball field) – relative accuracy goalabs_tol
(optional, default \(2^{-p}\) where \(p\) is the precision of the ball field) – absolute accuracy goal
Additionally, the following optional parameters can be used to control the integration algorithm. See the Arb documentation for more information.
deg_limit
– maximum quadrature degree for each subintervaleval_limit
– maximum number of function evaluationsdepth_limit
– maximum search depth for adaptive subdivisionuse_heap
(boolean, defaultFalse
) – ifTrue
, use a priority queue instead of a stack to manage subintervals. This sometimes gives better results for integrals with slow convergence but may require more memory and increasingdepth_limit
.verbose
(integer, default 0) – If set to 1, some information about the overall integration process is printed to standard output. If set to 2, information about each subinterval is printed.
EXAMPLES:
Some analytic integrands:
sage: CBF.integral(lambda x, _: x, 0, 1) [0.500000000000000 +/- ...e-16] sage: CBF.integral(lambda x, _: x.gamma(), 1 - CBF(i), 1 + CBF(i)) # abs tol 1e-13 [+/- 1.39e-15] + [1.57239266949806 +/- 8.33e-15]*I sage: C = ComplexBallField(100) sage: C.integral(lambda x, _: x.cos() * x.sin(), 0, 1) [0.35403670913678559674939205737 +/- ...e-30] sage: CBF.integral(lambda x, _: (x + x.exp()).sin(), 0, 8) [0.34740017266 +/- ...e-12] sage: C = ComplexBallField(2000) sage: C.integral(lambda x, _: (x + x.exp()).sin(), 0, 8) # long time [0.34740017...55347713 +/- ...e-598]
Here the integration path crosses the branch cut of the square root:
sage: def my_sqrt(z, analytic): ....: if (analytic and not z.real() > 0 ....: and z.imag().contains_zero()): ....: return CBF(NaN) ....: else: ....: return z.sqrt() sage: CBF.integral(my_sqrt, -1 + CBF(i), -1 - CBF(i)) [+/- ...e-14] + [-0.4752076627926 +/- 5...e-14]*I
Note, though, that proper handling of the
analytic
flag is required even when the path does not touch the branch cut:sage: correct = CBF.integral(my_sqrt, 1, 2); correct [1.21895141649746 +/- ...e-15] sage: RBF(integral(sqrt(x), x, 1, 2)) # long time [1.21895141649746 +/- ...e-15] sage: wrong = CBF.integral(lambda z, _: z.sqrt(), 1, 2) # WRONG! sage: correct - wrong [-5.640636259e-5 +/- ...e-15]
We can integrate the real absolute value function by defining a piecewise holomorphic extension:
sage: def real_abs(z, analytic): ....: if z.real().contains_zero(): ....: if analytic: ....: return z.parent()(NaN) ....: else: ....: return z.union(-z) ....: elif z.real() > 0: ....: return z ....: else: ....: return -z sage: CBF.integral(real_abs, -1, 1) [1.00000000000...] sage: CBF.integral(lambda z, analytic: real_abs(z.sin(), analytic), 0, 2*CBF.pi()) [4.00000000000...]
Some methods of complex balls natively support the
analytic
flag:sage: CBF.integral(lambda z, analytic: z.log(analytic=analytic), ....: -1-CBF(i), -1+CBF(i)) [+/- ...e-14] + [0.26394350735484 +/- ...e-15]*I sage: from sage.rings.complex_arb import ComplexBall sage: CBF.integral(ComplexBall.sqrt, -1+CBF(i), -1-CBF(i)) [+/- ...e-14] + [-0.4752076627926 +/- 5...e-14]*I
Here the integrand has a pole on or very close to the integration path, but there is no need to explicitly handle the
analytic
flag since the integrand is unbounded:sage: CBF.integral(lambda x, _: 1/x, -1, 1) nan + nan*I sage: CBF.integral(lambda x, _: 1/x, 10^-1000, 1) nan + nan*I sage: CBF.integral(lambda x, _: 1/x, 10^-1000, 1, abs_tol=1e-10) [2302.5850930 +/- ...e-8]
Tolerances:
sage: CBF.integral(lambda x, _: x.exp(), -1020, -1010) [+/- ...e-438] sage: CBF.integral(lambda x, _: x.exp(), -1020, -1010, abs_tol=1e-450) [2.304377150950e-439 +/- ...e-452] sage: CBF.integral(lambda x, _: x.exp(), -1020, -1010, abs_tol=0) [2.304377150950e-439 +/- 7...e-452] sage: CBF.integral(lambda x, _: x.exp(), -1020, -1010, rel_tol=1e-2, abs_tol=0) [2.3044e-439 +/- ...e-444] sage: epsi = CBF(1e-10) sage: CBF.integral(lambda x, _: x*(1/x).sin(), epsi, 1) [0.38 +/- ...e-3] sage: CBF.integral(lambda x, _: x*(1/x).sin(), epsi, 1, use_heap=True) [0.37853002 +/- ...e-9]
ALGORITHM:
Uses the acb_calc module of the Arb library.
- is_exact()#
Complex ball fields are not exact.
EXAMPLES:
sage: ComplexBallField().is_exact() False
- ngens()#
Return 1 as the only generator is the imaginary unit.
EXAMPLES:
sage: CBF.ngens() 1
- pi()#
Return a ball enclosing \(\pi\).
EXAMPLES:
sage: CBF.pi() [3.141592653589793 +/- ...e-16] sage: ComplexBallField(128).pi() [3.1415926535897932384626433832795028842 +/- ...e-38] sage: CBF.pi().parent() Complex ball field with 53 bits of precision
- prec()#
Return the bit precision used for operations on elements of this field.
EXAMPLES:
sage: ComplexBallField().precision() 53
- precision()#
Return the bit precision used for operations on elements of this field.
EXAMPLES:
sage: ComplexBallField().precision() 53
- some_elements()#
Complex ball fields contain elements with exact, inexact, infinite, or undefined real and imaginary parts.
EXAMPLES:
sage: CBF.some_elements() [1.000000000000000, -0.5000000000000000*I, 1.000000000000000 + [0.3333333333333333 +/- ...e-17]*I, [-0.3333333333333333 +/- ...e-17] + 0.2500000000000000*I, [-2.175556475109056e+181961467118333366510562 +/- ...e+181961467118333366510545], [+/- inf], [0.3333333333333333 +/- ...e-17] + [+/- inf]*I, [+/- inf] + [+/- inf]*I, nan, nan + nan*I, [+/- inf] + nan*I]
- class sage.rings.complex_arb.IntegrationContext#
Bases:
object
Used to wrap the integrand and hold some context information during numerical integration.