error: (-5) When the input arrays in add/subtract/multiply/divide functions have different types

error: (-5) When the input arrays in add/subtract/multiply/divide functions have different types, the output array type must be explicitly specified in function arithm_op

利用OpenCV函数

void addWeighted(InputArray src1, double alpha, InputArray src2,
double beta, double gamma, OutputArray dst, int dtype=-1);

1
2
3
合并两张图片时,发生以上错误:

error: (-5) When the input arrays in add/subtract/multiply/divide functions have different types,
the output array type must be explicitly specified in function arithm_op

1
2
3
原因是“输入数组是不同的类型”。

因为 addweighted()函数
第一个参数:src1,表示进行加权操作的第一个图像对象,即输入图片1。
第二个参数:double型的alpha,表示第一个图像的加权系数,即图片1的融合比例。
第三个参数:src2,表示进行加权操作的第二个图像对象,即输入图片2。
第四个参数:double型的beta,表示第二个图像的加权系数,即图片2的融合比例。很多情况下,有关系 alpha+beta=1.0。
第五个参数:double型的gamma,表示一个作用到加权和后的图像上的标量,可以理解为加权和后的图像的偏移量。
第六个参数:dst,表示两个图像加权和后的图像,尺寸和图像类型与src1和src2相同,即输出图像。
第七个参数:输出阵列的可选深度,有默认值-1。当两个输入数组具有相同的深度时,这个参数设置为-1(默认值),即等同于src1.depth()。

所以我将原来的代码

//利用addWeighted()函数对两幅图像进行融合
addWeighted(img, 0.5, img_sobel, 0.5, 0., img);

改为:

//利用addWeighted()函数对两幅图像进行融合
addWeighted(img, 0.5, img_sobel, 0.5, 0., img, CV_32F);

原来的两个图的深度不同,现在加上深度的限定值,即可。
前面的拔的别人的,他没解释清楚

根本原因

没解释太清楚,所谓深度位就是RGB图像里面的数据类型,因为是离散值,所以数据类型一般为Uint8无符号类型0-255 ,如果两张图片深度不同也就是离散值的切片数量不同,那么就。。。不能直接映射在一起拼接

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值