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.dev20230620.tar.gz (33.8 kB view details)

Uploaded Source

Built Distribution

File details

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

File metadata

File hashes

Hashes for jaxkern-nightly-0.0.5.dev20230620.tar.gz
Algorithm Hash digest
SHA256 f0445e9280c8e1f9d32ea087bab135d7451a5b8cfa2622e2dad9da84ba773006
MD5 5241d8d71c7f5a3e137bbb4d966b2db0
BLAKE2b-256 1b3c796a9cd0439ecbe9c8f393052c4fa8fcd055e228938e30f6c563b3a89b85

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for jaxkern_nightly-0.0.5.dev20230620-py3-none-any.whl
Algorithm Hash digest
SHA256 fa1c3acc3d052aa4b0bf7483b3fd2c8d921a6a75507b59bdda991d65f805d886
MD5 67a84a6427b82e77309d57d0d43b172a
BLAKE2b-256 f53a1e70708dc6fbd19797e36284bec2463002cd4b2efd1acb8404e0c09616b6

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