Skip to main content

Utility for reaction modeling using graph grammar

Project description

SynKit

PyPI version Conda version Docker Pulls Docker Image Version License Release Last Commit Zenodo CI Dependency PRs Stars

Toolkit for Synthesis Planning

SynKit is a collection of tools designed to support the planning and execution of chemical synthesis.

SynKit

Our tools are tailored to assist researchers and chemists in navigating complex chemical reactions and synthesis pathways, leveraging the power of modern computational chemistry. Whether you're designing novel compounds or optimizing existing processes, synkit aims to provide the critical tools you need.

For more details on each utility within the repository, please refer to the documentation provided in the respective folders.

Table of Contents

Installation

  1. Python Installation: Ensure that Python 3.11 or later is installed on your system. You can download it from python.org.

  2. Creating a Virtual Environment (Optional but Recommended): It's recommended to use a virtual environment to avoid conflicts with other projects or system-wide packages. Use the following commands to create and activate a virtual environment:

python -m venv synkit-env
source synkit-env/bin/activate  

Or Conda

conda create --name synkit-env python=3.11
conda activate synkit-env
  1. Install from PyPi: The easiest way to use SynTemp is by installing the PyPI package synkit.
pip install synkit

Optional if you want to install full version

pip install synkit[all]
  1. Install via Docker
    Pull the image:

    docker pull tieulongphan/synkit:latest
    # or a specific version:
    docker pull tieulongphan/synkit:0.1.0
    

    Run a container (sanity check):

    docker run --rm tieulongphan/synkit:latest
    

Contribute

We're welcoming new contributors to build this project better. Please not hesitate to inquire me via [email][tieu@bioinf.uni-leipzig.de].

Before you start, ensure your local development environment is set up correctly. Pull the latest version of the main branch to start with the most recent stable code.

git checkout main
git pull

Working on New Features

  1. Create a New Branch:
    For every new feature or bug fix, create a new branch from the main branch. Name your branch meaningfully, related to the feature or fix you are working on.

    git checkout -b feature/your-feature-name
    
  2. Develop and Commit Changes:
    Make your changes locally, commit them to your branch. Keep your commits small and focused; each should represent a logical unit of work.

    git commit -m "Describe the change"
    
  3. Run Quality Checks:
    Before finalizing your feature, run the following commands to ensure your code meets our formatting standards and passes all tests:

    ./lint.sh # Check code format
    pytest Test # Run tests
    

    Fix any issues or errors highlighted by these checks.

Integrating Changes

  1. Rebase onto Staging:
    Once your feature is complete and tests pass, rebase your changes onto the staging branch to prepare for integration.

    git fetch origin
    git rebase origin/staging
    

    Carefully resolve any conflicts that arise during the rebase.

  2. Push to Your Feature Branch: After successfully rebasing, push your branch to the remote repository.

    git push origin feature/your-feature-name
    
  3. Create a Pull Request: Open a pull request from your feature branch to the staging branch. Ensure the pull request description clearly describes the changes and any additional context necessary for review.

Contributing

Publication

SynKit: An Advanced Cheminformatics Python Library for Efficient Manipulation and Analysis of Chemical Reaction Data

License

This project is licensed under MIT License - see the License file for details.

Acknowledgments

This project has received funding from the European Unions Horizon Europe Doctoral Network programme under the Marie-Skłodowska-Curie grant agreement No 101072930 (TACsy -- Training Alliance for Computational)

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

synkit-0.0.16.tar.gz (4.5 kB view details)

Uploaded Source

Built Distribution

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

synkit-0.0.16-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

Details for the file synkit-0.0.16.tar.gz.

File metadata

  • Download URL: synkit-0.0.16.tar.gz
  • Upload date:
  • Size: 4.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for synkit-0.0.16.tar.gz
Algorithm Hash digest
SHA256 94095c5ef60b046193aa3d386876a5f04fd7910b089ff0de54cda51403be083d
MD5 d7781c76607acbb8eb4c8fb555513ca5
BLAKE2b-256 b018a49a98ed78f4e89d4c0b0bdff4928b7f98d39c34b30d4602383dedf980fb

See more details on using hashes here.

Provenance

The following attestation bundles were made for synkit-0.0.16.tar.gz:

Publisher: publish-package.yml on TieuLongPhan/SynKit

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

File details

Details for the file synkit-0.0.16-py3-none-any.whl.

File metadata

  • Download URL: synkit-0.0.16-py3-none-any.whl
  • Upload date:
  • Size: 4.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for synkit-0.0.16-py3-none-any.whl
Algorithm Hash digest
SHA256 8667bf3e8511cd6893a4ff8e62330301f8b96650fdf925fc4d130dd75a5ee9c9
MD5 3530794c79d586e3fa032645daabfc81
BLAKE2b-256 7f13040d188188f1f446e2eab4d4d7e7486778e568e9fb77e3db959e2bb9146b

See more details on using hashes here.

Provenance

The following attestation bundles were made for synkit-0.0.16-py3-none-any.whl:

Publisher: publish-package.yml on TieuLongPhan/SynKit

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