Skip to content

Latest commit

 

History

History
143 lines (103 loc) · 6.51 KB

README.md

File metadata and controls

143 lines (103 loc) · 6.51 KB

deal.II implementation of multiscale PDE

This repository contains a setup for a deal.II implementation for two-scale systems of equations. The main system is described in this thesis, even though the implementation is more general and has a separate framework for elliptic-elliptic systems. A paper that showcases some of the initial results has been published. A second paper that extends the framework is forthcoming.

Requirements

  • cmake, preferable version 3.1, but lower versions should work too, if you adapt CMakeLists.txt.
  • deal.II, version 9.1.1. Please note that lower versions (e.g. 8.5 or even 9.0) will not be compatible. See below for installation hints.

Installation for macOS

A bundled package in the form of an app is available here. Installing it provides your Mac with the deal.II library files. Other options are available as well and should work, but the rest of this README assumes the app installation.

Installation for Linux (Ubuntu/Debian)

Most popular distros have deal.II available in their repos. For Ubuntu (20.04), deal.II is installed using

sudo apt install libdeal.ii-dev

For older versions, backports can be installed from this repo.

Docker installation

Alternatively, if you can't/don't want to install a global version of deal.II, you can use Docker.

After installing Docker (guides are available online, should be quite easy), pull the dealii/dealii:v9.1.1-gcc-mpi-fulldepscandi-debugrelease image (more info here), mount the dealiiscale directory and compile the code. If run in a docker container, the CMakeLists.txt file assumes this image.

A complete workflow looks as follows (where /path/to/dealiiscale is the absolute path of the cloned repo).

git clone [email protected]:0mar/dealiiscale.git # Clone the source code
docker pull dealii/dealii:v9.1.1-gcc-mpi-fulldepscandi-debugrelease # Pull the docker image with deal.II installed
# Now start the container and mount the source directory and drop in
docker run --name dealii -v /path/to/dealiiscale:/home/dealii/dealiiscale -i -t dealii/dealii:v9.1.1-gcc-mpi-fulldepscandi-debugrelease
cd dealiiscale # Enter the source directory (inside the container)
mkdir build # Create a build folder
cd build
cmake .. # Setup the compilation structure (debug by default)
make # Compile all sources

Configuring CMake for deal.II

deal.II uses CMake for its compilation process, as does this repo. If for some reason CMake is not present on your system, it is easily installed using Homebrew (Mac) or apt-get (Debian/Ubuntu).

For Mac, Opening the OS X deal.II app will open a shell with preset environment variables that make compilation of your programs 'easy'. For some reason, this app takes quite some time to load, and its structure does not (by default) allow for the use of IDEs or other shells/terminals.

Luckily, we do not need to open the deal.II app to compile our programs, since we can point CMake to the installation.

After installation of version 9.1.1, add the following lines to your CMake:

set(deal.II_DIR /Applications/deal.II-9.1.1.app/Contents/Resources/lib/cmake/deal.II)
FIND_PACKAGE(deal.II 9.1.1 QUIET HINTS ${deal.II_DIR} ${DEAL_II_DIR} $ENV{DEAL_II_DIR})
DEAL_II_INITIALIZE_CACHED_VARIABLES()

For default installations on Ubuntu/Debian systems, the first line can be changed to

set(deal.II_DIR /usr/share/cmake/deal.II)

For a full (but not minimal) example of a deal.II CMake file, check the repository. This CMake file deals with both Mac and Ubuntu installations.

Compiling the source code

To build and install the binaries in directory build with a functioning CMake file, one can run the following commands:

git clone [email protected]:0mar/dealiiscale.git # if you haven't cloned the repository yet
mkdir build
cd build
cmake .. # debug version
# use `cmake -DCMAKE_BUILD_TYPE=Release .. ` for a release version
make

This builds a debug version of the code. One can then run any of the created binaries, e.g. manufactured, like this:

cd build
./solve_elliptic

Tests

This framework has some unit tests (present in tests) that use Boost's test framework. This might need to be installed, but since deal.II itself also uses the Boost testing suite, this is no extra prerequisite. Run tests with

cd bin
make test

Currently, tests are only present for self-developed extensions of the deal.II library.

Visualisation

The latest binary solve_biomath has support for visualisation in ParaView. Follow the [extended instructions][6] to get started.

Solver gallery

deal.II comes with many examples, located in /Applications/deal.II-9.1.1.app/Contents/Resources/examples, also found in a more legible format on the tutorial page.

This repo has a number of working implementations, most of which are used to test the performance of certain deal.II characteristics. Currently, the working implementations are:

  • biomath
    • solve_biomath, a multiscale elliptic-elliptic solver with convergence benchmarking and parallel-speed-up benchmarking.
  • elliptic-elliptic
    • solve_elliptic, a multiscale elliptic-elliptic solver with convergence testing.
  • elliptic-parabolic
    • solve_parabolic, a multiscale elliptic-parabolic solver (work in progress, main target of this exercise).
  • playground (collection of separate tests and implementations)
    • dirichlet, a Poisson problem in a circular domain.
    • robin, a Poisson problem with Robin boundary conditions.
    • simple, a (deprecated) working start for the target system.
    • integration, an example/convergence test on how to compute bulk and flux integrals.
    • parsing, a demo on interpreting functions from a parameter file and using them to construct and solve a PDE
    • transform, a toy elliptic PDE that uses a mapping to solve a PDE on a pulled-back domain

Report

To test and create a report for the elliptic-elliptic implementations (currently manufactured and separated), one can do the following:

./manufactured
./separated
cd results
make

This will post-process the output of the binaries into a (slightly outdated) latex report and compile it (requires pdftex)