pararealml


Namepararealml JSON
Version 0.3.0 PyPI version JSON
download
home_pagehttps://github.com/ViktorC/PararealML
SummaryA machine learning boosted parallel-in-time differential equation solver framework
upload_time2023-01-08 01:13:04
maintainer
docs_urlNone
authorViktor Csomor
requires_python
licenseMIT
keywords differential equations finite difference parallel-in-time parareal machine learning deep learning physics-informed neural networks scientific computing
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # PararealML

[![Build Status](https://github.com/ViktorC/PararealML/actions/workflows/build.yml/badge.svg)](https://github.com/ViktorC/PararealML/actions/workflows/build.yml)
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=net.viktorc%3Apararealml&metric=alert_status)](https://sonarcloud.io/dashboard?id=net.viktorc%3Apararealml)
[![PyPI Version](https://badge.fury.io/py/pararealml.svg)](https://badge.fury.io/py/pararealml)
[![Docs](https://img.shields.io/badge/docs-latest-blue.svg)](https://pararealml.readthedocs.io/en/latest/index.html)
[![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](https://opensource.org/licenses/MIT)

PararealML is a differential equation solver library featuring a [Parareal](https://en.wikipedia.org/wiki/Parareal) framework based on a unified interface for initial value problems and various solvers including a number of machine learning accelerated ones. The library's main purpose is to provide a toolset to investigate the properties of the Parareal algorithm, especially when using machine learning accelerated coarse operators, across various problems. The library's implementation of the Parareal algorithm uses [MPI](https://en.wikipedia.org/wiki/Message_Passing_Interface) via [mpi4py](https://mpi4py.readthedocs.io/en/stable/).

## Main components
The library has a modular design to allow for easy extensibility. The main components that enable this are described below.

<img src="https://user-images.githubusercontent.com/12938964/156269280-58213998-58c2-45f1-aabb-7441ac4aa33e.png" alt="pararealml"/>

### Differential equation
Differential equations extend the `DifferentialEquation` base class. In PararealML, all differential equations are time-dependent. Moreover, the unknown variables of differential equations are by definition vector-valued to support systems of differential equations. Both ordinary and partial differential equations are supported.

The library provides out-of-the-box implementations for a number of differential equations including:

 * `PopulationGrowthEquation`
 * `LotkaVolterraEquation`
 * `LorenzEquation`
 * `SIREquation`
 * `VanDerPolEquation`
 * `NBodyGravitationalEquation`
 * `DiffusionEquation`
 * `ConvectionDiffusionEquation`
 * `WaveEquation`
 * `CahnHilliardEquation`
 * `BurgerEquation`
 * `ShallowWaterEquation`
 * `NavierStokesEquation`

To solve other differential equations, the `DifferentialEquation` class can be easily extended. The only method that needs to be implemented to do so is `symbolic_equation_system` which defines the system of differential equations using symbolic expressions.

### Mesh
Meshes in PararealML are represented by the `Mesh` class which defines a hyper-grid with a pair of boundaries and a uniform step size along each dimension. Meshes may be defined in a Cartesian or curvilinear (polar, cylindrical, or spherical) coordinate system.

### Boundary conditions
All boundary conditions extend the `BoundaryCondition` base class. In PararealML, boundary conditions are functions of time and space. It is possible to specify static boundary conditions that only depend on the spatial coordinates to enable the pre-computation of boundary values and thus potentially improve the performance of some of the solvers.

The most important boundary conditions provided are:

 * `DirichletBoundaryCondition`
 * `NeumannBoundaryCondition`
 * `CauchyBoundaryCondition`
 
### Constrained problem
Constrained problems encapsulate either simple ordinary differential equations or partial differential equations coupled with a mesh and boundary conditions. This offers a level of abstraction over the two kinds of differential equations. Constrained problems are represented by the `ConstrainedProblem` class whose constructor takes a differential equation and optionally a mesh and a set of boundary conditions.

### Initial conditions
In PararealML, all initial conditions extend the `InitialCondition` base class.

The library provides a number initial condition implementations including:

 * `DiscreteInitialCondition`
 * `ContinuousInitialCondition`
    * `GaussianInitialCondition`
    * `MarginalBetaProductInitialCondition`

### Initial value problem
Initial value problems are constrained problems associated with a time domain and initial conditions. They are represented by the `InitialValueProblem` class whose constructor takes a constrained problem, a tuple of two bounds defining the time interval, and an initial condition instance.

### Operator
All operators extend the `Operator` base class. Operators are standalone differential equation solvers that can be used as operators in the Parareal framework as well. They are generally constructed by providing a time step size, possibly along other arguments. They then can solve initial value problems and return the trajectories of the solutions with a temporal granularity defined by their time step sizes. The Parareal framework is an operator itself as well.

The list of provided operators is:

 * `ODEOperator`: an ODE solver based on the [solve_ivp](https://docs.scipy.org/doc/scipy/reference/generated/scipy.integrate.solve_ivp.html#scipy.integrate.solve_ivp) function of SciPy's `integrate` module
 * `FDMOperator`: a fast finite difference operator that can solve both ODEs and PDEs
 * `PIDONOperator`: a [Physics-Informed DeepONet](https://arxiv.org/abs/2103.10974) operator that can be trained using variable initial conditions and that can solve both ODEs and PDEs
 * `AutoRegressionOperator`: an auto-regression operator trained on data generated by an oracle operator that can solve any differential equation that it is trained on
 * `PararealOperator`: a Parareal framework that can solve any differential equation its operators can

### Solution
The `solve` method of every operator returns an instance of the `Solution` class that supports a number of functionalities including interpolation, difference computation, and plot generation. The interpolation capability of this class allows the solution to be queried at any spatial point in addition to the cell centers or vertices of the mesh. Moreover, it also allows for the mixing of cell-center-oriented and vertex-oriented solvers as the fine and coarse operators of the Parareal framework.

### Plot
Visualizing the solutions of differential equations is supported by PararealML through the `Plot` base class which enables displaying and saving plots. There are a number of implementations of this class to visualize the solutions of various types of differential equations in any of the supported coordinate systems. The `generate_plots` method of the `Solution` class can conveniently generate all of the relevant plots based on the type of the problem solved. The library provides the following types of plots:

 * `TimePlot`: a simple y-against-t plot to visualise the solutions of systems of ODEs
 * `PhaseSpacePlot`: a 2D or 3D phase space plot for systems of 2 or 3 ODEs respectively
 * `NBodyPlot`: a 2D or 3D animated scatter plot for 2D or 3D n-body simulations
 * `SpaceLinePlot`: an animated line plot for 1D PDEs
 * `ContourPlot`: an animated contour plot for 2D PDEs
 * `SurfacePlot`: an animated 3D surface plot for 2D PDEs
 * `ScatterPlot`: an animated 3D scatter plot for 3D PDEs
 * `StreamPlot`: an animated 2D stream plot for the solution vector field of 2D PDEs
 * `QuiverPlot`: an animated 2D or 3D quiver plot for the solution vector field of 2D or 3D PDEs

A few examples of plots generated by PararealML can be seen below.

<p>
  <img src="https://user-images.githubusercontent.com/12938964/152646803-e044c86c-f631-4cf6-9f6b-d9efdb6ae8df.png" alt="lorenz" width="400"/>
  <img src="https://user-images.githubusercontent.com/12938964/152624090-cab353b4-0fe4-4d19-b9d0-71c9ff9103f5.png" alt="lorenz phase space" width="400"/> 
</p>
<p>
  <img src="https://user-images.githubusercontent.com/12938964/153720536-b4c22dc8-d112-4331-bcc5-130c22a36199.gif" alt="n-body" width="400"/>
  <img src="https://user-images.githubusercontent.com/12938964/152625732-f177fe9b-9184-404b-8737-79411e9ea7e3.gif" alt="wave 2d surface" width="400"/> 
</p>
<p>
  <img src="https://user-images.githubusercontent.com/12938964/152646506-1404a822-dbc9-481e-91ec-b1e6b5a49748.gif" alt="cahn hilliard 3d" width="400"/>
  <img src="https://user-images.githubusercontent.com/12938964/152649580-ced02c20-b95f-4ec2-bd81-d3e34b13f9a5.gif" alt="navier stokes stream" width="400"/> 
</p>

## Examples
The [examples](https://github.com/ViktorC/PararealML/tree/master/examples) folder contains a range of different examples of using the library for solving various differential equations both in serial and parallel. The scripts also include examples of using machine learning operators.

## Installation
To install PararealML, an implementation of the MPI standard must be pre-installed and the `mpicc` program must be on the search path as per the [installation guide](https://mpi4py.readthedocs.io/en/stable/install.html#using-pip) of mpi4py. With that set up, the library can be installed by running `pip install pararealml`.

## Development
 * To install the dependencies of the library, run `make install` (this requires an existing MPI installation and `mpicc`).
 * To perform linting, execute `make lint`.
 * The library uses type-hints throughout. For type checking, use the command `make type-check`.
 * The format any changed modules, run `make format`.
 * To run the unit tests, execute `make test`.
 * To run any of the example scripts using an arbitrary number of MPI processes, run `make run p={number of processes} example={name of example file without extension}` (e.g. `make run p=4 example=lorenz_parareal`).



            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/ViktorC/PararealML",
    "name": "pararealml",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "differential equations,finite difference,parallel-in-time,parareal,machine learning,deep learning,physics-informed neural networks,scientific computing",
    "author": "Viktor Csomor",
    "author_email": "viktor.csomor@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/5e/a5/76903b4893722181c5915de40607c4802f0374fbe4afa09ad07f98e46def/pararealml-0.3.0.tar.gz",
    "platform": null,
    "description": "# PararealML\n\n[![Build Status](https://github.com/ViktorC/PararealML/actions/workflows/build.yml/badge.svg)](https://github.com/ViktorC/PararealML/actions/workflows/build.yml)\n[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=net.viktorc%3Apararealml&metric=alert_status)](https://sonarcloud.io/dashboard?id=net.viktorc%3Apararealml)\n[![PyPI Version](https://badge.fury.io/py/pararealml.svg)](https://badge.fury.io/py/pararealml)\n[![Docs](https://img.shields.io/badge/docs-latest-blue.svg)](https://pararealml.readthedocs.io/en/latest/index.html)\n[![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](https://opensource.org/licenses/MIT)\n\nPararealML is a differential equation solver library featuring a [Parareal](https://en.wikipedia.org/wiki/Parareal) framework based on a unified interface for initial value problems and various solvers including a number of machine learning accelerated ones. The library's main purpose is to provide a toolset to investigate the properties of the Parareal algorithm, especially when using machine learning accelerated coarse operators, across various problems. The library's implementation of the Parareal algorithm uses [MPI](https://en.wikipedia.org/wiki/Message_Passing_Interface) via [mpi4py](https://mpi4py.readthedocs.io/en/stable/).\n\n## Main components\nThe library has a modular design to allow for easy extensibility. The main components that enable this are described below.\n\n<img src=\"https://user-images.githubusercontent.com/12938964/156269280-58213998-58c2-45f1-aabb-7441ac4aa33e.png\" alt=\"pararealml\"/>\n\n### Differential equation\nDifferential equations extend the `DifferentialEquation` base class. In PararealML, all differential equations are time-dependent. Moreover, the unknown variables of differential equations are by definition vector-valued to support systems of differential equations. Both ordinary and partial differential equations are supported.\n\nThe library provides out-of-the-box implementations for a number of differential equations including:\n\n * `PopulationGrowthEquation`\n * `LotkaVolterraEquation`\n * `LorenzEquation`\n * `SIREquation`\n * `VanDerPolEquation`\n * `NBodyGravitationalEquation`\n * `DiffusionEquation`\n * `ConvectionDiffusionEquation`\n * `WaveEquation`\n * `CahnHilliardEquation`\n * `BurgerEquation`\n * `ShallowWaterEquation`\n * `NavierStokesEquation`\n\nTo solve other differential equations, the `DifferentialEquation` class can be easily extended. The only method that needs to be implemented to do so is `symbolic_equation_system` which defines the system of differential equations using symbolic expressions.\n\n### Mesh\nMeshes in PararealML are represented by the `Mesh` class which defines a hyper-grid with a pair of boundaries and a uniform step size along each dimension. Meshes may be defined in a Cartesian or curvilinear (polar, cylindrical, or spherical) coordinate system.\n\n### Boundary conditions\nAll boundary conditions extend the `BoundaryCondition` base class. In PararealML, boundary conditions are functions of time and space. It is possible to specify static boundary conditions that only depend on the spatial coordinates to enable the pre-computation of boundary values and thus potentially improve the performance of some of the solvers.\n\nThe most important boundary conditions provided are:\n\n * `DirichletBoundaryCondition`\n * `NeumannBoundaryCondition`\n * `CauchyBoundaryCondition`\n \n### Constrained problem\nConstrained problems encapsulate either simple ordinary differential equations or partial differential equations coupled with a mesh and boundary conditions. This offers a level of abstraction over the two kinds of differential equations. Constrained problems are represented by the `ConstrainedProblem` class whose constructor takes a differential equation and optionally a mesh and a set of boundary conditions.\n\n### Initial conditions\nIn PararealML, all initial conditions extend the `InitialCondition` base class.\n\nThe library provides a number initial condition implementations including:\n\n * `DiscreteInitialCondition`\n * `ContinuousInitialCondition`\n    * `GaussianInitialCondition`\n    * `MarginalBetaProductInitialCondition`\n\n### Initial value problem\nInitial value problems are constrained problems associated with a time domain and initial conditions. They are represented by the `InitialValueProblem` class whose constructor takes a constrained problem, a tuple of two bounds defining the time interval, and an initial condition instance.\n\n### Operator\nAll operators extend the `Operator` base class. Operators are standalone differential equation solvers that can be used as operators in the Parareal framework as well. They are generally constructed by providing a time step size, possibly along other arguments. They then can solve initial value problems and return the trajectories of the solutions with a temporal granularity defined by their time step sizes. The Parareal framework is an operator itself as well.\n\nThe list of provided operators is:\n\n * `ODEOperator`: an ODE solver based on the [solve_ivp](https://docs.scipy.org/doc/scipy/reference/generated/scipy.integrate.solve_ivp.html#scipy.integrate.solve_ivp) function of SciPy's `integrate` module\n * `FDMOperator`: a fast finite difference operator that can solve both ODEs and PDEs\n * `PIDONOperator`: a [Physics-Informed DeepONet](https://arxiv.org/abs/2103.10974) operator that can be trained using variable initial conditions and that can solve both ODEs and PDEs\n * `AutoRegressionOperator`: an auto-regression operator trained on data generated by an oracle operator that can solve any differential equation that it is trained on\n * `PararealOperator`: a Parareal framework that can solve any differential equation its operators can\n\n### Solution\nThe `solve` method of every operator returns an instance of the `Solution` class that supports a number of functionalities including interpolation, difference computation, and plot generation. The interpolation capability of this class allows the solution to be queried at any spatial point in addition to the cell centers or vertices of the mesh. Moreover, it also allows for the mixing of cell-center-oriented and vertex-oriented solvers as the fine and coarse operators of the Parareal framework.\n\n### Plot\nVisualizing the solutions of differential equations is supported by PararealML through the `Plot` base class which enables displaying and saving plots. There are a number of implementations of this class to visualize the solutions of various types of differential equations in any of the supported coordinate systems. The `generate_plots` method of the `Solution` class can conveniently generate all of the relevant plots based on the type of the problem solved. The library provides the following types of plots:\n\n * `TimePlot`: a simple y-against-t plot to visualise the solutions of systems of ODEs\n * `PhaseSpacePlot`: a 2D or 3D phase space plot for systems of 2 or 3 ODEs respectively\n * `NBodyPlot`: a 2D or 3D animated scatter plot for 2D or 3D n-body simulations\n * `SpaceLinePlot`: an animated line plot for 1D PDEs\n * `ContourPlot`: an animated contour plot for 2D PDEs\n * `SurfacePlot`: an animated 3D surface plot for 2D PDEs\n * `ScatterPlot`: an animated 3D scatter plot for 3D PDEs\n * `StreamPlot`: an animated 2D stream plot for the solution vector field of 2D PDEs\n * `QuiverPlot`: an animated 2D or 3D quiver plot for the solution vector field of 2D or 3D PDEs\n\nA few examples of plots generated by PararealML can be seen below.\n\n<p>\n  <img src=\"https://user-images.githubusercontent.com/12938964/152646803-e044c86c-f631-4cf6-9f6b-d9efdb6ae8df.png\" alt=\"lorenz\" width=\"400\"/>\n  <img src=\"https://user-images.githubusercontent.com/12938964/152624090-cab353b4-0fe4-4d19-b9d0-71c9ff9103f5.png\" alt=\"lorenz phase space\" width=\"400\"/> \n</p>\n<p>\n  <img src=\"https://user-images.githubusercontent.com/12938964/153720536-b4c22dc8-d112-4331-bcc5-130c22a36199.gif\" alt=\"n-body\" width=\"400\"/>\n  <img src=\"https://user-images.githubusercontent.com/12938964/152625732-f177fe9b-9184-404b-8737-79411e9ea7e3.gif\" alt=\"wave 2d surface\" width=\"400\"/> \n</p>\n<p>\n  <img src=\"https://user-images.githubusercontent.com/12938964/152646506-1404a822-dbc9-481e-91ec-b1e6b5a49748.gif\" alt=\"cahn hilliard 3d\" width=\"400\"/>\n  <img src=\"https://user-images.githubusercontent.com/12938964/152649580-ced02c20-b95f-4ec2-bd81-d3e34b13f9a5.gif\" alt=\"navier stokes stream\" width=\"400\"/> \n</p>\n\n## Examples\nThe [examples](https://github.com/ViktorC/PararealML/tree/master/examples) folder contains a range of different examples of using the library for solving various differential equations both in serial and parallel. The scripts also include examples of using machine learning operators.\n\n## Installation\nTo install PararealML, an implementation of the MPI standard must be pre-installed and the `mpicc` program must be on the search path as per the [installation guide](https://mpi4py.readthedocs.io/en/stable/install.html#using-pip) of mpi4py. With that set up, the library can be installed by running `pip install pararealml`.\n\n## Development\n * To install the dependencies of the library, run `make install` (this requires an existing MPI installation and `mpicc`).\n * To perform linting, execute `make lint`.\n * The library uses type-hints throughout. For type checking, use the command `make type-check`.\n * The format any changed modules, run `make format`.\n * To run the unit tests, execute `make test`.\n * To run any of the example scripts using an arbitrary number of MPI processes, run `make run p={number of processes} example={name of example file without extension}` (e.g. `make run p=4 example=lorenz_parareal`).\n\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "A machine learning boosted parallel-in-time differential equation solver framework",
    "version": "0.3.0",
    "split_keywords": [
        "differential equations",
        "finite difference",
        "parallel-in-time",
        "parareal",
        "machine learning",
        "deep learning",
        "physics-informed neural networks",
        "scientific computing"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "2d8f81dd44f2502949acad03666bd865076caec1b5e963e295f3596123f6cf1f",
                "md5": "38ac589514f656a3a5de15155acb550d",
                "sha256": "ebf6bcdb6de3f33fd264e299d7d3fb4b74bb021a741780f0bf052df80c947c98"
            },
            "downloads": -1,
            "filename": "pararealml-0.3.0-py3.8.egg",
            "has_sig": false,
            "md5_digest": "38ac589514f656a3a5de15155acb550d",
            "packagetype": "bdist_egg",
            "python_version": "0.3.0",
            "requires_python": null,
            "size": 432745,
            "upload_time": "2023-01-08T01:13:02",
            "upload_time_iso_8601": "2023-01-08T01:13:02.494567Z",
            "url": "https://files.pythonhosted.org/packages/2d/8f/81dd44f2502949acad03666bd865076caec1b5e963e295f3596123f6cf1f/pararealml-0.3.0-py3.8.egg",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "7521bf5c3da8692d60fe1dd6c86a3162a1242fbd7edb0342b95404375ecd1262",
                "md5": "c756a52f4a7128e788cdb86173b62ec5",
                "sha256": "2859309ab7d76bb94f79b070ed18f9c6d684dd67e49ce7db5272feebbd2080f6"
            },
            "downloads": -1,
            "filename": "pararealml-0.3.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "c756a52f4a7128e788cdb86173b62ec5",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 169306,
            "upload_time": "2023-01-08T01:13:00",
            "upload_time_iso_8601": "2023-01-08T01:13:00.412282Z",
            "url": "https://files.pythonhosted.org/packages/75/21/bf5c3da8692d60fe1dd6c86a3162a1242fbd7edb0342b95404375ecd1262/pararealml-0.3.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "5ea576903b4893722181c5915de40607c4802f0374fbe4afa09ad07f98e46def",
                "md5": "98c8e2784260188a14ce6a77e6fbd4d4",
                "sha256": "a9340ddaf413c8b73e335fa37d6ef3e9da22a8e2dc9eb42ddeba74484d07a054"
            },
            "downloads": -1,
            "filename": "pararealml-0.3.0.tar.gz",
            "has_sig": false,
            "md5_digest": "98c8e2784260188a14ce6a77e6fbd4d4",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 101179,
            "upload_time": "2023-01-08T01:13:04",
            "upload_time_iso_8601": "2023-01-08T01:13:04.393019Z",
            "url": "https://files.pythonhosted.org/packages/5e/a5/76903b4893722181c5915de40607c4802f0374fbe4afa09ad07f98e46def/pararealml-0.3.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-01-08 01:13:04",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": "ViktorC",
    "github_project": "PararealML",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "pararealml"
}
        
Elapsed time: 0.02833s