binary-sortable-hash
Hash arrays of numbers into a binary string from which you can reconstruct the original values, with configurable precision loss. The generated hashes sort well, so similar input values cause large shared prefixes in hashes. (as seen in geohashing)
sortable === '011111111111111111111111111111111111111111111111111111111111';sortable === -8673617379884035e-17sortable === '110001001001110110011001100100001011100110001001100110011011';
Usage
Hash a lat/lon array representing Röcken Germany
[10, -10, 10]
and then restore it, using different
hash sizes.
var sortable = ; var rocken = lat: 512408 lon: 121161//normalize scalars to +-100var normalized = 100*rockenlat/180 100*rockenlon/90 var hash = sortable// => '110010010010000100101111010001010001001110011100001100111111' sortable;// => [ 51.24080015346408, 12.116099959239364 ] var lowerFidelityHash = sortable// => 1100100100sortable// => [50.625, 14.0625] var hexadecimalHash = // => c9212f45139c300 (limited precision beyond 53bits)
note: If you need precision when converting integers above 53 bits consider using bigint
API
sortable.encode(values[, options])
Hash the array values
, which may only contain Numbers in the range of
[-100, 100]
.
options
can either be an object with these possible keys:
precision
: Number of bits (read: length) of the resulting binary hash
or a Number, in which case it sets options.precision
.
sortable.decode(string, options)
Decode string
into an Array of Numbers.
options
can either be an object with these possible keys:
num
: number of elements initially passed tohash.encode
. (required)
Or a Number, in which case it sets options.num
Installation
With npm do:
$ npm install binary-sortable-hash
Kudos
This is the idea of geohashes generalized for use with all numeric data and numbers of input fields.
binary-sortable-hash is a derivative of the awesome sortable-hash by @juliangrubber