40 argsman.
AddArg(
"-priority-level=<l1,l2,l3>",
strprintf(
"Run benchmarks of one or multiple priority level(s) (%s), default: '%s'",
46 std::stringstream ss(str);
47 std::vector<double> numbers;
68 std::vector<std::string>
args;
69 static std::vector<std::string> AVAILABLE_ARGS = {
"-testdatadir"};
70 for (
const std::string& arg_name : AVAILABLE_ARGS) {
71 auto op_arg = argsman.
GetArg(arg_name);
72 if (op_arg)
args.emplace_back(
strprintf(
"%s=%s", arg_name, *op_arg));
77int main(
int argc,
char** argv)
84 tfm::format(std::cerr,
"Error parsing command line arguments: %s\n", error);
89 std::cout <<
"Usage: bench_bitcoin [options]\n"
94 " bench_bitcoin executes microbenchmarks. The quality of the benchmark results\n"
95 " highly depend on the stability of the machine. It can sometimes be difficult\n"
96 " to get stable, repeatable results, so here are a few tips:\n"
98 " * Use pyperf [1] to disable frequency scaling, turbo boost etc. For best\n"
99 " results, use CPU pinning and CPU isolation (see [2]).\n"
101 " * Each call of run() should do exactly the same work. E.g. inserting into\n"
102 " a std::vector doesn't do that as it will reallocate on certain calls. Make\n"
103 " sure each run has exactly the same preconditions.\n"
105 " * If results are still not reliable, increase runtime with e.g.\n"
106 " -min-time=5000 to let a benchmark run for at least 5 seconds.\n"
108 " * bench_bitcoin uses nanobench [3] for which there is extensive\n"
109 " documentation available online.\n"
111 "Environment Variables:\n"
113 " To attach a profiler you can run a benchmark in endless mode. This can be\n"
114 " done with the environment variable NANOBENCH_ENDLESS. E.g. like so:\n"
116 " NANOBENCH_ENDLESS=MuHash ./bench_bitcoin -filter=MuHash\n"
118 " In rare cases it can be useful to suppress stability warnings. This can be\n"
119 " done with the environment variable NANOBENCH_SUPPRESS_WARNINGS, e.g:\n"
121 " NANOBENCH_SUPPRESS_WARNINGS=1 ./bench_bitcoin\n"
126 " https://github.com/psf/pyperf\n"
128 " 2. CPU pinning & isolation\n"
129 " https://pyperf.readthedocs.io/en/latest/system.html\n"
132 " https://github.com/martinus/nanobench\n"
153 }
catch (
const std::exception& e) {
bool HelpRequested(const ArgsManager &args)
void SetupHelpOptions(ArgsManager &args)
Add help options to the args manager.
static constexpr int64_t DEFAULT_MIN_TIME_MS
static const std::string DEFAULT_PRIORITY
Priority level default value, run "all" priority levels.
static std::vector< std::string > parseTestSetupArgs(const ArgsManager &argsman)
int main(int argc, char **argv)
static uint8_t parsePriorityLevel(const std::string &str)
static std::vector< double > parseAsymptote(const std::string &str)
static const char * DEFAULT_BENCH_FILTER
static void SetupBenchArgs(ArgsManager &argsman)
@ ALLOW_ANY
disable validation
@ DISALLOW_NEGATION
disallow -nofoo syntax
bool ParseParameters(int argc, const char *const argv[], std::string &error)
std::string GetHelpMessage() const
Get the help string.
int64_t GetIntArg(const std::string &strArg, int64_t nDefault) const
Return integer argument or default value.
std::string GetArg(const std::string &strArg, const std::string &strDefault) const
Return string argument or default value.
bool GetBoolArg(const std::string &strArg, bool fDefault) const
Return boolean argument or default value.
void AddArg(const std::string &name, const std::string &help, unsigned int flags, const OptionsCategory &cat)
Add argument.
fs::path GetPathArg(std::string arg, const fs::path &default_value={}) const
Return path argument or default value.
static void RunAll(const Args &args)
std::string ListPriorities()
uint8_t StringToPriority(const std::string &str)
std::vector< std::string > SplitString(std::string_view str, char sep)
void SetupCommonTestArgs(ArgsManager &argsman)
Register common test args.
std::string SHA256AutoDetect(sha256_implementation::UseImplementation use_implementation)
Autodetect the best available SHA256 implementation.