Reef3D#
REEF3D is an open-source hydrodynamics framework with a focus on coastal, marine and hydraulic engineering flows. Tailor-made multiphysics solvers are available for a range of relevant problems (e.g. sediment transport or floating body dynamics). The modular programming approach allows the framework to incorporate a range of different flow solvers which together represent all relevant length scales. Depending on the wave or flow conditions, the following optimized hydrodynamic modules are available:
REEF3D::CFD solves the Navier-Stokes equations in three dimensions. For near-field simulations with a complex free surface pattern, it uses a two-phase flow approach with the level set method for interface capturing.
REEF3D::FNPF is a three-dimensional fully nonlinear potential flow solver. It is massively parallelized and can be used to create large-scale phase-resolved sea states at all water depths.
REEF3D::SFLOW is a depth-averaged model, solving the non-hydrostatic shallow water equations ideal for near-shore hydrodynamics and river flow.
Running a simulation#
Reef3D in Inductiva API executes two sequential steps:
the meshing with DiveMESH;
the simulation with Reef3D.
Each step is configured with input files, control.txt
and ctrl.txt
,
respectively. Other files may be used to inform the simulator about the grid,
geographical data or wave information. Reef3D has strict naming policies for
each file and we recommend users to follow
their guidelines.
To run the simulation users pass a folder with the above files and all others required to run the simulation. The folder is then uploaded to Inductiva API and the simulation is executed. The output files are then downloaded to the user’s machine.
The parallelization of the simulation is handled automatically by Inductiva API, based on the number of cores available in the machine.
General Arguments:
on
: set the machines where the simulations will run. Check here for further detail. If not selected the simulations will be picked-up by a default pool shared by everyone.storage_dir
: set the directory where the output files will be stored in the cloud. If not selected the output files will be stored in a folder named with the task id of the simulation.n_vcpus
: number of virtual CPUs / threads that will be used to configure the MPI parallism. This number needs to be set consistently with parameterM 10
to be set in bothcontrol.txt
andctrl.txt
configurations files.
For further information on handling the task of the simulation see here.
Example#
Here, we follow the tutorial with regular wave propagation from Reef3D repository.
import inductiva
input_dir = inductiva.utils.download_from_url(
"https://storage.googleapis.com/inductiva-api-demo-files/"
"reef3d-input-example.zip", unzip=True)
reef3d = inductiva.simulators.REEF3D()
task = reef3d.run(input_dir=input_dir)
task.wait()
task.download_outputs()
A slighly more advanced example#
Let’s now run a more advanced example, one that will also require a lot more compute power, and will illustrate more advanced features of the API. More specifically, we will use the API to run the “3D Dam Break Scenarion with Obstacle” that can be found in Reef3D tutorials.
As explained before, there are two files that are required to configure the simulation:
Let’s start by downloading both of these files and adding them to a folder named “10_2_3D_Dam_Break_with_Obstacle” inside our working folder. Just download each file directly from GitHub (use “Download raw file” option) and move them to the “10_2_3D_Dam_Break_with_Obstacle” local folder (that you also need to create locally).
Before we proceed, let’s inspect the files to check three Reed3D parameters that
are important to understand before we configure our simulation run. These
parameters are: N 41
, P 30
and M 10
:
control.txt (for DiveMESH):
C 11 21
C 12 21
C 13 21
C 14 21
C 15 21
C 16 21
B 1 0.025
B 10 0.0 2.0 0.0 1.0 0.0 1.0
O 10 1.2 1.4 0.4 0.6 0.0 1.0
M 10 4 <---- defines the nr. of processors for parallel computations (4)
ctrl.txt (for Reef3D):
D 10 4
D 20 2
D 30 1
F 30 3
F 40 3
F 54 0.5
F 56 0.7
N 40 3
N 41 25.0 <---- set the maximum modeled time (25 seconds).
N 45 50000
N 47 0.2
M 10 4 <---- defines the nr. of processors for parallel computations (4)
P 10 1
P 30 0.01 <---- defines the rate of paraview results (1 frame per 0.01 s)
T 10 0
W 22 -9.81
Observe that parameter M 10
, which controls the level of parallelism, is
set to 4 threads/vCPUs, a very low number. Depending on the number of vCPUs we
effectively wish to use for running the simulation, we will need to manually
change M 10
on both files to match the specs of corresponding the VM.
We will be using GCP VMs of the c2d family, which tend to provide a very good
price-performance point, especially when you run them in spot mode. More
specifically, we will be using the larger c2d-highcpu-112
machines with
112 vCPUs and 2GB of RAM per vCPU (this simulation will not require more than
224GB of RAM).
We will be setting M 10 56
on both files. Note that this is half the
available number of vCPUs available on the VM (112!). Actually, running on only
half of the vCPUs may provide significantly faster simulation times than running
on all the vCPUs for some simulators / VM types. This has to do with the fact
that these VMs run on processors with hyperthreading, meaning that two threads
will run per physical core. One of the issues with hyperthreading is that it
increases thread competition for cache (which is fixed), and this may lead to
some contention issues for I/O heavy simulators, as seems to be the case for
Reef3D.
Indeed, Reef3D can produce a huge amount of data. As it is currently configured,
this simulation would produce several dozen gigabytes of data. To reduce that
amount of data produced, we can reduce the rate at which (Paraview) data is
being produced (parameter P 30
). Therefore, we will set P 30 0.04
and
request Reef3D to “only” generate 25 frames per second (instead of 100 frames
per second as it was initially configure). Also, just in case, we will request
our machine to be equipped with a 20GB partition (just for data), using the
data_disk_gb
parameter of the inductiva.resources.MachineGroup
class.
Here is the final script:
import inductiva
machine_group = inductiva.resources.MachineGroup(
machine_type="c2d-highcpu-112",
spot=True,
data_disk_gb=20)
machine_group.start()
reef3d = inductiva.simulators.REEF3D()
task = reef3d.run(
input_dir="./10_2_3D_Dam_Break_with_Obstacle",
on=machine_group,
n_vcpus=56,
storage_dir="3D_dam_break_with_obstacle")
task.wait()
machine_group.terminate()
task.print_summary()
You should see something like this when you run this script end to end (it should take less than 15 minutes). Please take into consideration that some values related with user credits and quotas may differ substantially from the ones you may see depending on the tier you are in.
Username: sarmento
■ Tier: Power-User
■ Credits
Power-User (tier) 0.00 USD
----------------------------------------
Total 998.36 USD
■ Active Campaigns
Not currently enrolled in any campaign.
■ Global User quotas
CURRENT USAGE MAX ALLOWED
Maximum simultaneous instances 1 instance 100 instance
Maximum price per hour across all instances 0.87444 USD 270 USD
Maximum tasks per week 0 task N/A
Maximum number of VCPUs 112 vcpu 1000 vcpu
Maximum time a machine group can stay idle before termination N/A 120 minute
■ Instance User quotas
MAX ALLOWED
Maximum disk size 2000 GB
Maximum time a machine group can stay up before automatic termination 48 hour
Maximum amount of RAM per VCPU 6 GB
Maximum time a task can stay running in the default queue before automatic termination 16 hour
■ Registering MachineGroup configurations:
· Name: api-o4qozo7wafhwqcyz4xh1g4e7s
· Machine Type: c2d-highcpu-112
· Data disk size: 20 GB
· Maximum idle time: 30 minutes
· Auto terminate timestamp: 2024/08/11 00:43:06
· Number of machines: 1
· Spot: True
· Estimated cloud cost of machine group: 0.872 $/h
· You are spending 5.3x less by using spot machines.
Starting MachineGroup(name="api-o4qozo7wafhwqcyz4xh1g4e7s"). This may take a few minutes.
Note that stopping this local process will not interrupt the creation of the machine group. Please wait...
Machine Group api-o4qozo7wafhwqcyz4xh1g4e7s with c2d-highcpu-112 machines successfully started in 0:00:18.
The machine group is using the following quotas:
USED BY RESOURCE CURRENT USAGE MAX ALLOWED
Maximum number of VCPUs 112 224 1000
Maximum simultaneous instances 1 2 100
Maximum price per hour across all instances 0.87444 1.74888 270
■ Using production image of REEF3D version 24.02
■ Task Information:
· ID: arduwp0bnjkwz9d4xk7rabofi
· Simulator: REEF3D
· Version: 24.02
· Image: docker://inductiva/kutu:reef3d_v24.02
· Local input directory: 10_2_3D_Dam_Break_with_Obstacle
· Submitting to the following computational resources:
· Machine Group api-o4qozo7wafhwqcyz4xh1g4e7s with c2d-highcpu-112 machines
Preparing upload of the local input directory 10_2_3D_Dam_Break_with_Obstacle (390 B).
Input archive size: 689 B
Uploading input archive...
100%|████████████████████████████████████████████████████████████████| 689/689 [00:00<00:00, 1.65kB/s]
Local input directory successfully uploaded.
■ Task arduwp0bnjkwz9d4xk7rabofi submitted to the queue of the Machine Group api-o4qozo7wafhwqcyz4xh1g4e7s with c2d-highcpu-112 machines.
Number of tasks ahead in the queue: 0
Simulation metadata logged to: inductiva_output/task_metadata.json
Task arduwp0bnjkwz9d4xk7rabofi configurations metadata saved to the tasks metadata file task_metadata.json in the current working directory.
· Consider tracking the status of the task via CLI:
inductiva tasks list --id arduwp0bnjkwz9d4xk7rabofi
· Or, tracking the logs of the task via CLI:
inductiva logs arduwp0bnjkwz9d4xk7rabofi
· You can also get more information about the task via the CLI command:
inductiva tasks info arduwp0bnjkwz9d4xk7rabofi
■ Task arduwp0bnjkwz9d4xk7rabofi successfully queued and waiting to be picked-up for execution...
The task arduwp0bnjkwz9d4xk7rabofi is about to start.
■ Task arduwp0bnjkwz9d4xk7rabofi has started and is now running remotely.
■ Task arduwp0bnjkwz9d4xk7rabofi completed successfully.
Downloading stdout and stderr files to arduwp0bnjkwz9d4xk7rabofi...
Partial download completed to arduwp0bnjkwz9d4xk7rabofi.
Successfully requested termination of MachineGroup(name="api-o4qozo7wafhwqcyz4xh1g4e7s").
Termination of the machine group freed the following quotas:
FREED BY RESOURCE CURRENT USAGE MAX ALLOWED
Maximum number of VCPUs 112 112 1000
Maximum simultaneous instances 1 1 100
Maximum price per hour across all instances 0.87444 0.87444 270
Task status: success
Wall clock time: 0:10:34
Time breakdown:
Input upload: 0.60 s
Time in queue: 24.11 s
Container image download: 6.02 s
Input download: 0.08 s
Input decompression: 0.00 s
Computation: 0:07:36
Output upload: 0:02:27
Data:
Size of zipped output: 3.10 GB
Size of unzipped output: 7.51 GB
Number of output files: 35751
While the script is running, you can check the stdout of the simulation process in real time by issuing (please change to the id of your task):
inductiva logs arduwp0bnjkwz9d4xk7rabofi
The command line above is shown in the execution trace, so you can just copy and paste it to a new terminal (which needs also to have the API key set as an environment variable).
Once the script finishes, and you see the summary of the task, you can download the resulting files. Observe in the summary above that quite some data was produced: 35751 files for a total of 7.51 GB before compression. That is why the last stage of the process, “Output Upload”, which involves compressing and moving the outputs of the simulation to your personal cloud stoarge area, still takes a significant fraction of time of the overall process execution (2:27 out of 10:34).
You can download the (zipped) data by creating a simple script such as this (again, please change to the corresponding task id):
import inductiva
# You can retreive a Task by ID
task = inductiva.tasks.Task("arduwp0bnjkwz9d4xk7rabofi")
task.download_outputs()
Or, perhaps more conveniently, you can use Inductiva’s Command Line Interface (CLI) to list the contents of your personal remote storage and then download them:
inductiva storage list
which should get you something like this (you may have other contents)
NAME SIZE CREATION TIME
3D_dam_break_with_obstacle/ 3.09 GB 26 Jun, 07:39:11
And you can donwload the folder produced by this task by doing:
inductiva tasks download arduwp0bnjkwz9d4xk7rabofi
What to read next#
If you are interested in Reef3D, you may also be interested in checking the following related simulators that are also avaiable via Inductiva API: