
import numpy as np


def spsa(perturbation_plus, perturbation_minus, delta, c):

    estimate = np.zeros([perturbation_plus.shape[0], delta.shape[0]])
    for i in range(perturbation_plus.shape[0]):
        for j in range(delta.shape[0]):
            estimate[i][j] = (perturbation_plus[i] - perturbation_minus[i]) / (2 * c * delta[j])
    return estimate
