Skip to content
/ pyfk Public
forked from ziyixi/pyfk

PyFK is the python implementation of FK used to calculate the Green's function and the synthetic waveforms for the 1D Earth model.

License

Notifications You must be signed in to change notification settings

lynlyf/pyfk

 
 

Repository files navigation

PyFK

https://codecov.io/gh/ziyixi/pyfk/branch/master/graph/badge.svg?token=5EL7IDTYLJ

About

PyFK is the python port of FK used to calculate the Green's function and the synthetic waveforms for the 1D Earth model.

The main features of this package are:

  • Compute the Green's function for the explosion, single force, and double couple source using the frequency-wavenumber method.
  • Compute the static displacements and corresponding Green's function.
  • Compute the synthetic waveforms by convolving Green's function with the seismic source.
  • Use the seismic data format of Obspy, which is easy to perform the signal processing.

And the package is unique as:

  • all the code is written in pure python, and it's compatible with Unix-like systems including Mac and Linux. The Windows is not supported, as the package uses the complex number in Cython, which uses the C99 standard of "complex.h" that has not been supported by the Visual Studio compiler.

  • it uses Cython to speed up the computationally expensive part (mainly the wavenumber integration).

  • The package has also provided three modes:

    • Serial mode: the serial version implements the FK algorithm in Python.
    • Parallel mode on CPU: the wavenumber integration can be paralleled by MPI.
    • Parallel mode on GPU: the wavenumber integration can also be paralleled by CUDA on GPU.

Installation

The serial version and the parallel version on GPU can be simply installed using pip:

pip install pyfk

Or conda:

conda install -c ziyixi pyfk

It's also easy to install the MPI enabled version:

PYFK_USE_MPI=1 pip install pyfk[mpi]

Extra packages including numba and cupy will be required to enable the GPU mode. For more details about the Installation, you can refer to the Installing part of the document.

Todo

The current bugs to fix or features to provide are listed in TODO.

License

PyFK is a free software: you can redistribute it and modify it under the terms of the Apache License. A copy of this license is provided in LICENSE.

About

PyFK is the python implementation of FK used to calculate the Green's function and the synthetic waveforms for the 1D Earth model.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.6%
  • Other 0.4%