python - 图像分割以查找生物图像中的细胞

标签 python image-processing image-segmentation opencv hough-transform

我有一堆细胞图像,我想提取细胞所在的位置。我目前正在使用圆形霍夫变换,它工作正常,但经常出错。想知道人们是否有任何指示。抱歉,这不是一个专门关于软件的问题 - 这是如何在图像分割问题中获得更好的性能。

我在 skimage 中尝试过其他东西,但效果有限,例如轮廓查找、边缘检测和事件轮廓。尽管可能只是我没有正确调整参数,但开箱即用的效果并不好。我没有做过太多图像分割,而且我真的不知道这些东西是如何工作的,或者临时调整它的最佳方法是什么。

这是我当前使用的代码,它将灰度图像作为 numpy 数组,并以圆形形式查找单元格:

import cv2
import numpy as np
smallest_dim = min(img.shape)
min_rad = int(img.shape[0]*0.05)
max_rad = int(img.shape[0]*0.5) #0.5
circles = cv2.HoughCircles((img*255).astype(np.uint8),cv2.HOUGH_GRADIENT,1,50,
    param1=50,param2=30,minRadius=min_rad,maxRadius=max_rad)
circles = np.uint16(np.around(circles))
x, y, r = circles[0,:][:1][0]

下面是一个示例,其中代码发现错误的圆作为单元格的边界。它似乎被细胞周围的粘稠物搞糊涂了: Failed Hough Transform

最佳答案

我认为一个问题可能是圆的绘制(坐标可能是错误的)。

此外,就像 @Nicos 提到的那样,传统图像处理需要进行大量调整才能使特定案例发挥作用(而最近的机器学习方法,调整是为了使模型不会过度训练),我对 skimage 的尝试显示如下。考虑到图像之间和图像内的潜在变化,半径范围、圆圈数量、边缘检测图像,所有这些都需要调整。在这张图像中,至少对我来说,有 3 个具有不同梯度的圆圈,从 canny 边缘检测图像中,您可以看到我们得到了超过 3 个圆圈,此外,“照明” “似乎在不同的位置有所不同(因为这是一张 SEM 图像)?!

import matplotlib.pyplot as plt
import numpy as np
import imageio

from skimage import data, color
from skimage.transform import hough_circle, hough_circle_peaks
from skimage.feature import canny
from skimage.draw import circle_perimeter
from skimage.util import img_as_ubyte
!wget /image/2tsWw.jpg
# rgb to gray https://stackoverflow.com/a/51571053/868736
im = imageio.imread('2tsWw.jpg')
gray = lambda rgb : np.dot(rgb[... , :3] , [0.299 , 0.587, 0.114]) 
gray = gray(im)  
image = np.array(gray[60:220,210:450])
plt.imshow(image,cmap='gray')

enter image description here

edges = canny(image, sigma=3,)
plt.imshow(edges,cmap='gray')

enter image description here

overlayimage = np.copy(image)

# https://scikit-image.org/docs/dev/auto_examples/edges/plot_circular_elliptical_hough_transform.html

hough_radii = np.arange(30, 60, 2)
hough_res = hough_circle(edges, hough_radii)

# Select the most prominent X circles
x=1
accums, cx, cy, radii = hough_circle_peaks(hough_res, hough_radii,
                                           total_num_peaks=x)
# Draw them
fig, ax = plt.subplots(ncols=1, nrows=1, figsize=(10, 4))
#image = color.gray2rgb(image)
for center_y, center_x, radius in zip(cy, cx, radii):
    circy, circx = circle_perimeter(center_y, center_x, radius)
    overlayimage[circy, circx] = 255

print(radii)
ax.imshow(overlayimage,cmap='gray')
plt.show()

enter image description here

关于python - 图像分割以查找生物图像中的细胞,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55994311/

相关文章:

python - 尝试抓取,找回[]

matlab - 如何从图像中删除/替换边框像素?

c++ - 没有 if-else 语句的一维卷积(非 FFT)?

image - 如何检测区域上方和下方的点?

python - 使用 Python 从 Google Drive/Workspace 下载电子表格

python - AttributeError: 'ChatBot' 对象没有属性 'get_responce'

python - 如何在python中编辑拼接模块的opencv源代码?

tensorflow - 如何在机器学习中训练模型以从图像中去除背景

java - 使用opencv的分水岭java实现

python - 如何检查用户是否提供了参数 discord.py