opencv-python(十一)

news2024/12/26 23:44:11

 图像加法

import numpy as np
import cv2
img = cv2.imread('jk.jpg')
res = cv2.add(img, img)
cv2.imshow('Mypicture1',img)
cv2.imshow('MyPicture2',res)

cv2.waitKey(0)
cv2.destroyAllWindows()

res = cv2.add(src1, src2, dst=None, mask=None, dtype=None)

src1:第一幅图像

src2:第二幅图像

mask:图像掩膜

dtype:图像数据类型

2幅图像必须相同大小才可以相加。图像加法就是图像的像素值相加,如果a+b > 255,则c=255。最大的特色是图像会变得更亮。

import cv2
import numpy as np

img = cv2.imread('jk.jpg')
res1 = cv2.add(img,img)
res2 = img + img
cv2.imshow('MyPicture1',img)
cv2.imshow('MyPicture2',res1)
cv2.imshow('Mypicture3', res2)

cv2.waitKey(0)
cv2.destroyAllWindows()

使用数学符号(+)执行图象加法。

c= a+b   # 如果a+b<=255

c = mod((a+b), 256)     #如果a+b>255,相当于取256的余数

掩膜

import cv2
import numpy as np

img1 = np.ones((4,5), dtype=np.uint8)*8
img2 = np.ones((4,5), dtype=np.uint8)*9
mask = np.zeros((4,5), dtype=np.uint8)
mask[1:3,1:4] = 255
dst = np.random.randint(0,256,(4,5), np.uint8)
print('img1=\n',img1)
print('img2=\n',img2)
print('mask=\n',mask)
print('最初值 dst=\n',dst)
dst = cv2.add(img1,img2,mask=mask)
print('结果值 dst=\n',dst)

重复曝光技术

图像加权和

dst = saturate(src1 X alpha + src2 X beta + gamma)

src1和src2必须是大小相同的图像

dst = addWeighted(src1, alpha, src2, beta, gamma)

import cv2
import numpy as np

src1 = np.ones((2,3), dtype=np.uint8)*10
src2 = np.ones((2,3), dtype=np.uint8)*50
alpha = 1
beta = 0.5
gamma = 5
print(f'src1=\n{src1}')
print(f'src2=\n{src2}')
dst = cv2.addWeighted(src1,alpha,src2,beta,gamma)
print(f'dst=\n{dst}')

图像的位运算

cv2.bitwise_and():相当于逻辑的and运算

cv2.bitwise_or():相当于逻辑的or运算

cv2.bitwise_not():相当于逻辑的not运算

cv2.bitwise_xor():相当于逻辑的xor运算

dis = cv2.bitwise_and(src1, src2, mask=None)

import cv2
import numpy as np
src1 = np.random.randint(0,255,(3,5),dtype=np.uint8)
src2 = np.zeros((3,5),dtype=np.uint8)
src2[0:2,0:2] = 255
dst = cv2.bitwise_and(src1,src2)
print(f'src1=\n{src1}')
print(f'src2=\n{src2}')
print(f'dst=\n{dst}')

import cv2
import numpy as np

src1 =cv2.imread('jk.jpg')
src2 = np.zeros(src1.shape, dtype = np.uint8)
src2[30:260,70:260,:] = 255  #  这是三维数组
dst = cv2.bitwise_and(src1,src2)
cv2.imshow('Hung',src1)
cv2.imshow('Mask',src2)
cv2.imshow('Result',dst)

cv2.waitKey(0)
cv2.destroyAllWindows()

dst = cv2.bitwise_or(src1, src2, mask=None)

import cv2
import numpy as np

src1 = cv2.imread('jk.jpg')
src2 = np.zeros(src1.shape,dtype=np.uint8)

src2[30:260,70:260,:] = 255
dst = cv2.bitwise_or(src1,src2)
cv2.imshow('Hung',src1)
cv2.imshow('mask',src2)
cv2.imshow('Result',dst)

cv2.waitKey(0)
cv2.destroyAllWindows()

dst = cv2.bitwise_not(src, mask=None)

import cv2
import numpy as np

src = cv2.imread('forest.jpg')
dst = cv2.bitwise_not(src)
cv2.imshow('Forest',src)
cv2.imshow('Result',dst)

cv2.waitKey(0)
cv2.destroyAllWindows()

dst = cv2.bitwise_xor(src1,src2,mask=None)

只要不相同则返回1.

任意像素与白色像素值(11111111)执行xor运算时,结果是not运算的结果。

人以像素于黑色像素值(00000000)执行xor运算时,结果是原像素值。

import cv2
import numpy as np

src1 = cv2.imread('forest.jpg')
src2 = np.zeros(src1.shape, dtype=np.uint8)
src2[:,120:360,:] = 255
dst = cv2.bitwise_xor(src1,src2)
cv2.imshow('Forest',src1)
cv2.imshow('Mask',src2)
cv2.imshow('Forest xor operation', dst)

cv2.waitKey(0)
cv2.destroyAllWindows()

图像加密与解密

若C = A xor B

则A = B xor C

 将淹没图像B当作一个密钥图像,A于B的xor运算就可以为A图像加密,要解密就让密钥图像与C执行xor运算。

import cv2
import numpy as np

src = cv2.imread("forest.jpg")
key = np.random.randint(0,255,src.shape,dtype=np.uint8)
print(src.shape)
cv2.imshow('forest',src)
cv2.imshow('key',key)

img_encry = cv2.bitwise_xor(src,key)
img_decry = cv2.bitwise_xor(img_encry,key)
cv2.imshow('encrytion', img_encry)
cv2.imshow('decrytion',img_decry)

cv2.waitKey(0)
cv2.destroyAllWindows()

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1850198.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

colima配置docker镜像源

只在 colima ssh 环境下修改 docker 配置文件是无效的&#xff0c;我们需要修改 colima 配置文件才能使 docker 镜像源生效。 此时你需要进入到~/.colima/default目录下编辑colima.yaml文件。该文件是 colima 的配置文件。内容如下图所示&#xff0c;我这里配置了许多家的镜像源…

我的python-web基础(Flask前后端不分类)

1.HTML HTML是超文本标记语言 &#xff08; 英文 &#xff1a; HyperText Markup Language &#xff0c; HTML &#xff09;&#xff0c;它不是编程语言&#xff0c;而是一种标记语言 HTML标记标签通常被称为HTML标签&#xff0c;它的特点如下&#xff1a; HTML标签是由尖括…

数据集标注研究

主要研究数据集标注存储文件的数据存储格式 目录 0.简介1.coco128-seg数据格式1.1 分割标注格式2.YOLO格式2.1 YOLO目标识别标签2.2 yolov5-seg分割标签2.TT100K数据集标注2.1 TT100K数据集标注文件解析0.简介 1.coco128-seg数据格式 1.1 分割标注格式 如coco128-seg数据集 …

力扣85.最大矩形

力扣85.最大矩形 遍历所有行作为底边 做求矩形面积&#xff08;84. class Solution {public:int maximalRectangle(vector<vector<char>>& matrix) {if (matrix.empty()) return 0;int n matrix.size(),m matrix[0].size();int res0;vector<int> li…

链动3+1商业模式:革新之路,引领企业持续增长

随着信息技术的飞速发展和互联网的不断渗透&#xff0c;企业的商业模式变革已经成为市场竞争中不可或缺的一环。在这个变革的浪潮中&#xff0c;链动31商业模式以其独特的逻辑和高效的激励机制&#xff0c;成为了业界瞩目的焦点。本文将深入探讨链动31模式的运作机制&#xff0…

【Matlab】-- BP反向传播算法

文章目录 文章目录 00 写在前面01 BP算法介绍02 基于Matlab的BP算法03 代码解释 00 写在前面 BP算法可以结合鲸鱼算法、飞蛾扑火算法、粒子群算法、灰狼算法、蝙蝠算法等等各种优化算法一起&#xff0c;进行回归预测或者分类预测。 01 BP算法介绍 BP&#xff08;Backpropag…

怎样去掉卷子上的答案并打印

当面对试卷答案的问题时&#xff0c;一个高效而简单的方法是利用图片编辑软件中的“消除笔”功能。这种方法要求我们首先将试卷拍摄成照片&#xff0c;然后利用该功能轻松擦除答案。尽管这一方法可能需要些许时间和耐心&#xff0c;但它确实为我们提供了一个可行的解决途径。 然…

SystemVerilog Assertion精华知识

前言 断言主要用于验证设计的行为。断言也可用于提供功能覆盖率&#xff0c;并标记用于验证的输入激励不符合假定的需求。 在验证平台中&#xff0c;通常进行三个主要任务&#xff1a; 产生激励功能检查功能覆盖率度量 在当今的设计越来越复杂情况下&#xff0c;像波形调试…

大数据学习-Hive

介绍 分布式 SQL 计算 做数据的统计分析&#xff0c;SQL 是最方便的工具 在大数据中&#xff0c;有很多的统计分析场景&#xff0c;那么 SQL 来处理大数据是非常合适且频繁的 以后可能就是 SQL Boy 了&#xff0c;所以学习前需要有 MySQL 的基础 Hive 的功能 是一个分布式…

Microsoft Edge无法启动搜索问题的解决

今天本来想清一下电脑&#xff0c;看到visual studio2022没怎么用了就打算卸载掉。然后看到网上有篇文章说进入C盘的ProgramFiles&#xff08;x86&#xff09;目录下的microsoft目录下的microsoft visual studio目录下的install目录中&#xff0c;双击InstallCleanup.exe&#…

什么概率密度函数?

首先我们来理解一下什么是连续的随机变量&#xff0c;在此之前&#xff0c;我们要先理解什么是随机变量。所谓随机变量就是在一次随机实验中一组可能的值。比如说抛硬币&#xff0c;我们设正面100&#xff0c;反面200&#xff0c;设随机变量为X&#xff0c;那么X{100,200}。 X是…

[RK-Linux] RK3562 I2C驱动TP芯片GSL3680

TP芯片GSL3680 1、简介 GSL3680是一款电容屏多点触摸控制单芯片,其芯片内部框架图如下所示: GSL3680采用了独特的互电容感应技术,可以在1ms内测量多达192个节点,支持广泛的传感器选择,包括单层或双层ITO,玻璃或薄膜,采用了先进的抗电磁干扰信号处理技术,使其对各种干…

笑死,裁员裁到大动脉了…

近日&#xff0c;某知名科技公司的裁员事件引起了社会的广泛讨论。 “笑死&#xff0c;裁员裁到大动脉了…” 看起来是大众对裁员事件的戏谑之词&#xff0c;实际上却暗示出了“打工人”的心酸同时也揭开了企业管理层的遮羞布。 &#x1f4a1;裁员决策在项目管理视角下的分析 …

AOP应用之系统操作日志

本文演示下如何使用AOP&#xff0c;去实现系统操作日志功能。 实现步骤 引入AOP包 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId><version>2.6.6</version></de…

【Apache Doris】周FAQ集锦:第 7 期

【Apache Doris】周FAQ集锦&#xff1a;第 7 期 SQL问题数据操作问题运维常见问题其它问题关于社区 欢迎查阅本周的 Apache Doris 社区 FAQ 栏目&#xff01; 在这个栏目中&#xff0c;每周将筛选社区反馈的热门问题和话题&#xff0c;重点回答并进行深入探讨。旨在为广大用户和…

YYU-5/80-260mm型钢筋残余变形测试仪 电子引伸计

YYU-5/80-260mm型钢筋接头专用引伸计&#xff0c;是按照《JGJ 107 2010 钢筋技术连接技术规程》的技术要求设计的&#xff0c;专门用于测试钢筋接头残余变形的双向平均引伸计&#xff0c;其标距可以根据钢筋直径要求进行调整。 完全符合《JGJ 107 2010 钢筋技术连接技术规程》…

Vulnhub--OS-HACKNOS-2.1

渗透复现 目标站点为wordpress&#xff0c;通过wpscan进行漏洞扫描发现漏洞插件 通过漏洞插件存在的目录穿越漏洞成功读取/etc/passwd文件中flag用户的密码 SSH登录flag用户后在备份文件中找到rohit用户的密码 切换rohit用户&#xff0c;rohit用户能够以root权限执行任何文…

靠3个字寻求机会,情商不够,别勉强自己

之前我分享了一篇文章寻求一个自由职业的前端伙伴&#xff0c;吸引了好几位朋友来咨询合作&#xff0c;中间出现了不少插曲&#xff0c;好在结果是令人满意的。 作为一名初次创业者&#xff0c;我承认很多地方做的不是那么到位&#xff0c;比如招聘合作伙伴&#xff0c;理想的状…

监控 Prometheus源码安装实战和动态更新 Centos7

安装go环境 下载go安装包 #创建文件夹 mkdir /usr/local/software #进入文件夹 cd /usr/local/software #下载安装包 wget https://dl.google.com/go/go1.17.6.linux-amd64.tar.gz配置go环境变量 #解压 tar -zxvf go1.17.6.linux-amd64.tar.gz#配置环境变量 echo "exp…

AudioSep:从音频中分离出特定声音(人声、笑声、噪音、乐器等)本地一键整合包下载

AudioSep是一种 AI 模型&#xff0c;可以使用自然语言查询进行声音分离。这一创新性的模型由Audio-AGI开发&#xff0c;使用户能够通过简单的语言描述来分离各种声音源。 比如在嘈杂的人流车流中说话的录音中&#xff0c;可以分别提取干净的人声说话声音和嘈杂的人流车流噪声。…