rogues


Namerogues JSON
Version 1.0.0 PyPI version JSON
download
home_pagehttps://github.com/macd/rogues
SummaryPython and numpy port of Nicholas Higham's m*lab test matrices
upload_time2025-01-10 20:50:37
maintainerNone
docs_urlNone
authorDon MacMillen
requires_pythonNone
licenseMIT
keywords numpy scipy matplotlib linalg
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # rogues 1.0.0

## Python and Numpy port of Prof. Nicholas Higham's matlab test matrices

These matrices are a collection of interesting matrices that appear in
matlab's 'gallery' collection. This collection was originally defined
and implemented by Prof. Nicholas Higham of Manchester University and
is more fully discussed in "The Test Matrix Toolbox for Matlab
(Version 3.0)", N.J. Higham, Numerical Analysis Report No. 276,
September 1995 and available [here](http://www.ma.man.ac.uk/~higham/mctoolbox/toolbox.pdf) (Now appears to be a dead link)

The pdf of the 1991 TOMS (Algorithm 694) is available from ACM [here](https://dl.acm.org/citation.cfm?id=116805)

By 'interesting' we mean that these matrices either present some
challenges to numerical algorithms or have some a set of interesting
properties. The documentation of the individual functions contains
much more info, as well as references.

Also included are a set of matrix utility functions that are needed
for generating some of members of the collection as well as a few
functions from Prof. Higham’s matrixcomp package. One of the more
interesting routines here is mdsmax, a direct search optimization
algorithm.

The rogues package depends on numpy and scipy, both of which must be
installed. Additionally, there are a few routines that deal with
plotting, and these use matplotlib. While ipython is not strictly
necessary, it is a very convenient environment for numpy / scipy /
matplotlib. Finally, the unit tests now utilize pytest, and that
must be installed in your environment. Then just make certain you
are in the rogues top level directory and run pytest, ie

    cd rogues
    pytest

The included matrix generation functions are:

* **cauchy** Cauchy matrix
* **chebspec** Chebyshev spectral differentiation matrix
* **chebvand** Vandermonde-like matrix for the Chebyshev polynomials
* **chow** Chow matrix - a singular Toeplitz lower Hessenberg matrix
* **clement** Clement matrix - tridiagonal with zero diagonal entries
* **comp** Comparison matrices
* **compan** Companion matrix
* **condex** Counterexamples to matrix condition number estimators
* **cycol** Matrix whose columns repeat cyclically
* **dingdong** Dingdong matrix - a symmetric Hankel matrix
* **dorr** Dorr matrix - diagonally dominant, ill conditioned, tridiagonal.
* **dramadah** A (0,1) matrix whose inverse has large integer entries
* **fiedler** Fiedler matrix - symmetric
* **forsythe** Forsythe matrix - a perturbed Jordan block
* **frank** Frank matrix - ill conditioned eigenvalues.
* **gearm** Gear matrix
* **gfpp** Matrix giving maximal growth factor for GW with partial pivoting
* **grcar** Grcar matrix - a Toeplitz matrix with sensitive eigenvalues.
* **hadamard** Hadamard matrix
* **hankel** Hankel matrix
* **hanowa** A matrix whose eigenvalues lie on a vertical line in C
* **hilb** Hilbert matrix
* **invhess** Inverse of an upper Hessenberg matrix
* **invol** An involutory matrix
* **ipjfact** A Hankel matrix with factorial elements
* **jordbloc** Jordan block matrix
* **kahan** Kahan matrix - upper trapezoidal
* **kms** Kar-Murdock-Szego Toeplitz matrix
* **krylov** Krylov matrix
* **lauchli** Lauchli matrix - rectangular
* **lehmer** Lehmer matrix - symmetric positive definite
* **lesp** A tridiagonal matrix with real, sensitve eigenvalues
* **lotkin** Lotkin matrix
* **minij** Symmetric positive definite matrix min(i,j)
* **moler** Moler matrix symmetric positive definite
* **neumann** Singular matrix from the descrete Neumann problem (sparse)
* **ohess** Random, orthogonal upper Hessenberg matrix
* **parter** Parter matrix - a Toeplitz matrix with singular values near pi
* **pascal** Pascal matrix
* **pdtoep** Symmetric positive definite Toeplitz matrix
* **pei** Pei matrix
* **pentoep** Tentadiagonal Toeplitz matrix (sparse)
* **poisson** Block tridiagonal matrix from Poisson’s equation (sparse)
* **prolate** Prolate matrix - symmetric, ill-conditioned Toeplitz matrix
* **qmult** Pre-multiply by random orthogonal matrix
* **rando** Random matrix with elements -1, 0, or 1
* **randsvd** Random matrix with pre-assigned singular values
* **redheff** A (0,1) matrix of Redheffer associated with the Riemann hypothesis
* **riemann** A matrix associated with the Riemann hypothesis
* **smoke** Smoke matrix - complex, with a ‘smoke ring’ pseudospectrum
* **triw** Upper triangular matrix discussed by Wilkinson and others
* **wathen** Wathen matrix - a finite element matrix (sparse, random entries)
* **wilk** Various specific matrices devised /discussed by Wilkenson
* **wilkinson** Wilkinson matrix of size n, where n must be odd

Some of generally useful matrix utility functions:

* **augment** Agumented system matrix
* **bandred** Band reduction by two-sided unitary transformations
* **cgs** Classical Gram-Schmidt QR factorization
* **cond** Matrix condition number in 1,2,Frobenius, or infinity norm
* **condeig** Condition numbers for eigenvalues of a matrix
* **cpltaxes** Determine suitable axis for plot of complex vector
* **dual** Dual vector with respect to Holder p-norm
* **fv**  Evaluate and plot the field of values largest leading submatrices
* **ge** Gaussian elimination without pivoting
* **gersh** Plots Gershgorin disks for a square matrix
* **hankel** Given first row, returns a Toeplitz type matrix
* **house** Householder matrix
* **mdsmax** Multidimensional search method for direct search optimization
* **mgs** Modified Gram-Schmidt QR factorization
* **pow2** Vector whose i-th element is 2 ** x[i], where x[] is input
* **ps** Dot plot of a pseudospectrum
* **pscont** Plots contours and color plots of pseudospectra
* **repmat** Simple re-implementation of matlab's repmat function
* **rq** Rayleigh quotient
* **skewpart** Skew-symmetric (skew-Hermitian) part
* **sparsify** Randomly sets matrix elements to zero
* **sub** Principal submatrix
* **symmpart** Symmetric (Hermitian) part
* **toeplitz** Returns toeplitz matrix given first row of the matrix
* **treshape** Reshape vector to or from (unit) triangular matrix
* **tridiag** Sparse tridiagonl matrix given the diagonals
* **vand** Vandermonde matrix
* **vecperm** Vector permutation matrix

More information is available on any of these functions by typing **help <funcname>**

### 0.5.0 Release Notes
    Don't use the distribute_setuptools.py stuff for python 2.7.15
    Fixed type errors in cycol.py, dorr.py, hanowa.py, ohess.py, and treshape.py that have
    developed with newer versions of Python.
    Tested on Ubuntu 18.04.1 with Python 2.7.15 & Numpy 1.14.3; Python 3.6.5 & Numpy 1.14.3;
        and Python 3.7.0 and Numpy 1.15.0
### 0.4.0 Release Notes
    Added visualization routines fv, gersh, and pscont. Fixed issues with np.r_.
    Relaxed tolerances for two problematic unit tests. Only use distribute with
    Python 2 series.  Cleaned up pep8 warnings.
    Tested on Ubuntu 14.04 with Python 3.5.1,  Numpy 1.10.2, Scipy 0.16.1, IPython 4.0.1, Matplotlib 1.5.0
    Tested on Ubuntu 14.04 with Python 3.4.3,  Numpy 1.9.3,  Scipy 0.16.0, IPython 4.0.0, Matplotlib 1.4.3
    Tested on Ubuntu 14.04 with Python 2.7.10, Numpy 1.9.2,  Scipy 0.15.1, IPython 3.2.1, Matplotlib 1.3.1
    Tested on Windows 10   with Python 3.5.1,  Numpy 1.10.1, Scipy 0.16.0, IPython 4.0.0, Matplotlib 1.4.3

### 1.0.0 Release Notes
    Simplified tests and moved to pytest
    Removed deprecation warnings
    Tested on Ubuntu 24.04, Python 3.8.19 with Numpy 1.24.4, and Python 3.12.5 with Numpy 2.1.0

### 0.3.0 Release Notes
    Ported to Python 3. Added distribute_setup.py to fix installation problems.
    Tested on Ubuntu 12.04 with Python 2.7.3, Numpy 1.6.1, Scipy 0.10.0, IPython 0.12
    Tested on Ubuntu 12.04 with Python 3.2.3, Numpy 1.6.2, Scipy 0.11.0, IPython 0.13.1
    Tested on Windows 7    with Python 2.7.3, Numpy 1.6.2, Scipy 0.11.0, IPython 0.13.1

### 0.2.0 Release Notes
    Unit tests now included with distribution.



            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/macd/rogues",
    "name": "rogues",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "numpy scipy matplotlib linalg",
    "author": "Don MacMillen",
    "author_email": "don@macmillen.net",
    "download_url": "https://files.pythonhosted.org/packages/bf/03/6e0d95aae683ac699aaf5a3b6501303d400a3a05ddd143b892c571e90f16/rogues-1.0.0.tar.gz",
    "platform": null,
    "description": "# rogues 1.0.0\n\n## Python and Numpy port of Prof. Nicholas Higham's matlab test matrices\n\nThese matrices are a collection of interesting matrices that appear in\nmatlab's 'gallery' collection. This collection was originally defined\nand implemented by Prof. Nicholas Higham of Manchester University and\nis more fully discussed in \"The Test Matrix Toolbox for Matlab\n(Version 3.0)\", N.J. Higham, Numerical Analysis Report No. 276,\nSeptember 1995 and available [here](http://www.ma.man.ac.uk/~higham/mctoolbox/toolbox.pdf) (Now appears to be a dead link)\n\nThe pdf of the 1991 TOMS (Algorithm 694) is available from ACM [here](https://dl.acm.org/citation.cfm?id=116805)\n\nBy 'interesting' we mean that these matrices either present some\nchallenges to numerical algorithms or have some a set of interesting\nproperties. The documentation of the individual functions contains\nmuch more info, as well as references.\n\nAlso included are a set of matrix utility functions that are needed\nfor generating some of members of the collection as well as a few\nfunctions from Prof. Higham\u2019s matrixcomp package. One of the more\ninteresting routines here is mdsmax, a direct search optimization\nalgorithm.\n\nThe rogues package depends on numpy and scipy, both of which must be\ninstalled. Additionally, there are a few routines that deal with\nplotting, and these use matplotlib. While ipython is not strictly\nnecessary, it is a very convenient environment for numpy / scipy /\nmatplotlib. Finally, the unit tests now utilize pytest, and that\nmust be installed in your environment. Then just make certain you\nare in the rogues top level directory and run pytest, ie\n\n    cd rogues\n    pytest\n\nThe included matrix generation functions are:\n\n* **cauchy** Cauchy matrix\n* **chebspec** Chebyshev spectral differentiation matrix\n* **chebvand** Vandermonde-like matrix for the Chebyshev polynomials\n* **chow** Chow matrix - a singular Toeplitz lower Hessenberg matrix\n* **clement** Clement matrix - tridiagonal with zero diagonal entries\n* **comp** Comparison matrices\n* **compan** Companion matrix\n* **condex** Counterexamples to matrix condition number estimators\n* **cycol** Matrix whose columns repeat cyclically\n* **dingdong** Dingdong matrix - a symmetric Hankel matrix\n* **dorr** Dorr matrix - diagonally dominant, ill conditioned, tridiagonal.\n* **dramadah** A (0,1) matrix whose inverse has large integer entries\n* **fiedler** Fiedler matrix - symmetric\n* **forsythe** Forsythe matrix - a perturbed Jordan block\n* **frank** Frank matrix - ill conditioned eigenvalues.\n* **gearm** Gear matrix\n* **gfpp** Matrix giving maximal growth factor for GW with partial pivoting\n* **grcar** Grcar matrix - a Toeplitz matrix with sensitive eigenvalues.\n* **hadamard** Hadamard matrix\n* **hankel** Hankel matrix\n* **hanowa** A matrix whose eigenvalues lie on a vertical line in C\n* **hilb** Hilbert matrix\n* **invhess** Inverse of an upper Hessenberg matrix\n* **invol** An involutory matrix\n* **ipjfact** A Hankel matrix with factorial elements\n* **jordbloc** Jordan block matrix\n* **kahan** Kahan matrix - upper trapezoidal\n* **kms** Kar-Murdock-Szego Toeplitz matrix\n* **krylov** Krylov matrix\n* **lauchli** Lauchli matrix - rectangular\n* **lehmer** Lehmer matrix - symmetric positive definite\n* **lesp** A tridiagonal matrix with real, sensitve eigenvalues\n* **lotkin** Lotkin matrix\n* **minij** Symmetric positive definite matrix min(i,j)\n* **moler** Moler matrix symmetric positive definite\n* **neumann** Singular matrix from the descrete Neumann problem (sparse)\n* **ohess** Random, orthogonal upper Hessenberg matrix\n* **parter** Parter matrix - a Toeplitz matrix with singular values near pi\n* **pascal** Pascal matrix\n* **pdtoep** Symmetric positive definite Toeplitz matrix\n* **pei** Pei matrix\n* **pentoep** Tentadiagonal Toeplitz matrix (sparse)\n* **poisson** Block tridiagonal matrix from Poisson\u2019s equation (sparse)\n* **prolate** Prolate matrix - symmetric, ill-conditioned Toeplitz matrix\n* **qmult** Pre-multiply by random orthogonal matrix\n* **rando** Random matrix with elements -1, 0, or 1\n* **randsvd** Random matrix with pre-assigned singular values\n* **redheff** A (0,1) matrix of Redheffer associated with the Riemann hypothesis\n* **riemann** A matrix associated with the Riemann hypothesis\n* **smoke** Smoke matrix - complex, with a \u2018smoke ring\u2019 pseudospectrum\n* **triw** Upper triangular matrix discussed by Wilkinson and others\n* **wathen** Wathen matrix - a finite element matrix (sparse, random entries)\n* **wilk** Various specific matrices devised /discussed by Wilkenson\n* **wilkinson** Wilkinson matrix of size n, where n must be odd\n\nSome of generally useful matrix utility functions:\n\n* **augment** Agumented system matrix\n* **bandred** Band reduction by two-sided unitary transformations\n* **cgs** Classical Gram-Schmidt QR factorization\n* **cond** Matrix condition number in 1,2,Frobenius, or infinity norm\n* **condeig** Condition numbers for eigenvalues of a matrix\n* **cpltaxes** Determine suitable axis for plot of complex vector\n* **dual** Dual vector with respect to Holder p-norm\n* **fv**  Evaluate and plot the field of values largest leading submatrices\n* **ge** Gaussian elimination without pivoting\n* **gersh** Plots Gershgorin disks for a square matrix\n* **hankel** Given first row, returns a Toeplitz type matrix\n* **house** Householder matrix\n* **mdsmax** Multidimensional search method for direct search optimization\n* **mgs** Modified Gram-Schmidt QR factorization\n* **pow2** Vector whose i-th element is 2 ** x[i], where x[] is input\n* **ps** Dot plot of a pseudospectrum\n* **pscont** Plots contours and color plots of pseudospectra\n* **repmat** Simple re-implementation of matlab's repmat function\n* **rq** Rayleigh quotient\n* **skewpart** Skew-symmetric (skew-Hermitian) part\n* **sparsify** Randomly sets matrix elements to zero\n* **sub** Principal submatrix\n* **symmpart** Symmetric (Hermitian) part\n* **toeplitz** Returns toeplitz matrix given first row of the matrix\n* **treshape** Reshape vector to or from (unit) triangular matrix\n* **tridiag** Sparse tridiagonl matrix given the diagonals\n* **vand** Vandermonde matrix\n* **vecperm** Vector permutation matrix\n\nMore information is available on any of these functions by typing **help <funcname>**\n\n### 0.5.0 Release Notes\n    Don't use the distribute_setuptools.py stuff for python 2.7.15\n    Fixed type errors in cycol.py, dorr.py, hanowa.py, ohess.py, and treshape.py that have\n    developed with newer versions of Python.\n    Tested on Ubuntu 18.04.1 with Python 2.7.15 & Numpy 1.14.3; Python 3.6.5 & Numpy 1.14.3;\n        and Python 3.7.0 and Numpy 1.15.0\n### 0.4.0 Release Notes\n    Added visualization routines fv, gersh, and pscont. Fixed issues with np.r_.\n    Relaxed tolerances for two problematic unit tests. Only use distribute with\n    Python 2 series.  Cleaned up pep8 warnings.\n    Tested on Ubuntu 14.04 with Python 3.5.1,  Numpy 1.10.2, Scipy 0.16.1, IPython 4.0.1, Matplotlib 1.5.0\n    Tested on Ubuntu 14.04 with Python 3.4.3,  Numpy 1.9.3,  Scipy 0.16.0, IPython 4.0.0, Matplotlib 1.4.3\n    Tested on Ubuntu 14.04 with Python 2.7.10, Numpy 1.9.2,  Scipy 0.15.1, IPython 3.2.1, Matplotlib 1.3.1\n    Tested on Windows 10   with Python 3.5.1,  Numpy 1.10.1, Scipy 0.16.0, IPython 4.0.0, Matplotlib 1.4.3\n\n### 1.0.0 Release Notes\n    Simplified tests and moved to pytest\n    Removed deprecation warnings\n    Tested on Ubuntu 24.04, Python 3.8.19 with Numpy 1.24.4, and Python 3.12.5 with Numpy 2.1.0\n\n### 0.3.0 Release Notes\n    Ported to Python 3. Added distribute_setup.py to fix installation problems.\n    Tested on Ubuntu 12.04 with Python 2.7.3, Numpy 1.6.1, Scipy 0.10.0, IPython 0.12\n    Tested on Ubuntu 12.04 with Python 3.2.3, Numpy 1.6.2, Scipy 0.11.0, IPython 0.13.1\n    Tested on Windows 7    with Python 2.7.3, Numpy 1.6.2, Scipy 0.11.0, IPython 0.13.1\n\n### 0.2.0 Release Notes\n    Unit tests now included with distribution.\n\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Python and numpy port of Nicholas Higham's m*lab test matrices",
    "version": "1.0.0",
    "project_urls": {
        "Homepage": "https://github.com/macd/rogues"
    },
    "split_keywords": [
        "numpy",
        "scipy",
        "matplotlib",
        "linalg"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "6d13405277d79506684cbc7d11e5186836f9c18a74ea09db3ca27f5d42330246",
                "md5": "f8003df8f951bc81d714da1ab14a697e",
                "sha256": "b7cf0dafded055a289d3ef860e0d382923eecd9ca6c8a95de577b49579b7c2f1"
            },
            "downloads": -1,
            "filename": "rogues-1.0.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "f8003df8f951bc81d714da1ab14a697e",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 80206,
            "upload_time": "2025-01-10T20:50:36",
            "upload_time_iso_8601": "2025-01-10T20:50:36.282680Z",
            "url": "https://files.pythonhosted.org/packages/6d/13/405277d79506684cbc7d11e5186836f9c18a74ea09db3ca27f5d42330246/rogues-1.0.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "bf036e0d95aae683ac699aaf5a3b6501303d400a3a05ddd143b892c571e90f16",
                "md5": "21b770aa1bc7ff9f8a599f4837c36e30",
                "sha256": "c13602906b1de89fac58708dab3eef0588763b6624aeb4046813f18ca85d3d9b"
            },
            "downloads": -1,
            "filename": "rogues-1.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "21b770aa1bc7ff9f8a599f4837c36e30",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 70286,
            "upload_time": "2025-01-10T20:50:37",
            "upload_time_iso_8601": "2025-01-10T20:50:37.826299Z",
            "url": "https://files.pythonhosted.org/packages/bf/03/6e0d95aae683ac699aaf5a3b6501303d400a3a05ddd143b892c571e90f16/rogues-1.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-10 20:50:37",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "macd",
    "github_project": "rogues",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "rogues"
}
        
Elapsed time: 1.03400s