美文网首页
2.2 Core - 图像的算术运算

2.2 Core - 图像的算术运算

作者: sumpig | 来源:发表于2019-03-15 16:08 被阅读0次

图像加法

您可以通过opencv函数 cv2.add() 或通过numpy操作 res = img1+img2 添加两个图像。两个图像的深度和类型应该相同,或者第二个图像只能是一个标量值。

>>> x = np.uint8([250])
>>> y = np.uint8([10])

print(cv2.add(x,y)) # 250+10 = 260 => 255
# [[255]]

print(x+y)          # 250+10 = 260 % 256 = 4
# [4]

opencv函数将提供更好的结果。所以最好还是使用opencv函数。


图像融合

这也是图像加法,但是图像的权重不同,因此它会给人一种混合或透明的感觉。图像按以下公式添加:

g(x)=(1-a)f_0(x)+af_1(x)

这里把两张照片混合在一起。第一幅图像的权重为0.7,第二幅图像的权重为0.3。cv2.addWeighted() 在图像上应用以下公式。

dst = a * img1 + \beta* img2 +\gamma

这里 \gamma 取0。

img1 = cv2.imread('ml.png')
img2 = cv2.imread('opencv_logo.jpg')

dst = cv2.addWeighted(img1,0.7,img2,0.3,0)

cv2.imshow('dst',dst)
cv2.waitKey(0)
cv2.destroyAllWindows()
1.png

位运算

这包括按位的 AND、OR、NOT 和 XOR 操作。它们在提取图像的任何部分、定义和使用非矩形ROI等时都非常有用。下面我们将看到一个关于如何更改图像特定区域的示例。

我想把 opencv 标志放在图片上方。如果我添加两个图像,它将改变颜色。如果我混合它,我会得到一个透明的效果。但我希望它是不透明的。如果是矩形区域,我可以像上一章那样使用ROI。但是opencv标志不是矩形的。因此,您可以使用以下按位操作进行此操作:

import cv2

img1 = cv2.imread('google.png')
img2 = cv2.imread('deeplearning.png')

# I want to put logo on top-left corner, So I create a ROI
rows, cols, channels = img1.shape
roi = img2[0:rows, 0:cols]

# Now create a mask of logo and create its inverse mask also
img1gray = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY)
ret, mask = cv2.threshold(img1gray, 200, 255, cv2.THRESH_BINARY)
mask_inv = cv2.bitwise_not(mask)

# Now black-out the area of logo in ROI
img1_bg = cv2.bitwise_and(roi, roi, mask=mask)

# Take only region of logo from logo image.
img2_fg = cv2.bitwise_and(img1, img1, mask=mask_inv)

# Put logo in ROI and modify the main image
dst = cv2.add(img1_bg, img2_fg)
img1[0:rows, 0:cols] = dst

cv2.imshow('mask', mask)
cv2.imshow('mask_inv', mask_inv)
cv2.imshow('roi', roi)
cv2.imshow('img1_bg', img1_bg)
cv2.imshow('img1', img1)
cv2.imshow('img2_fg', img2_fg)
cv2.imshow('dst', dst)
cv2.waitKey(0)
cv2.destroyAllWindows()

把google logo 图片除了google这几个字以外的像素都变为0;把deep learning图片需要嵌入google logo图片的位置上的像素都变为0;那么最后把两张图片像素相加的时候,除了google这几个字,其他的像素值都是deep learning的像素。

2.png

相关文章

  • 2.2 Core - 图像的算术运算

    图像加法 您可以通过opencv函数 cv2.add() 或通过numpy操作 res = img1+img2 添...

  • 1.7 openCV-python 图像运算

    学习图像上的算术运算,加法,减法,位运算等。 按位运算

  • 小强学Python+OpenCV之-1.4.1平移、旋转、缩放、

    下面我们将进入实际的图像处理阶段。本阶段,我们将分别学习图像的平移、旋转、缩放、翻转、裁剪、算术运算、位运算、掩膜...

  • iOS-sqlite数据库常用SQL语句

    1.数据类型 没有对应的Boolean和Date类型,需要转成其他类型 2.运算符 2.1算术运算符 2.2比较运...

  • bash中的运算

    算术运算 bash中的算术运算:help let  +,-,*,/,%取模(取余),**(乘方) 实现算术运算:l...

  • Java中的运算符

    一:算术运算符 算术运算符主要用于进行基本的算术运算,如加法、减法、乘法、除法等。Java 中常用的算术运算符: ...

  • Opencv在图像上的算术运算

    图像上的算术运算 1.图像加法 图像相加:一般用于对同一场景的多幅图像求平均,以便有效地降低(additive)随...

  • Python中的运算符

    常用的运算符: 算术运算符 赋值运算符 比较运算符 布尔运算符 位运算符 1.算术运算符 基本运算: 标准算术运算...

  • es5--运算符笔记

    算术运算符 JavaScript 共提供10个算术运算符,用来完成基本的算术运算。 加法运算符:x + y 减法运...

  • JS运算符

    算术运算符 概述 JavaScript共提供10个算术运算符,用来完成基本的算术运算。 加法运算符:x + y 减...

网友评论

      本文标题:2.2 Core - 图像的算术运算

      本文链接:https://www.haomeiwen.com/subject/chtrmqtx.html