#include #include #include #include #include #include #include #include #include #include #include #include /** How to test: # Prepare data $ clickhouse-local --query="SELECT number FROM system.numbers LIMIT 10000000" > numbers1.tsv $ clickhouse-local --query="SELECT number % 10 FROM system.numbers LIMIT 10000000" > numbers2.tsv $ clickhouse-local --query="SELECT number / 1000 FROM system.numbers LIMIT 10000000" > numbers3.tsv $ clickhouse-local --query="SELECT rand64() / 1000 FROM system.numbers LIMIT 10000000" > numbers4.tsv $ clickhouse-local --query="SELECT rand64() / 0xFFFFFFFF FROM system.numbers LIMIT 10000000" > numbers5.tsv $ clickhouse-local --query="SELECT log(rand64()) FROM system.numbers LIMIT 10000000" > numbers6.tsv $ clickhouse-local --query="SELECT 1 / rand64() FROM system.numbers LIMIT 10000000" > numbers7.tsv $ clickhouse-local --query="SELECT exp(rand() / 0xFFFFFF) FROM system.numbers LIMIT 10000000" > numbers8.tsv $ clickhouse-local --query="SELECT number FROM system.numbers LIMIT 10000000" > numbers1.tsv $ clickhouse-local --query="SELECT toString(rand64(1)) || toString(rand64(2)) || toString(rand64(3)) || toString(rand64(4)) FROM system.numbers LIMIT 10000000" > numbers9.tsv $ clickhouse-local --query="SELECT toString(rand64(1)) || toString(rand64(2)) || '.' || toString(rand64(3)) || toString(rand64(4)) FROM system.numbers LIMIT 10000000" > numbers10.tsv # Run test $ for i in {1..10}; do echo $i; time ./read_float_perf 2 < numbers$i.tsv; done */ using namespace DB; template void NO_INLINE loop(ReadBuffer & in, WriteBuffer & out) { T sum = 0; T x = 0; Stopwatch watch; while (!in.eof()) { F(x, in); in.ignore(); sum += x; } watch.stop(); out << "Read in " << watch.elapsedSeconds() << " sec, " << formatReadableSizeWithBinarySuffix(in.count() / watch.elapsedSeconds()) << "/sec, result = " << sum << "\n"; } int main(int argc, char ** argv) try { int method = 0; if (argc >= 2) method = parse(argv[1]); using T = Float64; ReadBufferFromFileDescriptor in(STDIN_FILENO); WriteBufferFromFileDescriptor out(STDOUT_FILENO); if (method == 1) loop(in, out); if (method == 2) loop(in, out); if (method == 3) loop(in, out); return 0; } catch (const Exception & e) { std::cerr << e.what() << ", " << e.displayText() << std::endl; return 1; }