# Easy MD Analysis (EMDA)
![GitHub License](https://img.shields.io/github/license/MolBioMedUAB/EMDA)
![GitHub Tag](https://img.shields.io/github/v/tag/MolBioMedUAB/EMDA)
![PyPI - Version](https://img.shields.io/pypi/v/EasyMDA)
[![Powered by MDAnalysis](https://img.shields.io/badge/powered%20by-MDAnalysis-orange.svg?logoWidth=16&logo=)](https://www.mdanalysis.org)
## Description
Easy MD Analysis (EMDA) is a Python package based on [MDAnalysis](http://mdanalysis.org) created with the aim of providing an easy, yet powerful way to perform analysis of MD simulations.
## Table of contents
- [Features](#features)
- [Installation](#installation)
- [How to use EMDA](#how-to-use-emda)
- [Future implementations](#future-implementations)
- [Changelog](#changelog)
## Features
### Measurers
Several kinds of measures have been implemented in EMDA. Each of them has its own adder function and calculator function. Adder functions are the functions through which the user is able to request a certain kind of measure, while calculators are the engines that perform the measure when the run function is executed.
The available measures are listed below:
- __Distance__: measures the distance between two sets of atoms
- __Angle__: measures the angle between three atoms
- __Dihedral__: measures the dihedral angle between four atoms
- __Planar angle__: measures the angle between the closest planes to two sets of at least three atoms
- __Distance of bridging waters between two sets of atoms__: identifies the closest water that is bridging between two sets of atoms and measures the distances to each
- __RMSD__: measures the RMSD of a set of atoms (or the whole system) in reference of a frame of the structure
- __Contacts__, both of a group of atoms and of a whole protein: identifies the contacts stablished by a selection in a given radius or the contacts of each residue.
### Analysers
Some analysis can be performed from previous measures and they are stored as Analysis classes. In this case, each analysis has its own analyser. In opposition with measures, analysis are executed when requested. All the analysers functions' names start with the 'analyse_' string.
The available analyis are listed below:
- __value__: analyses the value of a frame-wise measure (like distance, for instance) and returns frame-wise list containing True if the value is between the given values or False if it is not.
- __contacts_frequency__: analyses the contacts and returns a dictionary containing the contacts that take place and how many times it takes place (in an absolute or relative number).
- __contacts_amounts__: analyses the contacts and returns a frame-wise list containing how many contacts a selection (or a residue) stablishes in each frame.
- __NACs__ (near-attack conformations): analyses two or more analysed values (so a frame-wise boolean list) and returns the combination of all the values as a boolean frame-wise list.
### Plotters
Some analysis or measures can be plotted. The plotters functions (named with the plot_ prefix) take the analysis or measures' result and returns a plot depending on the type of data.
The available plotters are listed below:
- __values__: plots a float-containing frame-wise list. A similar method has been implemented inside the Measure class.
- __contacts_frequencies_diff__: external plotter (so it is not a method of the EMDA class). It takes two contacts_frequency (analyser) results (or two lists of), compares them so a bar plot is returned containing the contacts that are the most different between the two sets.
## Installation
### Using pip
```bash
pip install EasyMDA
```
### From source code
1. Clone the GitHub repository in your local machine:
```bash
git clone https://github.com/MolBioMedUAB/EMDA
```
2. Move to the repository direcctory:
```bash
cd EMDA
```
3. Install using pip:
```bash
pip install .
```
## How to use EMDA
EMDA has been design to perform analysis of MD trajectories in three steps: measure, analyse, and plot. Nonetheless, measuring is the most time-consuming task in an analysis. Thus, the code has been structured in such a way that all the requested measures are firstly added using the adders and the ran with the run method. On the other hand, analysis of the measures and plotting tasks are executed at the moment.
An example Jupyter notebook showing how to perform an analysis of a sample trajectory can be found [here](https://github.com/MolBioMedUAB/EMDA/blob/main/example/example.ipynb).
## Future implementations
Future features that will be added in the future can be found in the [TO-DO](https://github.com/MolBioMedUAB/EMDA/blob/main/TO-DO.md) file
## Changelog
Additions or fixed bugs in each version can be found in the [CHANGELOG](https://github.com/MolBioMedUAB/EMDA/blob/main/CHANGELOG.md) file.
Raw data
{
"_id": null,
"home_page": "https://github.com/MolBioMedUAB/EMDA",
"name": "EasyMDA",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "biochemistry,simulations,MDAnalysis,molecular dynamics",
"author": "Miquel Canyelles Ni\u00f1o",
"author_email": "mcanyellesnino@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/68/ea/f9f301e311a21f7163beee303166a1226a8b6cf82c8d9605e9c07e8ad756/EasyMDA-0.3.4.tar.gz",
"platform": null,
"description": "# Easy MD Analysis (EMDA)\n![GitHub License](https://img.shields.io/github/license/MolBioMedUAB/EMDA)\n![GitHub Tag](https://img.shields.io/github/v/tag/MolBioMedUAB/EMDA)\n![PyPI - Version](https://img.shields.io/pypi/v/EasyMDA)\n[![Powered by MDAnalysis](https://img.shields.io/badge/powered%20by-MDAnalysis-orange.svg?logoWidth=16&logo=)](https://www.mdanalysis.org)\n\n## Description\n\nEasy MD Analysis (EMDA) is a Python package based on [MDAnalysis](http://mdanalysis.org) created with the aim of providing an easy, yet powerful way to perform analysis of MD simulations. \n\n## Table of contents\n\n- [Features](#features)\n- [Installation](#installation)\n- [How to use EMDA](#how-to-use-emda)\n- [Future implementations](#future-implementations)\n- [Changelog](#changelog)\n\n## Features\n\n### Measurers\n\nSeveral kinds of measures have been implemented in EMDA. Each of them has its own adder function and calculator function. Adder functions are the functions through which the user is able to request a certain kind of measure, while calculators are the engines that perform the measure when the run function is executed. \n\nThe available measures are listed below:\n- __Distance__: measures the distance between two sets of atoms\n- __Angle__: measures the angle between three atoms\n- __Dihedral__: measures the dihedral angle between four atoms\n- __Planar angle__: measures the angle between the closest planes to two sets of at least three atoms\n- __Distance of bridging waters between two sets of atoms__: identifies the closest water that is bridging between two sets of atoms and measures the distances to each\n- __RMSD__: measures the RMSD of a set of atoms (or the whole system) in reference of a frame of the structure\n- __Contacts__, both of a group of atoms and of a whole protein: identifies the contacts stablished by a selection in a given radius or the contacts of each residue.\n\n### Analysers\n\nSome analysis can be performed from previous measures and they are stored as Analysis classes. In this case, each analysis has its own analyser. In opposition with measures, analysis are executed when requested. All the analysers functions' names start with the 'analyse_' string.\n\nThe available analyis are listed below:\n- __value__: analyses the value of a frame-wise measure (like distance, for instance) and returns frame-wise list containing True if the value is between the given values or False if it is not.\n- __contacts_frequency__: analyses the contacts and returns a dictionary containing the contacts that take place and how many times it takes place (in an absolute or relative number).\n- __contacts_amounts__: analyses the contacts and returns a frame-wise list containing how many contacts a selection (or a residue) stablishes in each frame.\n- __NACs__ (near-attack conformations): analyses two or more analysed values (so a frame-wise boolean list) and returns the combination of all the values as a boolean frame-wise list.\n\n\n### Plotters\n\nSome analysis or measures can be plotted. The plotters functions (named with the plot_ prefix) take the analysis or measures' result and returns a plot depending on the type of data.\n\nThe available plotters are listed below:\n- __values__: plots a float-containing frame-wise list. A similar method has been implemented inside the Measure class.\n- __contacts_frequencies_diff__: external plotter (so it is not a method of the EMDA class). It takes two contacts_frequency (analyser) results (or two lists of), compares them so a bar plot is returned containing the contacts that are the most different between the two sets.\n\n## Installation\n\n### Using pip\n\n```bash\npip install EasyMDA\n```\n\n### From source code\n\n1. Clone the GitHub repository in your local machine:\n```bash\ngit clone https://github.com/MolBioMedUAB/EMDA\n```\n\n2. Move to the repository direcctory:\n```bash\ncd EMDA\n```\n\n3. Install using pip:\n```bash\npip install .\n```\n\n\n## How to use EMDA\n\nEMDA has been design to perform analysis of MD trajectories in three steps: measure, analyse, and plot. Nonetheless, measuring is the most time-consuming task in an analysis. Thus, the code has been structured in such a way that all the requested measures are firstly added using the adders and the ran with the run method. On the other hand, analysis of the measures and plotting tasks are executed at the moment. \n\nAn example Jupyter notebook showing how to perform an analysis of a sample trajectory can be found [here](https://github.com/MolBioMedUAB/EMDA/blob/main/example/example.ipynb).\n\n\n\n## Future implementations\n\nFuture features that will be added in the future can be found in the [TO-DO](https://github.com/MolBioMedUAB/EMDA/blob/main/TO-DO.md) file\n\n\n## Changelog\n\nAdditions or fixed bugs in each version can be found in the [CHANGELOG](https://github.com/MolBioMedUAB/EMDA/blob/main/CHANGELOG.md) file.\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Easy MD Analysis (EMDA) is a Python package created with the aim of providing an easy, yet powerful way to perform analysis of MD simulations.",
"version": "0.3.4",
"project_urls": {
"Download": "https://github.com/MolBioMedUAB/EMDA/archive/refs/tags/0.3.4.tar.gz",
"Homepage": "https://github.com/MolBioMedUAB/EMDA"
},
"split_keywords": [
"biochemistry",
"simulations",
"mdanalysis",
"molecular dynamics"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "68eaf9f301e311a21f7163beee303166a1226a8b6cf82c8d9605e9c07e8ad756",
"md5": "7c7333b27b1bfbf408a3aabbee8cfc5f",
"sha256": "c5924e54616853a8a78a06ce2832dbdebd5cabad90406e93669bf39cdfd395c6"
},
"downloads": -1,
"filename": "EasyMDA-0.3.4.tar.gz",
"has_sig": false,
"md5_digest": "7c7333b27b1bfbf408a3aabbee8cfc5f",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 22391,
"upload_time": "2024-02-26T19:13:48",
"upload_time_iso_8601": "2024-02-26T19:13:48.952858Z",
"url": "https://files.pythonhosted.org/packages/68/ea/f9f301e311a21f7163beee303166a1226a8b6cf82c8d9605e9c07e8ad756/EasyMDA-0.3.4.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-02-26 19:13:48",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "MolBioMedUAB",
"github_project": "EMDA",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "easymda"
}