Skip to main content

Kernels in Jax.

Project description


This project has now been incorporated into GPJax.

JaxKern's logo

Kernels in Jax.

codecov CircleCI Documentation Status PyPI version Downloads Slack Invite

Introduction

JaxKern is Python library for working with kernel functions in JAX. We currently support the following kernels:

  • Stationary
    • Radial basis function (Squared exponential)
    • Matérn
    • Powered exponential
    • Rational quadratic
    • White noise
    • Periodic
  • Non-stationary
    • Linear
    • Polynomial
  • Non-Euclidean
    • Graph kernels

In addition to this, we implement kernel approximations using the Random Fourier feature approach.

Example

The following code snippet demonstrates how the first order Matérn kernel can be computed and, subsequently, approximated using random Fourier features.

import jaxkern as jk
import jax.numpy as jnp
import jax.random as jr
key = jr.PRNGKey(123)

# Define the points on which we'll evaluate the kernel
X = jr.uniform(key, shape = (10, 1), minval=-3., maxval=3.)
Y = jr.uniform(key, shape = (20, 1), minval=-3., maxval=3.)

# Instantiate the kernel and its parameters
kernel = jk.Matern32()
params = kernel.init_params(key)

# Compute the 10x10 Gram matrix
Kxx = kernel.gram(params, X)

# Compute the 10x20 cross-covariance matrix
Kxy = kernel.cross_covariance(params, X, Y)

# Build a RFF approximation
approx = RFF(kernel, num_basis_fns = 5)
rff_params = approx.init_params(key)

# Build an approximation to the Gram matrix
Qff = approx.gram(rff_params, X)

Code Structure

All kernels are supplied with a gram and cross_covariance method. When computing a Gram matrix, there is often some structure in the data (e.g., Markov) that can be exploited to yield a sparse matrix. To instruct JAX how to operate on this, the return type of gram is a Linear Operator from JaxLinOp.

Within GPJax, all kernel computations are handled using JaxKern.

Documentation

A full set of documentation is a work in progress. However, many of the details in JaxKern can be found in the GPJax documentation.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jaxkern-nightly-0.0.5.dev20230916.tar.gz (33.8 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file jaxkern-nightly-0.0.5.dev20230916.tar.gz.

File metadata

File hashes

Hashes for jaxkern-nightly-0.0.5.dev20230916.tar.gz
Algorithm Hash digest
SHA256 117226cc8b869ad071c5bff1ff31afacb351d5f4ea0c3ce7f71193df41d0c404
MD5 1d182f5a9843085e70d36df0e3ba17ac
BLAKE2b-256 4a5706290a5d807fd8cc58e46220d643b1d0348a52dce6f055d0392021458b77

See more details on using hashes here.

File details

Details for the file jaxkern_nightly-0.0.5.dev20230916-py3-none-any.whl.

File metadata

File hashes

Hashes for jaxkern_nightly-0.0.5.dev20230916-py3-none-any.whl
Algorithm Hash digest
SHA256 e054bf3209ff1e163347435945fe3e65ee858e4f16b5c95e22700a6e38960a7e
MD5 8adbeaec015f20e8c1c36e317a37bdeb
BLAKE2b-256 2ce7e70af1befbff64c32ad34044ec9b17b15343630696c89b9e8dc1c793e1e3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page