如何在opencv中计算粗糙度轮廓?

0 投票
1 回答
3790 浏览
提问于 2025-04-17 17:26

有没有办法在opencv中计算粗糙度轮廓?

图片示例: https://docs.google.com/file/d/0ByS6Z5WRz-h2NDgySmJ6NnpId0U/edit?usp=sharing

更新

我用来计算粗糙度的代码:

周长轮廓 / 凸包周长

nomeimg = 'Riscalate2/JPEG/e (5).jpg'

img = cv2.imread(nomeimg)

gray = cv2.imread(nomeimg,0)#convert grayscale adn binarize

element = cv2.getStructuringElement(cv2.MORPH_CROSS,(6,6)) 
graydilate = cv2.erode(gray, element) #imgbnbin

cv2.imshow('image',graydilate)
cv2.waitKey(0)

ret,thresh = cv2.threshold(graydilate,127,255,cv2.THRESH_BINARY_INV)   # binarize

imgbnbin = thresh
cv2.imshow('bn',thresh)
cv2.waitKey()

#element = cv2.getStructuringElement(cv2.MORPH_CROSS,(2,2))
#element = np.ones((11,11),'uint8')


contours, hierarchy = cv2.findContours(imgbnbin, cv2.RETR_TREE ,cv2.CHAIN_APPROX_SIMPLE)
print(len(contours))


# Take only biggest contour basing on area
Areacontours = list()
calcarea = 0.0
unicocnt = 0.0
for i in range (0, len(contours)):
    area = cv2.contourArea(contours[i])
    #print("area")
    #print(area)
    if (area > 90 ):  #con 90 trova i segni e togli puntini
        if (calcarea<area):
            calcarea = area
            unicocnt = contours[i]

#ROUGHNESS
perimeter = cv2.arcLength(unicocnt,True)
hull = cv2.convexHull(unicocnt,returnPoints = False)
hullperimeter = cv2.arcLength(hull,True)

print("perimeter")
print(perimeter)
print("hullperimeter")
print(hullperimeter)


roughness = perimeter/hullperimeter
print("roughness")
print(roughness)

错误:

Traceback (most recent call last):
  File "C:\Python27\nuovefeature.py", line 417, in <module>
    hullperimeter = cv2.arcLength(hull,True)
error: ..\..\..\src\opencv\modules\imgproc\src\contours.cpp:1886: error: (-215) curve.checkVector(2) >= 0 && (curve.depth() == CV_32F || curve.depth() == CV_32S)

1 个回答

1

错误出现在寻找凸包的那一行。

hull = cv2.convexHull(unicocnt,returnPoints = False)

默认情况下,returnPoints这个选项是True。这样返回的结果会包含凸包点或者轮廓点的像素坐标。通常情况下,这些坐标是用来绘制凸包、计算面积、周长等。

但是如果你把这个选项设置为False,那么返回的结果就是这些坐标在轮廓中的索引。这个设置通常用来寻找凸性缺陷。

所以你的代码应该像下面这样:

hull = cv2.convexHull(unicocnt)

想要更详细的解释和例子,可以查看这篇文章.中的凸包部分。

撰写回答