mirror of
https://github.com/wassname/scikit-image.git
synced 2026-06-29 02:30:48 +08:00
60 lines
1.9 KiB
Python
60 lines
1.9 KiB
Python
import numpy as np
|
|
from numpy.testing import assert_equal, assert_array_equal
|
|
|
|
from skimage._shared.testing import assert_greater
|
|
from skimage.segmentation import felzenszwalb
|
|
from skimage import data
|
|
|
|
|
|
def test_grey():
|
|
# very weak tests. This algorithm is pretty unstable.
|
|
img = np.zeros((20, 21))
|
|
img[:10, 10:] = 0.2
|
|
img[10:, :10] = 0.4
|
|
img[10:, 10:] = 0.6
|
|
seg = felzenszwalb(img, sigma=0)
|
|
# we expect 4 segments:
|
|
assert_equal(len(np.unique(seg)), 4)
|
|
# that mostly respect the 4 regions:
|
|
for i in range(4):
|
|
hist = np.histogram(img[seg == i], bins=[0, 0.1, 0.3, 0.5, 1])[0]
|
|
assert_greater(hist[i], 40)
|
|
|
|
def test_minsize():
|
|
# single-channel:
|
|
img = data.coins()[20:168,0:128]
|
|
for min_size in np.arange(10, 100, 10):
|
|
segments = felzenszwalb(img, min_size=min_size, sigma=3)
|
|
counts = np.bincount(segments.ravel())
|
|
# actually want to test greater or equal.
|
|
assert_greater(counts.min() + 1, min_size)
|
|
# multi-channel:
|
|
coffee = data.coffee()[::4, ::4]
|
|
for min_size in np.arange(10, 100, 10):
|
|
segments = felzenszwalb(coffee, min_size=min_size, sigma=3)
|
|
counts = np.bincount(segments.ravel())
|
|
# actually want to test greater or equal.
|
|
# the construction doesn't guarantee min_size is respected
|
|
# after intersecting the sementations for the colors
|
|
assert_greater(np.mean(counts) + 1, min_size)
|
|
|
|
|
|
def test_color():
|
|
# very weak tests. This algorithm is pretty unstable.
|
|
img = np.zeros((20, 21, 3))
|
|
img[:10, :10, 0] = 1
|
|
img[10:, :10, 1] = 1
|
|
img[10:, 10:, 2] = 1
|
|
seg = felzenszwalb(img, sigma=0)
|
|
# we expect 4 segments:
|
|
assert_equal(len(np.unique(seg)), 4)
|
|
assert_array_equal(seg[:10, :10], 0)
|
|
assert_array_equal(seg[10:, :10], 2)
|
|
assert_array_equal(seg[:10, 10:], 1)
|
|
assert_array_equal(seg[10:, 10:], 3)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
from numpy import testing
|
|
testing.run_module_suite()
|