about summary refs log tree commit diff
path: root/nixpkgs/pkgs/applications/science/math/primecount/default.nix
blob: c3e2565989edccc7bf9a66b7217b612b497ee4e7 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
{ lib
, stdenv
, fetchFromGitHub
, cmake
, primesieve
}:

stdenv.mkDerivation rec {
  pname = "primecount";
  version = "7.10";

  src = fetchFromGitHub {
    owner = "kimwalisch";
    repo = "primecount";
    rev = "v${version}";
    hash = "sha256-z7sHGR6zZSTV1PbL0WPGHf52CYQ572KC1yznCuIEJbQ=";
  };

  nativeBuildInputs = [
    cmake
  ];

  buildInputs = [
    primesieve
  ];

  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";
    changelog = "https://github.com/kimwalisch/primecount/blob/v${version}/ChangeLog";
    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;
  };
}