Metadata-Version: 2.1
Name: konnoohmachi
Version: 0.2.0
Classifier: Topic :: Software Development
Requires-Dist: numpy ~= 1.20.0; extra == 'tests'
Requires-Dist: obspy; extra == 'tests'
Provides-Extra: tests
License-File: LICENSE
Summary: Spectral smoothing in Rust/Python
Keywords: seismology,spectral smoothing
Author: Marius Kriegerowski <marius.kriegerowski@gmail.com>
Author-email: Marius Kriegerowski <marius.kriegerowski@gmail.com>
License: MIT
Description-Content-Type: text/markdown; charset=UTF-8; variant=GFM

[![PyPI](https://img.shields.io/pypi/v/konnoohmachi.svg)](https://pypi.python.org/pypi)
[![PyPI](https://img.shields.io/pypi/dm/konnoohmachi.svg)](https://pypi.python.org/pypi)

Konno-Ohmachi spectral smoothing
================================

Implemented in Rust with a Python interface. The performance gain measured against the widely used Python/numpy implementation that comes with [obspy](https://docs.obspy.org/packages/autogen/obspy.signal.konnoohmachismoothing.konno_ohmachi_smoothing.html#obspy.signal.konnoohmachismoothing.konno_ohmachi_smoothing) approaches approximately a factor of 2.5 for large spectra (see [Benchmarks](#Benchmarks)).

## Dependencies

You need the rust compiler installed:

[Rust](https://www.rust-lang.org/tools/install)

## Installation

Installation from pypi:

```bash
pip install konnoohmachi
```

Installation from source:

```bash
pip install .
```

## Usage

This smoothes some random numbers:

```python
import konnoohmachi

b = 10
n = 1000
freqs = np.arange(n)
amplitudes = np.random.rand(n)
smoothed = konnoohmachi.smooth(freqs, amplitudes, b)
```

```rust
use konnoohmachi;

let frequencies = Array1::<f64>::zeros(10);
let amplitudes = Array1::<f64>::ones(10);
let bandwidth = 40.0;
konnoohmachi_smooth(
    frequencies.view().into_dyn(),
    amplitudes.view().into_dyn(),
    bandwidth,
);
```

## Benchmarks

Measuring the execution time based of increasing sized spectra yields:

```
❯ python3 benchmark.py
nsamples |    Rust      |    Python     | Performance Gain
----------------------------------------------------------
256      |    0.00017   |    0.00192    |   11.30802
512      |    0.00054   |    0.00431    |    7.97596
1024     |    0.00198   |    0.01117    |    5.63623
2048     |    0.00775   |    0.03143    |    4.05371
4096     |    0.03067   |    0.10024    |    3.26844
8192     |    0.12212   |    0.35058    |    2.87080
16384    |    0.49391   |    1.29653    |    2.62506
32768    |    1.98499   |    5.05335    |    2.54578
```

