summary refs log tree commit diff
diff options
context:
space:
mode:
authorChristopher Ostrouchov <chris.ostrouchov@gmail.com>2018-09-13 15:02:17 -0400
committerxeji <36407913+xeji@users.noreply.github.com>2018-09-13 21:02:17 +0200
commit3c2a74719a8877b9129568335c14c4bb8b0eba27 (patch)
tree9108150742291c371628d7d9b5ae9ba8f7977cf2
parentee21f64f6a6c555418905288a5ee2c072531d4f9 (diff)
downloadnixlib-3c2a74719a8877b9129568335c14c4bb8b0eba27.tar
nixlib-3c2a74719a8877b9129568335c14c4bb8b0eba27.tar.gz
nixlib-3c2a74719a8877b9129568335c14c4bb8b0eba27.tar.bz2
nixlib-3c2a74719a8877b9129568335c14c4bb8b0eba27.tar.lz
nixlib-3c2a74719a8877b9129568335c14c4bb8b0eba27.tar.xz
nixlib-3c2a74719a8877b9129568335c14c4bb8b0eba27.tar.zst
nixlib-3c2a74719a8877b9129568335c14c4bb8b0eba27.zip
parmetis: init at 4.0.3 (#46615)
-rw-r--r--pkgs/development/libraries/science/math/parmetis/default.nix33
-rw-r--r--pkgs/top-level/all-packages.nix4
2 files changed, 37 insertions, 0 deletions
diff --git a/pkgs/development/libraries/science/math/parmetis/default.nix b/pkgs/development/libraries/science/math/parmetis/default.nix
new file mode 100644
index 000000000000..6091031a115a
--- /dev/null
+++ b/pkgs/development/libraries/science/math/parmetis/default.nix
@@ -0,0 +1,33 @@
+{ stdenv
+, fetchurl
+, cmake
+, mpi
+}:
+
+stdenv.mkDerivation rec {
+  name = "parmetis-${version}";
+  version = "4.0.3";
+
+  src = fetchurl {
+    url = "http://glaros.dtc.umn.edu/gkhome/fetch/sw/parmetis/parmetis-${version}.tar.gz";
+    sha256 = "0pvfpvb36djvqlcc3lq7si0c5xpb2cqndjg8wvzg35ygnwqs5ngj";
+  };
+
+  buildInputs = [ cmake mpi ];
+
+  # metis and GKlib are packaged with distribution
+  # AUR https://aur.archlinux.org/packages/parmetis/ has reported that
+  # it easier to build with the included packages as opposed to using the metis
+  # package. Compilation time is short.
+  configurePhase = ''
+    make config metis_path=$PWD/metis gklib_path=$PWD/metis/GKlib prefix=$out
+  '';
+
+  meta = with stdenv.lib; {
+    description = "ParMETIS is an MPI-based parallel library that implements a variety of algorithms for partitioning unstructured graphs, meshes, and for computing fill-reducing orderings of sparse matrices";
+    homepage = http://glaros.dtc.umn.edu/gkhome/metis/parmetis/overview;
+    platforms = platforms.all;
+    license = licenses.cc-by-nc-sa-20;
+    maintainers = [ maintainers.costrouc ];
+  };
+}
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index b77806ddec69..e29c2db3577c 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -20839,6 +20839,10 @@ with pkgs;
 
   petsc = callPackage ../development/libraries/science/math/petsc { };
 
+  parmetis = callPackage ../development/libraries/science/math/parmetis {
+    mpi = openmpi;
+  };
+
   scs = callPackage ../development/libraries/science/math/scs {
     liblapack = liblapackWithoutAtlas;
   };