Skip to main content

calculus and analysis - Somewhat Irreproducible Integrate Results


Backslide introduced in v10 and persisting through v10.3.1.




In the course of considering question 102922, I encountered erratic results from a particular integration. It is illustrated as follows. With a new session of Mathematica


$Version
(* 10.3.0 for Microsoft Windows (64-bit) (October 9, 2015) *)


run


Do[ans = Integrate[k^n SphericalBesselJ[l, R*k], {k, 0, ∞}, 
Assumptions -> {l > 0, R > 0, n ∈ Integers}]; Print[ans], {i, 6}]

Integate returns unevaluated the first time called. Thereafter, it returns


(* ConditionalExpression[(2^(-1 + n)*Sqrt[Pi]*R^(-1 - n)*Gamma[(1 + l + n)/2])/
Gamma[(2 + l - n)/2], n < 1 && l + n > -1] *)

as expected. A variant on this strange behavior, again in a new session of Mathematica, is



Integrate[k^n SphericalBesselJ[l, R*k], {k, 0, ∞}, Assumptions -> {l > 0, R > 0}]
(* returns expected result *)
Integrate[k^n SphericalBesselJ[l, R*k], {k, 0, ∞}, Assumptions -> {l > 0, R > 0,
n ∈ Integers}]
(* returns unevaluated *)
Integrate[k^n SphericalBesselJ[l, R*k], {k, 0, ∞}, Assumptions -> {l > 0, R > 0,
n ∈ Integers}]
(* returns unevaluated *)
Integrate[k^n SphericalBesselJ[l, R*k], {k, 0, ∞}, Assumptions -> {l > 0, R > 0,
n ∈ Integers}]

(* returns expected result, as at the beginning of the question*)

There are many possible combinations of Assumptions for this calculation, and most behave similarly, at first returning unevaluated and later returning evaluated. Moreover, with Assumptions cases a, b, and c, Integrate run with the sets in that order typically returns unevaluated in the first two cases, and evaluated in the third, and shuffling the three cases likewise typically also returns the first two cases (for example, b and c) unevaluated and the third (in the same example, a) evaluated.


I know of two work-arounds. One, due to Bob Hanlon, is to use GenerateConditions -> False which gives the evaluated result but at the cost of no conditions. The second is illustrated at the beginning of this question. It, too, seems unsatisfactory. So, can this behavior be explained, and what is a better work-around? Thanks.



Answer



The reference provided above by Daniel Lichtblau, and the comments therein by Szabolcs and him, suggested that Integrate may be returning unevaluated simply because it timed out, which appears to occur after about 60 seconds. The obvious solution, then, is to give it more time.


TimeConstrained[
Integrate[k^n SphericalBesselJ[l, R*k], {k, 0, ∞},
Assumptions -> {l > 0, R > 0, n ∈ Integers}], 120]


which returns with the desired answer after nearly 100 seconds on my PC.


(As explained by Daniel Lichtblau and Szabolcs in the reference, a second call to Integrate after it times out may provide an answer even though the first call did not, because Integrate stores intermediate results and, therefore, may proceed more rapidly when called the second time. Consequently, the comparison made in the comment above by xzczd between v9 and v10 may reflect that v10 is slower than v9 or has a smaller default time limit in this instance.)


Comments

Popular posts from this blog

plotting - Filling between two spheres in SphericalPlot3D

Manipulate[ SphericalPlot3D[{1, 2 - n}, {θ, 0, Pi}, {ϕ, 0, 1.5 Pi}, Mesh -> None, PlotPoints -> 15, PlotRange -> {-2.2, 2.2}], {n, 0, 1}] I cant' seem to be able to make a filling between two spheres. I've already tried the obvious Filling -> {1 -> {2}} but Mathematica doesn't seem to like that option. Is there any easy way around this or ... Answer There is no built-in filling in SphericalPlot3D . One option is to use ParametricPlot3D to draw the surfaces between the two shells: Manipulate[ Show[SphericalPlot3D[{1, 2 - n}, {θ, 0, Pi}, {ϕ, 0, 1.5 Pi}, PlotPoints -> 15, PlotRange -> {-2.2, 2.2}], ParametricPlot3D[{ r {Sin[t] Cos[1.5 Pi], Sin[t] Sin[1.5 Pi], Cos[t]}, r {Sin[t] Cos[0 Pi], Sin[t] Sin[0 Pi], Cos[t]}}, {r, 1, 2 - n}, {t, 0, Pi}, PlotStyle -> Yellow, Mesh -> {2, 15}]], {n, 0, 1}]

plotting - Plot 4D data with color as 4th dimension

I have a list of 4D data (x position, y position, amplitude, wavelength). I want to plot x, y, and amplitude on a 3D plot and have the color of the points correspond to the wavelength. I have seen many examples using functions to define color but my wavelength cannot be expressed by an analytic function. Is there a simple way to do this? Answer Here a another possible way to visualize 4D data: data = Flatten[Table[{x, y, x^2 + y^2, Sin[x - y]}, {x, -Pi, Pi,Pi/10}, {y,-Pi,Pi, Pi/10}], 1]; You can use the function Point along with VertexColors . Now the points are places using the first three elements and the color is determined by the fourth. In this case I used Hue, but you can use whatever you prefer. Graphics3D[ Point[data[[All, 1 ;; 3]], VertexColors -> Hue /@ data[[All, 4]]], Axes -> True, BoxRatios -> {1, 1, 1/GoldenRatio}]

plotting - Adding a thick curve to a regionplot

Suppose we have the following simple RegionPlot: f[x_] := 1 - x^2 g[x_] := 1 - 0.5 x^2 RegionPlot[{y < f[x], f[x] < y < g[x], y > g[x]}, {x, 0, 2}, {y, 0, 2}] Now I'm trying to change the curve defined by $y=g[x]$ into a thick black curve, while leaving all other boundaries in the plot unchanged. I've tried adding the region $y=g[x]$ and playing with the plotstyle, which didn't work, and I've tried BoundaryStyle, which changed all the boundaries in the plot. Now I'm kinda out of ideas... Any help would be appreciated! Answer With f[x_] := 1 - x^2 g[x_] := 1 - 0.5 x^2 You can use Epilog to add the thick line: RegionPlot[{y < f[x], f[x] < y < g[x], y > g[x]}, {x, 0, 2}, {y, 0, 2}, PlotPoints -> 50, Epilog -> (Plot[g[x], {x, 0, 2}, PlotStyle -> {Black, Thick}][[1]]), PlotStyle -> {Directive[Yellow, Opacity[0.4]], Directive[Pink, Opacity[0.4]],