Opencv之saturate_cast防止数据溢出

在OpenCV学习中经常看见saturate_cast的使用,下面的代码会展示它的作用,这个功能实现的是两个图像融合,作者提供了saturate_case的作用,同时比较了两个方法的运行时间,后面会给出代码和结果。

也可以原文 http://blog.csdn.net/mjlsuccess/article/details/12401839

一、staturate_cast的原理

大致的原理应该如
if(data<0) 
        data=0; 
elseif(data>255) 
    data=255;

二、关键语句,同时保护与不保护可以自己修改

//使用图像混合例子中的C语言版本演示 
for (int i=0; i<src1.rows; i++) 
{ 
   const uchar* src1_ptr = src1.ptr<uchar>(i); 
   const uchar* src2_ptr = src2.ptr<uchar>(i); 
   uchar* dst_ptr  =dst.ptr<uchar>(i); 
   for (int j=0; j<src1.cols*nChannels; j++) 
   { 
       dst_ptr[j] = saturate_cast<uchar>(src1_ptr[j]*alpha +src2_ptr[j]*beta + gama);//gama = -100, alpha = beta = 0.5 
//     dst_ptr[j] = (src1_ptr[j]*alpha + src2_ptr[j]*beta + gama); 
   } 
} 
imshow("output2",dst);


//没加入溢出保护 
   for (int i=0; i<src1.rows; i++) 
   { 
       const uchar* src1_ptr = src1.ptr<uchar>(i); 
       const uchar* src2_ptr = src2.ptr<uchar>(i); 
       uchar* dst_ptr  =dst.ptr<uchar>(i); 
       for (int j=0; j<src1.cols*nChannels; j++) 
       { 
//         dst_ptr[j] = saturate_cast<uchar>(src1_ptr[j]*alpha +src2_ptr[j]*beta + gama);//gama = -100, alpha = beta = 0.5 
           dst_ptr[j] = (src1_ptr[j]*alpha + src2_ptr[j]*beta + gama); 
       } 
   } 
imshow("output2",dst);

三、整体代码

#include "StdAfx.h"  
#include "blending.h"  
using namespace std;  
using namespace cv;  
void blending_test()  
{  
    Mat src1, src2, dst;  
    double alpha = 0.5;  
    double beta = 1-alpha;  
  
    src1 = imread("LinuxLogo.jpg");  
    src2 = imread("WindowsLogo.jpg");  
  
    if(!src1.data) cout<<"error loading src1"<<endl;  
    if(!src2.data) cout<<"Error loading src2"<<endl;  
  
    addWeighted(src1, alpha, src2, beta, 0.0, dst);  
  
    imshow("output1", dst);  
  
//  waitKey(0);  
}  
//C语言自己实现  
void blending()  
{  
    Mat src1, src2, dst;  
    double alpha = 0.5;  
    double beta = 1-alpha;  
    double gama = 0;  
  
    src1 = imread("LinuxLogo.jpg");  
    src2 = imread("WindowsLogo.jpg");  
    //判断两幅图片是否相同  
    CV_Assert(src1.depth() == CV_8U);  
    CV_Assert(src1.depth() == src2.depth());  
    CV_Assert(src1.size() == src2.size());  
    //为dst申请内存  
    dst.create(src1.size(), src1.type());  
  
    const int nChannels = src1.channels();  
  
    if(!src1.data) cout<<"error loading src1"<<endl;  
    if(!src2.data) cout<<"Error loading src2"<<endl;  
  
    for (int i=0; i<src1.rows; i++)  
    {  
        const uchar* src1_ptr = src1.ptr<uchar>(i);  
        const uchar* src2_ptr = src2.ptr<uchar>(i);  
        uchar* dst_ptr  = dst.ptr<uchar>(i);  
        for (int j=0; j<src1.cols*nChannels; j++)  
        {  
            dst_ptr[j] = src1_ptr[j]*alpha + src2_ptr[j]*beta + gama;  
        }  
    }  
    imshow("output2",dst);  
  
//  cvWaitKey(0);  
}  

int main(int argc, char* argv[])   
{   
    double t;  
    t = (double)getTickCount();   
    blending_test();      
    t = 1000*((double)getTickCount() - t)/getTickFrequency();  
    cout<<"库函数时间:"<<t<<endl;  
  
    t = (double)getTickCount();  
    blending();  
    t = 1000*((double)getTickCount() - t)/getTickFrequency();  
    cout<<"C语言实现:"<<t<<endl;  
  
    cvWaitKey(0);  
    return 0;  
}  

结果如下:第一副是加保护,第二幅是不加保护,第三幅是运行时间的对比

                                                                                                                                                                                                                                       


                                              

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值