-
Notifications
You must be signed in to change notification settings - Fork 139
/
pyflow.pyx
51 lines (48 loc) · 2.35 KB
/
pyflow.pyx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# distutils: language = c++
# distutils: sources = src/Coarse2FineFlowWrapper.cpp
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
# from __future__ import unicode_literals
import numpy as np
cimport numpy as np
# Author: Deepak Pathak (c) 2016
cdef extern from "src/Coarse2FineFlowWrapper.h":
void Coarse2FineFlowWrapper(double * vx, double * vy, double * warpI2,
const double * Im1, const double * Im2,
double alpha, double ratio, int minWidth,
int nOuterFPIterations, int nInnerFPIterations,
int nSORIterations, int colType,
int h, int w, int c);
def coarse2fine_flow(np.ndarray[double, ndim=3, mode="c"] Im1 not None,
np.ndarray[double, ndim=3, mode="c"] Im2 not None,
double alpha=1, double ratio=0.5, int minWidth=40,
int nOuterFPIterations=3, int nInnerFPIterations=1,
int nSORIterations=20, int colType=0):
"""
Input Format:
double * vx, double * vy, double * warpI2,
const double * Im1 (range [0,1]), const double * Im2 (range [0,1]),
double alpha (1), double ratio (0.5), int minWidth (40),
int nOuterFPIterations (3), int nInnerFPIterations (1),
int nSORIterations (20),
int colType (0 or default:RGB, 1:GRAY)
Images Format: (h,w,c): float64: [0,1]
"""
cdef int h = Im1.shape[0]
cdef int w = Im1.shape[1]
cdef int c = Im1.shape[2]
cdef np.ndarray[double, ndim=2, mode="c"] vx = \
np.ascontiguousarray(np.zeros((h, w), dtype=np.float64))
cdef np.ndarray[double, ndim=2, mode="c"] vy = \
np.ascontiguousarray(np.zeros((h, w), dtype=np.float64))
cdef np.ndarray[double, ndim=3, mode="c"] warpI2 = \
np.ascontiguousarray(np.zeros((h, w, c), dtype=np.float64))
Im1 = np.ascontiguousarray(Im1)
Im2 = np.ascontiguousarray(Im2)
Coarse2FineFlowWrapper(&vx[0, 0], &vy[0, 0], &warpI2[0, 0, 0],
&Im1[0, 0, 0], &Im2[0, 0, 0],
alpha, ratio, minWidth, nOuterFPIterations,
nInnerFPIterations, nSORIterations, colType,
h, w, c)
return vx, vy, warpI2