Skala Exchange Correlation Functional
Project description
Skala: Accurate and scalable exchange-correlation with deep learning
Skala is a neural network-based exchange-correlation functional for density functional theory (DFT), developed by Microsoft Research AI for Science. It uses deep learning to predict exchange-correlation energies from electron density features, surpasses state-of-the-art hybrid functionals in accuracy for main group thermochemistry, kinetics and non-covalent interactions, all at a computational cost similar to semi-local DFT.
Trained on a large, diverse dataset — including coupled-cluster atomization energies and public benchmarks — Skala uses scalable message passing and local layers to learn both local and non-local effects. The model has about 385,000 parameters and matches the accuracy of leading hybrid functionals.
The recommended neural functional is skala-1.1, which uses per-atom packed grids, multiple non-local layers, and symmetric contraction. The legacy skala-1.0 traced model is still loadable via load_functional("skala-1.0").
Learn more about Skala in our ArXiv paper.
What's in here
This repository contains two main components:
- The Python package
skala, distributed on PyPI and on conda-forge. It contains a PyTorch implementation of the Skala model and its bindings to the quantum-chemistry packages PySCF, GPU4PySCF, and ASE. - Examples of using Skala from compiled code through LibTorch and GauXC:
Skala in Azure AI Foundry
The Skala model is also served on Azure AI Foundry.
GauXC development version for PyTorch-based functionals like Skala
GauXC is a CPU/GPU C++ library for XC functionals.
A development version with an add-on supporting PyTorch-based functionals like Skala is available in the skala branch of the GauXC repository.
GauXC is part of the stack that serves Skala in Azure AI Foundry and can be used to integrate Skala into other third-party DFT codes.
For detailed documentation on using GauXC visit the Skala integration guide.
Getting started: PySCF (CPU)
All information below relates to the Python package skala.
pip install skala works out of the box and pulls every dependency from PyPI.
If you don't already have PyTorch installed, install the CPU-only wheel first
to avoid pulling a large CUDA build:
pip install torch --index-url https://download.pytorch.org/whl/cpu
pip install skala
For a reproducible conda environment, use the provided
environment-cpu.yml, which pins CPU-only PyTorch and
all runtime dependencies:
mamba env create -n skala -f environment-cpu.yml
mamba activate skala
pip install skala
Run an SCF calculation with Skala for a hydrogen molecule:
from pyscf import gto
from skala.pyscf import SkalaKS
mol = gto.M(
atom="""H 0 0 0; H 0 0 1.4""",
basis="def2-tzvp",
)
ks = SkalaKS(mol, xc="skala-1.1")
ks.kernel()
Getting started: GPU4PySCF (GPU)
The GPU install is more involved because gpu4pyscf ships CUDA-version-specific
wheels that must match your CUDA toolkit. The recommended path is the provided
environment-gpu.yml, which pins pytorch-gpu,
cuda-toolkit 12, cutensor, and installs gpu4pyscf-cuda12x 1.5 from PyPI:
mamba env create -n skala -f environment-gpu.yml
mamba activate skala
pip install skala
If you are building inside a container without a GPU attached (e.g., CI or a
Docker image built on a CPU-only host), set CONDA_OVERRIDE_CUDA so the solver
proceeds without a device:
CONDA_OVERRIDE_CUDA=12.0 mamba env create -n skala -f environment-gpu.yml
For CUDA 11 or 13, adjust cuda-toolkit, cuda-version, and the
gpu4pyscf-cuda{11,13}x pin in environment-gpu.yml accordingly. Check your
driver's maximum supported CUDA version with nvidia-smi.
Run an SCF calculation with Skala for a hydrogen molecule on GPU:
from pyscf import gto
from skala.gpu4pyscf import SkalaKS
mol = gto.M(
atom="""H 0 0 0; H 0 0 1.4""",
basis="def2-tzvp",
)
ks = SkalaKS(mol, xc="skala-1.1")
ks.kernel()
Getting started: ASE calculator
Skala also provides an ASE calculator for energy, force, and geometry optimization workflows:
from ase.build import molecule
from ase.optimize import LBFGSLineSearch
from skala.ase import Skala
atoms = molecule("H2O")
atoms.calc = Skala(xc="skala-1.1", basis="def2-tzvp")
# Single-point energy (eV)
print(atoms.get_potential_energy())
# Geometry optimization
opt = LBFGSLineSearch(atoms)
opt.run(fmax=0.01)
Documentation and examples
See microsoft.github.io/skala for a more detailed installation guide and further examples of how to use the Skala functional with PySCF, GPU4PySCF, and ASE, as well as in Azure AI Foundry.
Security: loading .fun files
Skala model files (.fun) use TorchScript serialization, which can execute arbitrary code when loaded. Never load .fun files from untrusted sources.
When loading the official Skala models via load_functional("skala-1.1") or load_functional("skala-1.0"), file integrity is automatically verified against pinned SHA-256 hashes before deserialization. If you load .fun files directly with TracedFunctional.load(), pass the expected_hash parameter to enable verification:
TracedFunctional.load("model.fun", expected_hash="<sha256-hex-digest>")
Project information
See the following files for more information about contributing, reporting issues, and the code of conduct:
Trademarks
This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file skala-2026.2.tar.gz.
File metadata
- Download URL: skala-2026.2.tar.gz
- Upload date:
- Size: 84.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bb682c4a90e41170120464c220e01fdb12cd0fb7b0d26be7df0e0ce67e5997ed
|
|
| MD5 |
ea371de571e7e1c589c7eb3f0f11def8
|
|
| BLAKE2b-256 |
bd4183fb2b9fded89e44886b1403816ed83bb67168141e041a21c01b178f987c
|
Provenance
The following attestation bundles were made for skala-2026.2.tar.gz:
Publisher:
pypi.yml on microsoft/skala
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
skala-2026.2.tar.gz -
Subject digest:
bb682c4a90e41170120464c220e01fdb12cd0fb7b0d26be7df0e0ce67e5997ed - Sigstore transparency entry: 1439878797
- Sigstore integration time:
-
Permalink:
microsoft/skala@4aec636e06d21e4d07d8cd09cfa83849044029ea -
Branch / Tag:
refs/tags/v2026.2 - Owner: https://github.com/microsoft
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi.yml@4aec636e06d21e4d07d8cd09cfa83849044029ea -
Trigger Event:
push
-
Statement type:
File details
Details for the file skala-2026.2-py3-none-any.whl.
File metadata
- Download URL: skala-2026.2-py3-none-any.whl
- Upload date:
- Size: 73.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9a4dbdb2111653ab5898da3d22b55107f3ce0103ec46274f322ea489c02a6ef4
|
|
| MD5 |
710e20933666f580a8ebef8da1b2820c
|
|
| BLAKE2b-256 |
b585357129d330f74250ea6bf862c9a12695c0fffb24217e7406e719c8cf9d06
|
Provenance
The following attestation bundles were made for skala-2026.2-py3-none-any.whl:
Publisher:
pypi.yml on microsoft/skala
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
skala-2026.2-py3-none-any.whl -
Subject digest:
9a4dbdb2111653ab5898da3d22b55107f3ce0103ec46274f322ea489c02a6ef4 - Sigstore transparency entry: 1439878805
- Sigstore integration time:
-
Permalink:
microsoft/skala@4aec636e06d21e4d07d8cd09cfa83849044029ea -
Branch / Tag:
refs/tags/v2026.2 - Owner: https://github.com/microsoft
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi.yml@4aec636e06d21e4d07d8cd09cfa83849044029ea -
Trigger Event:
push
-
Statement type: