Main Page: Difference between revisions
m (→Citation) |
mNo edit summary |
||
Line 27: | Line 27: | ||
* May be run on a single core or in parallel (with MPI). Essentially linear scaling with number of cores. | * May be run on a single core or in parallel (with MPI). Essentially linear scaling with number of cores. | ||
* '2-dimensional' parallelisation, radial+axial split. | * '2-dimensional' parallelisation, radial+axial split. | ||
* Jacobian-Free Newton-Krylov (JFNK) solver. See [[Newton-Krylov_method]]. | * Jacobian-Free Newton-Krylov (JFNK) solver. See [[Newton-Krylov_method]], also at [https://github.com/apwillis1/JFNK-Hookstep GitHub]. | ||
Details for the above can be found in the [[Manual]]. | Details for the above can be found in the [[Manual]]. | ||
This article, [[File:TheOpenpipeflowSolver.pdf]], provides an overview of the code and its context. | This article, [[File:TheOpenpipeflowSolver.pdf]], provides an overview of the code and its context. |
Revision as of 03:00, 1 February 2023
Overview
openpipeflow.org is a free resource for researchers, engineers, educators and the interested public.
Pipe flow is a simple and familiar set up, yet the flow patterns exhibit rich chaotic dynamics. This provides a setting for investigating the principles of simulation at one level, and at another, for developing new methods designed to probe fundamental properties of dynamical systems.
The majority of mathematical techniques described on these pages are applicable to a huge range of problems, and subroutines for well-known methods are designed to be callable from any code. The core pipe flow code is designed to be flexible yet very fast.
Aims
- To make accessible a range of modelling techniques.
- To facilitate rapid entry into the world of numerical simulation and fluid dynamics.
- To provide flexible modules for more the use and development of advanced techniques in research.
Code features
- Primitive-variable pipe-flow code for incompressible flow.
- Simple scripts for visualisation with Matlab/Octave/Visit.
- Readable Fortran 90, uses modules and derived types, no esoteric extensions.
- Core program <3000 lines.
- Spatial discretisation: double-Fourier (theta,z) + finite difference (r).
- PPE formulation; influence matrix corrects boundary conditions to machine precision.
- Second-order predictor-corrector method, automatic timestep control.
- May be run on a single core or in parallel (with MPI). Essentially linear scaling with number of cores.
- '2-dimensional' parallelisation, radial+axial split.
- Jacobian-Free Newton-Krylov (JFNK) solver. See Newton-Krylov_method, also at GitHub.
Details for the above can be found in the Manual. This article, File:TheOpenpipeflowSolver.pdf, provides an overview of the code and its context.
Manual, Tutorial, FAQ
See left sidebar for links to the Manual, Tutorial and FAQ.
Download
Get the code here!
Database
The Database provides sample parameters and initial conditions from which to launch new simulations. In general, simulations start most reliably from an initial state computed for similar parameters. A range of starting points are provided.
Features to appear/wishlist
- Module for the immersed boundary method (IBM).
- More FAQ + documentation.
Citation
Please cite this article: File:TheOpenpipeflowSolver.pdf
Author
- Ashley P. Willis,
- School of Mathematics and Statistics (SoMaS),
- University of Sheffield, U.K.
- ashleypwillis/at/gmail.com
Thanks
- John Gibson (channelflow.org)
- Predrag Cvitanović (GaTech chaosbook.org)
- Rich Kerswell (Cambridge)
- many other people!
- EPSRC GR/S76144/01, EP/K03636X/1
- The University of Sheffield.