Skip to main content

ModiFinder package

Project description

Welcome to ModiFinder's documentation!

ModiFinder is a tool for site localization of structural modifications using MS/MS data.

This project is under active development.

The documentation is available at: https://wang-bioinformatics-lab.github.io/ModiFinder_base/

Citing

ModiFinder: Tandem Mass Spectral Alignment Enables Structural Modification Site Localization

Mohammad Reza Zare Shahneh, Michael Strobel, Giovanni Andrea Vitale, Christian Geibel, Yasin El Abiead, Neha Garg, Berenike Wagner, Karl Forchhammer, Allegra Aron, Vanessa V Phelan, Daniel Petras, and Mingxun Wang

Journal of the American Society for Mass Spectrometry 2024 35 (11), 2564-2578

DOI: 10.1021/jasms.4c00061

License

Academic Software License: © 2024 UCR (“Institution”). Academic or nonprofit researchers are permitted to use this Software (as defined below) subject to Paragraphs 1-4:

1. Institution hereby grants to you free of charge, so long as you are an academic or nonprofit researcher, a nonexclusive license under Institution’s copyright ownership interest in this software and any derivative works made by you thereof (collectively, the “Software”) to use, copy, and make derivative works of the Software solely for educational or academic research purposes, and to distribute such Software free of charge to other academic or nonprofit researchers for their educational or academic research purposes, in all cases subject to the terms of this Academic Software License. Except as granted herein, all rights are reserved by Institution, including the right to pursue patent protection of the Software.
2. Any distribution of copies of this Software -- including any derivative works made by you thereof -- must include a copy (including the copyright notice above), and be made subject to the terms, of this Academic Software License; failure by you to adhere to the requirements in Paragraphs 1 and 2 will result in immediate termination of the license granted to you pursuant to this Academic Software License effective as of the date you first used the Software.
3. IN NO EVENT WILL INSTITUTION BE LIABLE TO ANY ENTITY OR PERSON FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE, EVEN IF INSTITUTION HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. INSTITUTION SPECIFICALLY DISCLAIMS ANY AND ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING, BUT NOT LIMITED TO, ANY IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE IS PROVIDED “AS IS.” INSTITUTION HAS NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS OF THIS SOFTWARE.
4. Any academic or scholarly publication arising from the use of this Software or any derivative works thereof will include the following acknowledgment:  The Software used in this research was created by [INSERT AUTHOR NAMES] of UC Riverside. © 2024 UCR.

Commercial entities: please contact mingxun.wang@cs.ucr.edu or tp@ucr.edu for licensing opportunities.

Useful Utility Functions

ModiFinder includes several useful utility functions for mass spectrometry data analysis and visualization, exposed under modifinder.utilities.

Reading MGF Files You can easily read MGF files into a pandas DataFrame using read_mgf.

from modifinder.utilities import read_mgf

# Read MGF file
df = read_mgf("path/to/your/spectrum.mgf")
print(df.head())

Visualization The vis module provides powerful visualization tools.

from modifinder.utilities import vis
import matplotlib.pyplot as plt

# Draw a molecule
img = vis.draw_molecule("C1=CC=C(C=C1)O", output_type="png")
plt.imshow(img)
plt.show()

# Draw a spectrum
# spectrum_data is a list of (mz, intensity) tuples
spectrum_data = df.iloc[0]['spectrum'].T.tolist()
vis.draw_spectrum(spectrum_data)
plt.show()

Developer Guide

Running Tests

To run the automated tests, ensure you have pytest installed. Then run:

pytest

or specifically for utilities:

pytest modifinder/utilities/tests/

Release Process

ModiFinder uses GitHub Actions for automated releases and documentation deployment.

Creating a New Release (PyPI)

  1. Update the version number in modifinder/__init__.py, pyproject.toml and docs/source/conf.py.
  2. Create and push a new tag starting with v (e.g., v1.2.3).
    git tag v1.2.3
    git push origin v1.2.3
    
  3. This triggers the pypi_publish.yml workflow, which:
    • Builds the package.
    • Publishes it to PyPI (and TestPyPI).
    • Creates a GitHub Release.

Updating Documentation Documentation is automatically rebuilt and deployed to GitHub Pages whenever changes are pushed to the main branch (via documentation.yml).

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

modifinder-1.5.0.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

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

modifinder-1.5.0-py3-none-any.whl (12.3 kB view details)

Uploaded Python 3

File details

Details for the file modifinder-1.5.0.tar.gz.

File metadata

  • Download URL: modifinder-1.5.0.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for modifinder-1.5.0.tar.gz
Algorithm Hash digest
SHA256 633f6b1398e62aa479535b4f1986c2c8a87e3c05402727172f7172d5c7234a1e
MD5 91ad4eb08c99adefc361322d122a1409
BLAKE2b-256 32843c1af4d161c7f976a9ef14ce5a965c096ff1558d4ba98b494f0e680b1144

See more details on using hashes here.

Provenance

The following attestation bundles were made for modifinder-1.5.0.tar.gz:

Publisher: pypi_publish.yml on Wang-Bioinformatics-Lab/ModiFinder_base

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file modifinder-1.5.0-py3-none-any.whl.

File metadata

  • Download URL: modifinder-1.5.0-py3-none-any.whl
  • Upload date:
  • Size: 12.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for modifinder-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6be636f9ff5966950632d18feb7192cefbc9a83b917cca7a11a7f3219d995012
MD5 82fe55262e79ba7a88e008ac78c2e73b
BLAKE2b-256 5a6c3d384ee488bc5c9e24ee469af3b5068a913f8ade87f019d82fcf6b8b0e65

See more details on using hashes here.

Provenance

The following attestation bundles were made for modifinder-1.5.0-py3-none-any.whl:

Publisher: pypi_publish.yml on Wang-Bioinformatics-Lab/ModiFinder_base

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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