core: unify randomization
Non-security randomizations are changed to use boost::random,
with a global random number generator.
refs #1369
Change-Id: I5000fd02f170fa47058af790e2bea767f9c65650
diff --git a/daemon/table/cs.cpp b/daemon/table/cs.cpp
index ad666d5..f1bbb0f 100644
--- a/daemon/table/cs.cpp
+++ b/daemon/table/cs.cpp
@@ -27,11 +27,15 @@
#include "cs.hpp"
#include "core/logger.hpp"
+#include "core/random.hpp"
#include <ndn-cxx/util/crypto.hpp>
-#include "ndn-cxx/security/signature-sha256-with-rsa.hpp"
+#include <ndn-cxx/security/signature-sha256-with-rsa.hpp>
+#include <boost/random/bernoulli_distribution.hpp>
-#define SKIPLIST_MAX_LAYERS 32
-#define SKIPLIST_PROBABILITY 25 // 25% (p = 1/4)
+/// max skip list layers
+static const size_t SKIPLIST_MAX_LAYERS = 32;
+/// probability for an entry in layer N to appear also in layer N+1
+static const double SKIPLIST_PROBABILITY = 0.25;
NFD_LOG_INIT("ContentStore");
@@ -265,17 +269,15 @@
size_t
Cs::pickRandomLayer() const
{
- int layer = -1;
- int randomValue;
-
- do
- {
- layer++;
- randomValue = rand() % 100 + 1;
+ static boost::random::bernoulli_distribution<> dist(SKIPLIST_PROBABILITY);
+ // TODO rewrite using geometry_distribution
+ size_t layer;
+ for (layer = 0; layer < SKIPLIST_MAX_LAYERS; ++layer) {
+ if (!dist(getGlobalRng())) {
+ break;
}
- while ((randomValue < SKIPLIST_PROBABILITY) && (layer < SKIPLIST_MAX_LAYERS));
-
- return static_cast<size_t>(layer);
+ }
+ return layer;
}
bool