8 #include <botan/workfactor.h>
21 size_t nfs_workfactor(
size_t bits,
double k)
24 const double log2_e = std::log2(std::exp(1));
25 const double log_p = bits / log2_e;
27 const double log_log_p = std::log(log_p);
30 const double est = 1.92 * std::pow(log_p * log_log_p * log_log_p, 1.0/3.0);
33 return static_cast<size_t>(std::log2(k) + log2_e * est);
42 return nfs_workfactor(bits, .02);
59 const size_t MIN_WORKFACTOR = 64;
61 return 2 * std::max<size_t>(MIN_WORKFACTOR, nfs_workfactor(bits, 1));
size_t if_work_factor(size_t bits)
size_t ecp_work_factor(size_t bits)
size_t dl_exponent_size(size_t bits)
size_t dl_work_factor(size_t bits)