로그인

검색

Python
2014.01.16 00:49

OpenCV 이용한 템플릿 매칭

MoA
조회 수 9486 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄

템플릿 매칭(Template Matching) = 큰 이미지에서 특정 작은 이미지를 찾는 알고리즘


import cv2
import numpy as np
from matplotlib import pyplot as plt

img = cv2.imread('messi5.jpg',0)
img2 = img.copy()
template = cv2.imread('template.jpg',0)
w, h = template.shape[::-1]

# All the 6 methods for comparison in a list
methods = ['cv2.TM_CCOEFF', 'cv2.TM_CCOEFF_NORMED', 'cv2.TM_CCORR',
            'cv2.TM_CCORR_NORMED', 'cv2.TM_SQDIFF', 'cv2.TM_SQDIFF_NORMED']

for meth in methods:
    img = img2.copy()
    method = eval(meth)

    # Apply template Matching
    res = cv2.matchTemplate(img,template,method)
    min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)

    # If the method is TM_SQDIFF or TM_SQDIFF_NORMED, take minimum
    if method in [cv2.TM_SQDIFF, cv2.TM_SQDIFF_NORMED]:
        top_left = min_loc
    else:
        top_left = max_loc
    bottom_right = (top_left[0] + w, top_left[1] + h)

    cv2.rectangle(img,top_left, bottom_right, 255, 2)

    plt.subplot(121),plt.imshow(res,cmap = 'gray')
    plt.title('Matching Result'), plt.xticks([]), plt.yticks([])
    plt.subplot(122),plt.imshow(img,cmap = 'gray')
    plt.title('Detected Point'), plt.xticks([]), plt.yticks([])
    plt.suptitle(meth)

    plt.show()

https://opencv-python-tutroals.readthedocs.org/en/latest/py_tutorials/py_imgproc/py_template_matching/py_template_matching.html

?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 Tool/etc Programming 게시판 관련 2 MoA 2014.11.01 74592
231 Tool/etc AWS 망 분리하기 OBG 2022.09.06 7182
230 Deeplearning Keras를 활용한 주식 가격 예측 OBG 2022.09.02 8006
229 Deeplearning 강화학습 학습 관련 정리 OBG 2022.08.10 7942
228 Deeplearning 직접 보고 추천하는 머신러닝 & 딥러닝 & 수학 총정리(2022) OBG 2022.07.24 12630
227 Deeplearning 파이썬 머신러닝 무료 강의 (7시간) OBG 2022.07.06 12876
226 Tool/etc "Node.js를 떠나며" - express를 만든 TJ의 글 OBG 2022.06.23 7769
225 서버 Golang Tutorial for Node.js Developers, Part I.: Getting started OBG 2022.06.16 11324
224 Database What's the difference between comma separated joins and join on syntax in MySQL? OBG 2022.06.09 11143
223 서버 Building Pitaya, Wildlife’s own scalable game server framework OBG 2022.06.07 11617
222 Web How to send dynamic charts with a Slack bot OBG 2022.05.31 11172
221 Web [Javascript] 비동기, Promise, async, await 확실하게 이해하기 OBG 2022.05.27 6861
220 Web Address Bar Install for Progressive Web Apps on the Desktop OBG 2021.12.15 11665
219 Deeplearning 추천(Recommendation) 시스템 - 알고리즘 Trend 정리 OBG 2021.08.03 7935
218 Tool/etc What does set -e mean in a bash script? OBG 2021.04.29 12944
217 Tool/etc What does the last “-” (hyphen) mean in options of `bash`? OBG 2021.04.29 12779
216 Tool/etc 2016년에 자바스크립트를 배우는 기분 MoA 2016.12.27 7258
215 Database 서비스중인 게임 DB 설계(쿠키런) 기초 MoA 2016.07.12 7921
214 Site PHP: 잘못된 디자인의 프랙탈 MoA 2016.07.10 9021
213 API/MFC Windows 10 앱 개발(UWP) MoA 2015.10.13 14377
212 C/C++ 정신나간 정렬 알고리즘 file MoA 2015.10.13 9063
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17