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

locality_scorer.hpp « search - github.com/mapsme/omim.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: d0b51eaf68a037edad92cca743deb9c753d0c557 (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
#pragma once

#include "search/geocoder.hpp"
#include "search/ranking_utils.hpp"

#include "std/string.hpp"
#include "std/vector.hpp"

namespace search
{
struct QueryParams;

class LocalityScorer
{
public:
  static size_t const kDefaultReadLimit;

  class Delegate
  {
  public:
    virtual ~Delegate() = default;

    virtual void GetNames(uint32_t featureId, vector<string> & names) const = 0;
    virtual uint8_t GetRank(uint32_t featureId) const = 0;
  };

  LocalityScorer(QueryParams const & params, Delegate const & delegate);

  // Leaves at most |limit| elements of |localities|, ordered by some
  // combination of ranks and number of matched tokens.
  void GetTopLocalities(size_t limit, vector<Geocoder::Locality> & localities) const;

private:
  struct ExLocality
  {
    ExLocality();
    explicit ExLocality(Geocoder::Locality const & locality);

    inline uint32_t GetId() const { return m_locality.m_featureId; }

    Geocoder::Locality m_locality;
    size_t m_numTokens;
    uint8_t m_rank;
    NameScore m_nameScore;
  };

  void RemoveDuplicates(vector<ExLocality> & ls) const;
  void LeaveTopByRankAndProb(size_t limit, vector<ExLocality> & ls) const;
  void SortByNameAndProb(vector<ExLocality> & ls) const;

  QueryParams const & m_params;
  Delegate const & m_delegate;
};

}  // namespace search