Skip to content

Latest commit

 

History

History
56 lines (37 loc) · 2.14 KB

README.md

File metadata and controls

56 lines (37 loc) · 2.14 KB

Introduction

POPPY is a JAX library for linear algebra over finite fields.

POPPY has a field class, an array class, and a theta class.

array is a batch of matrices over field.

theta is a stabilizer state over field.

Motivation

Arithmetization compiles a computation to a set of combinatorial operations on arithmetic objects (polynomial rings, finitely generated groups, ...). Emerging technologies like zero knowledge proofs, error correcting codes, and derandomization, depend on arithmetization.

Linearization approximates a computation with a piecewise linear circuit. It is the basis of modern AI. Computer hardware is optimized for linear operations.

Modular representation theory linearizes arithmetic programs in a variety of constructible and interesting approximations. The resulting programs are piecewise linear over finite fields. Lattice cryptography algorithms are simple linear arithmetic programs.

POPPY runs linear arithmetic programs, quickly.

Notation

q = p^n is a prime power in the Conway polynomials database.

y = y_q is the Conway polynomial.

F = F_q is the finite field.

M_k( F ) is the associative algebra of k x k matrices over F.

X = X_y is an n x n matrix root of the polynomial y.

Linear Representation

POPPY represents the finite field element f mod y by the matrix f(X) mod p. The representation is n dimensional and faithful. It extends linearly to a faithful mod p representation of the matrix algebra M_k( F ). A matrix mod p is a 2-dimensional jax.numpy.int64 array of nonnegative integers less than p. The jax.numpy.mod() function reduces integer arrays mod p.

Performance

q = 12421^3.

a,b are random 222 x 222 matrices over F.

c is a random number in F.

operation time (T4 GPU)
a+b 200 us
a.trace() 300 us
a*c 1.4 ms
a@b 2.8 ms
a.lu() 20 ms
a.inv() 40 ms
a.det() 50 ms