Skip to main content

A package grouping matrices row reordering algorithms to minimize their front size.

Project description

matrex

matrex stands for Matrix Reordering algorithms.

The library implements the Modified Sloan Row Ordering (MSRO) algorithm. By permuting the rows of a matrix, the algorithm minimizes the mean/max front size of this matrix. The front size minimization can be viewed in the following example :

image

Here, the black squares represent the position in the matrix where there is a non-zero value. The columns of the matrix have been reordered so that those values are closer together as much as possible in each row. The mean of this distance (difference between first and last non-zero index in a row) is shown on top of those pictures (before vs after msro application).

The original Fortran implementation is called mc62 and is part of the HSL library.

Installation

You can install matrex using pip:

pip install matrex

or by directly downloading it from this github :

pip install matrex@git+https://github.com/benjaminlanthier/matrex

The MSRO algorithm

This paper by Jennifer A. Scott describes the logic and structure of the MSRO algorithm. It iteratively selects rows to be part of the new permutation according to a priority function. In the paper, the authors use the following priority function:

$$ \begin{equation} P_i = -W_1 \text{rcgain}_i + W_2 d(i, e), \end{equation} $$

We implement a slightly different priority function described in the manual for mc62:

$$ \begin{equation} P_i = -W_1 \text{rcgain}_i + W_2 d(i, e) - W_3 \text{nold}_i. \end{equation} $$

In both equations, we have that:

  • $\text{rcgain}_i$ is "the increases to the row and column front sizes resulting from assembling row $i$ next" [1]
  • $d(i, e)$ is the distance between the row $i$ and the row $e$, where $e$ is the target row, found by using the pseudodiameter of the row graph of the input matrix.
  • $\text{nold}_i$ is "the number of variables in row $i$ that are candidates for elimination and have already been brought into the front" [2].

Example

import numpy as np
from matrex import msro

m = np.array([[1, 1, 1, 0, 0, 0],
              [0, 1, 1, 0, 1, 0],
              [1, 1, 0, 1, 0, 0],
              [0, 0, 1, 0, 1, 1],
              [0, 1, 1, 0, 1, 0]])
# For the rows reordering
new_columns_order = msro(m)
reordered_rows_matrix = m[new_columns_order]
# For the columns reordering
new_columns_order = msro(m.T)
reordered_cols_matrix = m[:, new_columns_order]

Dependencies

Packages needed to run this algorithm :

  • numpy
  • networkx
  • Optional : matplotlib (for visualizing the row graph)

References

[1] Scott, Jennifer A. ‘A New Row Ordering Strategy for Frontal Solvers’. Numerical Linear Algebra with Applications, vol. 6, no. 3, Apr. 1999, pp. 189–211. DOI.

[2] HSL, a collection of Fortran codes for large-scale scientific computation. See their site.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

matrex-0.0.1.tar.gz (17.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

matrex-0.0.1-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file matrex-0.0.1.tar.gz.

File metadata

  • Download URL: matrex-0.0.1.tar.gz
  • Upload date:
  • Size: 17.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.13

File hashes

Hashes for matrex-0.0.1.tar.gz
Algorithm Hash digest
SHA256 7cf243fe0c726c928aaf5c30622292bb21189e5f91b8a3c79e5ce60e08fb0460
MD5 550d1c6f0556a4980cd2556278cc5ede
BLAKE2b-256 a476a1f2e0c86a33d1c56b2aa66fe21c1e60a23e4b486a612c9650a41ba74764

See more details on using hashes here.

File details

Details for the file matrex-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: matrex-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 7.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.13

File hashes

Hashes for matrex-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 48a3c9fc69ef893d1dfbd6248b3e156bdc7cf554096b0d3c2f9e2da07bbba899
MD5 888bff9df9eaaac693a9526caebc932d
BLAKE2b-256 b1db687ff41909ccd56ad17311bb9dcafbe1e7186bad5bf463e3c67582e013f2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page