blob: 5c244105af5bf0a1e795a2ee5fa6be9cd12a460e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
#ifndef _BACKOFF_SAMPLER_H_
#define _BACKOFF_SAMPLER_H_
#include <vector>
#include "sampler.h"
namespace extractor {
class DataArray;
class PhraseLocation;
class BackoffSampler : public Sampler {
public:
BackoffSampler(shared_ptr<DataArray> source_data_array, int max_samples);
BackoffSampler();
PhraseLocation Sample(
const PhraseLocation& location,
const unordered_set<int>& blacklisted_sentence_ids) const;
private:
virtual int GetNumSubpatterns(const PhraseLocation& location) const = 0;
virtual int GetRangeLow(const PhraseLocation& location) const = 0;
virtual int GetRangeHigh(const PhraseLocation& location) const = 0;
virtual int GetPosition(const PhraseLocation& location, int index) const = 0;
virtual void AppendMatching(vector<int>& samples, int index,
const PhraseLocation& location) const = 0;
shared_ptr<DataArray> source_data_array;
int max_samples;
};
} // namespace extractor
#endif
|