Opencv 矩阵运算python API
ndarray 的加法
与c++中Mat加法直接将123+150截断为255的方式不同,ndarray的处理方式是对大于255的数对255求余数再减1
import numpy as np
src1 = np.array([[23, 123,90],[100, 250, 0]],np.uint8)#uint8 即 uchar
src2 = np.array([[125, 150,60],[100,10,40]],np.uint8)
dst = src1 + src2
print(dst)
[[148 17 150]
[200 4 40]]
两个不同类型的数据类型相加返回类型与数值范围大的数值类型相同
src3 = np.array([[125, 150,60],[100,10,40]],np.float32)
dst = src1 + src3
print(dst)
[[148. 273. 150.]
[200. 260. 40.]]
ndarray的减法
numpy的处理方式 (23 - 125)%255+1
dst = src1 - src2
print(dst)
[[154 229 30]
[ 0 240 216]]
ndarray的点乘
#使用“*”运算符
dst = src1 * src3
print(dst)
dst = np.multiply(src1, src3)
print(dst)
[[ 2875. 18450. 5400.]
[10000. 2500. 0.]]
[[ 2875. 18450. 5400.]
[10000. 2500. 0.]]
ndarray的点除
如果两个ndarray都为uint8分母为0时返回0,其他情况返回inf
dst = src2 / src1
print(dst)
dst = src3 / src1
print(dst)
[[5.43478261 1.2195122 0.66666667]
[1. 0.04 inf]]
[[5.4347825 1.2195122 0.6666667]
[1. 0.04 inf]]
E:\ProgramData\Anaconda3\lib\site-packages\ipykernel_launcher.py:1: RuntimeWarning: divide by zero encountered in true_divide
"""Entry point for launching an IPython kernel.
E:\ProgramData\Anaconda3\lib\site-packages\ipykernel_launcher.py:3: RuntimeWarning: divide by zero encountered in true_divide
This is separate from the ipykernel package so we can avoid doing imports until
ndarray的乘法
在ndarray中使用 * 或者multiply可以完成两个矩阵的点乘,而矩阵的乘法需要使用dot函数
src4 = np.array([[1,2,3],[4,5,6]],np.uint8)
src5 = np.array([[6,5],[4,3],[2,1]],np.uint8)
dst = np.dot(src4, src5)
print(dst)
[[20 14]
[56 41]]
两个不同的数据类型也可以相乘返回的类型为范围大的
src6 = np.array([[1,2,3],[4,5,6]],np.uint8)
src7 = np.array([[6,5],[4,3],[2,1]],np.float32)
dst = np.dot(src6, src7)
print(dst)
[[20. 14.]
[56. 41.]]
ndarray的指数运算与对数运算
src8 = np.array([[6,5],[4,3]],np.uint8)
dst = np.log(src8)
dst.dtype
print(dst)
[[1.792 1.609]
[1.387 1.099]]
src9 = np.array([[6,5],[4,3]],np.uint8)
dst = np.exp(src9)
print(dst)
[[403.5 148.4 ]
[ 54.6 20.08]]
ndarray的幂指数运算和开平方运算
src = np.array([[25,40],[20,100]],np.uint8)
dst = np.power(src,2)
print(dst.dtype)
print(dst)
dst = np.power(src,2.0)
print(dst)
print(dst.dtype)
uint8
[[113 64]
[144 16]]
[[ 625. 1600.]
[ 400. 10000.]]
float64
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微服务架构学习与思考:微服务拆分的原则
· 记一次 .NET某云HIS系统 CPU爆高分析
· 如果单表数据量大,只能考虑分库分表吗?
· 一文彻底搞懂 MCP:AI 大模型的标准化工具箱
· 电商平台中订单未支付过期如何实现自动关单?
· 精选 4 款免费且实用的数据库管理工具,程序员必备!
· Cursor:一个让程序员“失业”的AI代码搭子
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(6)
· 重生之我是操作系统(七)----内存管理(上)
· .NET 阻止Windows关机以及阻止失败的一些原因