2021-01-02 14:41:15 +08:00
|
|
|
#pragma once
|
|
|
|
|
2021-01-05 04:21:50 +08:00
|
|
|
#ifdef SIMDJSON_COMPETITION_YYJSON
|
|
|
|
|
2021-01-02 14:41:15 +08:00
|
|
|
#include "kostya.h"
|
|
|
|
|
|
|
|
namespace kostya {
|
|
|
|
|
2021-01-06 03:41:07 +08:00
|
|
|
struct yyjson_base {
|
2021-01-07 11:58:38 +08:00
|
|
|
static constexpr diff_flags DiffFlags = diff_flags::NONE;
|
|
|
|
|
2021-01-02 14:41:15 +08:00
|
|
|
simdjson_really_inline double get_double(yyjson_val *obj, std::string_view key) {
|
|
|
|
yyjson_val *val = yyjson_obj_getn(obj, key.data(), key.length());
|
2021-01-05 07:32:03 +08:00
|
|
|
if (!val) { throw "missing point field!"; }
|
2021-01-05 05:05:08 +08:00
|
|
|
if (yyjson_get_type(val) != YYJSON_TYPE_NUM) { throw "Number is not a type!"; }
|
2021-01-05 04:37:25 +08:00
|
|
|
|
|
|
|
switch (yyjson_get_subtype(val)) {
|
|
|
|
case YYJSON_SUBTYPE_UINT:
|
2021-02-27 05:17:05 +08:00
|
|
|
return double(yyjson_get_uint(val));
|
2021-01-05 04:37:25 +08:00
|
|
|
case YYJSON_SUBTYPE_SINT:
|
2021-02-27 05:17:05 +08:00
|
|
|
return double(yyjson_get_sint(val));
|
2021-01-05 04:37:25 +08:00
|
|
|
case YYJSON_SUBTYPE_REAL:
|
|
|
|
return yyjson_get_real(val);
|
|
|
|
default:
|
2021-01-05 05:05:08 +08:00
|
|
|
SIMDJSON_UNREACHABLE();
|
2021-01-05 04:37:25 +08:00
|
|
|
}
|
2021-02-27 05:17:05 +08:00
|
|
|
SIMDJSON_UNREACHABLE();
|
|
|
|
return 0.0; // unreachable
|
2021-01-02 14:41:15 +08:00
|
|
|
}
|
|
|
|
|
2021-01-06 03:41:07 +08:00
|
|
|
bool run(yyjson_doc *doc, std::vector<point> &result) {
|
2021-01-02 14:41:15 +08:00
|
|
|
if (!doc) { return false; }
|
|
|
|
yyjson_val *root = yyjson_doc_get_root(doc);
|
2021-01-05 05:05:08 +08:00
|
|
|
if (!yyjson_is_obj(root)) { return false; }
|
2021-01-02 14:41:15 +08:00
|
|
|
yyjson_val *coords = yyjson_obj_get(root, "coordinates");
|
2021-01-05 07:32:03 +08:00
|
|
|
if (!yyjson_is_arr(coords)) { return false; }
|
2021-01-02 14:41:15 +08:00
|
|
|
|
|
|
|
size_t idx, max;
|
|
|
|
yyjson_val *coord;
|
|
|
|
yyjson_arr_foreach(coords, idx, max, coord) {
|
2021-01-05 05:05:08 +08:00
|
|
|
if (!yyjson_is_obj(coord)) { return false; }
|
2021-01-07 11:58:38 +08:00
|
|
|
result.emplace_back(json_benchmark::point{get_double(coord, "x"), get_double(coord, "y"), get_double(coord, "z")});
|
2021-01-02 14:41:15 +08:00
|
|
|
}
|
2021-01-05 04:21:50 +08:00
|
|
|
|
2021-01-02 14:41:15 +08:00
|
|
|
return true;
|
|
|
|
}
|
2021-01-05 04:21:50 +08:00
|
|
|
|
2021-01-02 14:41:15 +08:00
|
|
|
};
|
|
|
|
|
2021-01-06 03:41:07 +08:00
|
|
|
struct yyjson : yyjson_base {
|
|
|
|
bool run(simdjson::padded_string &json, std::vector<point> &result) {
|
|
|
|
return yyjson_base::run(yyjson_read(json.data(), json.size(), 0), result);
|
|
|
|
}
|
|
|
|
};
|
2021-01-06 02:45:49 +08:00
|
|
|
BENCHMARK_TEMPLATE(kostya, yyjson)->UseManualTime();
|
2021-01-02 14:41:15 +08:00
|
|
|
|
2021-01-06 03:41:07 +08:00
|
|
|
struct yyjson_insitu : yyjson_base {
|
|
|
|
bool run(simdjson::padded_string &json, std::vector<point> &result) {
|
|
|
|
return yyjson_base::run(yyjson_read_opts(json.data(), json.size(), YYJSON_READ_INSITU, 0, 0), result);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
BENCHMARK_TEMPLATE(kostya, yyjson_insitu)->UseManualTime();
|
|
|
|
|
2021-01-02 14:41:15 +08:00
|
|
|
} // namespace kostya
|
2021-01-05 04:21:50 +08:00
|
|
|
|
|
|
|
#endif // SIMDJSON_COMPETITION_YYJSON
|