vignettes/ItoIntegrals.Rmd
ItoIntegrals.Rmd
The objective of this vignette is to demonstrate how to perform (approximate) Itô integration numerically. We do not aim for very high accuracy; rather, our purpose is to build intuition for the integral, which is helpful when studying the theory of stochastic differential equations, in which Itô integratio is an essential element (Thygesen 2023).
We consider an integrator and an integrand , which are both stochastic processes. Think of as Brownian motion and as an adapted process, although this is not necessary. We aim to approximate the Itô integral numerically, for different values of .
Given a time discretization , the numerical Itô integral is given by This assumes that is piecewise constant between the time points .
This approximation is implemented in the function itointegral. For example, we can integrate Brownian motion w.r.t. itself:
## Loading required package: SDEtools
t <- seq(0,1,0.01)
B <- rBM(t)
I <- itointegral(B,B)
plot(t,I,type="l")
lines(t,0.5*(B^2-t),col="red")
We have included the analytical result (Thygesen 2023). The agreement is not perfect; there is a time discretization error.
Note that the numerical Itô integration routine does not need to know the time grid; only values of the integrator and the integrand at each time point. The integral is implemented as follows:
print(itointegral)
## function (G, B)
## {
## return(c(0, cumsum(G[-length(G)] * diff(B))))
## }
## <bytecode: 0x55e55135de98>
## <environment: namespace:SDEtools>
Note that the numerical Itô integral is essentially an Euler-Maruyama solution of the stochastic differential equation:
We see that there is a strong coupling between the Euler-Maruyama method and numerical Itô integration. To verify this, consider the Itô stochastic differential equation
with initial condition , where and :
plot(t,X,type="l")
For this solution, we have
The following code compares the Euler-Maruyama discretization of the stochastic differential equation with the numerical Itô integral:
plot(t,X,type="l")
lines(t,itointegral(f(X),t)+itointegral(g(X),B),col="red")
Note that they seem to fit perfectly. In fact, the error is roughly machine precision:
print(max(abs(X-itointegral(f(X),t)-itointegral(g(X),B))))
## [1] 2.220446e-16
That is, there is no time discretization error because we use the same principle for time discretization in the Euler-Maruyama method and in the numerical Itô integral.
We can perform numerical Itô integration of any process with respect to any process, even if the nice properties of the Itô integral (the martingale property and the Itô isometry) need not hold.
In the following, we demonstrate this by recomputing the Brownian motion:
W <- itointegral(1/g(X),X) - itointegral(f(X)/g(X),t)
plot(t,W,type="l")
lines(t,B,col="red")
Again, the error is machine precision so there is no time discretization error:
## [1] 2.220446e-16
We can repeat the previous with Stratonovich integrals such as For example, we can integrate Brownian motion with respect to itself:
Again, we see a reasonable agreement between the numerical and analytical result, even if it is not perfect, due to the time discretization.
The difference between the Itô and the Stratonovich integral comes from the quadratic cross-variation between the integrator and the integrand. The following code and figure compare the Itô and Stratonovich integrals with , as well as the relationship between the two
G <- X+B
Ii <- itointegral(G,X)
Is <- stochint(G,X,rule="c")
ylim <- range(c(Ii,Is))
plot(t,Ii,type="l",ylim=ylim)
lines(t,Is,col="red")
points(t,Ii + 0.5 * CrossVariation(G,X))