diff options
author | Henning Baldersheim <balder@yahoo-inc.com> | 2020-02-26 05:52:53 +0000 |
---|---|---|
committer | Henning Baldersheim <balder@yahoo-inc.com> | 2020-02-27 21:48:14 +0000 |
commit | e114a0390b0aeb493a922ed3f90d0b90c7ad3c7f (patch) | |
tree | 6b0c7dd132c347fe16cba0f5a7e299d8dcfba1ff /searchlib/src/tests/common | |
parent | d7fb5fac283eef2c09eeaabd94288fa123e9f94c (diff) |
Add single threaded thoughput optimized executor with high and low watermark at 25% / 75%.
Diffstat (limited to 'searchlib/src/tests/common')
-rw-r--r-- | searchlib/src/tests/common/sequencedtaskexecutor/sequencedtaskexecutor_benchmark.cpp | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/searchlib/src/tests/common/sequencedtaskexecutor/sequencedtaskexecutor_benchmark.cpp b/searchlib/src/tests/common/sequencedtaskexecutor/sequencedtaskexecutor_benchmark.cpp index b2b15ded274..2708399f653 100644 --- a/searchlib/src/tests/common/sequencedtaskexecutor/sequencedtaskexecutor_benchmark.cpp +++ b/searchlib/src/tests/common/sequencedtaskexecutor/sequencedtaskexecutor_benchmark.cpp @@ -10,13 +10,19 @@ using ExecutorId = search::ISequencedTaskExecutor::ExecutorId; int main(int argc, char *argv[]) { unsigned long numTasks = 1000000; unsigned numThreads = 4; + unsigned taskLimit = 1000; + SequencedTaskExecutor::Optimize optimize = SequencedTaskExecutor::Optimize::LATENCY; std::atomic<long> counter(0); if (argc > 1) numTasks = atol(argv[1]); if (argc > 2) numThreads = atoi(argv[2]); + if (argc > 3) + taskLimit = atoi(argv[3]); + if (argc > 4) + optimize = SequencedTaskExecutor::Optimize::THROUGHPUT; - auto executor = SequencedTaskExecutor::create(numThreads); + auto executor = SequencedTaskExecutor::create(numThreads, taskLimit, optimize); for (unsigned long tid(0); tid < numTasks; tid++) { executor->executeTask(ExecutorId(tid%numThreads), vespalib::makeLambdaTask([&counter] { counter++; })); } |