#include <iostream>
#include <iomanip>
#include <random>
#include <map>
int main() {
unsigned s = std::random_device()();
std::mt19937 g(s);
std::cerr << "Seed set to " << s << "\n"
<< "columns are l n prob(n/2^l)\n\n";
const unsigned b = 2;
long long num = 5000000LL;
unsigned maxl = 8, maxn = 3;
std::map<std::pair<long long, long long>, long long> hist;
for (long long i = 0; i < num; ++i) {
if (!(x.ndigits() <= maxl && x.integer() < maxn))
continue;
if (x.sign() < 1) x.negate();
++hist[x.rational()];
}
std::cout << std::setprecision(10);
for (long l = 0, d = 1; l <= long(maxl); ++l, d *= 2)
for (long n = 0; n < long(maxn)*d; ++n)
std::cout << l << " " << n << " "
<< hist[std::pair<long long,long long>(n,d)]/double(num)
<< "\n";
}