Skip to content
/ gq Public

R package for integral approximation with vector limits using Gaussian quadrature

License

Notifications You must be signed in to change notification settings

custora/gq

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gq

Ryan Gosling, almost as good-looking of a guy as we are

Gaussian quadrature-based integration functions in R. Depends on the statmod package (in fact statmod's gauss.quad function computes the quadrature points and weights). The integration limits can be vectors.

There is no numerical optimization to find the exact answer or to get the answer right within a certain error tolerance - you simply specify the number of points you want to use in the approximation. So this is not the best approach when you need high accuracy. This is more for when you want fast computation over a large number of different limits.

As an example of where you'd want that: we use this to evaluate integrals in likelihood functions. We may have millions of observations, each with a different limit, but in practice it may not adversely affect likelihood maximization too much if the integral is not exactly calculated.

Installation

Clone the repo and run R CMD INSTALL gq.

Usage

> legendreIntegrate(function(x) x^2 + sqrt(x), 1:5, 2:6)
> jacobiIntegrate(function(x) sqrt((1+x)/(1-x)), -1, 1, alpha=0, beta=0)       # inexact
> jacobiIntegrate(function(x) sqrt((1+x)/(1-x)), -1, 1, alpha=-0.5, beta=0.5)  # more exact with proper weight function
> laguerreIntegrate(function(x) exp(-x), c(0, Inf), c(Inf, 0))
> laguerreIntegrate(function(x) exp(x), c(-Inf, 0), c(0, -Inf))

See the documentation and inst/tests/test-gq.R for several examples.

Tests

Tests are written with testthat. You can test the package with test_package.

About

R package for integral approximation with vector limits using Gaussian quadrature

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages