图像均值方差MSE的c语言程序,C#图像处理之图像均值方差计算的方法

//本函数均是基于RGB颜色空间计算

//定义图像均值函数(RGB空间)

public double AnBitmap(Bitmap a)

{

double V = 0;

Rectangle rect = new Rectangle(0, 0, a.Width, a.Height);

System.Drawing.Imaging.BitmapData bmpData = a.LockBits(rect, System.Drawing.Imaging.ImageLockMode.ReadWrite, System.Drawing.Imaging.PixelFormat.Format24bppRgb);

unsafe

{

byte* pIn = (byte*)bmpData.Scan0.ToPointer();

byte* P;

int R, G, B;

double meanvalue = 0, sum = 0;

int stride = bmpData.Stride;

for (int y = 0; y < a.Height; y++)

{

for (int x = 0; x < a.Width; x++)

{

P = pIn;

B = P[0];

G = P[1];

R = P[2];

sum += B * 0.114 + G * 0.587 + R * 0.299;

pIn += 3;

}

pIn += stride - a.Width * 3;

}

meanvalue = sum / (a.Width * a.Height);

V = meanvalue;

}

a.UnlockBits(bmpData);

return V; //返回图像均值V

}

//定义图像统计方差函数(RGB空间)

public double AnCONBitmap(Bitmap a,double meanvalue)

{

double V = 0;

Rectangle rect = new Rectangle(0, 0, a.Width, a.Height);

System.Drawing.Imaging.BitmapData bmpData = a.LockBits(rect, System.Drawing.Imaging.ImageLockMode.ReadWrite, System.Drawing.Imaging.PixelFormat.Format24bppRgb);

unsafe

{

byte* pIn = (byte*)bmpData.Scan0.ToPointer();

byte* P;

int R, G, B;

double conv = 0, sum = 0;

int stride = bmpData.Stride;

for (int y = 0; y < a.Height; y++)

{

for (int x = 0; x < a.Width; x++)

{

P = pIn;

B = P[0];

G = P[1];

R = P[2];

sum += (B * 0.114 + G * 0.587 + R * 0.299 - meanvalue) * (B * 0.114 + G * 0.587 + R * 0.299 - meanvalue);

pIn += 3;

}

pIn += stride - a.Width * 3;

}

conv = sum / (a.Width * a.Height-1);

V = conv;

}

a.UnlockBits(bmpData);

return V; //返回图像方差V

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值