2021-01-05 07:22:35 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#ifdef SIMDJSON_COMPETITION_RAPIDJSON
|
|
|
|
|
|
|
|
#include "kostya.h"
|
|
|
|
|
|
|
|
namespace kostya {
|
|
|
|
|
|
|
|
using namespace rapidjson;
|
|
|
|
|
2021-01-05 12:20:24 +08:00
|
|
|
struct rapidjson_base {
|
2021-01-07 11:58:38 +08:00
|
|
|
static constexpr diff_flags DiffFlags = diff_flags::NONE;
|
|
|
|
|
2021-01-05 07:22:35 +08:00
|
|
|
Document doc;
|
|
|
|
|
|
|
|
simdjson_really_inline double get_double(Value &object, std::string_view key) {
|
|
|
|
auto field = object.FindMember(key.data());
|
|
|
|
if (field == object.MemberEnd()) { throw "Missing double field"; }
|
|
|
|
if (!field->value.IsNumber()) { throw "Field is not double"; }
|
|
|
|
return field->value.GetDouble();
|
|
|
|
}
|
|
|
|
|
2021-01-06 03:31:34 +08:00
|
|
|
bool run(Document &root, std::vector<point> &result) {
|
2021-01-05 07:22:35 +08:00
|
|
|
if (root.HasParseError()) { return false; }
|
|
|
|
if (!root.IsObject()) { return false; }
|
|
|
|
auto coords = root.FindMember("coordinates");
|
|
|
|
if (coords == root.MemberEnd()) { return false; }
|
|
|
|
if (!coords->value.IsArray()) { return false; }
|
|
|
|
for (auto &coord : coords->value.GetArray()) {
|
|
|
|
if (!coord.IsObject()) { 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-05 07:22:35 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-01-06 03:41:07 +08:00
|
|
|
struct rapidjson : rapidjson_base {
|
2021-01-06 03:31:34 +08:00
|
|
|
bool run(simdjson::padded_string &json, std::vector<point> &result) {
|
|
|
|
return rapidjson_base::run(doc.Parse<kParseValidateEncodingFlag>(json.data()), result);
|
2021-01-05 12:20:24 +08:00
|
|
|
}
|
|
|
|
};
|
2021-01-06 02:45:49 +08:00
|
|
|
BENCHMARK_TEMPLATE(kostya, rapidjson)->UseManualTime();
|
2021-01-05 12:20:24 +08:00
|
|
|
|
2021-01-06 03:41:07 +08:00
|
|
|
struct rapidjson_lossless : rapidjson_base {
|
2021-01-06 03:31:34 +08:00
|
|
|
bool run(simdjson::padded_string &json, std::vector<point> &result) {
|
|
|
|
return rapidjson_base::run(doc.Parse<kParseValidateEncodingFlag | kParseFullPrecisionFlag>(json.data()), result);
|
2021-01-05 12:20:24 +08:00
|
|
|
}
|
|
|
|
};
|
2021-01-06 02:45:49 +08:00
|
|
|
BENCHMARK_TEMPLATE(kostya, rapidjson_lossless)->UseManualTime();
|
2021-01-05 07:22:35 +08:00
|
|
|
|
2021-01-06 03:41:07 +08:00
|
|
|
struct rapidjson_insitu : rapidjson_base {
|
2021-01-06 03:31:34 +08:00
|
|
|
bool run(simdjson::padded_string &json, std::vector<point> &result) {
|
|
|
|
return rapidjson_base::run(doc.ParseInsitu<kParseValidateEncodingFlag>(json.data()), result);
|
2021-01-05 12:30:54 +08:00
|
|
|
}
|
|
|
|
};
|
2021-01-06 02:45:49 +08:00
|
|
|
BENCHMARK_TEMPLATE(kostya, rapidjson_insitu)->UseManualTime();
|
2021-01-05 12:30:54 +08:00
|
|
|
|
2021-01-05 07:22:35 +08:00
|
|
|
} // namespace kostya
|
|
|
|
|
|
|
|
#endif // SIMDJSON_COMPETITION_RAPIDJSON
|