두 영상의 같은 위치에 존재하는 픽셀 값을 더한 값을 설정
덧셈 결과 > 255 -> 픽셀 값 =255( 포화연산, 흰색)
cv2.add(src1, src2, dst=None, mask=None, dtype=None) -> dst
*참고사항
두 영상의 같은 위치에 존재하는 픽셀 값에 대하여 가중합을 계산하여 결과 영상의 픽셀 값
α + β = 1이 되도록 설정 -> 두 입력 영상의 평균 밝기를 유지
가중치를 α = β = 0.5 로 설정한 가중치 합
EX)
cv2.addWeighted(src1, alpha, src2, beta, gamma, dst=None, dtype = None) -> dst
두 영상의 같은 위치에 존재하는 픽셀 값에 대하여 뺄셈 연산을 수행하여 픽셀 값
뺄셈 결과 < 0, 픽셀 값= 0 (포화 연산,검은색)
cv2.substract(src1, src2, dst=None, mask=None, dtype=None) -> dst
cv2.absdiff(src1, src2, dst=None) -> dst
src1 : 첫 번째 영상 또는 스칼라
src2 : 두 번째 영상 또는 스칼라
dst : 차이 연산 결과 영상(차영상)
실습코드
import sys
import numpy as np
import cv2
from matplotlib import pyplot as plt
src1 = cv2.imread('lenna256.bmp', cv2.IMREAD_GRAYSACLE)
src2 = cv2.imread('square.bmp', cv2.IMREAD_GRAYSCALE)
dst1 = cv2.add(src1, src2, dtype=cv2.CV_8U)
dst2 = cv2.addWeighted(src1, 0.5, scr2, 0.5, 0.0)
dst3 = cv2.subtract(src1, src2)
dst4 = cv2.absdiff(src1, src2)
plt.subplot(231), plt.axis('off'), plt.imshow(src1, 'gray'), plt.title('src1')
plt.subplot(232), plt.axis('off'), plt.imshow(src2, 'gray'), plt.title('src2')
plt.subplot(233), plt.axis('off'), plt.imshow(dst1, 'gray'), plt.title('add')
plt.subplot(234), plt.axis('off'), plt.imshow(dst2, 'gray'), plt.title('addWeighted')
plt.subplot(235), plt.axis('off'), plt.imshow(dst3, 'gray'), plt.title('subtract')
plt.subplot(236), plt.axis('off'), plt.imshow(dst4, 'gray'), plt.title('absdiff')
plt.show()
*absidff
가운데 부분이 반전된 것 같은 효과 발생
포화가되지 않는다.
cv2.bitwise_and(src1, src2, dst=None, mask=None) -> dst
cv2.bitwise_or(src1, src2, dst=None, mask=None) -> dst
cv2.bitwise_xor(src1, src2, dst=None, mask=None) -> dst
cv2.bitwise_not(src1, dst=None, mask=None) -> dst
src1: 첫 번째 영상 혹은 스칼라
src2: 두 번째 영상 혹은 스칼라
dst: 출력 영상
mask: 마스크 영상
참고사항