Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions partitioned-heat-conduction-direct/dirichlet-gismo/clean.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/usr/bin/env sh
set -e -u

. ../../tools/cleaning-tools.sh

clean_gismo .
9 changes: 9 additions & 0 deletions partitioned-heat-conduction-direct/dirichlet-gismo/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/bin/bash
set -e -u

. ../../tools/log.sh
exec > >(tee --append "$LOGFILE") 2>&1

partitioned-heat-conduction -s 0 ../precice-config.xml --plot

close_log
6 changes: 6 additions & 0 deletions partitioned-heat-conduction-direct/neumann-gismo/clean.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/usr/bin/env sh
set -e -u

. ../../tools/cleaning-tools.sh

clean_gismo .
9 changes: 9 additions & 0 deletions partitioned-heat-conduction-direct/neumann-gismo/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/bin/bash
set -e -u

. ../../tools/log.sh
exec > >(tee --append "$LOGFILE") 2>&1

partitioned-heat-conduction -s 1 ../precice-config.xml --plot

close_log
27 changes: 26 additions & 1 deletion partitioned-heat-conduction/README.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
---
title: Partitioned heat conduction
permalink: tutorials-partitioned-heat-conduction.html
keywords: FEniCS, Nutils, Heat conduction
keywords: FEniCS, Nutils, G+Smo, Heat conduction
summary: We solve a simple heat equation. The domain is partitioned and the coupling is established in a Dirichlet-Neumann fashion.
---

Expand Down Expand Up @@ -37,6 +37,8 @@ You can either couple a solver with itself or different solvers with each other.

* OpenFOAM. This case uses the custom [heatTransfer](https://github.com/precice/tutorials/blob/master/partitioned-heat-conduction/solver-openfoam/heatTransfer.C) solver (find it in `solver-openfoam` and build with `wmake`). Read more details in the [OpenFOAM adapter](https://precice.org/adapter-openfoam-overview.html).

* G+Smo. Install the [G+Smo adapter](https://precice.org/adapter-gismo.html).

## Running the simulation

You can find the corresponding `run.sh` script for running the case in the folders corresponding to the participant you want to use:
Expand Down Expand Up @@ -73,6 +75,27 @@ If you want to use Nutils or OpenFOAM, use `cd dirichlet/neumann-nutils`, respec
mpirun -n <N_PROC> heat.py -d
```

For running G+Smo, follow the [G+Smo adapter installation instructions](https://precice.org/adapter-gismo.html) to build the `partitioned-heat-conduction` example. Then link the compiled executable to the `dirichlet-gismo` and `neumann-gismo` folders:

```bash
cd <tutorial-directory>/partitioned-heat-conduction/dirichlet-gismo
ln -sf <gismo-build-directory>/bin/partitioned-heat-conduction ./gismo-executable
cd ../neumann-gismo
ln -sf <gismo-build-directory>/bin/partitioned-heat-conduction ./gismo-executable
```

Then open two terminals and run:

```bash
cd dirichlet-gismo
./run.sh
```

```bash
cd neumann-gismo
./run.sh
```

### Note on the combination of Nutils & FEniCS

You can mix the Nutils and FEniCS solver, if you like. Note that the error for a pure FEniCS simulation is lower than for a mixed one. We did not yet study the origin of this error, but assume that this is due to the fact that Nutils uses Gauss points as coupling mesh and therefore entails extrapolation in the data mapping at the top and bottom corners.
Expand All @@ -85,6 +108,8 @@ For FEniCS you can visualize the content with paraview by opening the `*.pvd` fi

For Nutils, please use the files `Dirichlet-*.vtk` or `Neumann-*.vtk`. Please note that these files contain the temperature as well as the reference solution.

For G+Smo, please use the generated `solution.pvd` files in the dirichlet-gismo and neumann-gismo directories.

![Animation of the partitioned heat equation](images/tutorials-partitioned-heat-conduction-FEniCS-movie.gif)

Visualization in paraview for `x_c = 1.5`.
Expand Down
6 changes: 6 additions & 0 deletions partitioned-heat-conduction/dirichlet-gismo/clean.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/usr/bin/env sh
set -e -u

. ../../tools/cleaning-tools.sh

clean_gismo .
4 changes: 4 additions & 0 deletions partitioned-heat-conduction/dirichlet-gismo/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
#!/bin/bash
set -e -u

./gismo-executable -c ../precice-config.xml --plot -s 0
6 changes: 6 additions & 0 deletions partitioned-heat-conduction/neumann-gismo/clean.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/usr/bin/env sh
set -e -u

. ../../tools/cleaning-tools.sh

clean_gismo .
4 changes: 4 additions & 0 deletions partitioned-heat-conduction/neumann-gismo/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
#!/bin/bash
set -e -u

./gismo-executable -c ../precice-config.xml --plot -s 1
Loading