Skip to content

Commit

Permalink
Merge branch 'master' of https://github.com/UG4/ugcore
Browse files Browse the repository at this point in the history
  • Loading branch information
andreas.vogel committed Nov 23, 2018
2 parents 4469758 + 5f3bb59 commit 62bee23
Show file tree
Hide file tree
Showing 98 changed files with 5,589 additions and 612 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,5 @@
.project
.tags
.tags_sorted_by_file
.settings
.settings
/Debug/
12 changes: 9 additions & 3 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ os:

env:
global:
- if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then PATH=/usr/lib/ccache:${PATH}; fi
- TIMEOUT_BUILD='30m'
- BUILD_SUCCESS=true

Expand All @@ -36,12 +35,19 @@ env:
cache:
ccache: true
directories:
- travis_root
#- travis_root
- $HOME/.ccache
#- $HOME/Library/Caches/Homebrew
# TODO: how can we do conditional caching of directories (depending on OS)
#- /home/travis/build/miho/OCC-CSG/oce-OCE-0.18.3
#- /Users/travis/build/miho/ugcore/

# prepare ccache for (optional) install step
before_install:
# installing ccache and freetype packages via homebrew
- if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew install ccache; fi
- if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then export PATH="/usr/local/opt/ccache/libexec:$PATH"; fi

# prepare compilation
before_script:
- mkdir -p travis_root && cd travis_root
Expand Down Expand Up @@ -83,5 +89,5 @@ script:
# ccache fixes global build time of ~ 50 minutes
# we still need to use travis_wait to prevent "build error because of no output"
# https://docs.travis-ci.com/user/common-build-problems/#Build-times-out-because-no-output-was-received
- travis_wait 45 make -j3
- travis_wait 45 make -j2
- if [[ "$TARGET" == "ugshell" ]]; then ../bin/ugshell -call "print(\"it works\")"; fi
198 changes: 193 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,198 @@
[![Code Climate](https://codeclimate.com/github/UG4/ugcore/badges/gpa.svg)](https://codeclimate.com/github/UG4/ugcore)
[![Issue Count](https://codeclimate.com/github/UG4/ugcore/badges/issue_count.svg)](https://codeclimate.com/github/UG4/ugcore)

core functionality of **UG4**. Includes sources, build-scripts,
and utility-scripts
This repository contains the core functionality of **UG4**. Includes sources, build-scripts, and utility-scripts

Copyright 2009-2015 Goethe Center for Scientific Computing, University Frankfurt
Copyright 2009-2018 Goethe Center for Scientific Computing, Goethe-University Frankfurt am Main

Please install/clone this repository through UG4's package manager
[ughub](https://github.com/UG4/ughub).
Please install/clone this repository through *UG4's* package manager
[*ughub*](https://github.com/UG4/ughub).

#

# Introduction to UG4

*UG4* is an extensive, flexible, cross-platform open source simulation framework for the numerical solution of systems of partial differential equations. Using *Finite Element* and *Finite Volume* methods on hybrid, adaptive, unstructured multigrid hierarchies, *UG4* allows for the simulation of complex real world models (physical, biological etc.) on massively parallel computer architectures.

*UG4* is implemented in the *C++* programming language and provides grid management, discretization and (linear as well as non-linear) solver utilities. It is extensible and customizable via its plugin mechanism. The highly scalable *MPI* based parallelization of *UG4* has been shown to scale to hundred thousands of cores.

Simulation workflows are defined either using the *Lua* scripting language or the graphical VRL interface [https://vrl-studio.mihosoft.eu/](https://vrl-studio.mihosoft.eu/). Besides that, UG4 can be used as a library for third-party code.

Several examples are provided in the *Examples* application that can be used for simulations of the corresponding phenomena but also serve as demonstration modules for implementing user-defined plugins and scripts. By developing custom plugins, users can extend the functionality of the framework for their particular purposes. The framework provides coupling facilities for the models implemented in different plugins.

The source code is commented using the Doxygen markup language.

*UG4* is licensed under the *LGPL v3* license with amendments. Please have a look at the accompanying *LICENSE* file.

## Preparation of Data and Visualization of Results

The `.ugx` grids provided in the *Examples* applications can be created, visualized, and edited with *ProMesh*, a versatile graphical meshing solution for the generation, visualization, and preparation of computational domains for scientific computing on structured and unstructured grids. It allows users to process complicated geometries with curved boundaries and low-dimensional manifolds. *ProMesh* is based on *UG4's* grid manager and is available at http://www.promesh3d.com

![promesh](docs/ug4/img/readme/promesh.png "ProMesh")

The computational domain, the underlying grid, the boundary and initial conditions, as well as the problem coefficients can be specified as part of the simulation workflow in *Lua* scripts or the *VRL-Studio* GUI. However, for performance reasons, if the evaluation of the spatial and time dependence of the certain parameters is numerically expensive, one can implement those in C+\+, too, e.g. in a custom plugin.

Intermediate and final results of a simulation can be written to *VTK's* `.vtu` file format. These can be visualized using a number of free and open-source toolkits, e.g. *ParaView* [http://www.paraview.org](http://www.paraview.org) and *VisIt* [https://wci.llnl.gov/simulation/computer-codes/visit/](https://wci.llnl.gov/simulation/computer-codes/visit/).

## Setup and Compilation:

For the following guide, we assume the compilation is performed on a Linux/Unix machine using a standard Bash terminal. Please note that Microsoft Windows features such an environment through the free 'Ubuntu' app in the Microsoft Windows Store. If a native Windows executable is required, Visual Studio compilers can also be used.

**Requirements:**

- C++ Compiler (tested with GCC on Linux, Clang on macOS and MSVC 2017 on Windows)
- CMake >= 2.8
- ughub (https://github.com/UG4/ughub)
- git
- python

For a detailed list on required software and corresponding installation instructions, please visit https://github.com/UG4/ughub

Please start by creating a *UG4* root directory, e.g. `$HOME/ug4`. In your `ug4` directory please run the following commands to obtain all required sources:

ughub init
ughub install Examples

This will clone *ugcore*, the *Examples* app and all required plugins.

Starting from *UG4's* root directory, please execute the following to build *UG4*:

mkdir build
cd build
cmake -DENABLE_ALL_PLUGINS=ON -DDIM="2;3" -DCPU="1;2" -DCMAKE_BUILD_TYPE=Release ..
make -j
cd ..


## Running Examples:
Starting from *UG4's* root directory, please execute the following:

source ugcore/scripts/shell/ugbash
mkdir runs
cd runs
ugshell -ex Examples/poisson.lua
ugshell -ex Examples/poisson.lua -dim 3
ugshell -ex Examples/solmech.lua
ugshell -ex Examples/elder_adapt.lua
ugshell -ex Examples/navier_stokes.lua
ugshell -ex Examples/electromagnetism_pan.lua -numRefs 3

## Examples:

Please make sure that you installed *UG4's* *Examples* application as described above.

### Poisson Problem
A script computing the solution of the *Poisson* problem is given in `apps/Examples/poisson.lua`. The right hand side of the differential equation can be specified through a callback method in the *Lua* script.
A projector is used during grid refinement to approximate a circle with additional refinements.

![poisson](docs/ug4/img/readme/poisson.png "poisson")

### Linear Elasticity
A 3d simulation of deformation using *linear elasticity* is provided in `apps/Examples/solmech.lua`.

![springboard](docs/ug4/img/readme/springboard.png "springboard")

### Density Driven Flow
An adaptive simulation of the *Elder* problem is provided in `apps/Examples/elder_adapt.lua`. A gradient based error indicator is used to refine areas of interest.

![elder adaptive](docs/ug4/img/readme/elder_adapt.png "elder adaptive")

### Navier Stokes
Simulations of fluid flow in a channel with a cylindrical cutout are performed in `apps/Examples/navier_stokes.lua`.

![navier_stokes](docs/ug4/img/readme/navier_stokes.png "navier_stokes")

### Electromagnetism (induction heating)
Simulation of the eddy currents and the corresponding heat sources induced by alternating electromagnetic field in a conductive plate is represented in `apps/Examlpes/electromagnetism_pan.lua`. The stationary E-based formulation of the eddy current model for the complex-valued fields is used. The discretization of the Maxwell equations is done by the Nedelec elements on a tetrahedral grid. This example demonstrates in particular the projection of the refined elements to the curved boundaries in 3d.

![heat](docs/ug4/img/readme/PanSolution3d-coil_and_pan_v3-lev4.png "pan_solution")

## UG4 for VRL-Studio:

VRL-Studio is an innovative and powerful IDE for rapid prototyping, learning, teaching and experimentation. It introduces *Visual Reflection* for automatic user interface generation. It combines textual and visual programming in an intuitive user interface. *UG4* provides a built-in VRL binding that allows to setup and execute visual simulation workflows from VRL-Studio. The supplementary VRL-Studio folder contains a precompiled version of VRL-Studio which includes *UG4* and a sample project to briefly demonstrate UG4s capabilities as VRL-Studio plugin.

Download Links for supplementary software folder:

- **Linux x64:** [http://vrl-studio.mihosoft.eu/releases/vrl-studio-ug4-release-2018/vrl-ug4-linux.zip](http://vrl-studio.mihosoft.eu/releases/vrl-studio-ug4-release-2018/vrl-ug4-linux.zip)
- **Windows x64:** [http://vrl-studio.mihosoft.eu/releases/vrl-studio-ug4-release-2018/vrl-ug4-windows.zip](http://vrl-studio.mihosoft.eu/releases/vrl-studio-ug4-release-2018/vrl-ug4-windows.zip)
- **macOS x64:** [http://vrl-studio.mihosoft.eu/releases/vrl-studio-ug4-release-2018/vrl-ug4-macos.zip](http://vrl-studio.mihosoft.eu/releases/vrl-studio-ug4-release-2018/vrl-ug4-macos.zip)

### Opening the Sample Project:

The supplementary software folder contains a version of VRL-Studio that includes a precompiled version of *UG4* and additional plugins for visualization.

**Running VRL-Studio on Linux:**

To run VRL-Studio from the supplementary software folder, execute the following commands:

```
cd path/to/VRL-Studio-For-UG4
./run.sh
```

**Running VRL-Studio on macOS:**

For macOS, VRL-Studio is provided as application bundle. Simply double-click the application bundle to run VRL-Studio.

**Running VRL-Studio on Windows:**

For Windows, VRL-Studio is provided as application bundle. Just run the VRL-Studio.exe file inside the VRL-Studio folder.

If VRL-Studio runs for the first time, it will install several plugins (e.g. the *UG4* plugin) before showing the main user interface.

To open the sample project, click on `File->Load Project` and navigate to the sample project (`skin-2d.vrlp`).

Now do the following:

1. Select the desired output file (for this example `vtk-output/skin-2d.vtu`).
2. Select the desired geometry (for this example `skin-2d.ugx`).
3. Press `Start` to run the simulation.
4. Check the log window for simulation progress (click on `View->Show Log in Window` or drag up the divider at the bottom of the VRL-Studio main window to reveal the log).
5. The `vtk-output/` folder contains the simulation output that can be post-processed with a VTK viewer such as ParaView.

![vrl-skin2d](docs/ug4/img/readme/vrl_skin2d.png "UG4 as VRL-Studio Plugin")

### Compiling UG4 for VRL-Studio:

The following steps explain how to manually compile *UG4* for VRL-Studio.

In addition to the aforementioned requirements, compilation for VRL-Studio requires Java (JDK >= 1.8). Additionally, VRL-Studio needs to run at least once to make sure the required folder structure is created.

To build *UG4* as shared library for VRL-Studio, different CMake options have to be used. The following commands build *UG4* for VRL-Studio:

```
cd path/to/ug4
mkdir build_vrl && cd build_vrl
cmake .. -DTARGET=vrl -DLAPACK=OFF -DBLAS=OFF -DDIM=all -DCPU="1;2" -DCOMPILE_INFO=OFF -DEMBEDDED_PLUGINS=ON -DSTATIC_BUILD=OFF
make -j
```

After successful compilation, the shared library libug4.so (libug4.dylib on macOS and ug4.dll on Windows) needs to be copied to the VRL plugin folder. For VRL-Studio installed from the supplementary software folder, the following command can be used to copy the shared library to the correct plugin folder:

```
cp path/to/libug4.so $HOME/.vrl/0.4.3/default-ug4/plugins/VRL-UG/natives/linux/x64/
```

After restarting VRL-Studio, the new library is used.

## Further Documentation:

Installation instructions are given at https://github.com/UG4/ughub

Further documentation on *UG4* is available at http://ug4.github.io/docs/

Please have a look at http://ug4.github.io/docs/page_external_libraries.html for more information on used libraries and their licenses.

## Related Articles:
```
Reiter, S., Vogel, A., Heppner, I., Rupp, M., and Wittum, G.
A massively parallel geometric multigrid solver on hierarchically distributed grids.
Computing and visualization in science 16, 4 (2013), 151-164,
DOI: 10.1007/s00791-014-0231-x
Vogel, A., Reiter, S., Rupp, M., Nägel, A., and Wittum, G.
UG4 -- a novel flexible software system for simulating pde based models on high performance computers.
Computing and visualization in science 16, 4 (2013), 165-179,
DOI: 10.1007/s00791-014-0232-9
```
(Cf. the bib-file in the ugcore directory.)
62 changes: 62 additions & 0 deletions cmake/toolchain/juwels.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
################################################################################
# created by Markus Breit
# [email protected]
# adapted from corresponding JuQueen file created by Ingo Heppner
#
# Toolchain file for JUWELS (type Dual Intel Xeon Skylake 8168) FZ Juelich.
#
# This toolchain file is included in a CMake run by (check with 'cmake --trace')
# 'Modules/CMakeDetermineSystem.cmake', and (later again) by the - generated -
# file '<ug4_build_dir>/CMakeFiles/CMakeSystem.cmake'.
# (Subdirectory 'Modules/' is part of your CMake installation, on JURECA's login
# nodes: '/usr/local/software/jureca/Stage3/software/Core/CMake/3.2.3/share/cmake-3.2/Modules').
#
# Appropriate platform files for the "CMake system name" and compilers chosen
# here are called later (by 'Modules/CMakeSystemSpecificInformation.cmake'):
#
# I.e., for "BlueGeneQ-static" as "CMake system name" the platform file
# 'Modules/Platform/BlueGeneQ-static.cmake' is included first, which includes
# 'Modules/Platform/BlueGeneQ-base.cmake'. Afterwards CMake calls
# 'Modules/Platform/BlueGeneQ-static-GNU-C.cmake' and
# 'Modules/Platform/BlueGeneQ-static-GNU-CXX.cmake'
# if GNU compilers are chosen (by 'Modules/CMakeCInformation.cmake' and
# 'Modules/CMakeCXXInformation.cmake' respectively).
#
################################################################################

# Important: Setting the "cmake system name" will lead to automatic inclusion of
# the corresponding platform files:
set(CMAKE_SYSTEM_NAME Linux)
#list(APPEND CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/ugcore/cmake/modules")

# This option tells cmake/ug_includes.cmake to add the -dynamic option to the compiler flags.
SET(enableDynamicOption OFF)

# This option tells cmake/ug_includes.cmake to add the -fno-strict-aliasing option to the compiler flags.
SET(enableNoStrictAliasingOption ON)

# Some variables for paths
set(GCC_ROOT "/gpfs/software/juwels/stages/2018a/software/icc/2018.2.199-GCC-5.5.0/compilers_and_libraries_2018.2.199/linux/")
set(MPI_ROOT "/gpfs/software/juwels/stages/2018a/software/impi/2018.2.199-iccifort-2018.2.199-GCC-5.5.0/")
set(FTR_ROOT "/gpfs/software/juwels/stages/2018a/software/ifort/2018.2.199-GCC-5.5.0/compilers_and_libraries_2018.2.199/linux/")

# The serial GNU compilers
set(CMAKE_C_COMPILER ${GCC_ROOT}/bin/intel64/icc)
set(CMAKE_CXX_COMPILER ${GCC_ROOT}/bin/intel64/icpc)
set(CMAKE_Fortran_COMPILER ${FTR_ROOT}/bin/intel64/ifort)

# The MPI wrappers for the GNU compilers
set(MPI_C_COMPILER ${MPI_ROOT}/bin64/mpicc)
set(MPI_CXX_COMPILER ${MPI_ROOT}/bin64/mpicxx)
set(MPI_Fortran_COMPILER ${MPI_ROOT}/bin64/mpif90)

#message(STATUS "TMP INFO: Value of '\${CMAKE_C_COMPILER}' is: ${CMAKE_C_COMPILER}") # TMP
#message(STATUS "TMP INFO: Value of '\${CMAKE_CXX_COMPILER}' is: ${CMAKE_CXX_COMPILER}") # TMP
#message(STATUS "TMP INFO: Value of '\${CMAKE_Fortran_COMPILER}' is: ${CMAKE_Fortran_COMPILER}") # TMP

message(STATUS "TMP INFO: Value of '\${MPI_C_COMPILER}' is: ${MPI_C_COMPILER}") # TMP
message(STATUS "TMP INFO: Value of '\${MPI_CXX_COMPILER}' is: ${MPI_CXX_COMPILER}") # TMP
message(STATUS "TMP INFO: Value of '\${MPI_Fortran_COMPILER}' is: ${MPI_Fortran_COMPILER}") # TMP

# For debugging purposes
#include(CMakePrintSystemInformation)
Original file line number Diff line number Diff line change
Expand Up @@ -60,10 +60,10 @@ The page is an install guide for the usage of Eclipse for ug.
<hr>
\section secUG4AndEclipse Generating Eclipse Project-Files
In order work with UG4 in Eclipse, please download and install UG4 as usual through
UG4's package-manager (see https://github.com/UG4/ughub/wiki).
UG4's package-manager (see https://github.com/UG4/ughub).

You'll find detailed instructions on how to generate and import UG4 project-files
for Eclipse here: https://github.com/UG4/ughub/wiki#importing-ug4-into-your-ide
for Eclipse here: https://github.com/UG4/ughub#importing-ug4-into-your-ide


<hr>
Expand Down
16 changes: 10 additions & 6 deletions docs/ug4/additional_pages/introduction.doxygen
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,12 @@ Scientific Computing at the University of Frankfurt, Germany </em>
(http://www.g-csc.de).


Features are:
https://github.com/UG4/ugcore gives a quick overview on how to obtain and to install
\ug4. Several example applications are described and tools for pre- and
postprocessing are linked.


Features of \ug4 are:
- Fast and efficient numerical solvers for serial and parallel environments.

- A flexible discretization module, allowing to freely couple equations, input
Expand Down Expand Up @@ -96,9 +101,8 @@ Features are:
- \ug4 is a cross-platform tool and supports \em Linux, \em MacOSX and
<em>Microsoft Windows</em>.



Take a look at the current release for more information:
\ref pageUG4Releases

*/

// Removed the 'releases page' from the Overview for a lack of meaningful releases:
//Take a look at the current release for more information:
//\ref pageUG4Releases
5 changes: 5 additions & 0 deletions docs/ug4/additional_pages/main_page.doxygen
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,11 @@ Scientific Computing</em> at the <em>University of Frankfurt, Germany </em>
(http://www.g-csc.de).


https://github.com/UG4/ugcore gives a quick overview on how to obtain and to install
\ug4. Several example applications are described and tools for pre- and
postprocessing are linked.


<hr>
\section secWhatIsIt What is ug4?

Expand Down
2 changes: 1 addition & 1 deletion docs/ug4/additional_pages/setup/buildug.doxygen
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ for your system. Beginners might also want to have a look at \ref pageShellAndLi

<hr>
\section secBuildUG4Checkout Checkout ug4
Please follow the description at https://github.com/UG4/ughub/wiki to obtain a copy of UG4.
Please follow the description at https://github.com/UG4/ughub to obtain a copy of UG4.

<hr>
\section secBuildUG4BashTools Bash Tools
Expand Down
2 changes: 1 addition & 1 deletion docs/ug4/additional_pages/setup/install/install.doxygen
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@
\note Because of the great variety of systems, this installation guides may be outdated quickly. So if this guide is not working for you
\em please open an issue on github.com/UG4/docs

Additionally to the pages below, please have a look at https://github.com/UG4/ughub/wiki.
Additionally to the pages below, please have a look at https://github.com/UG4/ughub.
Installation and usage of UG4's package manager is detailed there.

- \subpage pageAdditionalSoftware "OS-independent (old)"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ from your cluster management tool (e.g. <tt>module load</tt>).

<hr>
\section secInstallUg Installation of UG4
Please follow the description at https://github.com/UG4/ughub/wiki to obtain a
Please follow the description at https://github.com/UG4/ughub to obtain a
copy of \ug4. Below you'll find hints on how to obtain additional software which
is required to build \ug4.

Expand Down
Loading

0 comments on commit 62bee23

Please sign in to comment.