Implementation of the Seriation sequence ordering algorithm.
Project description
seriate
Optimal ordering of elements in a set given their distance matrix.
Overview • How To Use • Contributions • License
Overview
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.
Any numpy.roll
-ed
result is equivalent.
How To Use
import numpy
from scipy.spatial.distance import pdist
from seriate import seriate
elements = numpy.array([
[3, 3, 3],
[5, 5, 5],
[4, 4, 4],
[2, 2, 2],
[1, 1, 1]
])
print(seriate(pdist(elements)))
# Output: [4, 3, 0, 2, 1]
The example above shows how we order 5 elements: [3, 3, 3]
,
[5, 5, 5]
, [4, 4, 4]
, [2, 2, 2]
and [1, 1, 1]
. The result
is expected:
[1, 1, 1]
[2, 2, 2]
[3, 3, 3]
[4, 4, 4]
[5, 5, 5]
pdist
from scipy.spatial.distance
uses Euclidean (L2) dstance metric by default, so the distance between
[x, x, x]
and [x + 1, x + 1, x + 1]
is constant: √3. Any other distance
is bigger, so the optimal ordering is to list our elements in the increasing
norm order.
Contributions
Contributions are very welcome and desired! Please follow the code of conduct and read the contribution guidelines.
License
Apache-2.0, see LICENSE.md.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file seriate-1.1.2-py3-none-any.whl
.
File metadata
- Download URL: seriate-1.1.2-py3-none-any.whl
- Upload date:
- Size: 8.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.37.0 CPython/3.5.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f813ae54214dec4ab689cade548cdedeae28fce19fec598f5f3c3415787b4dc1 |
|
MD5 | 673d8e33e5f35c9880951e1048fa7a86 |
|
BLAKE2b-256 | 6addc2343154d01e0062d464ec083488417134ca9b891d067822a1e770a57c98 |