two dimensional integration
On 16-02-2013, at 18:01, julia cafnik <julia.cafnik at gmail.com> wrote:
Dear R-users, I'm wondering how to calculate this double integral in R: int_a^b int_c^y g(x, y) dx dy where g(x,y) = exp(- alpha (y - x)) * b
A very similar question was asked about nine years ago: http://tolstoy.newcastle.edu.au/R/help/04/10/5831.html The final message in the thread gave a workable answer. In your case define function g (leave out the multiply by b since you can always do that outside the integral). g <- function(x,y,alpha=1) exp(-alpha*(y-x)) Assume a=0, b=1 and c=0. Then following the final message in the thread mentioned above there are two ways of getting an answer: if function g is fully vectorized: integrate( function(y) { sapply(y, function(y) { integrate(function(x) g(x,y),0,y)$value }) },0,1) and if g is not vectorized and only takes scalars as input integrate(function(y) { sapply(y, function(y) { integrate(function(x) { sapply(x, function(x) g(x,y)) },0,y)$value }) },0,1) Both of the approaches result in 0.3678794 with absolute error < 4.1e-15 which corresponds to the exact analytical answer 1/exp(1) (if I didn't make a mistake) You can also do this with package cubature with Gabor's approach (from the mentioned thread) like this library(cubature) h <- function(z) g(z[1],z[2])*(z[1]<z[2]) adaptIntegrate(h,c(0,0),c(1,1),tol=1e-4) but it's also very slow with higher tolerances.
adaptIntegrate(h,c(0,0),c(1,1),tol=1e-4)
$integral [1] 0.3678723 $error [1] 3.677682e-05 $functionEvaluations [1] 268413 $returnCode [1] 0 Berend