Title: | Brownian Motion Simulations |
---|---|
Description: | An implementation of algorithms for simulation of (multivariate) Brownian motion trajectories, including simple unconditional simulation, Brownian bridges, as well as layered and localised Brownian motion simulators. |
Authors: | Louis Aslett [aut, cre], Murray Pollock [aut] |
Maintainer: | Louis Aslett <[email protected]> |
License: | GPL-2 |
Version: | 0.3.0 |
Built: | 2025-01-04 04:27:04 UTC |
Source: | https://github.com/louisaslett/BrownianMotion |
Description of adding labels
add.labels(bm, t, label = names(t))
add.labels(bm, t, label = names(t))
bm |
a Brownian motion object from which simulation should continue. Note the object is updated in place |
t |
vector of fixed times of the Brownian motion. |
label |
vector of length 1 or the length of t indicating the introduction of user specified labels (if any). By default, uses any names in the vector of times. |
Note: Only valid for time points that don't lie within existing layers. Cannot be an existing time within the skeleton (in this case you should delete then add the point).
add.points(bm, t, W_t, label = names(t))
add.points(bm, t, W_t, label = names(t))
bm |
a Brownian motion object from which simulation should continue. Note the object is updated in place |
t |
vector of fixed times of the Brownian motion. Defaults to value of 0. |
W_t |
matrix of size the length of t (rows) x dimension (column). If dim = 1, a vector of the length of t is acceptable. If dim > 1 and the length of t = 1, then a vector of length 1 is acceptable (corresponding to the same value at every co-ordinate), or length d is acceptable (corresponding to the d components). Defaults to 0 for every component. |
label |
vector of length 1 or the length of t indicating the introduction of user specified labels (if any). By default, uses any names in the vector of times. |
Create / move a segment
add.segment(bm, l = -Inf, r = Inf, W_t = NULL, delta = NULL, label = NULL)
add.segment(bm, l = -Inf, r = Inf, W_t = NULL, delta = NULL, label = NULL)
bm |
a Brownian motion object from which simulation should continue. Note the object is updated in place |
l |
closed left end of interval to add a segment. By default, '-Inf' which results in the introduction of a segment by shifting the entire path up to 'r' |
r |
open right end of interval to add a segment. By default, 'Inf' which results in the introduction of a segment by shifting the entire path from 'l' |
W_t |
vector of length the dimension of the Brownian motion specifying the coordinate of the Brownian motion at the time l (specified by the user). A vector of length 1 is acceptable (corresponding to the same value at every co-ordinate). Defaults to NULL, meaning this argument is ignored in favor of delta. |
delta |
vector of length the dimension of the Brownian motion specifying the shift of the Brownian motion at the time l (specified by the user). A vector of length 1 is acceptable (corresponding to the same shift for every co-ordinate). Defaults to NULL, meaning this argument is ignored in favor of W_t. |
label |
vector of length 1 or the length of t indicating the introduction of user specified labels (if any). By default, uses any names in the vector of times. |
Copy / Concatenate Brownian motion objects
concat.bm(..., t0 = NULL)
concat.bm(..., t0 = NULL)
... |
multiple Brownian motion objects which will be concatenated together in the order provided into a new BrownianMotion object. Note the object is updated in place |
t0 |
scalar representing the time the new Brownian motion should be initialised. Defaults to value of initial time of the first Brownian motion object to be concatenated. |
Creates an R environment to contain the trajectories and layer information of a Brownian motion.
create.bm( t = 0, W_t = 0, dim = 1, cov = 1, refine = TRUE, mult = 1, prefer = "bessel" )
create.bm( t = 0, W_t = 0, dim = 1, cov = 1, refine = TRUE, mult = 1, prefer = "bessel" )
t |
vector of fixed times of the Brownian motion. Defaults to value of 0. |
W_t |
matrix of size the length of t (rows) x dimension (column). If dim = 1, a vector of the length of t is acceptable. If dim > 1 and the length of t = 1, then a vector of length 1 is acceptable (corresponding to the same value at every co-ordinate), or length d is acceptable (corresponding to the d components). Defaults to 0 for every component. |
dim |
scalar corresponding to the dimension of the Brownian motion. |
cov |
covariance matrix of the Brownian motion. If scalar corresponds to a multiple of the identity matrix. If matrix should be of size dim x dim. |
refine |
indicates whether refinement should be by default carried out. If of length 1, then this specifies refinement for every dimension. If of length dim, then this specifies refinement for each dimension (in order). |
mult |
set the default mult parameter to be used for any layer operations on this path, including for the level of refinement if |
prefer |
indicates whether there is a preference for "bessel" or "intersection" layers where possible. If of length 1, then this specifies the preference for every dimension. If of length dim, then this specifies preference for each dimension (in order). create.bm(....., refine = TRUE) create.bm(....., refine = FALSE) create.bm(....., refine = list(spatial = TRUE, temporal = FALSE)) |
Description of deleting labels
delete.labels(bm, t = NA, label = NA)
delete.labels(bm, t = NA, label = NA)
bm |
a Brownian motion object from which simulation should continue. Note the object is updated in place |
t |
vector of fixed times of the Brownian motion. |
label |
vector of length 1 or the length of t indicating the introduction of user specified labels (if any). By default, uses any names in the vector of times. |
Eliminate parts of path, layer or both from the skeleton
delete.skeleton(bm, l = -Inf, r = Inf, type = "all")
delete.skeleton(bm, l = -Inf, r = Inf, type = "all")
bm |
a Brownian motion object from which simulation should continue. Note the object is updated in place |
l |
closed left end of interval to delete. By default, '-Inf' which results in left truncation of the path up to 'r' |
r |
open right end of interval to delete. By default, 'Inf' which results in right truncation of the path from 'l' |
type |
one of '"all"' or '"layer"' to specify whether to delete both path observations and layers, or just layers in the open interval '(l,r)' |
Finds the first passage time of a Brownian motion object to a specified lower, upper, or lower and upper limit.
first.passage( bm, l = NULL, u = NULL, delta.l = NULL, delta.u = NULL, delta = NULL, label = NULL )
first.passage( bm, l = NULL, u = NULL, delta.l = NULL, delta.u = NULL, delta = NULL, label = NULL )
bm |
a Brownian motion object (of dimension 1) from which simulation should continue. Note the object is updated in place. |
l |
scalar giving lower bound for first passage. |
u |
scalar giving upper bound for first passage. |
delta.l |
provide bounds via the negative change in Brownian motion. May be specified together with |
delta.u |
provide bounds via the positive change in Brownian motion. May be specified together with |
delta |
scalar providing the bounds by way of the positive/negative change in the Brownian motion. |
label |
a user specified label for the first passage time created by this layer (optional). |
This function updates a Brownian motion object adding the first passage time to
the specified lower (l
), upper (u
), or lower and upper limits.
The limits can also be specfied via delta
which places the limits as the
current endpoint state +/- delta
.
Note that simulation of the first passage implicitly imposes constraints on the
underlying Brownian motion between the endpoint and the first passage
time.
In particular, in the case that the lower and upper limits are asymmetric around the endpoint, there may be a recursive simulation of nested symmetric first passages between the endpoint and the ultimate first passage, resulting in implicit imposition of nested constraints. When plotting a Brownian motion these are visible as dashed red lines nested within the solid red line constraint imposed by the overall first passage simulation.
The Brownian motion object which was passed in argument bm
is
updated in place and returned, enabling chaining of commands with
dplyr (and other) style pipes.
TODO UPDATE ME Performs unbiased simulation of the smallest specified layers which contain the Brownian motion between two known sample points by retrospective Bernoulli sampling and inversion sampling.
layers( bm, s, t, type = bm$prefer, refine = bm$refine, mult = bm$mult, prefer = bm$prefer, label = c(names(s), names(t)) )
layers( bm, s, t, type = bm$prefer, refine = bm$refine, mult = bm$mult, prefer = bm$prefer, label = c(names(s), names(t)) )
bm |
a Brownian motion object from which simulation should continue. Note the object is updated in place |
s |
left hand time point |
t |
right hand time point |
type |
type specifies whether to carry out "bessel" or "intersection" or "localised" simulation. If of length 1, then this specifies the type for every dimension. If of length dim, then this specifies for each dimension the type. By default this matches the setting for preference specified on the creation of the Brownian motion object. |
refine |
indicates whether refinement should be by default carried out. If of length 1, then this specifies refinement for every dimension. If of length dim, then this specifies refinement for each dimension (in order). By default uses the setting on creation of the Brownian motion object. |
mult |
the default layer size is |
prefer |
indicates whether there is a preference for "bessel" or "intersection" layers where possible. If of length 1, then this specifies the preference for every dimension. If of length dim, then this specifies preference for each dimension (in order). By default uses the setting on creation of the Brownian motion object. |
label |
vector of length 1 or the length of t indicating the introduction of user specified labels (if any). By default, uses any names in the vector of times. |
The Brownian motion object which was passed in argument bm
is
updated in place and returned, enabling chaining of commands with
dplyr (and other) style pipes.
Refine an intersection layer
refine(bm, s, t, mult = bm$mult)
refine(bm, s, t, mult = bm$mult)
bm |
a Brownian motion object from which simulation should continue. Note the object is updated in place |
s |
left hand time point |
t |
right hand time point |
mult |
the default layer size is |
Simulates Brownian motion at chosen times, automatically applying the correct algorithm to condition on the current known (ie previously simulated) states of the trajectory.
sim( bm, t, refine = bm$refine, mult = bm$mult, prefer = bm$prefer, label = names(t) )
sim( bm, t, refine = bm$refine, mult = bm$mult, prefer = bm$prefer, label = names(t) )
bm |
a Brownian motion object from which simulation should continue. Note the object is updated in place. |
t |
a vector of times to simulate at. |
refine |
whether to automatically refine layers where the simulated
time results in bisection of an existing layer. Defaults to the option
specified at the time of creation of |
mult |
the mult parameter to be passed through to any layer operations
including for the level of refinement if |
prefer |
indicate the preferred layer type which should arise after
conditional simulation bisects an existing layer (this will be respected
where possible, but it not always achievable). Defaults to the option
specified at the time of creation of |
label |
vector of length 1 or the length of t indicating the introduction of user specified labels (if any). By default, uses any names in the vector of times. |
the Brownian motion object which was passed in argument bm
is
updated in place and returned, enabling chaining of commands with
dplyr (and other) style pipes.