一、定义
代数运算-图像相加,就是对两幅图像的点之间进行加的运算。运算相应的公式为:
s(x,y) = f(x,y) + g(x,y)
图像相加常用来求平均值去除addtive噪声或者实现二次曝光(double-exposure)。图像平均的一种重要应用是在天文学领域,在该领域,由于在非常低的照度下成像常常会导致传感器噪声,以至于单幅图像无法分析。
相加是连续积分的离散形式。在天文观测中,一种与刚刚描述的方法等同的处理是使用CCD或累死传感器的积累能力,通过长时间的观察同一场景来达到降噪的目的。
二、举例
#include "stdafx.h"
#include <iostream>
#include <cv.h>
#include <highgui.h>
using namespace std;
using namespace cv;
int main()
{
IplImage * imgsum =NULL;
IplImage *img = NULL;
CvSize size;
for (int i = 0; i != 5; ++ i)
{
//导入原图
img = cvLoadImage("Fig0226(galaxy_pair_original).tif");
if(imgsum==NULL)
{
cvShowImage("src",img);
size = cvGetSize(img);
imgsum=cvCreateImage(size,IPL_DEPTH_32F,3);
cvZero(imgsum);
}
//累计相加
cvAcc(img,imgsum);
cvReleaseImage(&img);
}
IplImage * imgavg = cvCreateImage(size,IPL_DEPTH_8U,3);
cvConvertScale(imgsum,imgavg,1.0/4.0);
//显示图像
cvShowImage("imageavg",imgavg);
cvWaitKey(0);
return 0;
}
三、结果