Skip to main content

finance - ItoProcess function


While looking in the help manual of Mathematica concerning the ItoProcess function I found the following:


ItoProcess[{a,b,c},x,t]: represents an Ito Process y(t)=c(t,x(t)), where dx(t)=a(t,x(t))dt+b(t,x(t)).dw(t)


In order to replicate and Plot this, I entered the following code:


(*Defining a process y(t)=c((xt)), where \[DifferentialD]x(t)=μ\
\[DifferentialD]t+σ\[DifferentialD]w(t)*)


ItoProcess[\[DifferentialD]x[
t] == μ \[DifferentialD]t + σ \[DifferentialD]w[t],
c[x[t]], {x, 0}, t, w \[Distributed] WienerProcess[]]

Then I wanted to Plot one process by implementing drift and volatility.


(*Simulation of one Ito Process with μ=0.1 and σ=0.2, \
starting value x=0*)

testprocess5 =

ItoProcess[\[DifferentialD]x[t] ==
0.1 *\[DifferentialD]t + 0.2 *\[DifferentialD]w[t],
c[x[t]], {x, 0}, t, w \[Distributed] WienerProcess[]]

Concerning this code I got the same output like in the Mathematica help manual just the drift and the volatility were substituted by 0.1 and 0.2 respectively.


However, when I tried to plot the process it did not work out.


ListLinePlot[
Table[RandomFunction[
testprocess5, {0 (*startis from t=0*), 5 (*ends at t=5*),
0.01 (*Δt*)}] ["Path"], {1(*number of paths*)}],

Joined -> True, AxesLabel -> {"time", "value"}, ImageSize -> 400,
PlotRange -> All]

I am not sure, why it is not workling, maybe it could be due to y (t) = c ((xt)). Does anyone of you have a solution for this problem or a suggestion how to change the code?


thanks



Answer



I'm not sure if I correctly understood what you want... However, I could read in the question that you want to simulate Ito Processes and, at the same time, to be able to change its parameters, especially the processes drifts and volatilities. In the comments I've read about the processes being correlated, so, let me try to put everything together in this answer...


First: set all the parameters you want to simulate;


iv1 = 1; (* initial value for process 1 *)
iv2 = -1; (* initial value for process 2 *)

drift1 = 0; (* drift of process 1 *)
drift2 = 0; (* drift of process 2 *)
diffusion1 = .2; (* diffusion of process 1 *)
diffusion2 = .2; (* diffusion of process 2 *)
correl = 0; (* Set the correlation value here *)
covar = correl*Sqrt[diffusion1]*Sqrt[diffusion2]; (* don't touch here! *)

Second: define the 2D-process;


proc = ItoProcess[{{drift1, drift2}, {{diffusion1, covar}, {covar, diffusion2}}}, {{w1,w2}, {iv1, iv2}}, t];


Third: compute the 2D-process means and variances;


processmean[x_] = Mean[proc[t]]; // Quiet
processvariance[x_] = Variance[proc[t]]; // Simplify // Quiet

Fourth: show the theoretical path intervals


G1 = Show[Plot[{processmean[t] - 2 Sqrt[processvariance[t]], processmean[t] + 2 Sqrt[processvariance[t]], processmean[t]}, {t, 0, 20}, Filling -> {1 -> {2}}], PlotRange -> All]

enter image description here


Fifth: generate the k desired amount of random paths;


k = 10; (* amount of paths to be generated for each individual process *)

path = RandomFunction[proc, {0, 20}, k]

Sixth: see the paths you've generated;


G2 = ListLinePlot[path["PathComponent", 1], PlotRange -> All, PlotStyle -> Directive[{Thin, Lighter@Red}]]
G3 = ListLinePlot[path["PathComponent", 2], PlotRange -> All, PlotStyle -> Directive[{Thin, Lighter@Green}]]

enter image description here enter image description here


Seventh: show everything together;


Show[G2,G3,G1]


enter image description here



According to this post there is a known bug affecting 2D-correlated Ito Processes. However, in my simulations I couldn't find any problem when generating correlated processes.


Consider, for instance, the 2D-process. In order to visualize the correlated processes I'll use the extrem case of a high negative correlation between the processes (ρ=0.95). I'll also generate only two paths for better visualization/understanding.


ClearAll["Global`*"]
iv1 = 1;
iv2 = 1;
drift1 = 0;
drift2 = 0;
diffusion1 = .2;

diffusion2 = .2;
correl = -.95; (* Set correlation here *)
covar = correl*Sqrt[diffusion1]*Sqrt[diffusion2];
proc = ItoProcess[{{drift1, drift2}, {{diffusion1, covar}, {covar, diffusion2}}}, {{w1, w2}, {iv1, iv2}}, t];
k = 2;
path = RandomFunction[proc, {0, 20}, k]

Now you can visually observe the negative relationship between the generated processes:


G5 = ListLinePlot[path["PathComponent", 1], PlotRange -> All, PlotStyle -> Directive[{Thick, Lighter@Red}]]
G6 = ListLinePlot[path["PathComponent", 2], PlotRange -> All, PlotStyle -> Directive[{Thick, Lighter@Green}]]


enter image description here enter image description here


You might also want to see them all together with theoretical paths:


processmean[x_] = Mean[proc[t]]; // Quiet
processvariance[x_] = Variance[proc[t]]; // Simplify // Quiet
G7 = Show[Plot[{processmean[t] - 2 Sqrt[processvariance[t]], processmean[t] + 2 Sqrt[processvariance[t]], processmean[t]}, {t, 0, 20}, Filling -> {1 -> {2}}], PlotRange -> All];
Show[G5, G6, G7]

enter image description here


I hope this will help you.



EDITED


Another example of negative-correlated processes, this time with positive drifts.


iv1 = 1;
iv2 = 1;
drift1 = .1;
drift2 = .3;
diffusion1 = .15;
diffusion2 = .25;
correl = -.95; (* Set correlation here *)
covar = correl*Sqrt[diffusion1]*Sqrt[diffusion2];

proc = ItoProcess[{{drift1, drift2}, {{diffusion1, covar}, {covar, diffusion2}}}, {{w1, w2}, {iv1, iv2}}, t];
processmean[x_] = Mean[proc[t]]; // Quiet
processvariance[x_] = Variance[proc[t]]; // Simplify // Quiet
G8 = Show[Plot[{processmean[t] - 2 Sqrt[processvariance[t]], processmean[t] + 2 Sqrt[processvariance[t]], processmean[t]}, {t, 0, 20}, Filling -> {1 -> {2}}], PlotRange -> All]
k = 1;
path = RandomFunction[proc, {0, 20}, k]
G9 = ListLinePlot[path["PathComponent", 1], PlotRange -> All, PlotStyle -> Directive[{Thick, Lighter@Red}]]
G10 = ListLinePlot[path["PathComponent", 2], PlotRange -> All, PlotStyle -> Directive[{Thick, Lighter@Green}]]
Show[G8, G9, G10]


enter image description here enter image description here enter image description here enter image description here


Comments

Popular posts from this blog

functions - Get leading series expansion term?

Given a function f[x] , I would like to have a function leadingSeries that returns just the leading term in the series around x=0 . For example: leadingSeries[(1/x + 2)/(4 + 1/x^2 + x)] x and leadingSeries[(1/x + 2 + (1 - 1/x^3)/4)/(4 + x)] -(1/(16 x^3)) Is there such a function in Mathematica? Or maybe one can implement it efficiently? EDIT I finally went with the following implementation, based on Carl Woll 's answer: lds[ex_,x_]:=( (ex/.x->(x+O[x]^2))/.SeriesData[U_,Z_,L_List,Mi_,Ma_,De_]:>SeriesData[U,Z,{L[[1]]},Mi,Mi+1,De]//Quiet//Normal) The advantage is, that this one also properly works with functions whose leading term is a constant: lds[Exp[x],x] 1 Answer Update 1 Updated to eliminate SeriesData and to not return additional terms Perhaps you could use: leadingSeries[expr_, x_] := Normal[expr /. x->(x+O[x]^2) /. a_List :> Take[a, 1]] Then for your examples: leadingSeries[(1/x + 2)/(4 + 1/x^2 + x), x] leadingSeries[Exp[x], x] leadingSeries[(1/x + 2 + (1 - 1/x...

mathematical optimization - Minimizing using indices, error: Part::pkspec1: The expression cannot be used as a part specification

I want to use Minimize where the variables to minimize are indices pointing into an array. Here a MWE that hopefully shows what my problem is. vars = u@# & /@ Range[3]; cons = Flatten@ { Table[(u[j] != #) & /@ vars[[j + 1 ;; -1]], {j, 1, 3 - 1}], 1 vec1 = {1, 2, 3}; vec2 = {1, 2, 3}; Minimize[{Total@((vec1[[#]] - vec2[[u[#]]])^2 & /@ Range[1, 3]), cons}, vars, Integers] The error I get: Part::pkspec1: The expression u[1] cannot be used as a part specification. >> Answer Ok, it seems that one can get around Mathematica trying to evaluate vec2[[u[1]]] too early by using the function Indexed[vec2,u[1]] . The working MWE would then look like the following: vars = u@# & /@ Range[3]; cons = Flatten@{ Table[(u[j] != #) & /@ vars[[j + 1 ;; -1]], {j, 1, 3 - 1}], 1 vec1 = {1, 2, 3}; vec2 = {1, 2, 3}; NMinimize[ {Total@((vec1[[#]] - Indexed[vec2, u[#]])^2 & /@ R...

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}]