Skip to content

Post-processing projections for displacement-based finite-element simulations in Room Acoustics

License

Notifications You must be signed in to change notification settings

ashwin-nayak/pressure-projections

Repository files navigation

Pressure Projections

Code supplement for article "Accuracy of post-processing projections for displacement based finite element simulations in room acoustics".

This repository contains scripts to reproduce all the numerical results included as benchmark cases in the article. The implementation is in the Julia programming language, primarily using Gridap package.

Details:

  • Weak formulation for pressure $L^2$ and $H^1$-projections
  • Continuous and discontinuous Galerkin discretizations for computing the pressure field
  • First and second-order finite element discretizations are analyzed
  • Error convergence and computational performance is illustrated with different benchmarks

Authors:

  • Ashwin S. Nayak orcid github
  • Andrés Prieto orcid github
  • Daniel Fernández-Comesaña orcid github

Affiliation:

Repository:

License:

Table of Contents

Getting Started

First, clone the repository or download the contents locally on your computer, and ensure you are working within project directory,

git clone git@github.com:ashwin-nayak/pressure-projections.git
cd pressure-projections

The library is structured into the following folders, which correspond to each benchmark scenarios:

Folder Information
1D-example One-dimensional planewave propagation in an elongated rectangle
2D-annulus-example Two-dimensional radial wave propagation in a quarter of an annular domain
2D-square-structured-example Two-dimensional planewave propagation in the unit square using a structured mesh
2D-square-unstructured-example Two-dimensional planewave propagation in the unit square using an unstructured mesh
2D-square-noise-example Two-dimensional planewave propagation in the unit square in the presence of noise
2D-room-example Two-dimensional transmitted field in the interior of the cross-section of an auditorium

To run the scripts, you must first set the environment and dependent Julia packages. Instructions provided here are provided for standard UNIX distributions, but maybe easily adopted (but not tested) in other operating systems.

You may either choose to use,

Warning

The code execution requires a large amount of free RAM memory (>40 GB) and a runtime of about ~20 h (due to large problem sizes for highly resolved meshes).

Run using docker container

The project offers a Dockerfile to automate the configuration and execution by, setting relevant dependencies, hosting the source code, building executables and running the demos.

Necessary tools:

Build the pressure-projections image which contains the environment, copies the source code and builds executables

docker build -f Dockerfile --tag pressure-projections .

Run a disposable container by sharing the project folder within,

docker run --rm \
  -u $(id -u):$(id -g) \
  -v $PWD:/src \
  -w /src \
  pressure-projections \
    julia \
      --project=/pressure-projections \
      --startup-file=no \
      --history-file=no \
      main.jl

This should run an instance of the Julia REPL where each benchmark can be executed.

Tip

The flags ensure correct user permissions are set on the container-generated output files. Additionally, the container information is cleared at the end of the run.

Run in Julia

Setup the right versions and proper environment to run the scripts by following along the links,

  1. Install Julia (v1.11.0) (not described here)
  2. Install Dependencies

Tip

If juliaup is available (recommended), the right version can be installed simply by,

juliaup add 1.11.0

Tip

If you already have installed Julia before, verify the version you have by,

julia -e 'using InteractiveUtils; versioninfo()'

Install relevant dependencies to ensure proper environment,

julia +1.11.0 --project=. -e "using Pkg; Pkg.instantiate();"

Each benchmark can be run independently in its respective folder. Alternatively, an automated script main.jl is provided to run all the benchmarks,

julia +1.11.0 --project=. main.jl

Development Container (for developers)

If you intend to develop the source code without modifying/installing any dependencies on your host computer, you can make use of development containers for setting up the requisite environment.

A specification file .devcontainer.json is provided for building the devcontainer and can be utilized by supporting editors.

Necessary tools :

Start VS Code, run the "Dev Containers: Open Folder in Container..." command from the Command Palette (F1), and select the project folder. While done for the first time, this should start building the container and can take a while (~5 min) and subsequently open the project within the container. The build is cached for subsequent runs and should be fairly quick thereon.

Proceed to running the benchmarks.

About

Post-processing projections for displacement-based finite-element simulations in Room Acoustics

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published