summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew W Elble <aweits@rit.edu>2020-10-22 12:36:12 -0400
committerGitHub <noreply@github.com>2020-10-22 12:36:12 -0400
commitb77279e9cc51f47bfdbaa4aca73b967e82e84383 (patch)
treeabba839df58e9cb0e9c48ba75c4b0c8f06e7b1d5
parent745875b00848a6d8229461ab07316d7d8e901625 (diff)
downloadspack-b77279e9cc51f47bfdbaa4aca73b967e82e84383.tar.gz
spack-b77279e9cc51f47bfdbaa4aca73b967e82e84383.tar.bz2
spack-b77279e9cc51f47bfdbaa4aca73b967e82e84383.tar.xz
spack-b77279e9cc51f47bfdbaa4aca73b967e82e84383.zip
py-seriate (#19432)
-rw-r--r--var/spack/repos/builtin/packages/py-seriate/package.py26
1 files changed, 26 insertions, 0 deletions
diff --git a/var/spack/repos/builtin/packages/py-seriate/package.py b/var/spack/repos/builtin/packages/py-seriate/package.py
new file mode 100644
index 0000000000..c1c81e97af
--- /dev/null
+++ b/var/spack/repos/builtin/packages/py-seriate/package.py
@@ -0,0 +1,26 @@
+# Copyright 2013-2020 Lawrence Livermore National Security, LLC and other
+# Spack Project Developers. See the top-level COPYRIGHT file for details.
+#
+# SPDX-License-Identifier: (Apache-2.0 OR MIT)
+
+
+class PySeriate(PythonPackage):
+ """This is a Python implementation of Seriation
+ algorithm. Seriation is an approach for ordering elements in a set
+ so that the sum of the sequential pairwise distances is
+ minimal. We state this task as a Travelling Salesman Problem (TSP)
+ and leverage the powerful Google's or-tools to do
+ heavy-lifting. Since TSP is NP-hard, it is not possible to
+ calculate the precise solution for a big number of
+ elements. However, the or-tools' heuristics work very well in
+ practice, and they are used in e.g. Google Maps."""
+
+ homepage = "https://github.com/src-d/seriate"
+ url = "https://github.com/src-d/seriate/archive/1.1.2.tar.gz"
+
+ version('1.1.2', sha256='5e031e865398fbe24aebdbb4a2e0015447aec50478830850f29d38660fd266e3')
+
+ depends_on('py-setuptools', type='build')
+ depends_on('py-numpy@1.0:', type=('build', 'run'))
+ depends_on('py-packaging@16.0:', type=('build', 'run'))
+ depends_on('py-or-tools', type=('build', 'run'))