3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-15 05:18:44 +00:00
z3/src/util/prime_generator.h
Nikolaj Bjorner d0e20e44ff booyah
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
2020-07-04 15:56:30 -07:00

57 lines
1 KiB
C++

/*++
Copyright (c) 2011 Microsoft Corporation
Module Name:
prime_generator.h
Abstract:
Prime generator
Author:
Leonardo (leonardo) 2011-12-23
Notes:
--*/
#pragma once
#include "util/vector.h"
#include "util/z3_exception.h"
#include "util/util.h"
class prime_generator_exception : public default_exception {
public:
prime_generator_exception(char const * msg):default_exception(msg) {}
};
/**
\brief Prime generator
*/
class prime_generator {
svector<uint64_t> m_primes;
void process_next_k_numbers(uint64_t k);
public:
uint64_t operator()(unsigned idx);
void initialize();
void finalize();
};
class prime_iterator {
unsigned m_idx;
prime_generator * m_generator;
bool m_global;
public:
prime_iterator(prime_generator * g = nullptr);
uint64_t next();
static void initialize();
static void finalize();
/*
ADD_INITIALIZER('prime_iterator::initialize();')
ADD_FINALIZER('prime_iterator::finalize();')
*/
};