Я хочу реализовать взвешенное случайное распределение в упругом поиске. В моем указателе каждый документ имеет вес от 1 до N. Таким образом, элемент с весом 1 должен появляться в результате в 2 раза меньше, чем документ с весом 2.
Например, у меня есть 3 документа (один с весом 2, два с весом 1):
[
{
"_index": "we_recommend_on_main",
"_type": "we_recommend_on_main",
"_id": "5-0",
"_score": 1.1245852,
"_source": {
"id_map_placement": 6151,
"image": "/upload/banner1",
"weight": 2
}
},
{
"_index": "we_recommend_on_main",
"_type": "we_recommend_on_main",
"_id": "8-0",
"_score": 0.14477867,
"_source": {
"id_map_placement": 6151,
"image": "/upload/banner1",
"weight": 1
}
},
{
"_index": "we_recommend_on_main",
"_type": "we_recommend_on_main",
"_id": "8-1",
"_score": 0.0837487,
"_source": {
"id_map_placement": 6151,
"image": "/upload/banner2",
"weight": 1
}
}
]
Я нашел решение с помощью поиска так:
{
"size": 1,
"query": {
"function_score": {
"functions": [
{
"random_score": {}
},
{
"field_value_factor": {
"field": "weight",
"modifier": "none",
"missing": 1
}
}
],
"score_mode": "multiply",
"boost_mode": "replace"
}
},
"sort": [
{
"_score": "desc"
}
]
}
После того, как я проверил этот запрос с 10000 раз, результат будет
{
"5-0": 6730,
"8-1": 1613,
"8-0": 1657
}
Но нет
{
"5-0": 5000,
"8-1": 2500,
"8-0": 2500
}
как я и предполагал. Что случилось?