Skip to content

Commit

Permalink
Update readme and start expanding documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
kburns committed Aug 21, 2020
1 parent 0459cc5 commit 5fcf1ae
Show file tree
Hide file tree
Showing 15 changed files with 278 additions and 84 deletions.
45 changes: 27 additions & 18 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,30 +1,39 @@
# Dedalus Project

## About Dedalus
<!-- Title -->
<h1 align="center">
Dedalus Project
</h1>

<!-- Information badges -->
<p align="center">
<a href="https://www.repostatus.org/#active">
<img alt="Repo status" src="https://www.repostatus.org/badges/latest/active.svg" />
</a>
<a href="http://dedalus-project.readthedocs.org">
<img alt="Read the Docs" src="https://img.shields.io/readthedocs/dedalus-project">
</a>
<img alt="PyPI - Python Version" src="https://img.shields.io/pypi/pyversions/dedalus">
<img alt="PyPI" src="https://img.shields.io/pypi/v/dedalus">
<img alt="PyPI - License" src="https://img.shields.io/pypi/l/dedalus">
</p>

Dedalus is a flexible framework for solving partial differential equations using spectral methods.
The code is open-source and developed by a team of researchers working on problems in astrophysical and geophysical fluid dynamics.
The code is open-source and developed by a team of researchers studying astrophysical and geophysical fluid dynamics.

The code is written primarily in Python and features an easy-to-use interface, including text-based equation entry.
Our numerical algorithm produces highly sparse systems for a wide variety of equations on spectrally-discretized domains.
These systems are efficiently solved using compiled libraries and multidimensional parallelization though MPI.
Dedalus is written primarily in Python and features an easy-to-use interface with symbolic equation entry.
Our numerical algorithm produces sparse systems for a wide variety of equations and spectrally-discretized domains.
These systems are efficiently solved using compiled libraries and are automatically parallelized using MPI.

## Links

Learn more about Dedalus by visiting the

* Project homepage: <http://dedalus-project.org>
* Code repository: <https://github.com/DedalusProject/dedalus>
* Documentation: <http://dedalus-project.readthedocs.org>
* User mailing list: <https://groups.google.com/forum/#!forum/dedalus-users>
* Development mailing list: <https://groups.google.com/forum/#!forum/dedalus-dev>
* Mailing list: <https://groups.google.com/forum/#!forum/dedalus-users>

## Developers

The core development team consists of

* Keaton Burns (<[email protected]>)
* Ben Brown (<[email protected]>)
* Daniel Lecoanet (<[email protected]>)
* Jeff Oishi (<[email protected]>)
* Geoff Vasil (<[email protected]>)
* [Keaton Burns (@kburns)](https://github.com/kburns)
* [Geoff Vasil (@gmvasil)](https://github.com/gmvasil)
* [Jeff Oishi (@jsoishi)](https://github.com/jsoishi)
* [Daniel Lecoanet (@lecoanet)](https://github.com/lecoanet/)
* [Ben Brown (@bpbrown)](https://github.com/bpbrown)
2 changes: 1 addition & 1 deletion docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
# -- Project information -----------------------------------------------------

project = 'Dedalus Project'
copyright = '2018 Dedalus Collaboration'
copyright = '2020 Dedalus Collaboration'
author = 'Dedalus Collaboration'

# The short X.Y version
Expand Down
42 changes: 0 additions & 42 deletions docs/getting_started.rst

This file was deleted.

32 changes: 19 additions & 13 deletions docs/index.rst
Original file line number Diff line number Diff line change
@@ -1,32 +1,38 @@
Dedalus Project
***************

About Dedalus
=============

Dedalus is a flexible framework for solving partial differential equations using spectral methods.
The code is open-source and developed by a team of researchers working on problems in astrophysical and geophysical fluid dynamics.
The code is open-source and developed by a team of researchers studying astrophysical, geophysical, and biological fluid dynamics.

The code is written primarily in Python and features an easy-to-use interface, including text-based equation entry.
Our numerical algorithm produces highly sparse systems for a wide variety of equations on spectrally-discretized domains.
These systems are efficiently solved using compiled libraries and multidimensional parallelization though MPI.
Dedalus is written primarily in Python and features an easy-to-use interface with symbolic equation entry.
Our numerical algorithm produces sparse systems for a wide variety of equations and spectrally-discretized domains.
These systems are efficiently solved using compiled libraries and are automatically parallelized using MPI.

Doc Contents
============

.. toctree::
:maxdepth: 2

installation
getting_started
pages/installation
pages/tutorials
pages/user_guide
pages/methodology
Dedalus API reference <autoapi/dedalus/index>

Other Links
===========
Links
=====

* Project homepage: http://dedalus-project.org
* Code repository: https://github.com/DedalusProject/dedalus
* Documentation: http://dedalus-project.readthedocs.org
* User mailing list: https://groups.google.com/forum/#!forum/dedalus-users
* Development mailing list: https://groups.google.com/forum/#!forum/dedalus-dev
* Mailing list: https://groups.google.com/forum/#!forum/dedalus-users

Developers
==========

* `Keaton Burns <http://keaton-burns.com/>`_
* `Geoff Vasil <https://www.sydney.edu.au/science/about/our-people/academic-staff/geoffrey-vasil.html>`_
* `Jeff Oishi <https://jsoishi.github.io/>`_
* `Daniel Lecoanet <http://www.princeton.edu/~lecoanet/>`_
* `Ben Brown <https://bpbrown.bitbucket.io/>`_
20 changes: 20 additions & 0 deletions docs/pages/configuration.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
.. _configuration:

Configuring Dedalus
*******************

Various aspects of the underlying numerics, logging behavior, and output behavior of Dedalus can be modified through a configuration interface using Python's standard-library `ConfigParser` structure.

A ``dedalus.cfg`` file with the default configuration and descriptions of each option is included in the package.
This file can be copied to any working directory with the command ``python3 -m dedalus get_config``.
The configuration settings can be modified by, in order of increasing precedence:

1. Modifying the package's ``dedalus.cfg`` file (not recommended).
2. Creating a user-based config file at ``~/.dedalus/dedalus.cfg``.
3. Creating a local config file called ``dedalus.cfg`` in the directory where you execute a Dedalus script.
4. Modifying configuration values at the top of a Dedalus script like:

.. code-block:: python
from dedalus.tools.config import config
config['logging']['stdout_level'] = 'debug'
4 changes: 4 additions & 0 deletions docs/pages/general_functions.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
General Functions
*****************

Documentation coming soon.
20 changes: 10 additions & 10 deletions docs/installation.rst → docs/pages/installation.rst
Original file line number Diff line number Diff line change
Expand Up @@ -121,16 +121,16 @@ Below are instructions for building the dependency stack on a variety of machine
.. toctree::
:maxdepth: 1

machines/bridges/bridges
machines/cedar/cedar
machines/engaging/engaging
machines/janus/janus
machines/mac_os/mac_os
machines/nasa_discover/discover
machines/nasa_pleiades/pleiades
machines/savio/savio
machines/stampede/stampede
machines/trestles/trestles
/machines/bridges/bridges
/machines/cedar/cedar
/machines/engaging/engaging
/machines/janus/janus
/machines/mac_os/mac_os
/machines/nasa_discover/discover
/machines/nasa_pleiades/pleiades
/machines/savio/savio
/machines/stampede/stampede
/machines/trestles/trestles

Once the dependency stack has been installed, Dedalus can be installed `as described above <#installing-the-dedalus-package>`_.

14 changes: 14 additions & 0 deletions docs/pages/methodology.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
Methodology
***********

Dedalus Methods Paper
=====================

This is a work-in-progress section on the mathematical and computational methodologies underlying Dedalus.
Until this section is completed, please consult the Dedalus methods paper:

K J Burns, G M Vasil, J S Oishi, D Lecoanet, B P Brown, "Dedalus: A Flexible Framework for Numerical Simulations with Spectral Methods," Physical Review Research, vol. 2, no. 2, p. 838, Apr. 2020.
`[doi] <https://doi.org/10.1103/PhysRevResearch.2.023068>`_
`[arxiv] <https://arxiv.org/abs/1905.10388>`_
`[bibtex] <https://ui.adsabs.harvard.edu/abs/2019arXiv190510388B/exportcitation>`_
`[examples] <https://github.com/DedalusProject/methods_paper_examples>`_
4 changes: 4 additions & 0 deletions docs/pages/output_format.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
Output Formatting
*****************

Documentation coming soon.
4 changes: 4 additions & 0 deletions docs/pages/parallel_data.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
Parallel Data Interaction
*************************

Documentation coming soon.
68 changes: 68 additions & 0 deletions docs/pages/performance_tips.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
.. _performance_tips:

Performance Tips
****************

Domain Specification
====================

Resolutions for faster transforms
---------------------------------

The transforms for the ``Fourier``, ``SinCos``, and ``Chebyshev`` bases are computed using fast Fourier transforms (FFTs).
The underlying FFT algorithms are most efficient when the transform sizes are products of small primes.
We recommend choosing basis resolutions that are powers of two, or powers of two multiplied by other small factors.

Process meshes for better load balancing
----------------------------------------

Dedalus uses multidimensional block distributions when decomposing domains in parallel.
By default, problems are parallelized over a 1D process mesh of all available MPI processes.
Multidimensional parallelization is easily enabled by specifing a mesh shape using the ``mesh`` keyword when instantiating a ``Domain`` object.
The specified mesh shape should be a tuple with a length one less than the problem dimension.

Ideal load balancing occurs when the size of a distributed dimension is evenly divisible by the corresponding mesh size.
We recommend choosing mesh sizes that are powers of two, or powers of two multiplied by other small factors.
An "isotropic" mesh with the same number of processes in each mesh dimension, e.g. ``(8, 8)``, will theoretically be the most efficient for a given number of processes.

Avoid empty cores
-----------------

Note that it is possible to end up with empty cores in certain layouts if the mesh shape is chosen improperly or if a mesh is not specified for a 3D problem ran over many cores.
For example, consider a problem with global shape ``N = (64, 64, 64)`` distributed on ``P = 256`` cores.
Keeping the default 1D mesh or choosing a mesh of shape ``(128, 2)`` or ``(2, 128)`` will result in many empty cores -- a better choice would be a mesh of shape ``(16, 16)``.

Problem Formulation
===================

Minimize the number of problem variables
----------------------------------------

The number of variables used in a problem can have a large impact on the overall simulation performance.
We recommend formulating problems to use as few variables as possible, within the constraints posed by Dedalus itself, which require that PDEs are written as first-order systems in terms of temporal and non-Fourier spatial derivatives.
Often the ``problem.substitutions`` interface can be used to simplify the entry of complex equations without introducing new variables into a problem.

Formulate boundary conditions as Dirichlet conditions
-----------------------------------------------------

Maintaining a high degree of bandedness in the LHS matrices can greatly improve the performance of Dedalus.
This requires using Dirichlet rather than integral, Neumann, or other mixed boundary conditions.
Note that the first-order formulation required by Dedalus often means that such boundary conditions can be posed as Dirichlet conditions on the first-order variables, e.g. the Neumann condition ``dz(u) = 0`` for an elliptic or parabolic problem can be written as the Dirichlet condition ``uz = 0``, assuming the first-order reduction definition ``"uz - dz(u) = 0"`` is part of the PDE system.

Avoid non-smooth or rational-function NCCs
------------------------------------------

High bandedness also requires that non-constant coefficients (NCCs) appearing on the LHS are spectrally smooth.
An amplitude cutoff and a limit to the number of terms used when expanding the LHS NCCs can be specified with the ``ncc_cutoff`` and ``max_ncc_terms`` keywords when instantiating a problem.
These settings can have a large performance impact for problems with NCCs that are not low-degree polynomials.
Problems with NCCs that are rational functions (such as ``1/r**2`` terms that appear in problems in curvilinear coordinates) should usually be multiplied through to clear the polynomial denominators, resulting in purely polynomial and hence well-banded NCC operators.

Timestepping
============

Avoid changing the simulation timestep unless necessary
-------------------------------------------------------

Changing the simulation timestep requires refactorizing the LHS matrices, so the timestep should be changed as infrequently as possible for maximum performance.
If you are using the built-in CFL tools to calculate the simulation timestep, be sure to specify a ``threshold`` parameter greater than zero to prevent the timestep from changing due to small variations in the flow.

4 changes: 4 additions & 0 deletions docs/pages/restarting.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
Restarting Simulations
**********************

Documentation coming soon.
50 changes: 50 additions & 0 deletions docs/pages/troubleshooting.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
Troubleshooting
***************

Singular matrix errors
======================

If you come across an error in the linear solver stating that a matrix/factor is singular, that means that the linear LHS portion of the PDE system is not solvable.
This error indicates that some degrees of freedom of the solution are unconstrained and some of the specified equations are redundant (these are equivalent since the LHS matrices must be square).

These errors are often due to imposing boundary conditions that are redundant for some set of modes and/or failing to constrain a gauge freedom in the solution.
For instance, when simulating incompressibly hydrodynamics in a channel, specifying the mean wall-normal velocity on both walls is redundant with the incompressiblity constraint (the mean wall-normal velocity at one wall must be the same as at the other wall for the flow to be divergence-free).
Instead, the wall-normal velocity boundary condition at one wall should be removed and replaced with a gauge condition setting the constant portion of the pressure.
This is why you'll see these types of boundary conditions for the wall-normal velocity (e.g. ``w``) in Dedalus scripts for incompressible flow:

.. code-block:: python
problem.add_bc("left(w) = 0")
problem.add_bc("right(w) = 0", condition="(nx != 0)")
problem.add_bc("right(p) = 0", condition="(nx == 0)")
Maintaining Hermitian symmetry with real variables
==================================================

In certain problems with real variables, numerical instabilities may arise due to the loss of Hermitian symmetry in the Fourier components of the solution.
When the grid datatype is set to ``float`` or ``np.float64`` in Dedalus, that means that the first Fourier transform (say in the x direction) will be computed with a real-to-complex FFT where the negative half of the spectrum (kx < 0) is discarded.
Subsequent transforms are then complex-to-complex.

This strategy maintains the proper Hermitian symmetry for the majority of the modes, since only the non-negative kx half of the spectrum is evolved and the negative kx modes are computed from the conjugates of the positive kx modes whenever they are needed (i.e. for interpolation along x).
However, modes with kx = 0 should have coefficients that are real after the x-transform, and should have Hermitian symmetry in e.g. ky if there's a subsequent Fourier transform in y.
This is not enforced by Dedalus, so if the PDE has a linear instability for modes with kx = 0, then the imaginary part of the solution can grow tihout bound (the nonlinear terms are computed in grid space, so they only affect the real portion of the solution and can’t saturate a growing imaginary part).

A simple solution is to periodically transform all the state variables to grid space, which will project away any imaginary component that may have been building up during timestepping.
This can be done with a simple statement in the main loop like:

.. code-block:: python
if solver.iteration % 100 == 0:
for field in solver.state.fields:
field.require_grid_space()
Out of memory errors
====================

Spectral simulations with implicit timestepping can require a large amount of memory to store the LHS matrices and their factorizations.
The best way to minimize the required memory is to minimize the LHS matrix size by using as few variables as possible and to minimize the LHS matrix bandwidth (see the :ref:`performance_tips` page).
Beyond this, several of the Dedalus configuration options can be changed the minimize the simulation's memory footprint, potentially at the cost of reduced performance (see the :ref:`configuration` page).

Reducing memory consumption in Dedalus is an ongoing effort.
Any assistance with memory profiling and contributions reducing the code's memory footprint would be greatly appreciated!

Loading

0 comments on commit 5fcf1ae

Please sign in to comment.