#ifndef _SAMPLER_H_ #define _SAMPLER_H_ #include <memory> using namespace std; namespace extractor { class PhraseLocation; class SuffixArray; /** * Provides uniform sampling for a PhraseLocation. */ class Sampler { public: Sampler(shared_ptr<SuffixArray> suffix_array, int max_samples); virtual ~Sampler(); // Samples uniformly at most max_samples phrase occurrences. virtual PhraseLocation Sample(const PhraseLocation& location) const; protected: Sampler(); private: // Round floating point number to the nearest integer. int Round(double x) const; shared_ptr<SuffixArray> suffix_array; int max_samples; }; } // namespace extractor #endif