Вопрос

Я хочу найти эквивалент Python из следующего оператора MATLAB:

vq interp1(x,y, xq,'nearest','extrap')
.

Это выглядит так, как будто interp(xq, x, y) отлично работает для линейной интерполяции / экстраполяции.

Я также смотрел на

F = scipy.interpolate.interp1d(x, y, kind='nearest')
.

Что отлично работает для ближайшего метода, но не будет выполнять экстраполяцию.

Есть что-нибудь еще, что я упускаю из виду?Спасибо.

Это было полезно?

Решение

для линейной интерполяции, которая будет экстраполировать с использованием ближайшей интерполяции, используйте генеракодицетагкод.Это делает это по умолчанию.

Например:

yi = np.interp(xi, x, y)
.

В противном случае, если вы просто хотите воплотить ближайшую интерполяцию везде, как вы описываете, вы можете сделать это в коротком, но неэффективном способе: (вы можете сделать это одним вкладом, если хотите)

def nearest_interp(xi, x, y):
    idx = np.abs(x - xi[:,None])
    return y[idx.argmin(axis=1)]
.

или более эффективным способом использования numpy.interp:

def fast_nearest_interp(xi, x, y):
    """Assumes that x is monotonically increasing!!."""
    # Shift x points to centers
    spacing = np.diff(x) / 2
    x = x + np.hstack([spacing, spacing[-1]])
    # Append the last point in y twice for ease of use
    y = np.hstack([y, y[-1]])
    return y[np.searchsorted(x, xi)]
.

Чтобы проиллюстрировать разницу между searchsorted и ближайшими примерами интерполяции выше:

import numpy as np
import matplotlib.pyplot as plt

def main():
    x = np.array([0.1, 0.3, 1.9])
    y = np.array([4, -9, 1])
    xi = np.linspace(-1, 3, 200)

    fig, axes = plt.subplots(nrows=2, sharex=True, sharey=True)
    for ax in axes:
        ax.margins(0.05)
        ax.plot(x, y, 'ro')

    axes[0].plot(xi, np.interp(xi, x, y), color='blue')
    axes[1].plot(xi, nearest_interp(xi, x, y), color='green')

    kwargs = dict(x=0.95, y=0.9, ha='right', va='top')
    axes[0].set_title("Numpy's $interp$ function", **kwargs)
    axes[1].set_title('Nearest Interpolation', **kwargs)

    plt.show()

def nearest_interp(xi, x, y):
    idx = np.abs(x - xi[:,None])
    return y[idx.argmin(axis=1)]

main()
.

Введите описание изображения здесь

Другие советы

В более поздних версиях Scipy (по крайней мере V0.19.1 +) scipy.interpolate.interp1d имеет опцию fill_value = “extrapolate”.

Например:

import pandas as pd
>>> s = pd.Series([1, 2, 3])
Out[1]: 
0    1
1    2
2    3
dtype: int64

>>> t = pd.concat([s, pd.Series(index=s.index + 0.1)]).sort_index()
Out[2]: 
0.0    1.0
0.1    NaN
1.0    2.0
1.1    NaN
2.0    3.0
2.1    NaN
dtype: float64

>>> t.interpolate(method='nearest')
Out[3]: 
0.0    1.0
0.1    1.0
1.0    2.0
1.1    2.0
2.0    3.0
2.1    NaN
dtype: float64

>>> t.interpolate(method='nearest', fill_value='extrapolate')
Out[4]: 
0.0    1.0
0.1    1.0
1.0    2.0
1.1    2.0
2.0    3.0
2.1    3.0
dtype: float64

.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top