Skip to content

aszepieniec/barff

Folders and files

NameName
Last commit message
Last commit date
Nov 13, 2016
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jul 21, 2017
May 19, 2017
May 19, 2017
Jan 26, 2019
Oct 30, 2017
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jul 2, 2017
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jan 26, 2019
Jul 9, 2017
Jul 3, 2017
Jan 26, 2019
Jan 26, 2019

Repository files navigation

barff

Ansi C library for basic algebra routines for prime finite fields, for instance for MQ cryptography; or for error correcting codes

Features

  • matrix routines including initialization to random values, multiplication, echelon reduction, and system solving
  • homogeneous quadratic systems, evaluation and composition with linear transforms
  • csprng based on an ANSI C89 compliant version of Keccak
  • big integer routines

TODO

  • polynomial and extension field arithmetic
  • make primality test faster

How To

  • compile:
    • standard unit tests: gcc -o test_algebra test_algebra.c gfp.c csprng.c Keccak-readable-and-compact-c89.c gf*x.c gfpm.c hqs.c -ansi -Wpedantic
    • big field unit tests: gcc -o test_algebra test_algebra.c gfbi.c bi.c csprng.c Keccak-readable-and-compact-c89.c gf*x.c gfpm.c hqs.c -DBIG -ansi -Wpedantic
    • big number arithmetic: gcc -o test_bi test_bi.c bi.c csprng.c Keccak-readable-and-compact-c89.c -ansi -Wpedantic
    • prime sampling benchmark: gcc -o benchmark_primality benchmark_primality.c bi.c csprng.c Keccak-readable-and-compact-c89.c -ansi -Wpedantic -O3

About

basic algebra routines for finite fields

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published