Skip to content

Commit

Permalink
feat: implement Sliding Window Bloom Filter (#715)
Browse files Browse the repository at this point in the history
This feature enhances the existing Bloom Filter capabilities
by allowing time-based item tracking, making it suitable for
use cases requiring temporary membership checks.

Signed-off-by: Ernesto Alejandro Santana Hidalgo <[email protected]>
  • Loading branch information
nesty92 authored Jan 11, 2025
1 parent 992fc76 commit 09ad427
Show file tree
Hide file tree
Showing 4 changed files with 1,182 additions and 0 deletions.
59 changes: 59 additions & 0 deletions rueidisprob/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -134,3 +134,62 @@ func main() {
fmt.Println(count) // 1
}
```

### Sliding Window Bloom Filter

It is a variation of the standard Bloom filter that adds a sliding window mechanism.
Useful for use cases where you need to keep track of items for a certain amount of time.

Example:

```go
package main

import (
"context"
"fmt"
"time"

"github.com/redis/rueidis"
"github.com/redis/rueidis/rueidisprob"
)

func main() {
client, err := rueidis.NewClient(rueidis.ClientOption{
InitAddress: []string{"localhost:6379"},
})
if err != nil {
panic(err)
}

sbf, err := NewSlidingBloomFilter(client, "sliding_bloom_filter", 1000, 0.01, time.Minute)

err = sbf.Add(context.Background(), "hello")
if err != nil {
panic(err)
}

err = sbf.Add(context.Background(), "world")
if err != nil {
panic(err)
}

exists, err := sbf.Exists(context.Background(), "hello")
if err != nil {
panic(err)
}
fmt.Println(exists) // true

exists, err = sbf.Exists(context.Background(), "world")
if err != nil {
panic(err)
}
fmt.Println(exists) // true

count, err := sbf.Count(context.Background())
if err != nil {
panic(err)
}
fmt.Println(count) // 2
}
```
Loading

0 comments on commit 09ad427

Please sign in to comment.