이미지 블러링은 이미지를 로우 패스 필터 커널로 컨벌루션하는 것입니다. 이미지에서 고주파인 노이즈가 흐려지게 됩니다. 이때 같은 고주파인 선도 같이 흐려지게 됩니다. 마지막 업데이트 - 2018. 10. 11 다음 OpenCV Python 튜토리얼을 참고하여 강좌를 비정기적로 포스팅하고 있습니다. https://docs.opencv.org/3.4.3/d6/d00/tutorial_py_root.html 컨볼루션(Convolution) 이미지에 커널(마스크)을 컨볼루션하여 블러닝(흐리게), 샤프닝(선명하게) 등의 처리를 할 수 있습니다. 컨볼루션 계산은 커널과 이미지 상에 대응되는 값끼리 곱한 후, 모두 더하여 구해집니다. 이 결과값을 결과 영상의 현재 위치에 기록하면 됩니다. img_output(1,1) ..
threshold 함수와 adaptiveThreshold함수를 사용한 영상 이진화를 다루고 있습니다. 마지막 업데이트 - 2018. 10. 5 다음 OpenCV Python 튜토리얼을 참고하여 강좌를 비정기적로 포스팅하고 있습니다. https://docs.opencv.org/3.4.3/d6/d00/tutorial_py_root.html 보실때 HD 화질로 해야 합니다. Simple Thresholdingthreshold 함수를 사용한 이진화입니다. 전체 이미지에 하나의 임계값을 적용합니다. 첫번째 아규먼트는 원본 이미지, 두번째 아규먼트는 임계값, 세번째 아규먼트는 임계값 이상일 경우 바꿀 최대값(보통 흰색인 255로 지정)을 지정합니다.네번째 아규먼트로 THRESH_BINARY를 사용하면 픽셀값이 임계..
warpPerspective 함수를 사용하여 퍼스펙티브 변환(Perspective Transformation)을 구현합니다. 퍼스펙티브 변환에서 원본 이미지의 모든 직선은 출력 이미지에서 직선으로 유지됩니다. 퍼스펙티브 변환 행렬을 찾으려면 입력 이미지의 4점과 대응하는 출력 이미지의 4점이 필요합니다. getPerspectiveTransform 함수를 사용하면 대응하는 4점 쌍에 대한 변환 행렬을 구할 수 있습니다.warpPerspective 함수를 사용하여 변환을 실행합니다. 마지막 업데이트 - 2018. 10. 4 다음 OpenCV Python 튜토리얼을 참고하여 강좌를 비정기적로 포스팅하고 있습니다. https://docs.opencv.org/3.4.3/d6/d00/tutorial_py_root...
warpAffine 함수를 사용하여 아핀 변환(Affine Transformation)을 구현합니다. 아핀 변환에서 원본 이미지의 모든 평행선은 출력 이미지에서 여전히 평행합니다. 아핀 변환 행렬을 찾으려면 입력 이미지의 3점과 대응하는 출력 이미지의 3점이 필요합니다. getAffineTransform 함수를 사용하면 대응하는 3점 쌍에 대한 변환 행렬을 구할 수 있습니다.warpAffine함수를 사용하여 변환을 실행합니다. 마지막 업데이트 - 2018. 10. 5 다음 OpenCV Python 튜토리얼을 참고하여 강좌를 비정기적로 포스팅하고 있습니다. https://docs.opencv.org/3.4.3/d6/d00/tutorial_py_root.html 왼쪽 위, 오른쪽 위, 왼쪽 아래 순으로 마우..

warpAffine함수를 사용하여 이미지를 이동 및 회전하는 방법을 다루고 있습니다. 마지막 업데이트 - 2018. 10. 3 다음 OpenCV Python 튜토리얼을 참고하여 강좌를 비정기적로 포스팅하고 있습니다. https://docs.opencv.org/3.4.3/d6/d00/tutorial_py_root.html translation matrix를 사용하여 x축 방향 및 y축 방향으로 이미지를 이동시킵니다. rotation matrix를 사용하여 이미지를 회전시킵니다. OpenCV의 getRotationMatrix2D 함수는 배율 및 회전 중심 좌표가 추가된 rotation matrix를 사용합니다. 테스트에 사용한 전체 코드입니다. import numpy as np import cv2 # 원본 ..
이미지의 투명도를 조정하여 두 개의 이미지가 겹쳐보이게 하는 블렌딩(Blending)을 다룹니다. 마지막 업데이트 - 2018. 9. 18 다음 OpenCV Python 튜토리얼을 참고하여 강좌를 비정기적로 포스팅하고 있습니다. https://docs.opencv.org/3.4.3/d6/d00/tutorial_py_root.html 상수 α와 β로 이미지의 투명도를 조정하여 두 이미지가 겹쳐보이게 만듭니다. 상수가 0.0이면 투명한 상태가 되며 1.0에 가까워질수록 불투명해집니다. import cv2 as cv a = 0.0 while(a
깃허브에 있는 차선인식 파이썬 코드를 C++로 변환후 분석해 본 결과물입니다. 원본 코드 https://github.com/georgesung/road_lane_line_detection/blob/master/lane_lines.py 최초 작성 - 2018. 9. 17 2019. 3. 21 Visual Studio 2017에 gls 라이브러리를 추가하는 방법, OpenCV C API 부분 수정 리눅스에서 작업한 결과입니다. 리눅스에서 gls 라이브러리 추가하는 방법은 소스코드 상단에 있습니다.Visual Studio 2017에서는 아래 링크를 참고하여 진행하세요. Visual Studio 2017에서 GLS(GNU Scientific Library) 사용하기https://webnautes.tistory...
이미지를 채널별 이미지로 분리하는 방법과 채널별 이미지를 합치는 방법을 설명합니다. 마지막 업데이트 - 2018. 9. 14 다음 OpenCV Python 튜토리얼을 참고하여 강좌를 비정기적로 포스팅하고 있습니다. https://docs.opencv.org/3.4.3/d6/d00/tutorial_py_root.html 이미지를 불러오면 Blue, Green, Red 채널을 가진 BGR 이미지가 됩니다. split 함수를 사용하여 색 채널별로 분리하여 출력해보겠습니다. import cv2 img_color = cv2.imread('Billiard.jpg', cv2.IMREAD_COLOR ) img_b,img_g,img_r = cv2.split(img_color) cv2.imshow("BGR", img_co..
OpenCV Python에서 이미지의 개별 픽셀에 접근하여 값을 읽어오거나 변경하는 방법을 다루고 있습니다. 마지막 업데이트 - 2018. 9. 13 다음 OpenCV Python 튜토리얼을 참고하여 강좌를 비정기적로 포스팅하고 있습니다. https://docs.opencv.org/3.4.3/d6/d00/tutorial_py_root.html 다음 이미지의 픽셀값을 읽어오고 수정하는 예제입니다. 픽셀 단위로 r, g, b 값을 한번에 가져오고 한번에 설정합니다.. import cv2 as cv img = cv.imread('test.png') # (y, x) = (50, 50) 좌표의 픽셀값을 읽어오면 [153 43 36]입니다. 좌표 순서가 y, x 순인 것에 유의하세요. # 픽셀값은 [blue, gr..
이전 포스팅에서 다루었던 이미지에서 도형을 검출하는 예제 코드를 웹캠 기반으로 수정하여 테스트해 본 과정을 설명합니다. OpenCV 사용해서 실시간으로 도형 검출하기(shape detection) 1 / 2 - 이미지에서 검출http://webnautes.tistory.com/1097 OpenCV 사용해서 실시간으로 도형 검출하기(shape detection) 2 / 2 - 웹캠에서 검출 2016. 12. 29 최초 작성2018. 6. 30 도형 판정하는 방법 변경( 내각 체크 → Convex polygon 여부 검사 ) webcam으로 테스트 추가 프린트한 이미지에 있는 도형들을 검출해본 테스트 결과입니다. 이전 포스팅에서 사용했던 도형 검출 코드를 수정하여 웹캠에서 가져온 이미지를 사용하도록 했습니다..