2015-12-08 04:51:55 +08:00
|
|
|
#pragma once
|
2015-06-23 21:17:10 +08:00
|
|
|
|
|
|
|
#include "utils/random/xorshift.hpp"
|
|
|
|
|
2015-08-30 07:12:46 +08:00
|
|
|
template <class randomizer_t>
|
2015-06-23 21:17:10 +08:00
|
|
|
size_t new_height(int max_height)
|
|
|
|
{
|
|
|
|
// get 64 random bits (coin tosses)
|
|
|
|
uint64_t rand = xorshift::next();
|
2015-06-28 17:43:52 +08:00
|
|
|
size_t height = 1;
|
2015-06-23 21:17:10 +08:00
|
|
|
|
|
|
|
// for every head (1) increase the tower height by one until the tail (0)
|
|
|
|
// comes. this gives the following probabilities for tower heights:
|
|
|
|
//
|
|
|
|
// 1/2 1/4 1/8 1/16 1/32 1/64 ...
|
|
|
|
// 1 2 3 4 5 6 ...
|
|
|
|
//
|
|
|
|
while(max_height-- && ((rand >>= 1) & 1))
|
|
|
|
height++;
|
|
|
|
|
|
|
|
return height;
|
|
|
|
}
|