From 3c46aa47ce891cc52e81c03dd88aaa64d276dace Mon Sep 17 00:00:00 2001 From: Daniel Lemire Date: Tue, 8 May 2018 12:37:21 -0400 Subject: [PATCH] Adding more benchmarks. --- scalarvssimd/benchmarks/bench.cpp | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/scalarvssimd/benchmarks/bench.cpp b/scalarvssimd/benchmarks/bench.cpp index 76c0cbb0..4ed06b43 100644 --- a/scalarvssimd/benchmarks/bench.cpp +++ b/scalarvssimd/benchmarks/bench.cpp @@ -15,9 +15,27 @@ using namespace rapidjson; using namespace std; +std::string rapidstringmeInsitu(char * json) { + Document d; + d.ParseInsitu(json); + if(d.HasParseError()) { + std::cerr << "problem!" << std::endl; + return "";// should do something + } + StringBuffer buffer; + Writer writer(buffer); + d.Accept(writer); + return buffer.GetString(); +} + + std::string rapidstringme(char * json) { Document d; d.Parse(json); + if(d.HasParseError()) { + std::cerr << "problem!" << std::endl; + return "";// should do something + } StringBuffer buffer; Writer writer(buffer); d.Accept(writer); @@ -92,5 +110,7 @@ int main(int argc, char *argv[]) { std::cout << "input length is "<< p.second << " stringified length is " << strlength << std::endl; BEST_TIME_NOCHECK(rapidstringme((char*) p.first), , repeat, volume, true); + BEST_TIME_NOCHECK(rapidstringmeInsitu((char*) buffer), memcpy(buffer, p.first, p.second) , repeat, volume, + true); free(buffer); }