Skip to content
forked from fabsig/GPBoost

GPBoost is a software library for combining tree-boosting with Gaussian process and mixed effects models

License

Notifications You must be signed in to change notification settings

stanpcf/GPBoost

 
 

Repository files navigation

GPBoost: Combining Tree-Boosting with Gaussian Process and Mixed Effects Models

Table of Contents

  1. Get Started
  2. Modeling Background
  3. News
  4. Open Issues - Contribute
  5. References
  6. License

Get started

GPBoost is a software library for combining tree-boosting with Gaussian process and mixed effects models. It also allows for independently doing tree-boosting as well as inference and prediction for linear Gaussian process and mixed effects models.

The GPBoost library is written in C++ and it has a C API. There exist both a Python package and an R package.

For more information, you may want to have a look at:

Modeling Background

Both tree-boosting and Gaussian processes are techniques that achieve state-of-the-art predictive accuracy. Besides this, tree-boosting has the following advantages:

  • Automatic modeling of non-linearities, discontinuities, and complex high-order interactions
  • Robust to outliers in and multicollinearity among predictor variables
  • Scale-invariant to monotone transformations of the predictor variables
  • Automatic handling of missing values in predictor variables

Gaussian process models have the following advantage:

  • Probabilistic predictions which allows for uncertainty quantification

For the GPBoost algorithm, it is assumed that the response variable (label) is the sum of a non-linear mean function and so-called random effects. The random effects can consists of

  • Gaussian processes (including random coefficient processes)
  • Grouped random effects (including nested, crossed, and random coefficient effects)
  • A sum of the above

The model is trained using the GPBoost algorithm, where training means learning the covariance parameters of the random effects and the mean function F(X) using a tree ensemble. In brief, the GPBoost algorithm is a boosting algorithm that iteratively learns the covariance parameters and adds a tree to the ensemble of trees using a gradient and/or a Newton boosting step. In the GPBoost library, covariance parameters can be learned using (Nesterov accelerated) gradient descent or Fisher scoring. Further, trees are learned using the LightGBM library. See Sigrist (2020) for more details.

News

Open Issues - Contribute

Software issues

  • Add tests: Python tests and R tests such that the coverage is higher
  • Setting up Travis CI for GPBoost

Computational issues

  • Add GPU support for Gaussian processes

Methodological issues

  • Add a spatio-temporal Gaussian process model (e.g. a separable one)
  • Add possibility to predict latent Gaussian processes and random effects (e.g. random coefficients)
  • Add backtracking (e.g. step-halving) to Fisher scoring to safeguard against potential convergence problems

References

Sigrist Fabio. "Gaussian Process Boosting". Preprint (2020).

Guolin Ke, Qi Meng, Thomas Finley, Taifeng Wang, Wei Chen, Weidong Ma, Qiwei Ye, Tie-Yan Liu. "LightGBM: A Highly Efficient Gradient Boosting Decision Tree". Advances in Neural Information Processing Systems 30 (NIPS 2017), pp. 3149-3157.

License

This project is licensed under the terms of the Apache License 2.0. See LICENSE for additional details.

About

GPBoost is a software library for combining tree-boosting with Gaussian process and mixed effects models

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 88.3%
  • Python 5.2%
  • R 3.7%
  • C 1.9%
  • CMake 0.6%
  • Cuda 0.3%