2024-09-19 14:19:46 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
cmake,
|
|
|
|
fetchFromGitHub,
|
|
|
|
gitUpdater,
|
|
|
|
primesieve,
|
|
|
|
stdenv,
|
2022-05-18 14:49:53 +00:00
|
|
|
}:
|
|
|
|
|
2024-04-21 15:54:59 +00:00
|
|
|
stdenv.mkDerivation (finalAttrs: {
|
2022-05-18 14:49:53 +00:00
|
|
|
pname = "primecount";
|
2024-09-19 14:19:46 +00:00
|
|
|
version = "7.14";
|
2022-05-18 14:49:53 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "kimwalisch";
|
|
|
|
repo = "primecount";
|
2024-04-21 15:54:59 +00:00
|
|
|
rev = "v${finalAttrs.version}";
|
2024-09-19 14:19:46 +00:00
|
|
|
hash = "sha256-N4eENwYuf8ZR1JQyFtoWl6H3ITpGZVaOMEU3gx0f9yQ=";
|
2022-05-18 14:49:53 +00:00
|
|
|
};
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
outputs = [
|
|
|
|
"out"
|
|
|
|
"dev"
|
|
|
|
"lib"
|
|
|
|
"man"
|
2022-12-17 10:02:37 +00:00
|
|
|
];
|
2022-05-18 14:49:53 +00:00
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
nativeBuildInputs = [ cmake ];
|
|
|
|
|
|
|
|
buildInputs = [ primesieve ];
|
2022-05-18 14:49:53 +00:00
|
|
|
|
2024-04-21 15:54:59 +00:00
|
|
|
strictDeps = true;
|
|
|
|
|
2022-05-18 14:49:53 +00:00
|
|
|
cmakeFlags = [
|
2024-04-21 15:54:59 +00:00
|
|
|
(lib.cmakeBool "BUILD_LIBPRIMESIEVE" true)
|
|
|
|
(lib.cmakeBool "BUILD_PRIMECOUNT" true)
|
|
|
|
(lib.cmakeBool "BUILD_SHARED_LIBS" (!stdenv.hostPlatform.isStatic))
|
|
|
|
(lib.cmakeBool "BUILD_STATIC_LIBS" stdenv.hostPlatform.isStatic)
|
|
|
|
(lib.cmakeBool "BUILD_TESTS" true)
|
2022-05-18 14:49:53 +00:00
|
|
|
];
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
passthru = {
|
|
|
|
tests = {
|
|
|
|
inherit primesieve; # dependency
|
|
|
|
};
|
|
|
|
updateScript = gitUpdater { rev-prefix = "v"; };
|
|
|
|
};
|
|
|
|
|
2024-04-21 15:54:59 +00:00
|
|
|
meta = {
|
2022-05-18 14:49:53 +00:00
|
|
|
homepage = "https://github.com/kimwalisch/primecount";
|
|
|
|
description = "Fast prime counting function implementations";
|
|
|
|
longDescription = ''
|
|
|
|
primecount is a command-line program and C/C++ library that counts the
|
|
|
|
primes below an integer x ≤ 10^31 using highly optimized implementations
|
|
|
|
of the combinatorial prime counting algorithms.
|
|
|
|
|
|
|
|
primecount includes implementations of all important combinatorial prime
|
|
|
|
counting algorithms known up to this date all of which have been
|
|
|
|
parallelized using OpenMP. primecount contains the first ever open source
|
|
|
|
implementations of the Deleglise-Rivat algorithm and Xavier Gourdon's
|
|
|
|
algorithm (that works). primecount also features a novel load balancer
|
|
|
|
that is shared amongst all implementations and that scales up to hundreds
|
|
|
|
of CPU cores. primecount has already been used to compute several prime
|
|
|
|
counting function world records.
|
|
|
|
'';
|
2024-04-21 15:54:59 +00:00
|
|
|
changelog = "https://github.com/kimwalisch/primecount/blob/${finalAttrs.src.rev}/ChangeLog";
|
|
|
|
license = lib.licenses.bsd2;
|
|
|
|
mainProgram = "primecount";
|
2022-05-18 14:49:53 +00:00
|
|
|
inherit (primesieve.meta) maintainers platforms;
|
|
|
|
};
|
2024-04-21 15:54:59 +00:00
|
|
|
})
|