forked from organicmaps/organicmaps
[search] Fix LocalityScorer similarity calculation.
This commit is contained in:
parent
91fe72db9c
commit
29a981d124
2 changed files with 20 additions and 7 deletions
|
@ -3,6 +3,7 @@
|
|||
#include "search/cbv.hpp"
|
||||
#include "search/geocoder_context.hpp"
|
||||
#include "search/idf_map.hpp"
|
||||
#include "search/ranking_utils.hpp"
|
||||
#include "search/retrieval.hpp"
|
||||
#include "search/token_slice.hpp"
|
||||
#include "search/utils.hpp"
|
||||
|
@ -267,6 +268,7 @@ void LocalityScorer::GetDocVecs(uint32_t localityId, vector<DocVec> & dvs) const
|
|||
{
|
||||
vector<UniString> tokens;
|
||||
NormalizeAndTokenizeString(name, tokens);
|
||||
base::EraseIf(tokens, &IsStopWord);
|
||||
|
||||
DocVec::Builder builder;
|
||||
for (auto const & token : tokens)
|
||||
|
|
|
@ -2835,7 +2835,8 @@ UNIT_CLASS_TEST(ProcessorTest, LocalityScorer)
|
|||
TestCity sp2(m2::PointD(2.0, 2.0), "San Pedro", "en", 50 /* rank */);
|
||||
TestCity sp3(m2::PointD(3.0, 3.0), "San Pedro", "en", 50 /* rank */);
|
||||
TestCity sp4(m2::PointD(4.0, 4.0), "San Pedro", "en", 50 /* rank */);
|
||||
TestCity sp_good(m2::PointD(6.0, 6.0), "San Pedro de Atacama", "en", 100 /* rank */);
|
||||
TestCity spAtacama(m2::PointD(5.5, 5.5), "San Pedro de Atacama", "en", 100 /* rank */);
|
||||
TestCity spAlcantara(m2::PointD(6.5, 6.5), "San Pedro de Alcantara", "en", 40 /* rank */);
|
||||
|
||||
auto worldId = BuildWorld([&](TestMwmBuilder & builder) {
|
||||
builder.Add(sp0);
|
||||
|
@ -2843,21 +2844,31 @@ UNIT_CLASS_TEST(ProcessorTest, LocalityScorer)
|
|||
builder.Add(sp2);
|
||||
builder.Add(sp3);
|
||||
builder.Add(sp4);
|
||||
builder.Add(sp_good);
|
||||
builder.Add(spAtacama);
|
||||
builder.Add(spAlcantara);
|
||||
});
|
||||
|
||||
SetViewport(m2::RectD(m2::PointD(5.0, 5.0), m2::PointD(7.0, 7.0)));
|
||||
{
|
||||
// No results because GetToLocalities leaves sp0..sp4 even if |sp_good| has bigger rank and
|
||||
// is closer to viewort center.
|
||||
// sp0..sp4 are not in final results because there is no relaxed results for cities with multiple unmatched tokens.
|
||||
Rules rules = {};
|
||||
Rules rules = {ExactMatch(worldId, spAtacama)};
|
||||
TEST(ResultsMatch("San Pedro de Atacama ", rules), ());
|
||||
}
|
||||
{
|
||||
Rules rules = {ExactMatch(worldId, sp_good)};
|
||||
// No results because GetToLocalities leaves sp0..sp4 because sp0..sp4 and spAlcantara have
|
||||
// same similarity (1.0) and sp0..sp4 have higher rank.
|
||||
// sp0..sp4 are not in final results because there is no relaxed results for cities with multiple
|
||||
// unmatched tokens.
|
||||
Rules rules = {};
|
||||
TEST(ResultsMatch("San Pedro de Alcantara ", rules), ());
|
||||
}
|
||||
{
|
||||
Rules rules = {ExactMatch(worldId, spAtacama)};
|
||||
TEST(ResultsMatch("Atacama ", rules), ());
|
||||
}
|
||||
{
|
||||
Rules rules = {ExactMatch(worldId, spAlcantara)};
|
||||
TEST(ResultsMatch("Alcantara ", rules), ());
|
||||
}
|
||||
}
|
||||
} // namespace
|
||||
} // namespace search
|
||||
|
|
Loading…
Add table
Reference in a new issue