{"id":13688890,"url":"https://github.com/JaxGaussianProcesses/GPJax","last_synced_at":"2025-05-01T20:30:57.336Z","repository":{"id":37078238,"uuid":"299115429","full_name":"JaxGaussianProcesses/GPJax","owner":"JaxGaussianProcesses","description":"Gaussian processes in JAX and Flax.","archived":false,"fork":false,"pushed_at":"2025-04-13T20:26:49.000Z","size":293009,"stargazers_count":505,"open_issues_count":6,"forks_count":63,"subscribers_count":3,"default_branch":"main","last_synced_at":"2025-05-01T15:17:26.010Z","etag":null,"topics":["bayesian-inference","gaussian-processes","jax","machine-learning","probabilistic-programming"],"latest_commit_sha":null,"homepage":"https://docs.jaxgaussianprocesses.com/","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/JaxGaussianProcesses.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"docs/contributing.md","funding":null,"license":"LICENSE.txt","code_of_conduct":".github/CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":"CITATION.bib","codeowners":null,"security":null,"support":null,"governance":"docs/GOVERNANCE.md","roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2020-09-27T20:40:59.000Z","updated_at":"2025-04-30T18:17:39.000Z","dependencies_parsed_at":"2024-01-03T03:28:47.767Z","dependency_job_id":"491ff742-10cd-4a52-9a82-26398d2bed54","html_url":"https://github.com/JaxGaussianProcesses/GPJax","commit_stats":{"total_commits":1152,"total_committers":34,"mean_commits":33.88235294117647,"dds":0.5746527777777778,"last_synced_commit":"8f14cbd6985b8340ae8987d45025c96a07cc83e7"},"previous_names":["thomaspinder/gpjax"],"tags_count":47,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JaxGaussianProcesses%2FGPJax","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JaxGaussianProcesses%2FGPJax/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JaxGaussianProcesses%2FGPJax/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JaxGaussianProcesses%2FGPJax/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/JaxGaussianProcesses","download_url":"https://codeload.github.com/JaxGaussianProcesses/GPJax/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":251940543,"owners_count":21668555,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["bayesian-inference","gaussian-processes","jax","machine-learning","probabilistic-programming"],"created_at":"2024-08-02T15:01:26.615Z","updated_at":"2025-05-01T20:30:57.328Z","avatar_url":"https://github.com/JaxGaussianProcesses.png","language":"Python","readme":"\u003c!-- \u003ch1 align='center'\u003eGPJax\u003c/h1\u003e\n\u003ch2 align='center'\u003eGaussian processes in Jax.\u003c/h2\u003e --\u003e\n\u003cp align=\"center\"\u003e\n\u003cimg width=\"700\" height=\"300\" src=\"https://raw.githubusercontent.com/JaxGaussianProcesses/GPJax/main/docs/static/gpjax_logo.svg\" alt=\"GPJax's logo\"\u003e\n\u003c/p\u003e\n\n[![codecov](https://codecov.io/gh/JaxGaussianProcesses/GPJax/branch/master/graph/badge.svg?token=DM1DRDASU2)](https://codecov.io/gh/JaxGaussianProcesses/GPJax)\n[![CodeFactor](https://www.codefactor.io/repository/github/jaxgaussianprocesses/gpjax/badge)](https://www.codefactor.io/repository/github/jaxgaussianprocesses/gpjax)\n[![Netlify Status](https://api.netlify.com/api/v1/badges/d3950e6f-321f-4508-9e52-426b5dae2715/deploy-status)](https://app.netlify.com/sites/endearing-crepe-c2d5fe/deploys)\n[![PyPI version](https://badge.fury.io/py/GPJax.svg)](https://badge.fury.io/py/GPJax)\n[![DOI](https://joss.theoj.org/papers/10.21105/joss.04455/status.svg)](https://doi.org/10.21105/joss.04455)\n[![Downloads](https://pepy.tech/badge/gpjax)](https://pepy.tech/project/gpjax)\n[![Slack Invite](https://img.shields.io/badge/Slack_Invite--blue?style=social\u0026logo=slack)](https://join.slack.com/t/gpjax/shared_invite/zt-1da57pmjn-rdBCVg9kApirEEn2E5Q2Zw)\n\n[**Quickstart**](#simple-example)\n| [**Install guide**](#installation)\n| [**Documentation**](https://docs.jaxgaussianprocesses.com/)\n| [**Slack Community**](https://join.slack.com/t/gpjax/shared_invite/zt-1da57pmjn-rdBCVg9kApirEEn2E5Q2Zw)\n\nGPJax aims to provide a low-level interface to Gaussian process (GP) models in\n[Jax](https://github.com/google/jax), structured to give researchers maximum\nflexibility in extending the code to suit their own needs. The idea is that the\ncode should be as close as possible to the maths we write on paper when working\nwith GP models.\n\n# Package organisation\n\n## Contributions\n\nWe would be delighted to receive contributions from interested individuals and\ngroups. To learn how you can get involved, please read our [guide for\ncontributing](https://github.com/JaxGaussianProcesses/GPJax/blob/main/docs/contributing.md).\nIf you have any questions, we encourage you to [open an\nissue](https://github.com/JaxGaussianProcesses/GPJax/issues/new/choose). For\nbroader conversations, such as best GP fitting practices or questions about the\nmathematics of GPs, we invite you to [open a\ndiscussion](https://github.com/JaxGaussianProcesses/GPJax/discussions).\n\nAnother way you can contribute to GPJax is through [issue\ntriaging](https://www.codetriage.com/what).  This can include reproducing bug reports,\nasking for vital information such as version numbers and reproduction instructions, or\nidentifying stale issues. If you would like to begin triaging issues, an easy way to get\nstarted is to\n[subscribe to GPJax on CodeTriage](https://www.codetriage.com/jaxgaussianprocesses/gpjax).\n\nAs a contributor to GPJax, you are expected to abide by our [code of\nconduct](docs/CODE_OF_CONDUCT.md). If you feel that you have either experienced or\nwitnessed behaviour that violates this standard, then we ask that you report any such\nbehaviours through [this form](https://jaxgaussianprocesses.com/contact/) or reach out to\none of the project's [_gardeners_](https://docs.jaxgaussianprocesses.com/GOVERNANCE/#roles).\n\nFeel free to join our [Slack\nChannel](https://join.slack.com/t/gpjax/shared_invite/zt-1da57pmjn-rdBCVg9kApirEEn2E5Q2Zw),\nwhere we can discuss the development of GPJax and broader support for Gaussian\nprocess modelling.\n\n\n## Governance\n\nGPJax was founded by [Thomas Pinder](https://github.com/thomaspinder). Today, the\nproject's gardeners are [daniel-dodd@](https://github.com/daniel-dodd),\n[henrymoss@](https://github.com/henrymoss), [st--@](https://github.com/st--), and\n[thomaspinder@](https://github.com/thomaspinder), listed in alphabetical order. The full\ngovernance structure of GPJax is detailed [here](docs/GOVERNANCE.md). We appreciate all\n[the contributors to\nGPJax](https://github.com/JaxGaussianProcesses/GPJax/graphs/contributors) who have\nhelped to shape GPJax into the package it is today.\n\n\n# Supported methods and interfaces\n\n## Notebook examples\n\n\u003e - [**Conjugate Inference**](https://docs.jaxgaussianprocesses.com/_examples/regression/)\n\u003e - [**Classification**](https://docs.jaxgaussianprocesses.com/_examples/classification/)\n\u003e - [**Sparse Variational Inference**](https://docs.jaxgaussianprocesses.com/_examples/collapsed_vi/)\n\u003e - [**Stochastic Variational Inference**](https://docs.jaxgaussianprocesses.com/_examples/uncollapsed_vi/)\n\u003e - [**Laplace Approximation**](https://docs.jaxgaussianprocesses.com/_examples/classification/#laplace-approximation)\n\u003e - [**Inference on Non-Euclidean Spaces**](https://docs.jaxgaussianprocesses.com/_examples/constructing_new_kernels/#custom-kernel)\n\u003e - [**Inference on Graphs**](https://docs.jaxgaussianprocesses.com/_examples/graph_kernels/)\n\u003e - [**Pathwise Sampling**](https://docs.jaxgaussianprocesses.com/_examples/spatial/)\n\u003e - [**Learning Gaussian Process Barycentres**](https://docs.jaxgaussianprocesses.com/_examples/barycentres/)\n\u003e - [**Deep Kernel Regression**](https://docs.jaxgaussianprocesses.com/_examples/deep_kernels/)\n\u003e - [**Poisson Regression**](https://docs.jaxgaussianprocesses.com/_examples/poisson/)\n\u003e - [**Bayesian Optimisation**](https://docs.jaxgaussianprocesses.com/_examples/bayesian_optimisation/)\n\n## Guides for customisation\n\u003e\n\u003e - [**Custom kernels**](https://docs.jaxgaussianprocesses.com/_examples/constructing_new_kernels/#custom-kernel)\n\u003e - [**UCI regression**](https://docs.jaxgaussianprocesses.com/_examples/yacht/)\n\n## Conversion between `.ipynb` and `.py`\nAbove examples are stored in [examples](docs/examples) directory in the double\npercent (`py:percent`) format. Checkout [jupytext\nusing-cli](https://jupytext.readthedocs.io/en/latest/using-cli.html) for more\ninfo.\n\n* To convert `example.py` to `example.ipynb`, run:\n\n```bash\njupytext --to notebook example.py\n```\n\n* To convert `example.ipynb` to `example.py`, run:\n\n```bash\njupytext --to py:percent example.ipynb\n```\n\n# Installation\n\n## Stable version\n\nThe latest stable version of GPJax can be installed via\npip:\n\n```bash\npip install gpjax\n```\n\n\u003e **Note**\n\u003e\n\u003e We recommend you check your installation version:\n\u003e ```python\n\u003e python -c 'import gpjax; print(gpjax.__version__)'\n\u003e ```\n\n\n\n## Development version\n\u003e **Warning**\n\u003e\n\u003e This version is possibly unstable and may contain bugs.\n\n\u003e **Note**\n\u003e\n\u003e We advise you create virtual environment before installing:\n\u003e ```\n\u003e conda create -n gpjax_experimental python=3.10.0\n\u003e conda activate gpjax_experimental\n\u003e  ```\n\n\nClone a copy of the repository to your local machine and run the setup\nconfiguration in development mode.\n```bash\ngit clone https://github.com/JaxGaussianProcesses/GPJax.git\ncd GPJax\nhatch env create\nhatch shell\n```\n\n\u003e We recommend you check your installation passes the supplied unit tests:\n\u003e\n\u003e ```python\n\u003e hatch run dev:test\n\u003e ```\n\n# Citing GPJax\n\nIf you use GPJax in your research, please cite our [JOSS paper](https://joss.theoj.org/papers/10.21105/joss.04455#).\n\n```\n@article{Pinder2022,\n  doi = {10.21105/joss.04455},\n  url = {https://doi.org/10.21105/joss.04455},\n  year = {2022},\n  publisher = {The Open Journal},\n  volume = {7},\n  number = {75},\n  pages = {4455},\n  author = {Thomas Pinder and Daniel Dodd},\n  title = {GPJax: A Gaussian Process Framework in JAX},\n  journal = {Journal of Open Source Software}\n}\n```\n","funding_links":[],"categories":["Python","Libraries"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FJaxGaussianProcesses%2FGPJax","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FJaxGaussianProcesses%2FGPJax","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FJaxGaussianProcesses%2FGPJax/lists"}