OpenCv可以对图片进行多种操作,其中,在机器学习中,若要增大样本库,可以对图片进行加噪,增加亮度,扭曲。
增加噪声
首先,要安装python的OpenCv库,在此就不介绍直接开始用了
1、导入opencv以及numpy
import cv2
import numpy as np
2、读入图片
img=cv2.imread('logo.png')
3、由于示例图片是150*180的,所以在图中增加1000个噪点
coutn = 1000
for k in range(0,coutn):
#get the random point
xi = int(np.random.uniform(0,img.shape[1]))
xj = int(np.random.uniform(0,img.shape[0]))
#add noise
if img.ndim == 2:
img[xj,xi] = 255
elif img.ndim == 3:
img[xj,xi,0] = 50
img[xj,xi,1] = 40
img[xj,xi,2] = 30
cv2.namedWindow('img')
cv2.imshow('img',img)
cv2.imwrite('noiselogo.jpg',img)
cv2.waitKey()
cv2.destroyAllWindows()
图片叠加
OpenCv可以实现对照片的叠加
我试着用opencv对两张图片进行权重叠加
img_original=cv2.imread('picture.jpg') #读入所要修饰的图片
img_while=255*np.ones(img_original.shape,np.uint8) #创建一个和所读入图片一样大小的空白图片
img_ori_whi=cv2.addWeighted(img_while,0.8,img_original,0.2,0) #利用opencv中的权重相加算法,将二者相加,即可得到叠加的图
cv2.namedWindow('result')
cv2.imshow('result',img_ori_whi)
cv2.waitKey()
cv2.destroyAllWindows()
掩模操作
img_ori_whi=cv2.pyrUp(img_ori_whi)
img_logo=cv2.imread("neu_logo.png")
img_logo=cv2.pyrDown(img_logo)
img_logo=cv2.pyrDown(img_logo)
#创建roi区域
rows1,cols1,channels1 = img_ori_whi.shape
rows2,cols2,channels2 = img_logo.shape
roi = img_ori_whi[0:rows2, 0:cols2 ]
#创建logo的掩模
img2gray = cv2.cvtColor(img_logo,cv2.COLOR_BGR2GRAY)
ret, mask = cv2.threshold(img2gray, 50, 255, cv2.THRESH_BINARY)
mask_inv = cv2.bitwise_not(mask)
# 在Mavic Air的ROI区域放上掩膜 即贴上"胶带"
img1_bg = cv2.bitwise_and(roi,roi,mask = mask_inv)
# 现在"刷上"颜色
img2_fg = cv2.bitwise_and(img_logo,img_logo,mask = mask)
# "撕掉胶带"
dst = cv2.add(img1_bg, img2_fg)
cv2.imwrite('merge.jpg', dst)
roi[:] = dst
cv2.imshow('res',img_ori_whi)
#cv2.imwrite('finiaa.jpg',img_ori_whi)
cv2.waitKey(0)
cv2.destroyAllWindows()