From 5d8dfe892a2ea89f706ee140c3bdcfd89fe03fda Mon Sep 17 00:00:00 2001 From: Mitja Felicijan Date: Wed, 21 Jan 2026 22:40:55 +0100 Subject: Add Redis source code for testing --- .../redis-unstable/utils/hyperloglog/hll-err.rb | 30 ++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 examples/redis-unstable/utils/hyperloglog/hll-err.rb (limited to 'examples/redis-unstable/utils/hyperloglog/hll-err.rb') diff --git a/examples/redis-unstable/utils/hyperloglog/hll-err.rb b/examples/redis-unstable/utils/hyperloglog/hll-err.rb new file mode 100644 index 0000000..1278397 --- /dev/null +++ b/examples/redis-unstable/utils/hyperloglog/hll-err.rb @@ -0,0 +1,30 @@ +# hll-err.rb - Copyright (C) 2014-Present Redis Ltd. +# +# Licensed under your choice of (a) the Redis Source Available License 2.0 +# (RSALv2); or (b) the Server Side Public License v1 (SSPLv1); or (c) the +# GNU Affero General Public License v3 (AGPLv3). +# +# Check error of HyperLogLog Redis implementation for different set sizes. + +require 'rubygems' +require 'redis' +require 'digest/sha1' + +r = Redis.new +r.del('hll') +i = 0 +while true do + 100.times { + elements = [] + 1000.times { + ele = Digest::SHA1.hexdigest(i.to_s) + elements << ele + i += 1 + } + r.pfadd('hll',elements) + } + approx = r.pfcount('hll') + abs_err = (approx-i).abs + rel_err = 100.to_f*abs_err/i + puts "#{i} vs #{approx}: #{rel_err}%" +end -- cgit v1.2.3