Если я правильно понимаю ваш вопрос, то мы можем использовать вещание для этого, но перед этим мы должны выложить наш первоначальный фильтр, чтобы он соответствовал одному из измерений нашего изображения. И, к счастью, изображение здесь является квадратным изображением. Итак, многое становится проще:
In [70]: filter_ = np.array([-1/np.sqrt(2), 1/np.sqrt(2)])
In [71]: filter_
Out[71]: array([-0.70710678, 0.70710678])
# tile the initial array to match the dimensions of image
In [72]: filter_1d = np.tile(filter_, 768//2)
In [73]: filter_1d.shape
Out[73]: (768,)
In [74]: img = np.random.random_sample((768, 768))
# apply the filter on the image
In [76]: filtered = np.multiply(img, filter_1d)
In [77]: filtered.shape
Out[77]: (768, 768)