forked from amueller/gco_python
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathexample_middlebury.py
46 lines (39 loc) · 1.55 KB
/
example_middlebury.py
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
import Image
import matplotlib.pyplot as plt
import numpy as np
from pygco import cut_simple
def stereo_unaries(img1, img2):
differences = []
max_disp = 8
for disp in np.arange(max_disp):
if disp == 0:
diff = np.sum((img1 - img2) ** 2, axis=2)
else:
diff = np.sum((img1[:, 2 * disp:, :] - img2[:, :-2 * disp, :]) **
2, axis=2)
if disp != max_disp - 1:
diff = diff[:, max_disp - disp - 1:disp - max_disp + 1]
differences.append(diff)
return np.dstack(differences).copy("C")
def potts_example():
img1 = np.asarray(Image.open("scene1.row3.col1.ppm")) / 255.
img2 = np.asarray(Image.open("scene1.row3.col2.ppm")) / 255.
unaries = (stereo_unaries(img1, img2) * 100).astype(np.int32)
n_disps = unaries.shape[2]
newshape = unaries.shape[:2]
potts_cut = cut_simple(unaries, -5 * np.eye(n_disps, dtype=np.int32))
x, y = np.ogrid[:n_disps, :n_disps]
one_d_topology = np.abs(x - y).astype(np.int32).copy("C")
one_d_cut = cut_simple(unaries, 5 * one_d_topology)
plt.subplot(231, xticks=(), yticks=())
plt.imshow(img1)
plt.subplot(232, xticks=(), yticks=())
plt.imshow(img2)
plt.subplot(233, xticks=(), yticks=())
plt.imshow(np.argmin(unaries, axis=2), interpolation='nearest')
plt.subplot(223, xticks=(), yticks=())
plt.imshow(potts_cut.reshape(newshape), interpolation='nearest')
plt.subplot(224, xticks=(), yticks=())
plt.imshow(one_d_cut.reshape(newshape), interpolation='nearest')
plt.show()
potts_example()