エッジ検出のための異なる方法


  1. ソベルフィルタ: ソベルフィルタは、画像の勾配を計算してエッジを検出するために使用される一般的な手法です。横方向と縦方向の勾配を計算し、それらを組み合わせることでエッジの強度と方向を得ることができます。以下はPythonでのソベルフィルタの例です。
import cv2
import numpy as np
def edge_detection_sobel(image):
    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
    sobelx = cv2.Sobel(gray, cv2.CV_64F, 1, 0, ksize=3)
    sobely = cv2.Sobel(gray, cv2.CV_64F, 0, 1, ksize=3)
    edges = np.sqrt(sobelx2 + sobely2)
    edges = np.uint8(edges)
    return edges
# 画像読み込み
image = cv2.imread('image.jpg')
# エッジ検出
edges = edge_detection_sobel(image)
# 結果表示
cv2.imshow('Edges', edges)
cv2.waitKey(0)
cv2.destroyAllWindows()
  1. キャニー法: キャニー法は、エッジ検出のためによく使われるアルゴリズムです。ガウシアンフィルタを使って画像を平滑化し、勾配の強度と方向を計算し、非最大値抑制とヒステリシス閾値処理を適用して最終的なエッジを得ます。以下はPythonでのキャニー法の例です。
import cv2
import numpy as np
def edge_detection_canny(image):
    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
    blurred = cv2.GaussianBlur(gray, (5, 5), 0)
    edges = cv2.Canny(blurred, 50, 150)
    return edges
# 画像読み込み
image = cv2.imread('image.jpg')
# エッジ検出
edges = edge_detection_canny(image)
# 結果表示
cv2.imshow('Edges', edges)
cv2.waitKey(0)
cv2.destroyAllWindows()

これらはエッジ検出のための一部の一般的な手法ですが、他にも様々な手法があります。エッジ検出は、画像処理やコンピュータビジョンの多くのアプリケーションで使用されるため、これらの手法を理解し、適切に選択することは重要です。