Metadata-Version: 2.1
Name: crimm
Version: 2023.5a3
Summary: Chemistry with the ReInvented Macromolecular
Author-email: Truman Xu <ziqiaoxu@umich.edu>
Project-URL: Homepage, https://github.com/Truman-Xu/crimm
Project-URL: Bug Tracker, https://github.com/Truman-Xu/crimm/issues
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: GNU General Public License v3 (GPLv3)
Classifier: Operating System :: OS Independent
Classifier: Development Status :: 2 - Pre-Alpha
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE

# **CRIMM**
**CRIMM** stands for **Chemistry with the ReInvented Macromolecular Mechanics**. This project aims to integrate and supplement CHARMM with better object handle and APIs

## Why *"reinvent the wheel"*
This is a toolkit that is under active development, where many useful macromolecular modeling routines are selected to be reimplemented. This is an attempt to unify many macromolecular preparation/modeling routine under one platform while offering proper object handles and APIs in python. While currently, we aim to integrate with CHARMM and pyCHARMM, the broader goal is to provide highly usable, integratable, and scriptable python library/platform for simplifying any macromolecular modeling pipelines.

## Base Library and Object Handles
This library is built upon the excellent Biopython library. The macromolecular entity representations are derived from Biopython's entity classes and follow the same hierarchy. As a result, the entities in this library remain fully compatible with all functions and routines provided in Biopython.
## Parser Module
New and improved mmCIF parser is implemented to allow accurate structure representations and more complete information.

## Looper Module
For a given PDB structure with gaps or missing loops in the chain, this module provides functions to query PDB for the residue sequence and fill in the gaps or missing loop regions with the residues coordinates from the homology models.

## Structure Alignment/Superposition

Structure Alignment utilizes Biopython's [Superimposer](http://biopython.org/DIST/docs/tutorial/Tutorial.html#sec241) tool. However, sequence alignment based on the canonical sequence will be performed prior to the superimposition to determine where the residues should be aligned for two polymer chains that are not identical in sequence identity.

## Visualization
[NGLView](http://nglviewer.org/nglview/latest/) is integrated for a direct visualization of structures for Jupyter Notebook/JupuyterLab.
