scipy convolve2d выводит неверные значения

Вот мой код, который я использовал для проверки правильности convolve2d

import numpy as np
from scipy.signal import convolve2d

X = np.random.randint(5, size=(10,10))
K = np.random.randint(5, size=(3,3))
print "Input's top-left corner:"
print X[:3,:3]
print 'Kernel:'
print K

print 'Hardcording the calculation of a valid convolution (top-left)'
print (X[:3,:3]*K)
print 'Sums to'
print (X[:3,:3]*K).sum()
print 'However the top-left value of the convolve2d result'
Y = convolve2d(X, K, 'valid')
print Y[0,0]

На моем компьютере это приводит к следующему:

Input's top-left (3x3) corner:
[[0 0 0]
 [1 1 2]
 [1 3 0]]
Kernel:
[[4 1 1]
 [0 3 3]
 [2 1 2]]
Hardcording the calculation of a valid convolution (top-left)
[[0 0 0]
 [0 3 6]
 [2 3 0]]
Sums to
14
However the top-left value of the convolve2d result
10

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

Ответы на вопрос(2)

Ваш ответ на вопрос