Удалить небольшие объекты в маске и создать новую двоичную маску из цикла for
Я ценю вашу помощь;
Эта часть кода позволяет мне построить то, что я хочу, но мне нужно назначить результат (двоичное изображение с>500 объектами области) переменной для дальнейшей обработки
Improved_label = np.zeros_like(label_image)
#props = regionprops(label_image)
for R in regionprops(label_image):
if R.area > 500:
# draw the region (I'm sure there's a more efficient way of doing it)
for c in R.coords:
Improved_label[c[0], c[1]] = 1
#Improved_labe1 = Improved_label > 1
1 ответ
Видимо, что-то не так с именем "улучшено" в начале имени переменной (не знаю почему). но в любом случае, есть два решения этой проблемы. Я надеюсь, что это будет полезно для людей с опытом работы в Matlab:
------------- Вариант А --------------
label2_test = np.zeros_like(label_image)
for R in regionprops(label_image):
if R.area > 1000:
# draw the region (I'm sure there's a more efficient way of doing it)
for c in R.coords:
label2_test[c[0], c[1]] = 1
label2_test = label2_test > 0
plt.imshow(labe2_test)
---------------- Вариант B-----------------
from skimage import morphology
labe1_improved = morphology.remove_small_objects(label_image, min_size=1000)