Welcome to mirror list, hosted at ThFree Co, Russian Federation.

features_filter.hpp « v2 « search - github.com/mapsme/omim.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: f84ca3a7bff9deee0396dc6741f238c9e4c0d5a7 (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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#pragma once

#include "std/unique_ptr.hpp"

namespace coding
{
class CompressedBitVector;
}

namespace search
{
namespace v2
{
// A lightweight filter of features.
//
// NOTE: this class and its subclasses *ARE* thread-safe.
class FeaturesFilter
{
public:
  FeaturesFilter(coding::CompressedBitVector const & filter, uint32_t threshold);

  virtual ~FeaturesFilter() = default;

  bool NeedToFilter(coding::CompressedBitVector const & features) const;

  virtual unique_ptr<coding::CompressedBitVector> Filter(
      coding::CompressedBitVector const & cbv) const = 0;

protected:
  coding::CompressedBitVector const & m_filter;
  uint32_t const m_threshold;
};

// Exact filter - leaves only features belonging to the set it was
// constructed from.
class LocalityFilter : public FeaturesFilter
{
public:
  LocalityFilter(coding::CompressedBitVector const & filter);

  // FeaturesFilter overrides:
  unique_ptr<coding::CompressedBitVector> Filter(
      coding::CompressedBitVector const & cbv) const override;
};

// Fuzzy filter - tries to leave only features belonging to the set it
// was constructed from, but if the result is empty, leaves at most
// first |threshold| features instead. This property is quite useful
// when there are no matching features in viewport but it's ok to
// process a limited number of features outside the viewport.
class ViewportFilter : public FeaturesFilter
{
public:
  ViewportFilter(coding::CompressedBitVector const & filter, uint32_t threshold);

  // FeaturesFilter overrides:
  unique_ptr<coding::CompressedBitVector> Filter(
      coding::CompressedBitVector const & cbv) const override;
};
}  // namespace v2
}  // namespace search