Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
7f4af18
Add an empty metatomic-core python package, re-exporting metatomic-torch
Luthaf May 12, 2026
7b6dc8b
Use pathlib for all path manipulations
Luthaf May 21, 2026
92b0121
Switch main test runner from tox to cargo
Luthaf May 12, 2026
70d3563
Scaffold a new metatomic-core package
Luthaf May 13, 2026
b8dee0c
Draft the C API for metatomic-core
Luthaf May 27, 2026
64c693b
Implement PairListOptions json serialization
sofiia-chorna May 28, 2026
daa5ec0
Implement JSON serialization for `Quantity`
GardevoirX May 28, 2026
1f34385
Validate quantities names
Luthaf May 29, 2026
14aac9c
Implement JSON serialization for ModelMetadata
alessandroforina May 28, 2026
11968be
Add error handling based on metatensor
RMeli May 28, 2026
3c674fd
Implement mta_string_t in the C API
johannes-spies May 28, 2026
a32670c
Port unit parsing from metatomic-torch
Luthaf May 29, 2026
59b7275
document mta_model_t and related functions in C API
sofiia-chorna May 30, 2026
302be28
Add ModelCapabilities to the JSON structs
Luthaf May 31, 2026
624ec6b
Implement plugin registration and loading, model loading
frostedoyster Jun 1, 2026
bca245b
Add a C model registration test
frostedoyster May 29, 2026
aac38ae
Implement System in metatomic-core
Luthaf Jun 1, 2026
833b9aa
Implement `mta_format_metadata`
GardevoirX Jun 3, 2026
7820405
Add unit conversion and error handling to C++
RMeli Jun 2, 2026
8aa8516
Add C++ documentation
Luthaf Jun 3, 2026
b385477
Make `quantity` a module and create the skeleton of `check_quantity`
GardevoirX Jun 4, 2026
82f90f6
Implement `check_quantities`
GardevoirX Jun 5, 2026
4ea18f0
Remove marco importing commands
GardevoirX Jun 5, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 10 additions & 1 deletion .github/workflows/build-wheels.yml
Original file line number Diff line number Diff line change
Expand Up @@ -100,8 +100,17 @@ jobs:
CIBW_BUILD_VERBOSITY: 1
CIBW_MANYLINUX_X86_64_IMAGE: gcc11-manylinux_2_28_x86_64
CIBW_MANYLINUX_AARCH64_IMAGE: gcc11-manylinux_2_28_aarch64
# METATOMIC_NO_LOCAL_DEPS is set to 1 when building a tag of
# metatomic-torch, which will force to use the version of
# metatomic-core already released on PyPI. Otherwise, this will use
# the version of metatomic-core from git checkout (in case there are
# unreleased breaking changes).
#
# This means that when releasing a breaking change in metatomic-core,
# the full release should be available on PyPI before pushing the new
# metatomic-torch tag.
CIBW_ENVIRONMENT: >
METATOMIC_NO_LOCAL_DEPS=1
METATOMIC_NO_LOCAL_DEPS=${{ startsWith(github.ref, 'refs/tags/metatomic-torch-v') && '1' || '0' }}
METATOMIC_TORCH_BUILD_WITH_TORCH_VERSION=${{ matrix.torch-version }}.*
PIP_EXTRA_INDEX_URL=https://download.pytorch.org/whl/cpu
MACOSX_DEPLOYMENT_TARGET=11
Expand Down
96 changes: 96 additions & 0 deletions .github/workflows/python-tests.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
name: Python tests

on:
push:
branches: [main]
pull_request:
# Check all PR

concurrency:
group: python-tests-${{ github.ref }}
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }}

jobs:
python-tests:
runs-on: ${{ matrix.os }}
name: ${{ matrix.os }} / Python ${{ matrix.python-version }} / Torch ${{ matrix.torch-version }}
strategy:
matrix:
include:
- os: ubuntu-24.04
python-version: "3.10"
torch-version: "2.3"
numpy-version-pin: "<2.0"
# Do not run docs-tests with python 3.10 since torch-sim-atomistic
# is not available for this version of python
tox-envs: lint,torch-tests
- os: ubuntu-24.04
python-version: "3.10"
torch-version: "2.12"
# See above
tox-envs: lint,torch-tests
- os: ubuntu-24.04
# TorchScript is no longer supported in Python 3.14
# so we keep a test with 3.13 to make sure this doesn't break
python-version: "3.13"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
- os: ubuntu-24.04
python-version: "3.14"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
- os: macos-15
python-version: "3.14"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
- os: windows-2022
python-version: "3.14"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
steps:
- uses: actions/checkout@v6
with:
fetch-depth: 0

- name: setup Python
uses: actions/setup-python@v6
with:
python-version: ${{ matrix.python-version }}

- name: setup rust
uses: dtolnay/rust-toolchain@master
with:
toolchain: stable

- name: Cache Rust dependencies
uses: Leafwing-Studios/cargo-cache@v2.6.1
with:
sweep-cache: true

- name: Setup sccache
if: ${{ !env.ACT }}
uses: mozilla-actions/sccache-action@v0.0.10
with:
version: "v0.10.0"

- name: setup MSVC command prompt
uses: ilammy/msvc-dev-cmd@v1

- name: Setup sccache environnement variables
if: ${{ !env.ACT }}
run: |
echo "SCCACHE_GHA_ENABLED=true" >> $GITHUB_ENV
echo "RUSTC_WRAPPER=sccache" >> $GITHUB_ENV
echo "CMAKE_C_COMPILER_LAUNCHER=sccache" >> $GITHUB_ENV
echo "CMAKE_CXX_COMPILER_LAUNCHER=sccache" >> $GITHUB_ENV

- name: install tests dependencies
run: |
python -m pip install --upgrade pip
python -m pip install tox coverage

- name: run tests
run: tox -e ${{ matrix.tox-envs }}
env:
PIP_EXTRA_INDEX_URL: https://download.pytorch.org/whl/cpu
METATOMIC_TESTS_TORCH_VERSION: ${{ matrix.torch-version }}
186 changes: 186 additions & 0 deletions .github/workflows/rust-tests.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,186 @@
name: Rust tests

on:
push:
branches: [main]
pull_request:
# Check all PR

concurrency:
group: rust-tests-${{ github.ref }}
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }}

jobs:
rust-tests:
name: ${{ matrix.os }} / Rust ${{ matrix.rust-version }}${{ matrix.extra-name }}
runs-on: ${{ matrix.os }}
container: ${{ matrix.container }}
defaults:
run:
shell: "bash"
env:
CMAKE_CXX_COMPILER: ${{ matrix.cxx }}
CMAKE_C_COMPILER: ${{ matrix.cc }}
CMAKE_GENERATOR: ${{ matrix.cmake-generator }}
strategy:
matrix:
include:
- os: ubuntu-24.04
rust-version: stable
rust-target: x86_64-unknown-linux-gnu
cxx: g++
cc: gcc
cmake-generator: Unix Makefiles

# check the build on a stock Ubuntu 22.04, which uses cmake 3.22, and
# with our minimal supported rust version
- os: ubuntu-24.04
rust-version: 1.74
container: ubuntu:22.04
rust-target: x86_64-unknown-linux-gnu
extra-name: ", cmake 3.22"
cxx: g++
cc: gcc
cmake-generator: Unix Makefiles

- os: macos-15
rust-version: stable
rust-target: aarch64-apple-darwin
extra-name: ""
cxx: clang++
cc: clang
cmake-generator: Unix Makefiles

# - os: windows-2022
# rust-version: stable
# rust-target: x86_64-pc-windows-msvc
# extra-name: " / MSVC"
# cxx: cl.exe
# cc: cl.exe
# cmake-generator: Visual Studio 17 2022

# - os: windows-2022
# rust-version: stable
# rust-target: x86_64-pc-windows-gnu
# extra-name: " / MinGW"
# cxx: g++.exe
# cc: gcc.exe
# cmake-generator: MinGW Makefiles
steps:
- name: install dependencies in container
if: matrix.container == 'ubuntu:22.04'
run: |
apt update
apt install -y software-properties-common
apt install -y cmake make gcc g++ git curl python3-venv

- uses: actions/checkout@v6
with:
fetch-depth: 0

- name: Configure git safe directory
if: matrix.container == 'ubuntu:22.04'
run: git config --global --add safe.directory /__w/metatomic/metatomic

- name: setup rust
uses: dtolnay/rust-toolchain@master
with:
toolchain: ${{ matrix.rust-version }}
target: ${{ matrix.rust-target }}

- name: setup Python
uses: actions/setup-python@v6
if: matrix.container == null
with:
# Python 3.14.5 fails with "No module named pip.__main__; 'pip' is a
# package and cannot be directly executed" when using a venv, so we
# use 3.14.4 for now
python-version: "3.14.4"

- name: Cache Rust dependencies
uses: Leafwing-Studios/cargo-cache@v2.6.1
with:
sweep-cache: true

- name: install valgrind
if: matrix.do-valgrind
run: |
sudo apt-get install -y valgrind

- name: Setup sccache
if: ${{ !env.ACT }}
uses: mozilla-actions/sccache-action@v0.0.10
with:
version: "v0.15.0"

- name: Setup sccache environnement variables
if: ${{ !env.ACT }}
run: |
echo "SCCACHE_GHA_ENABLED=true" >> $GITHUB_ENV
echo "RUSTC_WRAPPER=sccache" >> $GITHUB_ENV
echo "CMAKE_C_COMPILER_LAUNCHER=sccache" >> $GITHUB_ENV
echo "CMAKE_CXX_COMPILER_LAUNCHER=sccache" >> $GITHUB_ENV

- name: run tests
run: |
cargo test --package metatomic-core --target ${{ matrix.rust-target }}
env:
RUST_BACKTRACE: full

- name: check that the header was already up to date
run: |
git diff --exit-code

# check that the C API declarations are correctly documented and used
prevent-bitrot:
runs-on: ubuntu-24.04
name: check C API declarations
steps:
- uses: actions/checkout@v6

- name: setup Python
uses: actions/setup-python@v6
with:
python-version: "3.14"

- name: install python dependencies
run: |
pip install pycparser

- name: check that C API functions are all documented
run: |
python scripts/check-c-api-docs.py

# make sure no debug print stays in the code
check-debug-prints:
runs-on: ubuntu-24.04
name: check leftover debug print

steps:
- uses: actions/checkout@v6

- name: install ripgrep
run: |
wget https://github.com/BurntSushi/ripgrep/releases/download/13.0.0/ripgrep-13.0.0-x86_64-unknown-linux-musl.tar.gz
tar xf ripgrep-13.0.0-x86_64-unknown-linux-musl.tar.gz
echo "$(pwd)/ripgrep-13.0.0-x86_64-unknown-linux-musl" >> $GITHUB_PATH

- name: check for leftover dbg!
run: |
# use ripgrep (rg) to check for instances of `dbg!` in rust files.
# rg will return 1 if it fails to find a match, so we invert it again
# with the `!` builtin to get the error/success in CI

! rg "dbg!" --type=rust --quiet

- name: check for leftover \#include <iostream>
run: |
! rg "<iostream>" --iglob "\!metatomic-core/tests/cpp/external/catch/catch.hpp" --quiet

- name: check for leftover std::cout
run: |
! rg "cout" --iglob "\!metatomic-core/tests/cpp/external/catch/catch.hpp" --quiet

- name: check for leftover std::cerr
run: |
! rg "cerr" --iglob "\!metatomic-core/tests/cpp/external/catch/catch.hpp" --quiet
Loading
Loading