Skip to content
Snippets Groups Projects
README.md 2.37 KiB
Newer Older
David Sehnal's avatar
David Sehnal committed
[![License](http://img.shields.io/badge/license-MIT-blue.svg?style=flat)](./LICENSE)
# Mol*
David Sehnal's avatar
David Sehnal committed
The goal of **Mol\*** (*/'mol-star/*) is to provide a technology stack that will serve as basis for the next-generation data delivery and analysis tools for macromolecular structure data. This is a collaboration between PDBe and RCSB PDB teams and the development will be open source and available to anyone who wants to use it for developing visualisation tools for macromolecular structure data available from [PDB](https://www.wwpdb.org/) and other institutions.
David Sehnal's avatar
David Sehnal committed
This particular project is a prototype implementation of this technology (still under development).
David Sehnal's avatar
David Sehnal committed
## Project Overview
David Sehnal's avatar
David Sehnal committed
The core of Mol* currently consists of these modules:
- `mol-task` Computation abstraction with progress tracking and cancellation support.
David Sehnal's avatar
David Sehnal committed
- `mol-data` Collections (integer based sets, interface to columns/tables, etc.)
David Sehnal's avatar
David Sehnal committed
- `mol-math` Math related (loosely) algorithms and data structures.
David Sehnal's avatar
David Sehnal committed
- `mol-io` Parsing library. Each format is parsed into an interface that corresponds to the data stored by it. Support for common coordinate, experimental/map, and annotation data formats.
- `mol-model` Data structures and algorithms (such as querying) for representing molecular data (including coordinate, experimental/map, and annotation data).
- `mol-ql` Mapping of `mol-model` to the [MolQL query language](https://molql.github.io) spec.
David Sehnal's avatar
David Sehnal committed
- `mol-util` Useful things that do not fit elsewhere.

David Sehnal's avatar
David Sehnal committed
The project also contains performance tests (`perf-tests`), `examples`, and basic proof of concept `apps` (CIF to BinaryCIF converter and JSON domain annotation to CIF converter).

## Previous Work
This project builds on experience from previous solutions:
- [LiteMol Suite](https://www.litemol.org)
- [WebChemistry](https://webchem.ncbr.muni.cz)
- [NGL Viewer](http://nglviewer.org/)
- [MolQL](https://molql.github.io)
- [PDB Component Library](https://www.ebi.ac.uk/pdbe/pdb-component-library/)
- And many others (list will be continuously expanded).

Alexander Rose's avatar
Alexander Rose committed
## Building & Running

### Build:
David Sehnal's avatar
David Sehnal committed
   npm install
   npm run build
Alexander Rose's avatar
Alexander Rose committed

### Build automatically on file save:
David Sehnal's avatar
David Sehnal committed
   npm run watch
David Sehnal's avatar
David Sehnal committed
### Run test script from src/script.ts
   npm run script
David Sehnal's avatar
David Sehnal committed
## Contributing
Just open an issue or make a pull request. All contributions are welcome.
David Sehnal's avatar
David Sehnal committed
## Roadmap
Continually develop this prototype project. As individual modules become stable, make them into standalone libraries.