Skip to main content

Pytorch based crystallographic refinement

Reason this release was yanked:

New version changes cli args

Project description

TorchRef

A PyTorch-based crystallographic refinement library

Python 3.8+ PyTorch License: MIT Documentation

TorchRef is a crystallographic refinement package built entirely on PyTorch. By leveraging PyTorch's automatic differentiation and GPU acceleration, TorchRef enables seamless integration with machine learning workflows and provides a flexible, extensible framework for crystallographic structure refinement.

Key Features

  • Native PyTorch Integration: Built on PyTorch's nn.Module architecture, TorchRef integrates naturally with the PyTorch ecosystem, including machine learning models, optimizers, and GPU acceleration.

  • Automatic Differentiation: Dynamic computational graphs eliminate the need for manually implemented gradient calculations. Define new refinement targets directly—PyTorch handles the derivatives automatically.

  • Modular Architecture: Following PyTorch's module pattern, components are easily composable and extensible. Add custom targets, restraints, or optimizers without modifying core code.

  • GPU Acceleration: Leverage CUDA for structure factor calculations, scaling, and optimization—achieving significant speedups for large structures.

  • FFT-based Structure Factors: Efficient structure factor calculation using Fast Fourier Transform (FFT) methods, enabling rapid F_calc computation even for large unit cells.

  • State Management: Full state_dict support enables saving and loading complete refinement states, including model parameters, scaler settings, and restraints.

Getting Started

Notebook Description
Open In Colab Basic Usage - Getting started tutorial
Open In Colab Code Examples - Common patterns and recipes
Open In Colab Target Exploration - Exploring refinement targets
Open In Colab Structure Factor Calculation - FFT-based F_calc

Installation

pip install torchref

Local installation for development

clone the repository

git clone https://github.com/HatPdotS/TorchRef.git cd torchref

Install with pip

pip install -e .

Or install with development dependencies

pip install -e ".[dev]"

Dependencies

  • Python ≥ 3.10
  • PyTorch ≥ 2.40
  • NumPy ≥ 2.0
  • Gemmi ≥ 0.5
  • reciprocalspaceship ≥ 0.9
  • SciPy ≥ 1.7

Testing

# Run all tests
pytest tests/

# Run with coverage
pytest tests/ --cov=torchref

# Run specific test categories
pytest tests/unit/           # Fast unit tests
pytest tests/integration/    # Integration tests
pytest tests/functional/     # Full workflow tests

Contributing

Contributions are welcome! Please follow these guidelines:

  1. Follow the NumPy docstring style
  2. Add tests for new functionality
  3. Ensure all tests pass before submitting

License

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

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

torchref-0.4.2.tar.gz (2.9 MB view details)

Uploaded Source

Built Distribution

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

torchref-0.4.2-py3-none-any.whl (3.1 MB view details)

Uploaded Python 3

File details

Details for the file torchref-0.4.2.tar.gz.

File metadata

  • Download URL: torchref-0.4.2.tar.gz
  • Upload date:
  • Size: 2.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for torchref-0.4.2.tar.gz
Algorithm Hash digest
SHA256 72a67eab38d06c9f1c59acd4f2e398faa45f78453d3e787dc136b9385a19cf73
MD5 b24c019264edb1c70b76193c293ea833
BLAKE2b-256 ae0d52864d8146269e718c1cb7b47a20f899e4035f19e0ccb7e5d59315f65bb4

See more details on using hashes here.

Provenance

The following attestation bundles were made for torchref-0.4.2.tar.gz:

Publisher: publish.yml on HatPdotS/TorchRef

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

File details

Details for the file torchref-0.4.2-py3-none-any.whl.

File metadata

  • Download URL: torchref-0.4.2-py3-none-any.whl
  • Upload date:
  • Size: 3.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for torchref-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 89f57ab18d26c3527f4fce2ae61c89b37b9d8813c42fe6090a8fcc2e10c0eb6c
MD5 05c11ada6382d97067d0234fd713bf6e
BLAKE2b-256 1537ed32c8184a2173783ba9429a9a0b2932172539ba3cb7b23f3ca26dfba1fd

See more details on using hashes here.

Provenance

The following attestation bundles were made for torchref-0.4.2-py3-none-any.whl:

Publisher: publish.yml on HatPdotS/TorchRef

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