2022-05-18 14:49:53 +00:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
|
|
|
, fetchFromGitHub
|
|
|
|
, cmake
|
|
|
|
, primesieve
|
|
|
|
}:
|
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
|
|
|
pname = "primecount";
|
2024-01-13 08:15:51 +00:00
|
|
|
version = "7.10";
|
2022-05-18 14:49:53 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "kimwalisch";
|
|
|
|
repo = "primecount";
|
|
|
|
rev = "v${version}";
|
2024-01-13 08:15:51 +00:00
|
|
|
hash = "sha256-z7sHGR6zZSTV1PbL0WPGHf52CYQ572KC1yznCuIEJbQ=";
|
2022-05-18 14:49:53 +00:00
|
|
|
};
|
|
|
|
|
2022-12-17 10:02:37 +00:00
|
|
|
nativeBuildInputs = [
|
|
|
|
cmake
|
|
|
|
];
|
2022-05-18 14:49:53 +00:00
|
|
|
|
2022-12-17 10:02:37 +00:00
|
|
|
buildInputs = [
|
|
|
|
primesieve
|
|
|
|
];
|
2022-05-18 14:49:53 +00:00
|
|
|
|
|
|
|
cmakeFlags = [
|
|
|
|
"-DBUILD_LIBPRIMESIEVE=ON"
|
|
|
|
"-DBUILD_PRIMECOUNT=ON"
|
|
|
|
"-DBUILD_SHARED_LIBS=ON"
|
|
|
|
"-DBUILD_STATIC_LIBS=OFF"
|
|
|
|
"-DBUILD_TESTS=ON"
|
|
|
|
];
|
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
homepage = "https://github.com/kimwalisch/primecount";
|
2022-12-17 10:02:37 +00:00
|
|
|
changelog = "https://github.com/kimwalisch/primecount/blob/v${version}/ChangeLog";
|
2022-05-18 14:49:53 +00:00
|
|
|
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.
|
|
|
|
'';
|
|
|
|
license = licenses.bsd2;
|
|
|
|
inherit (primesieve.meta) maintainers platforms;
|
|
|
|
};
|
|
|
|
}
|