2021-09-14 00:08:28 +08:00
|
|
|
mod datasets_paths;
|
|
|
|
mod utils;
|
|
|
|
|
|
|
|
use criterion::{criterion_group, criterion_main};
|
2021-09-22 18:10:21 +08:00
|
|
|
use milli::update::Settings;
|
2021-09-14 00:08:28 +08:00
|
|
|
use utils::Conf;
|
|
|
|
|
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
#[global_allocator]
|
|
|
|
static ALLOC: jemallocator::Jemalloc = jemallocator::Jemalloc;
|
|
|
|
|
|
|
|
fn base_conf(builder: &mut Settings) {
|
|
|
|
let displayed_fields =
|
|
|
|
["geonameid", "name", "asciiname", "alternatenames", "_geo", "population"]
|
|
|
|
.iter()
|
|
|
|
.map(|s| s.to_string())
|
|
|
|
.collect();
|
|
|
|
builder.set_displayed_fields(displayed_fields);
|
|
|
|
|
|
|
|
let searchable_fields =
|
|
|
|
["name", "alternatenames", "elevation"].iter().map(|s| s.to_string()).collect();
|
|
|
|
builder.set_searchable_fields(searchable_fields);
|
|
|
|
|
|
|
|
let filterable_fields =
|
|
|
|
["_geo", "population", "elevation"].iter().map(|s| s.to_string()).collect();
|
|
|
|
builder.set_filterable_fields(filterable_fields);
|
|
|
|
|
|
|
|
let sortable_fields =
|
|
|
|
["_geo", "population", "elevation"].iter().map(|s| s.to_string()).collect();
|
|
|
|
builder.set_sortable_fields(sortable_fields);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[rustfmt::skip]
|
|
|
|
const BASE_CONF: Conf = Conf {
|
|
|
|
dataset: datasets_paths::SMOL_ALL_COUNTRIES,
|
2021-09-22 18:10:21 +08:00
|
|
|
dataset_format: "jsonl",
|
2021-09-14 00:08:28 +08:00
|
|
|
queries: &[
|
|
|
|
"",
|
|
|
|
],
|
|
|
|
configure: base_conf,
|
|
|
|
primary_key: Some("geonameid"),
|
|
|
|
..Conf::BASE
|
|
|
|
};
|
|
|
|
|
|
|
|
fn bench_geo(c: &mut criterion::Criterion) {
|
|
|
|
#[rustfmt::skip]
|
|
|
|
let confs = &[
|
|
|
|
// A basic placeholder with no geo
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "placeholder with no geo",
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
// Medium aglomeration: probably the most common usecase
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "asc sort from Lille",
|
|
|
|
sort: Some(vec!["_geoPoint(50.62999333378238, 3.086269263384099):asc"]),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "desc sort from Lille",
|
|
|
|
sort: Some(vec!["_geoPoint(50.62999333378238, 3.086269263384099):desc"]),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
// Big agglomeration: a lot of documents close to our point
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "asc sort from Tokyo",
|
|
|
|
sort: Some(vec!["_geoPoint(35.749512532692144, 139.61664952543356):asc"]),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "desc sort from Tokyo",
|
|
|
|
sort: Some(vec!["_geoPoint(35.749512532692144, 139.61664952543356):desc"]),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
// The furthest point from any civilization
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "asc sort from Point Nemo",
|
|
|
|
sort: Some(vec!["_geoPoint(-48.87561645055408, -123.39275749319793):asc"]),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "desc sort from Point Nemo",
|
|
|
|
sort: Some(vec!["_geoPoint(-48.87561645055408, -123.39275749319793):desc"]),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
// Filters
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "filter of 100km from Lille",
|
|
|
|
filter: Some("_geoRadius(50.62999333378238, 3.086269263384099, 100000)"),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "filter of 1km from Lille",
|
|
|
|
filter: Some("_geoRadius(50.62999333378238, 3.086269263384099, 1000)"),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "filter of 100km from Tokyo",
|
|
|
|
filter: Some("_geoRadius(35.749512532692144, 139.61664952543356, 100000)"),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "filter of 1km from Tokyo",
|
|
|
|
filter: Some("_geoRadius(35.749512532692144, 139.61664952543356, 1000)"),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "filter of 100km from Point Nemo",
|
|
|
|
filter: Some("_geoRadius(-48.87561645055408, -123.39275749319793, 100000)"),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
utils::Conf {
|
|
|
|
group_name: "filter of 1km from Point Nemo",
|
|
|
|
filter: Some("_geoRadius(-48.87561645055408, -123.39275749319793, 1000)"),
|
|
|
|
..BASE_CONF
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
utils::run_benches(c, confs);
|
|
|
|
}
|
|
|
|
|
|
|
|
criterion_group!(benches, bench_geo);
|
|
|
|
criterion_main!(benches);
|