Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dosyago/floppsy
:baby_chick: floppsy - SMHasher-passing 200Mb/s hash using floating-point ops
https://github.com/dosyago/floppsy
continued-fractions cryptography cryptohash egyptian-fractions floating-point hashing hashing-algorithm slow smhasher tiny
Last synced: about 2 months ago
JSON representation
:baby_chick: floppsy - SMHasher-passing 200Mb/s hash using floating-point ops
- Host: GitHub
- URL: https://github.com/dosyago/floppsy
- Owner: dosyago
- License: mit
- Created: 2017-06-08T09:59:41.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-07-08T14:48:38.000Z (over 1 year ago)
- Last Synced: 2024-11-10T12:48:37.550Z (about 2 months ago)
- Topics: continued-fractions, cryptography, cryptohash, egyptian-fractions, floating-point, hashing, hashing-algorithm, slow, smhasher, tiny
- Language: JavaScript
- Homepage: https://88e9g.csb.app/
- Size: 743 KB
- Stars: 12
- Watchers: 5
- Forks: 3
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# :baby_chick: [floppsy](https://github.com/dosyago/floppsy)
#### **[200MB/s SMHasher](https://github.com/rurban/smhasher/blob/master/doc/floppsyhash.txt)** [![version](https://img.shields.io/npm/v/floppsy.svg?label=&color=0080FF)](https://github.com/dosyago/floppsy/releases/latest) ![npm downloads](https://img.shields.io/npm/dt/floppsy)
A tiny, simple and SMHasher-passing slow (200Mb/s) hash designed for floating point hardware. It's also non-deterministic (different values depend on architecture, due to quirks and differences in floating point implementations).
[Link to the SUPERCOP ECRYPT benchmark for floppsy](https://bench.cr.yp.to/impl-hash/floppsy.html)
## demo
[play with a demo online here](https://88e9g.csb.app/)
## construction
constructed using floating point multiplication, division and addition.
based on continued and egyptian fractions.
*no bit operations used in the making of this hash.*
## accolades
passes [smhasher](https://github.com/rurban/smhasher)
[see the results for all tests](https://github.com/crislin2046/floppsy/blob/master/smhasher.results.txt)
also see [an independent confirmation of these results](https://github.com/rurban/smhasher/blob/master/doc/floppsyhash.txt)
## c source
```c++
FORCE_INLINE void q ( double * state, double key_val,
double numerator, double denominator )
{
state[0] += numerator / denominator;
state[0] = 1.0 / state[0];state[1] += key_val + M_PI;
state[1] = numerator / state[1];
}//---------
// round function : process the messageFORCE_INLINE void round ( const uint8_t * msg, long len,
double * state )
{
double numerator = 1.0;// Loop
for( long i = 0; i < len; i++ ) {
double val = (double)msg[i];
double denominator = (M_E * val + i + 1) / state[1];q( state, val, numerator, denominator );
numerator = denominator + 1;
}
}//---------
// setup function : setup the stateFORCE_INLINE void setup ( double * state, double init = 0 )
{
state[0] += init != 0 ? pow(init + 1.0/init, 1.0/3) : 3.0;
state[1] += init != 0 ? pow(init + 1.0/init, 1.0/7) : 1.0/7;
}//---------
// floppsyhash
// with 64 bit continued egyptian fractionsvoid floppsyhash_64 ( const void * key, int len,
uint32_t seed, void * out )
{
const uint8_t * data = (const uint8_t *)key;
uint8_t buf [16];
double * state = (double*)buf;
uint32_t * state32 = (uint32_t*)buf;
double seed32 = (double)seed;uint8_t * seedbuf;
seedbuf = (uint8_t *)&seed;setup( state, seed32 );
round( seedbuf, 4, state );
round( data, len, state );uint8_t output [8];
uint32_t * h = (uint32_t*)output;
h[0] = state32[0] + state32[3];
h[1] = state32[1] + state32[2];((uint32_t*)out)[0] = h[0];
((uint32_t*)out)[1] = h[1];
}
```
## disclaimerno claims are made regarding the security of this system.
## get
```console
npm i --save floppsy
```## use-cases
- A slow hash for password hashing.
- Hashing arrays of numbers (vectors, floating point).
- As a basis for a cryptographic primitive (such as a PRNG, or symmetric cipher).## include
As a Node ES module:
```javascript
import floppsy from 'floppsy';
```As old style modules:
```javascript
const floppsy = require('floppsy').default;
```Using [Snowpack](https://github.com/pikapkg/snowpack) in a web app:
```javascript
import floppsy from './web_modules/floppsy.js';
```## api
Can produce digests of 32, 64 or 128 bits.
```console
> f.hash('')
'7f5f8491f0b745bf'
> f.hash('', {bits:32})
'7016ca50'
> f.hash('', {bits:128})
'3f7f508e3fe034033ff0e269b0c66356'
```*Can also change output format:*
```javascript
x.hash('',{out_format:'hex'}); // default
x.hash('',{out_format:'binary'}); // binary string
x.hash('',{out_format:'bytes'}); // Uint8Array
x.hash('',{out_format:'uint32s'}); // Uint32Array
```---------------
[play with a demo online here](https://codesandbox.io/s/blue-cache-88e9g?fontsize=14&hidenavigation=1&theme=dark)