Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ORNL/TASMANIAN

The Toolkit for Adaptive Stochastic Modeling and Non-Intrusive ApproximatioN
https://github.com/ORNL/TASMANIAN

high-order-approximation-models inverse-problems reduced-order-models uncertainty-quantification

Last synced: 14 days ago
JSON representation

The Toolkit for Adaptive Stochastic Modeling and Non-Intrusive ApproximatioN

Awesome Lists containing this project

README

        

# Tasmanian

[![Ubuntu-tested](https://github.com/ORNL/TASMANIAN/actions/workflows/build-ubuntu.yaml/badge.svg?branch=master)](https://github.com/ORNL/TASMANIAN/actions/workflows/build-ubuntu.yaml)
[![MacOSX-tested](https://github.com/ORNL/TASMANIAN/actions/workflows/build-macos.yaml/badge.svg?branch=master)](https://github.com/ORNL/TASMANIAN/actions/workflows/build-macos.yaml)
[![Windows-tested](https://github.com/ORNL/TASMANIAN/actions/workflows/build-windows.yaml/badge.svg?branch=master)](https://github.com/ORNL/TASMANIAN/actions/workflows/build-windows.yaml)

The Toolkit for Adaptive Stochastic Modeling and Non-Intrusive ApproximatioN is a collection of robust libraries for high dimensional integration and interpolation as well as parameter calibration. This documentation focuses on the libraries and the software API, refer to the PDF document on the project web-page for specifics about the mathematics of the implemented methods.

[Downloads](https://github.com/ORNL/TASMANIAN/releases)

Visit us at [https://github.com/ORNL/Tasmanian](https://github.com/ORNL/Tasmanian)

[Documentation: Latest Stable](https://ornl.github.io/TASMANIAN/stable/)

[Documentation: development (rolling)](https://ornl.github.io/TASMANIAN/)

### Sparse Grids

Sparse Grids is a family of algorithms for constructing multidimensional quadrature and interpolation rules
using multiple tensor products of one dimensional rules with varying degree of precision.
The Tasmanian Sparse Grids Module implements a variety of grids that fall into five major categories:
* **Global grids** use polynomials supported over the entire domain of integration or interpolation.
Such grids are suitable for approximating functions with smooth response.
* **Sequence grids** work much like Global grids, but use optimized internal data-structures for rules that
are based on sequences of points formed from solving a greedy optimization problem
* **Local polynomial grids** use hierarchical piece-wise polynomials with compact support.
Such grids are suitable for approximating functions with localized sharp behavior.
* **Wavelet grids** use special functions that form a Riesz basis which allows for more accurate
local error estimations. Compared to Local polynomial grids, the wavelet basis can provide
similar accuracy with significantly fewer points, but the advantage of the Riesz basis could also
be negated from the higher Lebesgue constant near the domain boundary.
* **Fourier grids** use trigonometric functions with varying frequency and rely on Discrete (complex)
Fourier Transforms. Such grids are suitable for approximating periodic functions,
since periodicity if preserved in the approximation.

### DREAM

The DiffeRential Evolution Adaptive Metropolis is a method to draw samples from an arbitrary probability
distribution defined by an arbitrary non-negative function (not necessarily normalized to integrate to 1).
The DREAM approach is similar to the classical Markov Chain Monte Carlo, but it evolves a large number
of chains simultaneously which leads to better parallelization and (potentially) faster convergence.
In addition, multiple chains allow for better exploration of the probability domain, which is often
advantageous when working with multi-modal distributions.

One of the main applications of DREAM is in the field of Bayesian inference, where samples are drawn
from a posterior distribution comprised from a data-informed likelihood and an arbitrary model.
The DREAM module of Tasmanian can use Tasmanian Sparse Grids approximation to either the model
or the likelihood.

### Math details

The online documentation focuses on the API and usage of the Tasmanian software.
More detailed description of the mathematical capabilities and some of the terminology
can be found at the **Math Manual**

[https://mkstoyanov.github.io/tasmanian_aux_files/docs/TasmanianMathManual.pdf](https://mkstoyanov.github.io/tasmanian_aux_files/docs/TasmanianMathManual.pdf)

### Please cite us
If you use Tasmanian for your research, please cite the Manual and our work on global and locally adaptive grids.

[https://github.com/mkstoyanov/tasmanian_aux_files/blob/main/docs/Tasmanian.bib](https://github.com/mkstoyanov/tasmanian_aux_files/blob/main/docs/Tasmanian.bib)

Download the .bib file:

[https://mkstoyanov.github.io/tasmanian_aux_files/docs/Tasmanian.bib](https://mkstoyanov.github.io/tasmanian_aux_files/docs/Tasmanian.bib)

### Quick Install

See also the detailed [Installation](Doxygen/Installation.md) instructions.

* The CMake way: see the detailed instruction for a full list of options
* supported on Linux, MacOSX and Windows
* The basic way: using GNU Make, `g++` and `/usr/bin/python3`
* supported only on Linux and MacOSX
* enables only very basic features in C++, MATLAB and Python
* Tasmanian is available through Python PIP, make sure you have the latest `pip`
```
python3 -m pip install Tasmanian --user
```
* Tasmanian is included in Spack: [https://spack.io/](https://spack.io/)

### Basic Usage of Tasmanian

* See the Examples in the install prefix:
```
/share/Tasmanian/examples/
```
* The Examples source code is in:
```
//Examples/
```