mole

MOLE: Mimetic Operators Library Enhanced

Description

MOLE is a high-quality (C++ & MATLAB/Octave) library that implements high-order mimetic operators to solve partial differential equations. It provides discrete analogs of the most common vector calculus operators: Gradient, Divergence, Laplacian, Bilaplacian, and Curl. These operators (highly sparse matrices) act on staggered grids (uniform, non-uniform, curvilinear) and satisfy local and global conservation laws.

Mathematics is based on the work of Corbino and Castillo, 2020. However, the user may find helpful previous publications, such as Castillo and Grone, 2003, in which similar operators were derived using a matrix analysis approach.

Licensing

MOLE is distributed under a GNU General Public License; please refer to the LICENSE file for more details.

Installation

Prerequisites

To install the MOLE library, you’ll need the following packages:

For documentation build requirements, please refer to the Documentation Guide.

Package Installation by OS

Ubuntu/Debian Systems

# Install all required packages
sudo apt install cmake libopenblas-dev libeigen3-dev

macOS Systems

Install Homebrew if you don’t have it already, then run:

# Install all required packages
brew install cmake openblas eigen libomp lapack

Troubleshooting Homebrew: If you encounter installation errors, try these steps:

# Fix permissions issues
sudo chown -R $(whoami) /usr/local/Cellar
# Fix shallow clone issues
git -C /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core fetch --unshallow
# Remove Java dependencies if they cause conflicts
brew uninstall --ignore-dependencies java
brew update

RHEL/CentOS/Fedora Systems

# Install all required packages
sudo yum install cmake openblas-devel eigen3-devel

Building and Installing MOLE

  1. Clone the repository:
    git clone https://github.com/csrc-sdsu/mole.git  
    cd mole  
    
  2. Build the library:
    mkdir build && cd build  
    cmake ..
    make
    
  3. Install the library:
    • For a custom location:
      cmake --install . --prefix /path/to/location
      
    • For a system location (requires privileges):
      sudo cmake --install .
      

      Or

      sudo cmake --install . --prefix /path/to/privileged/location
      

Note: Armadillo and SuperLU will be automatically installed in the build directory during the build process.

Examples and Tests

MOLE provides comprehensive examples and tests for both C++ and MATLAB/Octave implementations to help you get started quickly.

Available Resources

Tests

Examples

We recommend running the tests before starting to use the library to ensure everything is working correctly.

Documentation

MOLE comes with comprehensive documentation:

Important Note: Performing non-unary operations involving operands constructed over different grids may lead to unexpected results. While MOLE allows such operations without throwing errors, users must exercise caution when manipulating operators across different grids.

Community Guidelines

We welcome contributions to MOLE, including:

Please refer to our Contribution Guidelines for more details.

Citations

Please cite our work if you use MOLE in your research or software. Citations are helpful for the continued development and maintenance of the library DOI

View mole on File Exchange

Now, some cool pictures obtained with MOLE:

Obtained with curvilinear operators Obtained with curvilinear operators Obtained with curvilinear operators Obtained with curvilinear operators Obtained with curvilinear operators Obtained with curvilinear operators Obtained with curvilinear operators Obtained with curvilinear operators