Skip to main content
Help the Python Software Foundation raise $60,000 USD by December 31st!  Building the PSF Q4 Fundraiser

A multigrid solver for 3D electromagnetic diffusion.

Project description

emg3d logo

A multigrid solver for 3D electromagnetic diffusion with tri-axial electrical anisotropy. The matrix-free solver can be used as main solver or as preconditioner for one of the Krylov subspace methods implemented in scipy.sparse.linalg, and the governing equations are discretized on a staggered Yee grid. The code is written completely in Python using the NumPy/SciPy-stack, where the most time- and memory-consuming parts are sped up through jitted numba-functions.

More information

For more information regarding installation, usage, contributing, roadmap, bug reports, and much more, see

Features

  • Multigrid solver for 3D electromagnetic diffusion with regular grids.
  • Can be used together with the SimPEG-framework.
  • Can be used as a standalone solver or as a pre-conditioner for various Krylov subspace methods implemented in SciPy, e.g., BiCGSTAB (scipy.sparse.linalg.bicgstab) or CGS (scipy.sparse.linalg.cgs).
  • Tri-axial electrical anisotropy.
  • Semicoarsening and line relaxation.
  • Grid-size can be anything.
  • As a multigrid method it scales with the number of unknowns N and has therefore optimal complexity O(N).

Installation

You can install emg3d either via conda (preferred):

conda install -c prisae emg3d

or via pip:

pip install emg3d

Required are Python version 3.7 or higher and the modules NumPy, SciPy, and numba; discretize (from SimPEG) is highly recommended.

If you are new to Python we recommend using a Python distribution, which will ensure that all dependencies are met, specifically properly compiled versions of NumPy and SciPy; we recommend using Anaconda. If you install Anaconda you can simply start the Anaconda Navigator, add the channel prisae and emg3d will appear in the package list and can be installed with a click.

Citation

If you publish results for which you used emg3d, please give credit by citing us. We will soon submit an article to JOSS, and will post here the details as soon as we have them.

All releases have a Zenodo-DOI, provided on the release-page.

See CREDITS for the history of the code.

License information

Copyright 2018-2019 The emg3d Developers.

Licensed under the Apache License, Version 2.0, see the LICENSE-file.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for emg3d, version 0.6.2
Filename, size File type Python version Upload date Hashes
Filename, size emg3d-0.6.2-py3-none-any.whl (49.5 kB) File type Wheel Python version py3 Upload date Hashes View
Filename, size emg3d-0.6.2.tar.gz (51.0 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page