XOR code engine in pure Go
more than 50GB/S per core
Move to: https://github.com/templexxx/xorsimd
- Use SIMD (SSE2 or AVX2) for speeding up
- ...
To get the package use the standard:
go get github.com/templexxx/xor
See the associated GoDoc
Performance depends mainly on:
- SIMD extension
- unit size of worker
- hardware ( CPU RAM etc)
Example of performance on my MacBook 2014-mid(i5-4278U 2.6GHz 2 physical cores). The 16MB per shards.
speed = ( shards * size ) / cost
data_shards | shard_size | speed (MB/S) |
---|---|---|
2 | 1KB | 64127.95 |
2 | 1400B | 59657.55 |
2 | 16KB | 35370.84 |
2 | 16MB | 12128.95 |
5 | 1KB | 78837.33 |
5 | 1400B | 58054.89 |
5 | 16KB | 50161.19 |
5 | 16MB | 12750.41 |
- https://github.com/xtaci/kcp-go -- A Production-Grade Reliable-UDP Library for golang