Generation of Q-coefficients for Spectral Deferred Corrections (and other time-integration methods ...)
Project description
QMat Package
qmat
is a python package to generate matrix coefficients related to Collocation methods, Spectral Deferred Corrections (SDC),
and more general multi-stages time-integration methods (like Runge-Kutta, etc ...).
It allows to generate $Q$-coefficients for multi-stages methods (equivalent to Butcher tables) :
$$ Q\text{-coefficients : } \begin{array}{c|c} \tau & Q \ \hline & w^\top \end{array} \quad \Leftrightarrow \quad \begin{array}{c|c} c & A \ \hline & b^\top \end{array} \quad\text{(Butcher table)} $$
and many different lower-triangular approximations of the $Q$ matrix, named $Q_\Delta$, which are key elements for Spectral Deferred Correction (SDC), or more general Iterated Runge-Kutta Methods.
Installation
pip install qmat
🔍 See more detailed instructions for conda environment, development, ...
Basic usage
📜 If you are already familiar with those concepts, you can use this package like this :
from qmat import genQCoeffs, genQDeltaCoeffs
# Coefficients or specific collocation method
nodes, weights, Q = genQCoeffs(
"Collocation", nNodes=4, nodeType="LEGENDRE", quadType="RADAU-RIGHT")
# QDelta matrix from Implicit-Euler based SDC
QDelta = genQDeltaCoeffs("IE", nodes=nodes)
# Butcher table of the classical explicit RK4 method
c, b, A = genQCoeffs("ERK4")
🔔 If you are not familiar with SDC or related methods, and want to learn more about it, checkout the latest documentation build and in particular the step by step tutorials
For any contribution, please checkout out (very cool) Contribution Guidelines and the current Development Roadmap.
Projects relying on qmat
- pySDC : Python implementation of the spectral deferred correction (SDC) approach and its flavors, esp. the multilevel extension MLSDC and PFASST.
Links
- Documentation : https://qmat.readthedocs.io/
- Issues Tracker : https://github.com/Parallel-in-Time/qmat/issues
- Q&A : https://github.com/Parallel-in-Time/qmat/discussions/categories/q-a
- Project Proposals : https://github.com/Parallel-in-Time/qmat/discussions/categories/project-proposals
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file qmat-0.1.13.tar.gz
.
File metadata
- Download URL: qmat-0.1.13.tar.gz
- Upload date:
- Size: 388.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4500b97fdf0a50102603eac92ae0fdde9775374c9457a5cf4965dff27f028940 |
|
MD5 | d8ed8326a2a6014a746860577a02c538 |
|
BLAKE2b-256 | 9842cc749c3ad917fecab6b061ea2b245840d7807de80e488e81ccbc47a0193d |
Provenance
The following attestation bundles were made for qmat-0.1.13.tar.gz
:
Publisher:
publish.yml
on Parallel-in-Time/qmat
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
qmat-0.1.13.tar.gz
- Subject digest:
4500b97fdf0a50102603eac92ae0fdde9775374c9457a5cf4965dff27f028940
- Sigstore transparency entry: 148683028
- Sigstore integration time:
- Predicate type: