This question would have been more properly posed on ask.sagemath.org... The firs argument of numerical integral must be a function of one (real) variable returning a real. It is indeed possible to nest such integrals, but the second one *nests* the first one, hence long computation times. Examples:
sage: (e^-(x^2/2)).integrate(x,-oo,oo) sqrt(2)*sqrt(pi) sage: (e^-(x^2/2)).integrate(x,-oo,oo).n() 2.50662827463100 sage: %time numerical_integral(lambda x1:e^-(x1^2/2),-oo,oo) CPU times: user 29.8 ms, sys: 21 µs, total: 29.9 ms Wall time: 29.8 ms (2.5066282746309994, 2.5512942303338327e-08) Both precision and computation time are acceptable. But consider: sage: var("y") y sage: (e^-((x^2+y^2)/2)).integrate(y,-oo,oo).integrate(x,-oo,oo) 2*pi sage: (e^-((x^2+y^2)/2)).integrate(y,-oo,oo).integrate(x,-oo,oo).n() 6.28318530717959 sage: %time numerical_integral(lambda x2:numerical_integral(lambda x1:e^-((x1^2+x ....: 2^2)/2),-oo,oo)[0],-oo,oo) CPU times: user 4.05 s, sys: 32 ms, total: 4.08 s Wall time: 4.08 s (6.283185307182902, 6.39626298408729e-08) Acceptable precision, coputation time questionable. And this is only for a double integral of a "well behaved" real function. Furthermore, as pointed out, the values of your function are complex. You must, at each step, separate real and imaginary part... Therefore, I doubt that this solution is viable. Monte-Carlo integration has been suggested. This solution has been well-explored in some R packages dedicated to Bayesian statistics, but the computation of the =value of the integral is still a delicate question (and, being only of secondary interest to applied statistics, not as well explored). You may try to separate the real and imaginary part of your function, and sample from these part. Look at Stan <https://mc-stan.org/> and the companion R package bridgesampling <https://cran.r-project.org/web/packages/bridgesampling/index.html> (which could compute the integral from a pseudo-random sample obtained via Stan). HTH, Le jeudi 27 février 2020 04:21:21 UTC+1, saad khalid a écrit : > > I'm trying to compute/estimate a rather complicated looking integral. Here > is the code I'm trying to run, with the necessary constants defined: > > var('t1,t2,u,w,k') > T = 1 > m = 100 > E = 1 > v = 0 > y=1 > O = 1 > integral(integral(integral( > integral(integral( > e^(-t1^2/T^2)*e^(-t2^2/T^2)*e^(I*O*t1)* > e^(-I*O*t2)*e^(-I*E*y^2*(1 - v)*t1^2/2)* > e^(-I*E*y^2*(1 - v)*t2^2/2)*e^(-I*k*y*(1 - u)*t1)* > e^(I*k*y*(1 - v)*t2)* > e^((1 + I)*(sqrt(E)*y*w*t1 + w*k/sqrt(E)))* > e^((1 - I)*(sqrt(E)*y*u*t2 + u*k/sqrt(E)))* > e^(-w^2/2)*e^(-u^2/2)*w^(-1/2 + I*m^2/(2*E))* > u^(-1/2 - I*m^2/(2*E)), (u, 0, Infinity)), (w, 0, > Infinity)), (t2, -Infinity, Infinity)), (t1, -Infinity, > Infinity)), (k, -Infinity, Infinity)) > > I haven't been able to get a result from this code, it seems to run > forever. I was hoping to be able to estimate the integral with some > numerical methods, however I was having trouble getting a numerical > integral set up properly. My first question is, can someone help me set up > multivariable numerical integrals properly. I was trying something like > numerical_integral(x*y,(x,0,1),(y,0,1)) > or > numerical_integral(numerical_integral(x*y,(x,0,1)),(y,0,1)) > > but neither seem to be the correct format, as they both give errors. > > My second question is, can anyone give some advice on how to approximate > such an integral, where it's multivariable and the bounds are at infinity? > I don't really know where to start. > > Thanks! > > -- You received this message because you are subscribed to the Google Groups "sage-support" group. To unsubscribe from this group and stop receiving emails from it, send an email to sage-support+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/sage-support/29ba4111-0ccc-4143-b68a-092e29ec6ceb%40googlegroups.com.