scikit-image
36 строк · 987.0 Байт
1#cython: cdivision=True
2#cython: nonecheck=False
3#cython: wraparound=False
4import numpy as np
5cimport numpy as cnp
6
7from .._shared.fused_numerics cimport np_floats
8cnp.import_array()
9
10
11def moments_hu(np_floats[:, :] nu):
12if np_floats is cnp.float32_t:
13dtype = np.float32
14else:
15dtype = np.float64
16
17cdef np_floats[::1] hu = np.zeros((7,), dtype=dtype)
18cdef np_floats t0 = nu[3, 0] + nu[1, 2]
19cdef np_floats t1 = nu[2, 1] + nu[0, 3]
20cdef np_floats q0 = t0 * t0
21cdef np_floats q1 = t1 * t1
22cdef np_floats n4 = 4 * nu[1, 1]
23cdef np_floats s = nu[2, 0] + nu[0, 2]
24cdef np_floats d = nu[2, 0] - nu[0, 2]
25hu[0] = s
26hu[1] = d * d + n4 * nu[1, 1]
27hu[3] = q0 + q1
28hu[5] = d * (q0 - q1) + n4 * t0 * t1
29t0 *= q0 - 3 * q1
30t1 *= 3 * q0 - q1
31q0 = nu[3, 0]- 3 * nu[1, 2]
32q1 = 3 * nu[2, 1] - nu[0, 3]
33hu[2] = q0 * q0 + q1 * q1
34hu[4] = q0 * t0 + q1 * t1
35hu[6] = q1 * t0 - q0 * t1
36return np.asarray(hu)
37