luhav/havok-n

PHP implementation of Havok-N, a modified version of Fletcher & Adler checksums plus an optional iterative hash function.


Keywords
hash, checksum, Fletcher, Adler, adler-32, adler32, fletcher-checksum, php, php-library
License
BSD-1-Clause

Documentation

Havok-N PHP Composer Package

What is Havok-N?

A modified version of Fletcher & Adler checksums plus an optional iterative hash function, by Lucy Havok.

Fletcher's Checksum algorithm is way overengineered. Adler had the right idea with many of the tweaks he made to simplify and solidify the algorithm. However, I liked the idea of having a user-defined arbitrary checksum bitdepth, but also make sure that the modulo is always prime so as to reduce checksum collision.

Table comparison

Fletcher Adler Havok
Word Size 8b | 16b | 32b 8b 8b
Bits 16 | 32 | 64 32 arbitrary
Modulo 28 | 216 | 232 65,521 nearest prime under 2Bits
Shift 8 | 16 | 32 16 Bits/2
Iterative Hash no no optional, arbitrary

Usage

composer require luhav/havok-n
use Luhav\HavokN;

$havokN = new HavokN();

$data       = "Toast"; // This is the data you want a sum of. Can be of any type.
$bitdepth   = 16;      // This is sort of like the length of the checksum, but it's not directly proportionate. If you wanted to pretend this is Adler-32, you would put 32 here. Should be an integer.
$iterations = 0;       // Optional. This is the number of iterations over the iterative hash function (defaults to 0).
$havokN->sum($data, $bitdepth, $iterations);

Upstream

Havok-N is part of the EmojiHash project at Peepee Party, of which I am the creator, maintainer, and current sole contributor. The upstream version of havokn.php can be seen at https://fossil.peepee.party/emojihash/file?name=php/havokn.php.

License

Havok-N is licensed under The 3-Clause BSD License with the explicit military disclaimer (SPDX: BSD-3-Clause-No-Military-License). See LICENSE for the full text.