Title: | Estimation of Hawkes Processes from Binned Observations |
---|---|
Description: | Implements an estimation method for Hawkes processes when count data are only observed in discrete time, using a spectral approach derived from the Bartlett spectrum, see Cheysson and Lang (2020) <arXiv:2003.04314>. Some general use functions for Hawkes processes are also included: simulation of (in)homogeneous Hawkes process, maximum likelihood estimation, residual analysis, etc. |
Authors: | Felix Cheysson [aut, cre] |
Maintainer: | Felix Cheysson <[email protected]> |
License: | MIT + file LICENSE |
Version: | 1.0.3 |
Built: | 2024-12-08 07:14:53 UTC |
Source: | CRAN |
Outputs the compensator (integrated intensity) of a Hawkes process.
compensator(x, t, fun = NULL, repr = NULL, family = NULL, M = NULL, ...)
compensator(x, t, fun = NULL, repr = NULL, family = NULL, M = NULL, ...)
x |
A non-negative numeric vector, sorted in ascending order; or an object of class "hawkes" output by function |
t |
A non-negative numeric value or vector, at which the intensity should be computed. |
fun |
(default = TRUE) A non-negative numeric function or value - intensity (function) of the immigrant process. |
repr |
(default = NULL) A non-negative numeric value - mean number of offsprings. |
family |
(default = NULL) A character string "name" naming a distribution with corresponding distribution function |
M |
(default = NULL) A non-negative numeric value - upper bound on |
... |
Additional arguments passed on to the random generation function |
The compensator at time t.
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility distribution with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) compensator(x, 0:10) # Compensator with a different set of parameters compensator(x, 0:10, repr=0.8, rate=3) # Compensator with a different distribution function compensator(x, 0:10, family="chisq", df=2) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))}) compensator(x, 0:10, family=function(y) ifelse(y>0 & y<1, 2-2*y, 0))
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility distribution with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) compensator(x, 0:10) # Compensator with a different set of parameters compensator(x, 0:10, repr=0.8, rate=3) # Compensator with a different distribution function compensator(x, 0:10, family="chisq", df=2) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))}) compensator(x, 0:10, family=function(y) ifelse(y>0 & y<1, 2-2*y, 0))
Discretizes a Hawkes simulation
discrete(hawkes, length = NULL, binsize = NULL)
discrete(hawkes, length = NULL, binsize = NULL)
hawkes |
An object created by the function |
length |
(Either) The length for the output vector |
binsize |
(Either) The binsize for the discretization |
The vector of counts
x = hawkes(100, fun=1, repr=0.5, family="exp", rate=2) y = discrete(x, length=100) z = discrete(x, binsize=1) all(y == z)
x = hawkes(100, fun=1, repr=0.5, family="exp", rate=2) y = discrete(x, length=100) z = discrete(x, binsize=1) all(y == z)
Density, distribution function, quantile function and random generation for
the power law distribution with shape equal to shape
and scale equal to
scale
.
dpowerlaw(x, shape = 1, scale = 1) ppowerlaw(q, shape = 1, scale = 1) qpowerlaw(p, shape = 1, scale = 1) rpowerlaw(n, shape = 1, scale = 1)
dpowerlaw(x, shape = 1, scale = 1) ppowerlaw(q, shape = 1, scale = 1) qpowerlaw(p, shape = 1, scale = 1) rpowerlaw(n, shape = 1, scale = 1)
x , q
|
vector of quantiles. |
shape |
parameter of shape. |
scale |
parameter of scale. |
p |
vector of probabilities. |
n |
number of observations. |
The density function of the power law distribution is
where is the shape parameter, and
the scale parameter.
dpowerlaw
gives the density, ppowerlaw
gives the distribution function,
qpowerlaw
gives the quantile function, and rpowerlaw
generates random
deviates.
Calculates the value of
using its relation to the trigonometric integrals (cf. https://en.wikipedia.org/wiki/Exponential_integral#Exponential_integral_of_imaginary_argument):
and their Pad\'e approximants (cf. https://en.wikipedia.org/wiki/Trigonometric_integral#Efficient_evaluation)
E1_imaginary(x)
E1_imaginary(x)
x |
A non-negative number |
The exponential integral of argument ix
E1_imaginary(1.0)
E1_imaginary(1.0)
Calculates the value of
for .
This is achieved using recursive integrations by parts until
,
then using either the exponential integral
E1_imaginary
if ,
or the incomplete gamma function
inc_gamma_imag
if .
Etheta_imaginary(theta, x)
Etheta_imaginary(theta, x)
theta |
A strictly positive number |
x |
A vector of non-negative numbers |
The incomplete gamma function of imaginary argument with arbitrary power (see Details)
Etheta_imaginary(3.14, 1.0)
Etheta_imaginary(3.14, 1.0)
These classes are derived from the class Model
, each implementing
a different reproduction kernel for the Hawkes process.
They inherit all fields from Model.
The kernel Exponential
has density function
Its vector of parameters must be of the form .
Both
loglik
, its derivatives, and whittle
can be used with this reproduction kernel.
The kernel SymmetricExponential
has density function
Its vector of parameters must be of the form .
Only
whittle
can be used with this reproduction kernel.
The kernel Gaussian
has density function
Its vector of parameters must be of the form .
Only
whittle
is available with this reproduction kernel.
The kernel PowerLaw
has density function
Its vector of parameters must be of the form .
Both
loglik
, its derivatives, and whittle
can be used with this reproduction kernel.
The kernels Pareto3
, Pareto2
and Pareto1
have density function
with = 3, 2 and 1 respectively.
Their vectors of parameters must be of the form
.
Only
whittle
is available with this reproduction kernel.
Simulates a Hawkes process using its cluster representation:
First, the immigrants are drawn according to an (inhomogeneous) Poisson process with intensity measure fun
.
Second, the number of offsprings of an immigrant follows a Poisson distribution with intensity repr
.
Third, these offsprings are distributed according to the family
distribution.
Then, generate further offsprings according to the last two steps.
hawkes(end, fun, repr, family, M = NULL, ...)
hawkes(end, fun, repr, family, M = NULL, ...)
end |
A non-negative numeric value - right bound of the interval |
fun |
A non-negative function or numeric value - intensity (function) of the immigrant process. |
repr |
A non-negative numeric value - mean number of offsprings. |
family |
A character string "name" naming a distribution with corresponding random generation function |
M |
(default = NULL) A non-negative numeric value - upper bound on |
... |
Additional arguments passed on to the random generation function. |
A S3 object of class Hawkes containing a vector ($p) of simulated values, and all other objects used for the simulation.
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility function with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))})
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility function with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))})
Simulates a Hawkes process via Ogata's modified thinning algorithm on .
This is less efficient than function
hawkes
, but can be useful for pedagogical reasons.
hawkes_ogata(end, lambda, alpha, beta, lambda0 = NULL)
hawkes_ogata(end, lambda, alpha, beta, lambda0 = NULL)
end |
Right bound on time. |
lambda |
Baseline intensity. |
alpha |
Parameter for the amplitude of the spike. |
beta |
Parameter for the speed of exponential decay. |
lambda0 |
(Optional) Initial value of the conditional intensity. |
A S3 object of class Hawkes containing a vector ($p) of simulated values, and all other objects used for the simulation.
# Simulate an exponential Hawkes process with baseline intensity 1 and # excitation function 1*exp(-2t) x <- hawkes_ogata(10, 1, 1, 2) plot(x)
# Simulate an exponential Hawkes process with baseline intensity 1 and # excitation function 1*exp(-2t) x <- hawkes_ogata(10, 1, 1, 2) plot(x)
Calculates the value of
for through the following relations:
obtained by contour integration, and:
. The first integral is calculated using function "tgamma" from the library "boost::math", while the functions Ci and Si are approximated via Taylor expansions.
inc_gamma_imag(x, alpha)
inc_gamma_imag(x, alpha)
x |
A non-negative number |
alpha |
A number between 0 and 1 (strictly) |
The incomplete gamma function of imaginary argument (see Details)
inc_gamma_imag(1.0, 0.5)
inc_gamma_imag(1.0, 0.5)
Simulates an inhomogeneous Poisson process via Ogata's modified thinning algorithm on .
An homogeneous Poisson process with intensity
M
is first generated on , then thinned using the specified intensity function
fun
.
inhpois(end, fun, M = NULL)
inhpois(end, fun, M = NULL)
end |
A non-negative numeric value - right bound of the interval |
fun |
A non-negative function or numeric value - intensity (function) of the Poisson process. |
M |
(default = NULL) A non-negative numeric value - upper bound on |
A S3 object of class inhpois
containing a vector ($p) of simulated values,
and all other objects used for the simulation.
# Simulate an inhomogeneous Poisson process with function intensity 1 + sin(x) (bounded by 2) x <- inhpois(end=10, fun=function(y) {1 + sin(y)}, M=2) # Simulate a homogeneous Poisson process with intensity 3 x <- inhpois(end=10, fun=3)
# Simulate an inhomogeneous Poisson process with function intensity 1 + sin(x) (bounded by 2) x <- inhpois(end=10, fun=function(y) {1 + sin(y)}, M=2) # Simulate a homogeneous Poisson process with intensity 3 x <- inhpois(end=10, fun=3)
Outputs the intensity of a Hawkes process x
, given the specified set of parameters.
intensity(x, t, fun = NULL, repr = NULL, family = NULL, M = NULL, ...)
intensity(x, t, fun = NULL, repr = NULL, family = NULL, M = NULL, ...)
x |
A non-negative numeric vector, sorted in ascending order; or an object of class "hawkes" output by function |
t |
A non-negative numeric value or vector, at which the intensity should be computed. |
fun |
(default = TRUE) A non-negative numeric function or value - intensity (function) of the immigrant process. |
repr |
(default = NULL) A non-negative numeric value - mean number of offsprings. |
family |
(default = NULL) A character string "name" naming a distribution with corresponding distribution function |
M |
(default = NULL) A non-negative numeric value - upper bound on |
... |
Additional arguments passed on to the random generation function |
If the input x
has been simulated using the function hawkes
, the parameters of the simulation will be used by default to compute the intensity.
If any parameter is specified in this function call, the function will use this instead.
The intensity at time t.
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility distribution with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) intensity(x, 0:10) # Intensity with a different set of parameters intensity(x, 0:10, repr=0.8, rate=3) # Intensity with a different distribution function intensity(x, 0:10, family="chisq", df=2) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))}) intensity(x, 0:10, family=function(y) ifelse(y>0 & y<1, 2-2*y, 0))
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility distribution with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) intensity(x, 0:10) # Intensity with a different set of parameters intensity(x, 0:10, repr=0.8, rate=3) # Intensity with a different distribution function intensity(x, 0:10, family="chisq", df=2) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))}) intensity(x, 0:10, family=function(y) ifelse(y>0 & y<1, 2-2*y, 0))
This function fits a Hawkes process to continuous data by minimizing the likelihood
on the interval .
mle(events, kern, end, init = NULL, opts = NULL, ...)
mle(events, kern, end, init = NULL, opts = NULL, ...)
events |
The locations of events (sorted in ascending order) |
kern |
Either a string (partially) matching one of the kernels implemented (see Details), or an object of class Model |
end |
The time until which the process is observed. |
init |
(Optional) Initial values of the optimisation algorithm |
opts |
(Optional) To be passed to |
... |
Additional arguments passed to |
The maximum likelihood estimation procedure has only been implemented for the
exponential and the power law kernels.
For the exponential kernel, the likelihood is computed in complexity
(as described in details in T. Ozaki and Y. Ogata, “Maximum likelihood
estimation of Hawkes’ self-exciting point processes,” Ann. Inst. Stat. Math.,
vol. 31, no. 1, pp. 145–155, Dec. 1979).
For the power law kernel, the complexity is
.
Returns a list containing the solution of the optimisation procedure, the object Model
with its parameters updated to the solution, and the output produced by nloptr
.
hawkes()
for the simulation of Hawkes processes,
Model for the abstract class, and Exponential for the specific
reproduction kernels.
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility function with rate 2. x = hawkes(100, fun = 1, repr = .5, family = "exp", rate = 1) # Estimate the parameters from the arrival times of `x` using MLE opt = mle(x$p, "Exponential", x$end) opt$par # Estimated parameters opt$model$ddloglik(x$p, x$end) # Hessian matrix of the log-likelihood
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility function with rate 2. x = hawkes(100, fun = 1, repr = .5, family = "exp", rate = 1) # Estimate the parameters from the arrival times of `x` using MLE opt = mle(x$p, "Exponential", x$end) opt$par # Estimated parameters opt$model$ddloglik(x$p, x$end) # Hessian matrix of the log-likelihood
This is a C++ abstract class for Hawkes processes, which holds methods for the estimation of its parameters.
This serves as a basis for the Hawkes model and its count sequence, with conditional intensity function
As an abstract class, an object of class Model
should never be directly
instanciated, but rather one of its derived class.
The constructor can take no argument, in which case the vector param
is
initialised to sensible values and binsize
defaults to 1.
Alternatively, param
and/or binsize
can be specified.
param
Vector of parameters of the Hawkes process, of the form .
binsize
Bin size for the count sequences.
new(DerivedClass,(param),(binsize))
Constructor for derived classes; param
and/or binsize
can be safely ignored.
mean()
Returns the expected value on .
dmean()
Returns the Jacobian matrix of the expected value on .
ddmean()
Returns the Hessian matrix of the expected value on .
f(xi)
Returns the spectral density function of the time-continuous count sequence.
xi
A numeric vector of frequencies.
f1(xi,trunc)
Returns the spectral density function of the discrete time count sequence.
xi
A numeric vector of frequencies.
trunc
The number of foldings to take into account for the aliasing.
whittle(I,trunc)
Returns the log-spectral likelihood of a discrete time count sequence.
I
The periodogram of the count sequence.
trunc
The number of foldings to take into account for the aliasing.
loglik(events,end)
Returns the log-likelihood of a sequence of arrival times.
events
The sequence of arrival times.
end
The endpoint of the observation window .
dloglik(events,end)
Returns the Jacobian matrix of the log-likelihood of a sequence of arrival times.
events
The sequence of arrival times.
end
The endpoint of the observation window .
ddloglik(events,end)
Returns the Hessian matrix of the log-likelihood of a sequence of arrival times.
events
The sequence of arrival times.
end
The endpoint of the observation window .
# Simulate 1000 exponential Hawkes processes on \eqn{[0, 100]}, # and average the periodogram of the count sequences with bin size 1 # at each frequency. I = rep(0, 100) for (k in 1:1e3) { x = hawkes(100, fun = 1, repr = .5, family = "exp", rate = 2) y = discrete(x, binsize = 1) I = I + Mod(fft(y - mean(y)))^2 / length(y) } # Check that the averaged periodogram correctly approximates the spectral # density function of the count sequence model = new(Exponential) model$param = c(1, .5, 2) model$binsize = 1 z = 2 * pi * 0:99 / 100 # Frequencies of the periodogram plot(z, I / 1e3, type = "l") # Averaged periodogram lines(z, model$f1(xi = z, trunc = 10L), col = "red")
# Simulate 1000 exponential Hawkes processes on \eqn{[0, 100]}, # and average the periodogram of the count sequences with bin size 1 # at each frequency. I = rep(0, 100) for (k in 1:1e3) { x = hawkes(100, fun = 1, repr = .5, family = "exp", rate = 2) y = discrete(x, binsize = 1) I = I + Mod(fft(y - mean(y)))^2 / length(y) } # Check that the averaged periodogram correctly approximates the spectral # density function of the count sequence model = new(Exponential) model$param = c(1, .5, 2) model$binsize = 1 z = 2 * pi * 0:99 / 100 # Frequencies of the periodogram plot(z, I / 1e3, type = "l") # Averaged periodogram lines(z, model$f1(xi = z, trunc = 10L), col = "red")
Plots the realisation of a Hawkes process and either its cluster representation (intensity=FALSE
, only available for a simulated Hawkes process) or its intensity function (intensity=TRUE
).
## S3 method for class 'hawkes' plot( x, intensity = FALSE, precision = 1000, fun = NULL, repr = NULL, family = NULL, M = NULL, ... )
## S3 method for class 'hawkes' plot( x, intensity = FALSE, precision = 1000, fun = NULL, repr = NULL, family = NULL, M = NULL, ... )
x |
Either: a numeric vector, sorted in ascending order; or an object of class "hawkes" output by function |
intensity |
(default = FALSE) A boolean - whether to represent the cluster representation ( |
precision |
(default = 1e3) Number of points to plot. |
fun |
(default = NULL) A numeric function - intensity (function) of the immigrant process. |
repr |
(default = NULL) A non-negative numeric value - mean number of offsprings. |
family |
(default = NULL) A character string "name" naming a distribution with corresponding distribution function |
M |
(default = NULL) A non-negative numeric value - upper bound on |
... |
Additional arguments passed on to the random generation function |
None
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility function with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) plot(x) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))}) plot(x, intensity=TRUE, family=function(y) ifelse(y>0 & y<1, 2-2*y, 0))
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility function with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) plot(x) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))}) plot(x, intensity=TRUE, family=function(y) ifelse(y>0 & y<1, 2-2*y, 0))
Plots a Hawkes process simulated by the function hawkes_ogata
,
highlighting the steps used in Ogata's thinning algorithm.
## S3 method for class 'hawkes_ogata' plot(x, precision = 1000, ...)
## S3 method for class 'hawkes_ogata' plot(x, precision = 1000, ...)
x |
A simulated Hawkes process from |
precision |
(default = 1e3) Number of points to plot. |
... |
Only there to fit the declaration of S3 method |
None
# Simulate an exponential Hawkes process with baseline intensity 1 and # excitation function 1*exp(-2t) x <- hawkes_ogata(10, 1, 1, 2) plot(x)
# Simulate an exponential Hawkes process with baseline intensity 1 and # excitation function 1*exp(-2t) x <- hawkes_ogata(10, 1, 1, 2) plot(x)
Plots a simulated inhomogeneous Poisson process, highlighting the steps used in Ogata's thinning algorithm.
## S3 method for class 'inhpois' plot(x, precision = 1000, ...)
## S3 method for class 'inhpois' plot(x, precision = 1000, ...)
x |
A simulated inhomogeneous Poisson process. |
precision |
(default = 1e3) Number of points to plot. |
... |
Only there to fit the declaration of S3 method |
None
# Simulate an inhomogeneous Poisson process with function intensity 1 + sin(x) x <- inhpois(end=10, fun=function(y) {1 + sin(y)}, M=2) plot(x)
# Simulate an inhomogeneous Poisson process with function intensity 1 + sin(x) x <- inhpois(end=10, fun=function(y) {1 + sin(y)}, M=2) plot(x)
Outputs the residuals (values of the compensator at the times of arrival) of a Hawkes process. Useful function for diagnosis through the random time change theorem: the residuals should follow a unit rate Poisson process.
residuals(x, fun = NULL, repr = NULL, family = NULL, M = NULL, ...)
residuals(x, fun = NULL, repr = NULL, family = NULL, M = NULL, ...)
x |
A non-negative numeric vector, sorted in ascending order; or an object of class "hawkes" output by function |
fun |
(default = TRUE) A non-negative numeric function or value - intensity (function) of the immigrant process. |
repr |
(default = NULL) A non-negative numeric value - mean number of offsprings. |
family |
(default = NULL) A character string "name" naming a distribution with corresponding distribution function |
M |
(default = NULL) A non-negative numeric value - upper bound on |
... |
Additional arguments passed on to the random generation function |
The residuals of the process.
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility distribution with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) resid = residuals(x) resid plot(resid) abline(0, 1, col="red", lty="dashed") # Residuals with a different set of parameters residuals(x, repr=0.8, rate=3) # Residuals with a different distribution function residuals(x, family="chisq", df=2) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))}) resid = residuals(x, family=function(y) ifelse(y>0 & y<1, 2-2*y, 0)) plot(resid) abline(0, 1, col="red", lty="dashed")
# Simulate an exponential Hawkes process with baseline intensity 1, # reproduction mean 0.5 and exponential fertility distribution with rate 2. x <- hawkes(10, fun=1, repr=0.5, family="exp", rate=2) resid = residuals(x) resid plot(resid) abline(0, 1, col="red", lty="dashed") # Residuals with a different set of parameters residuals(x, repr=0.8, rate=3) # Residuals with a different distribution function residuals(x, family="chisq", df=2) # Simulate a Hawkes process with baseline intensity function 1 + sin(x), # reproduction mean 0.5 and custom [0,1]-triangular fertility function. x <- hawkes(10, fun=function(y) {1+sin(y)}, M=2, repr=0.5, family=function(n) {1 - sqrt(1 - runif(n))}) resid = residuals(x, family=function(y) ifelse(y>0 & y<1, 2-2*y, 0)) plot(resid) abline(0, 1, col="red", lty="dashed")
This function fits a Hawkes process to discrete data by minimizing the Whittle contrast.
whittle(counts, kern, binsize = NULL, trunc = 5L, init = NULL, ...)
whittle(counts, kern, binsize = NULL, trunc = 5L, init = NULL, ...)
counts |
A bin-count sequence |
kern |
Either a string (partially) matching one of the kernels implemented (see Details), or an object of class Model |
binsize |
(Optional) The bin size of the bin-count sequence; if omitted, defaults to 1 if |
trunc |
(Optional) The number of foldings taken into account due to aliasing |
init |
(Optional) Initial values of the optimisation algorithm |
... |
Additional arguments passed to |
If specified as string, the argument kern
must match (partially) one of the following
(upper cases not taken into account): Exponential, SymmetricExponential,
Gaussian, PowerLaw, Pareto3, Pareto2, Pareto1.
The periodogram used in the optimisation procedure is computed in complexity
, using function
fft
.
Returns a list containing the solution of the optimisation procedure, the object Model
with its parameters updated to the solution, and the output produced by optim
.
hawkes()
for the simulation of Hawkes processes,
discrete()
for the discretisation of simulated Hawkes processes,
Model for the abstract class, and Exponential for the specific
reproduction kernels.
# Simulate and fit a Hawkes process with exponential kernel x = hawkes(1000, fun = 1, repr = .5, family = "exp", rate = 1) y = discrete(x, binsize = 1) opt = whittle(y, "Exponential") opt$par # Estimated parameters # May take up to 20 seconds # Simulate and fit a Hawkes process with power law kernel x = hawkes(1000, fun = 1, repr= .3, family = "powerlaw", shape = 3.5, scale = 1.0) y = discrete(x, binsize = 1) opt = whittle(y, "powerlaw") opt$par # Estimated parameters
# Simulate and fit a Hawkes process with exponential kernel x = hawkes(1000, fun = 1, repr = .5, family = "exp", rate = 1) y = discrete(x, binsize = 1) opt = whittle(y, "Exponential") opt$par # Estimated parameters # May take up to 20 seconds # Simulate and fit a Hawkes process with power law kernel x = hawkes(1000, fun = 1, repr= .3, family = "powerlaw", shape = 3.5, scale = 1.0) y = discrete(x, binsize = 1) opt = whittle(y, "powerlaw") opt$par # Estimated parameters