2014-01-10 16:21:35 +01:00
|
|
|
/*
|
2014-02-03 23:03:13 +01:00
|
|
|
* Copyright (C) 2013 Freie Universität Berlin
|
2014-01-10 16:21:35 +01:00
|
|
|
*
|
2014-07-31 19:45:27 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2014-01-10 16:21:35 +01:00
|
|
|
*/
|
|
|
|
|
2014-02-03 23:03:13 +01:00
|
|
|
/**
|
|
|
|
* @ingroup tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Bloom filter test application
|
|
|
|
*
|
|
|
|
* @author Christian Mehlis <mehlis@inf.fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2014-01-10 16:21:35 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "hashes.h"
|
|
|
|
#include "bloom.h"
|
|
|
|
|
|
|
|
#include "sets.h"
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
struct bloom_t *bloom = bloom_new(1 << 7, 6, fnv_hash, sax_hash, sdbm_hash,
|
2014-01-25 11:29:35 +01:00
|
|
|
djb2_hash, kr_hash, dek_hash, rotating_hash, one_at_a_time_hash);
|
2014-01-10 16:21:35 +01:00
|
|
|
|
|
|
|
printf("Testing Bloom filter.\n\n");
|
|
|
|
printf("m: %zd\nk: %zd\n\n", bloom->m, bloom->k);
|
|
|
|
|
|
|
|
for (int i = 0; i < lenB; i++) {
|
|
|
|
bloom_add(bloom, (const uint8_t *) B[i], strlen(B[i]));
|
|
|
|
printf("Added \"%s\"\n", B[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
int in = 0;
|
|
|
|
int not_in = 0;
|
|
|
|
|
|
|
|
for (int i = 0; i < lenA; i++) {
|
|
|
|
if (bloom_check(bloom, (const uint8_t *) A[i], strlen(A[i]))) {
|
|
|
|
in++;
|
2014-01-25 11:29:35 +01:00
|
|
|
}
|
|
|
|
else {
|
2014-01-10 16:21:35 +01:00
|
|
|
not_in++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("\n");
|
|
|
|
printf("%d elements probably in the filter.\n", in);
|
|
|
|
printf("%d elements not in the filter.\n", not_in);
|
|
|
|
double false_positive_rate = (double) in / (double) lenA;
|
|
|
|
printf("%f false positive rate.\n", false_positive_rate);
|
|
|
|
|
|
|
|
bloom_del(bloom);
|
|
|
|
printf("\nAll done!\n");
|
|
|
|
return 0;
|
|
|
|
}
|