diffpy.snmf


Namediffpy.snmf JSON
Version 0.1.0 PyPI version JSON
download
home_pageNone
SummaryA python package implementing the stretched NMF algorithm.
upload_time2024-08-13 19:16:13
maintainerNone
docs_urlNone
authorNone
requires_python>=3.10
licenseNone
keywords diffpy pdf
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            |Icon| |title|_
===============

.. |title| replace:: diffpy.snmf
.. _title: https://diffpy.github.io/diffpy.snmf

.. |Icon| image:: https://avatars.githubusercontent.com/diffpy
        :target: https://diffpy.github.io/diffpy.snmf
        :height: 100px

|PyPi| |Forge| |PythonVersion| |PR|

|CI| |Codecov| |Black| |Tracking|

.. |Black| image:: https://img.shields.io/badge/code_style-black-black
        :target: https://github.com/psf/black

.. |CI| image:: https://github.com/diffpy/diffpy.snmf/actions/workflows/main.yml/badge.svg
        :target: https://github.com/diffpy/diffpy.snmf/actions/workflows/main.yml

.. |Codecov| image:: https://codecov.io/gh/diffpy/diffpy.snmf/branch/main/graph/badge.svg
        :target: https://codecov.io/gh/diffpy/diffpy.snmf

.. |Forge| image:: https://img.shields.io/conda/vn/conda-forge/diffpy.snmf
        :target: https://anaconda.org/conda-forge/diffpy.snmf

.. |PR| image:: https://img.shields.io/badge/PR-Welcome-29ab47ff

.. |PyPi| image:: https://img.shields.io/pypi/v/diffpy.snmf
        :target: https://pypi.org/project/diffpy.snmf/

.. |PythonVersion| image:: https://img.shields.io/pypi/pyversions/diffpy.snmf
        :target: https://pypi.org/project/diffpy.snmf/

.. |Tracking| image:: https://img.shields.io/badge/issue_tracking-github-blue
        :target: https://github.com/diffpy/diffpy.snmf/issues

A python package implementing the stretched NMF algorithm.

``diffpy.snmf`` implements the stretched non negative matrix factorization (sNMF) and sparse stretched NMF
(ssNMF) algorithms.

This algorithm is designed to do an NMF factorization on a set of signals ignoring any uniform stretching of the signal
on the independent variable axis. For example, for powder diffraction data taken from samples containing multiple
chemical phases where the measurements were done at different temperatures and the materials were undergoing thermal
expansion.

For more information about the diffpy.snmf library, please consult our `online documentation <https://diffpy.github.io/diffpy.snmf>`_.

Citation
--------

If you use this program for a scientific research that leads
to publication, we ask that you acknowledge use of the program
by citing the following paper in your publication:

   Ran Gu, Yevgeny Rakita, Ling Lan, Zach Thatcher, Gabrielle E. Kamm, Daniel O’Nolan, Brennan Mcbride, Allison Wustrow, James R. Neilson, Karena W. Chapman, Qiang Du, and Simon J. L. Billinge,
   `Stretched Non-negative Matrix Factorization
   <https://doi.org/10.48550/arXiv.2311.15173>`__,
   arXiv:2311.15173 [cond-mat.mtrl-sci] (2023).


Installation
------------

The preferred method is to use `Miniconda Python
<https://docs.conda.io/projects/miniconda/en/latest/miniconda-install.html>`_
and install from the "conda-forge" channel of Conda packages.

To add "conda-forge" to the conda channels, run the following in a terminal. ::

        conda config --add channels conda-forge

We want to install our packages in a suitable conda environment.
The following creates and activates a new environment named ``diffpy.snmf_env`` ::

        conda create -n diffpy.snmf_env python=3
        conda activate diffpy.snmf_env

Then, to fully install ``diffpy.snmf`` in our active environment, run ::

        conda install diffpy.snmf

Another option is to use ``pip`` to download and install the latest release from
`Python Package Index <https://pypi.python.org>`_.
To install using ``pip`` into your ``diffpy.snmf_env`` environment, we will also have to install dependencies ::

        pip install -r https://raw.githubusercontent.com/diffpy/diffpy.snmf/main/requirements/run.txt

and then install the package ::

        pip install diffpy.snmf

If you prefer to install from sources, after installing the dependencies, obtain the source archive from
`GitHub <https://github.com/diffpy/diffpy.snmf/>`_. Once installed, ``cd`` into your ``diffpy.snmf`` directory
and run the following ::

        pip install .

Support and Contribute
----------------------

`Diffpy user group <https://groups.google.com/g/diffpy-users>`_ is the discussion forum for general questions and discussions about the use of diffpy.snmf. Please join the diffpy.snmf users community by joining the Google group. The diffpy.snmf project welcomes your expertise and enthusiasm!

If you see a bug or want to request a feature, please `report it as an issue <https://github.com/diffpy/diffpy.snmf/issues>`_ and/or `submit a fix as a PR <https://github.com/diffpy/diffpy.snmf/pulls>`_. You can also post it to the `Diffpy user group <https://groups.google.com/g/diffpy-users>`_. 

Feel free to fork the project and contribute. To install diffpy.snmf
in a development mode, with its sources being directly used by Python
rather than copied to a package directory, use the following in the root
directory ::

        pip install -e .

To ensure code quality and to prevent accidental commits into the default branch, please set up the use of our pre-commit
hooks.

1. Install pre-commit in your working environment by running ``conda install pre-commit``.

2. Initialize pre-commit (one time only) ``pre-commit install``.

Thereafter your code will be linted by black and isort and checked against flake8 before you can commit.
If it fails by black or isort, just rerun and it should pass (black and isort will modify the files so should
pass after they are modified). If the flake8 test fails please see the error messages and fix them manually before
trying to commit again.

Improvements and fixes are always appreciated.

Before contribuing, please read our `Code of Conduct <https://github.com/diffpy/diffpy.snmf/blob/main/CODE_OF_CONDUCT.rst>`_.

Contact
-------

For more information on diffpy.snmf please visit the project `web-page <https://diffpy.github.io/>`_ or email Prof. Simon Billinge at sb2896@columbia.edu.

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "diffpy.snmf",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.10",
    "maintainer_email": "\"Simon J.L. Billinge group\" <simon.billinge@gmail.com>",
    "keywords": "diffpy, PDF",
    "author": null,
    "author_email": "\"Simon J.L. Billinge group\" <simon.billinge@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/5e/c4/02b9885334545981507e0204c49357cfb0d3801560e4c89d7a8261e77db3/diffpy_snmf-0.1.0.tar.gz",
    "platform": null,
    "description": "|Icon| |title|_\n===============\n\n.. |title| replace:: diffpy.snmf\n.. _title: https://diffpy.github.io/diffpy.snmf\n\n.. |Icon| image:: https://avatars.githubusercontent.com/diffpy\n        :target: https://diffpy.github.io/diffpy.snmf\n        :height: 100px\n\n|PyPi| |Forge| |PythonVersion| |PR|\n\n|CI| |Codecov| |Black| |Tracking|\n\n.. |Black| image:: https://img.shields.io/badge/code_style-black-black\n        :target: https://github.com/psf/black\n\n.. |CI| image:: https://github.com/diffpy/diffpy.snmf/actions/workflows/main.yml/badge.svg\n        :target: https://github.com/diffpy/diffpy.snmf/actions/workflows/main.yml\n\n.. |Codecov| image:: https://codecov.io/gh/diffpy/diffpy.snmf/branch/main/graph/badge.svg\n        :target: https://codecov.io/gh/diffpy/diffpy.snmf\n\n.. |Forge| image:: https://img.shields.io/conda/vn/conda-forge/diffpy.snmf\n        :target: https://anaconda.org/conda-forge/diffpy.snmf\n\n.. |PR| image:: https://img.shields.io/badge/PR-Welcome-29ab47ff\n\n.. |PyPi| image:: https://img.shields.io/pypi/v/diffpy.snmf\n        :target: https://pypi.org/project/diffpy.snmf/\n\n.. |PythonVersion| image:: https://img.shields.io/pypi/pyversions/diffpy.snmf\n        :target: https://pypi.org/project/diffpy.snmf/\n\n.. |Tracking| image:: https://img.shields.io/badge/issue_tracking-github-blue\n        :target: https://github.com/diffpy/diffpy.snmf/issues\n\nA python package implementing the stretched NMF algorithm.\n\n``diffpy.snmf`` implements the stretched non negative matrix factorization (sNMF) and sparse stretched NMF\n(ssNMF) algorithms.\n\nThis algorithm is designed to do an NMF factorization on a set of signals ignoring any uniform stretching of the signal\non the independent variable axis. For example, for powder diffraction data taken from samples containing multiple\nchemical phases where the measurements were done at different temperatures and the materials were undergoing thermal\nexpansion.\n\nFor more information about the diffpy.snmf library, please consult our `online documentation <https://diffpy.github.io/diffpy.snmf>`_.\n\nCitation\n--------\n\nIf you use this program for a scientific research that leads\nto publication, we ask that you acknowledge use of the program\nby citing the following paper in your publication:\n\n   Ran Gu, Yevgeny Rakita, Ling Lan, Zach Thatcher, Gabrielle E. Kamm, Daniel O\u2019Nolan, Brennan Mcbride, Allison Wustrow, James R. Neilson, Karena W. Chapman, Qiang Du, and Simon J. L. Billinge,\n   `Stretched Non-negative Matrix Factorization\n   <https://doi.org/10.48550/arXiv.2311.15173>`__,\n   arXiv:2311.15173 [cond-mat.mtrl-sci] (2023).\n\n\nInstallation\n------------\n\nThe preferred method is to use `Miniconda Python\n<https://docs.conda.io/projects/miniconda/en/latest/miniconda-install.html>`_\nand install from the \"conda-forge\" channel of Conda packages.\n\nTo add \"conda-forge\" to the conda channels, run the following in a terminal. ::\n\n        conda config --add channels conda-forge\n\nWe want to install our packages in a suitable conda environment.\nThe following creates and activates a new environment named ``diffpy.snmf_env`` ::\n\n        conda create -n diffpy.snmf_env python=3\n        conda activate diffpy.snmf_env\n\nThen, to fully install ``diffpy.snmf`` in our active environment, run ::\n\n        conda install diffpy.snmf\n\nAnother option is to use ``pip`` to download and install the latest release from\n`Python Package Index <https://pypi.python.org>`_.\nTo install using ``pip`` into your ``diffpy.snmf_env`` environment, we will also have to install dependencies ::\n\n        pip install -r https://raw.githubusercontent.com/diffpy/diffpy.snmf/main/requirements/run.txt\n\nand then install the package ::\n\n        pip install diffpy.snmf\n\nIf you prefer to install from sources, after installing the dependencies, obtain the source archive from\n`GitHub <https://github.com/diffpy/diffpy.snmf/>`_. Once installed, ``cd`` into your ``diffpy.snmf`` directory\nand run the following ::\n\n        pip install .\n\nSupport and Contribute\n----------------------\n\n`Diffpy user group <https://groups.google.com/g/diffpy-users>`_ is the discussion forum for general questions and discussions about the use of diffpy.snmf. Please join the diffpy.snmf users community by joining the Google group. The diffpy.snmf project welcomes your expertise and enthusiasm!\n\nIf you see a bug or want to request a feature, please `report it as an issue <https://github.com/diffpy/diffpy.snmf/issues>`_ and/or `submit a fix as a PR <https://github.com/diffpy/diffpy.snmf/pulls>`_. You can also post it to the `Diffpy user group <https://groups.google.com/g/diffpy-users>`_. \n\nFeel free to fork the project and contribute. To install diffpy.snmf\nin a development mode, with its sources being directly used by Python\nrather than copied to a package directory, use the following in the root\ndirectory ::\n\n        pip install -e .\n\nTo ensure code quality and to prevent accidental commits into the default branch, please set up the use of our pre-commit\nhooks.\n\n1. Install pre-commit in your working environment by running ``conda install pre-commit``.\n\n2. Initialize pre-commit (one time only) ``pre-commit install``.\n\nThereafter your code will be linted by black and isort and checked against flake8 before you can commit.\nIf it fails by black or isort, just rerun and it should pass (black and isort will modify the files so should\npass after they are modified). If the flake8 test fails please see the error messages and fix them manually before\ntrying to commit again.\n\nImprovements and fixes are always appreciated.\n\nBefore contribuing, please read our `Code of Conduct <https://github.com/diffpy/diffpy.snmf/blob/main/CODE_OF_CONDUCT.rst>`_.\n\nContact\n-------\n\nFor more information on diffpy.snmf please visit the project `web-page <https://diffpy.github.io/>`_ or email Prof. Simon Billinge at sb2896@columbia.edu.\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "A python package implementing the stretched NMF algorithm.",
    "version": "0.1.0",
    "project_urls": {
        "Homepage": "https://github.com/diffpy/diffpy.snmf/",
        "Issues": "https://github.com/diffpy/diffpy.snmf/issues/"
    },
    "split_keywords": [
        "diffpy",
        " pdf"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "a852ada9191db4f0c35dee2e9f4b99b17785335820a2b300b1c9cb7e65c8bbcc",
                "md5": "451a235c901be10a549870d650a4eda2",
                "sha256": "7fdfbe5a1c6dc378de4f0d3d26833b09f043ddd961344037f3366568210771b7"
            },
            "downloads": -1,
            "filename": "diffpy.snmf-0.1.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "451a235c901be10a549870d650a4eda2",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.10",
            "size": 16900,
            "upload_time": "2024-08-13T19:16:11",
            "upload_time_iso_8601": "2024-08-13T19:16:11.417298Z",
            "url": "https://files.pythonhosted.org/packages/a8/52/ada9191db4f0c35dee2e9f4b99b17785335820a2b300b1c9cb7e65c8bbcc/diffpy.snmf-0.1.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "5ec402b9885334545981507e0204c49357cfb0d3801560e4c89d7a8261e77db3",
                "md5": "bcf980aa32839dc3ccd7558e473b928f",
                "sha256": "2903bd7d9df588b35bd45bc07ea745c69fb281fb774beef8af645cebcb980b7c"
            },
            "downloads": -1,
            "filename": "diffpy_snmf-0.1.0.tar.gz",
            "has_sig": false,
            "md5_digest": "bcf980aa32839dc3ccd7558e473b928f",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.10",
            "size": 16864,
            "upload_time": "2024-08-13T19:16:13",
            "upload_time_iso_8601": "2024-08-13T19:16:13.311805Z",
            "url": "https://files.pythonhosted.org/packages/5e/c4/02b9885334545981507e0204c49357cfb0d3801560e4c89d7a8261e77db3/diffpy_snmf-0.1.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-08-13 19:16:13",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "diffpy",
    "github_project": "diffpy.snmf",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "lcname": "diffpy.snmf"
}
        
Elapsed time: 0.53410s