CV_Assert函数 C++ assert()函数

https://blog.csdn.net/u010402483/article/details/39213813

CV_Assert()作用:CV_Assert()若括号中的表达式值为false,则返回一个错误信息。

CV_Assert() 中 cn > 1 && _mask.empty() && !minIdx && !maxIdx) 为空则不报错
作用是对输入数据进行检查,仅支持以下两种格式:
1. cn == 1 && (_mask.empty() || _mask.type() == CV_8U)
2. cn > 1 && _mask.empty() && !minIdx && !maxIdx)

一下形式将会报错:

错误原因:不满足cn > 1 && _mask.empty() && !minIdx && !maxIdx)

解决办法:
将矩阵转换为一维矩阵.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AVX2指令集是一组针对Intel处理器的指令集,可以在处理器上并行执行多个操作,可以用来加速cv::bitwise_and函数。 以下是使用AVX2指令集加速cv::bitwise_and函数的示范代码: ```c++ #include <immintrin.h> // 包含AVX2指令集的头文件 void bitwise_and_avx2(const cv::Mat& src1, const cv::Mat& src2, cv::Mat& dst) { CV_Assert(src1.type() == CV_8UC1 && src2.type() == CV_8UC1); // 确保输入图像类型为8位无符号整数类型 dst.create(src1.size(), src1.type()); // 创建与输入图像相同大小和类型的输出图像 int rows = src1.rows; int cols = src1.cols; const uchar* src1_ptr = src1.ptr<uchar>(); const uchar* src2_ptr = src2.ptr<uchar>(); uchar* dst_ptr = dst.ptr<uchar>(); const int step = dst.step; // 图像步长 __m256i v_mask = _mm256_set1_epi8(0xff); // 创建掩码向量 for (int i = 0; i < rows; i++) { int j = 0; // 循环处理8个像素点 for (; j <= cols - 8; j += 8) { __m256i v_src1 = _mm256_loadu_si256((__m256i*)(src1_ptr + i * step + j)); // 读取src1中的8个像素点 __m256i v_src2 = _mm256_loadu_si256((__m256i*)(src2_ptr + i * step + j)); // 读取src2中的8个像素点 __m256i v_dst = _mm256_and_si256(v_src1, v_src2); // 对8个像素点进行按位与运算 _mm256_storeu_si256((__m256i*)(dst_ptr + i * step + j), v_dst); // 将8个像素点写入输出图像 } // 处理剩余的像素点 for (; j < cols; j++) { dst_ptr[i * step + j] = src1_ptr[i * step + j] & src2_ptr[i * step + j]; // 对单个像素点进行按位与运算 } } } ``` 上述代码使用AVX2指令集对8个像素点进行按位与运算,从而提高了计算速度。但是,由于AVX2指令集只能在支持AVX2的CPU上运行,因此需要在运行代码前检查CPU是否支持AVX2指令集。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值