2020-09-04 04:32:13 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#if SIMDJSON_EXCEPTIONS
|
|
|
|
|
2021-01-06 02:42:17 +08:00
|
|
|
#include "json_benchmark/string_runner.h"
|
2021-01-05 04:21:50 +08:00
|
|
|
#include <vector>
|
|
|
|
#include <random>
|
2020-09-04 04:32:13 +08:00
|
|
|
|
|
|
|
namespace kostya {
|
2021-01-05 04:21:50 +08:00
|
|
|
|
|
|
|
static const simdjson::padded_string &get_built_json_array();
|
|
|
|
|
|
|
|
struct point {
|
|
|
|
double x;
|
|
|
|
double y;
|
|
|
|
double z;
|
|
|
|
simdjson_really_inline bool operator==(const point &other) const {
|
|
|
|
return x == other.x && y == other.y && z == other.z;
|
|
|
|
}
|
|
|
|
simdjson_really_inline bool operator!=(const point &other) const {
|
|
|
|
return !(*this == other);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
simdjson_unused static std::ostream &operator<<(std::ostream &o, const point &p) {
|
|
|
|
return o << p.x << "," << p.y << "," << p.z << std::endl;
|
2020-09-04 04:32:13 +08:00
|
|
|
}
|
|
|
|
|
2021-01-05 04:21:50 +08:00
|
|
|
template<typename I>
|
2021-01-06 02:42:17 +08:00
|
|
|
struct runner : public json_benchmark::string_runner<I> {
|
2021-01-05 04:21:50 +08:00
|
|
|
std::vector<point> points;
|
|
|
|
|
2021-01-06 02:42:17 +08:00
|
|
|
runner() : json_benchmark::string_runner<I>(get_built_json_array()) {}
|
2021-01-05 04:21:50 +08:00
|
|
|
|
|
|
|
bool before_run(benchmark::State &state) {
|
2021-01-06 02:42:17 +08:00
|
|
|
if (!json_benchmark::string_runner<I>::before_run(state)) { return false; }
|
2021-01-05 04:21:50 +08:00
|
|
|
points.clear();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool run(benchmark::State &) {
|
|
|
|
return this->implementation.run(this->json, points);
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename R>
|
|
|
|
bool diff(benchmark::State &state, runner<R> &reference) {
|
|
|
|
return diff_results(state, points, reference.points);
|
|
|
|
}
|
2021-01-05 07:22:35 +08:00
|
|
|
|
|
|
|
size_t items_per_iteration() {
|
|
|
|
return points.size();
|
|
|
|
}
|
2021-01-05 04:21:50 +08:00
|
|
|
};
|
2020-09-04 04:32:13 +08:00
|
|
|
|
|
|
|
static void append_coordinate(std::default_random_engine &e, std::uniform_real_distribution<> &dis, std::stringstream &myss) {
|
|
|
|
using std::endl;
|
|
|
|
myss << R"( {)" << endl;
|
|
|
|
myss << R"( "x": )" << dis(e) << "," << endl;
|
|
|
|
myss << R"( "y": )" << dis(e) << "," << endl;
|
|
|
|
myss << R"( "z": )" << dis(e) << "," << endl;
|
|
|
|
myss << R"( "name": ")" << char('a'+dis(e)*25) << char('a'+dis(e)*25) << char('a'+dis(e)*25) << char('a'+dis(e)*25) << char('a'+dis(e)*25) << char('a'+dis(e)*25) << " " << int(dis(e)*10000) << "\"," << endl;
|
|
|
|
myss << R"( "opts": {)" << endl;
|
|
|
|
myss << R"( "1": [)" << endl;
|
|
|
|
myss << R"( 1,)" << endl;
|
|
|
|
myss << R"( true)" << endl;
|
|
|
|
myss << R"( ])" << endl;
|
|
|
|
myss << R"( })" << endl;
|
|
|
|
myss << R"( })";
|
|
|
|
}
|
|
|
|
|
|
|
|
static std::string build_json_array(size_t N) {
|
|
|
|
using namespace std;
|
|
|
|
default_random_engine e;
|
|
|
|
uniform_real_distribution<> dis(0, 1);
|
|
|
|
stringstream myss;
|
|
|
|
myss << R"({)" << endl;
|
|
|
|
myss << R"( "coordinates": [)" << endl;
|
|
|
|
for (size_t i=1; i<N; i++) {
|
|
|
|
append_coordinate(e, dis, myss); myss << "," << endl;
|
|
|
|
}
|
|
|
|
append_coordinate(e, dis, myss); myss << endl;
|
|
|
|
myss << R"( ],)" << endl;
|
|
|
|
myss << R"( "info": "some info")" << endl;
|
|
|
|
myss << R"(})" << endl;
|
|
|
|
string answer = myss.str();
|
2020-11-04 04:48:09 +08:00
|
|
|
cout << "Creating a source file spanning " << (answer.size() + 512) / 1024 << " KB " << endl;
|
2020-09-04 04:32:13 +08:00
|
|
|
return answer;
|
|
|
|
}
|
|
|
|
|
2021-01-05 04:21:50 +08:00
|
|
|
static const simdjson::padded_string &get_built_json_array() {
|
|
|
|
static simdjson::padded_string json = build_json_array(524288);
|
2020-09-04 04:32:13 +08:00
|
|
|
return json;
|
|
|
|
}
|
|
|
|
|
2021-01-05 04:21:50 +08:00
|
|
|
struct simdjson_dom;
|
2020-09-04 04:32:13 +08:00
|
|
|
|
2021-01-05 04:21:50 +08:00
|
|
|
template<typename I> simdjson_really_inline static void kostya(benchmark::State &state) {
|
|
|
|
json_benchmark::run_json_benchmark<runner<I>, runner<simdjson_dom>>(state);
|
2020-09-04 04:32:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace kostya
|
|
|
|
|
|
|
|
#endif // SIMDJSON_EXCEPTIONS
|