处理图像时,Int32的值太大或太小

时间:2012-08-08 18:47:57

标签: c# .net image-processing

下面是我的代码的一部分,我正在尝试应用图像文件管理器来清除图像

       //Convert the image to integer array
        uint[,] image = new uint[use.Width, use.Height];
        for (i = 0; i < use.Width; i++)
        {
            for (j = 0; j < use.Height; j++)
            {
                image[i, j] = Convert.ToUInt32(use.GetPixel(i, j).R);
            }
        }

        int Block = 5;
        int BlockSqr = 25;

        // Internal Block Processing
        for (i = Block; i < use.Width- Block; i = i + 1)
            for (j = Block; j < use.Height- Block; j = j + 1)
            {
                int lM, lVAR;

                // Calculating the Mean of the Block
                tmp = 0;
                for (int k = i - Block; k < i + Block; k = k + 1)
                {
                    for (int l = j - Block; l < j + Block; l = l + 1)
                    {
                        tmp = tmp + image[k, l];
                    }
                }
                lM = Convert.ToInt32(Math.Abs(tmp / BlockSqr));

                // Calculating the Variance of the Block
                tmp = 0;
                M1 = 0;
                for (int k = i - Block; k < Block + i; k = k + 1)
                {
                    for (int l = j - Block; l < Block + j; l = l + 1)
                    {
                        M1 = ((image[k, l] - Convert.ToUInt32(lM)) * (image[k, l] - Convert.ToUInt32(lM)));
                        tmp = tmp + M1;
                    }
                }
                lVAR = Convert.ToInt32(Math.Abs(tmp / BlockSqr));

                //Putting the filtered value

                float tm = (lVAR - mVAR);
                float tm1 = tm / lVAR;
                int mm = Convert.ToInt32(image[i, j] - lM);
                float tm2 = tm1 * (image[i, j] - lM);
                int A = lM + Convert.ToInt32(tm2);

                if (A < 255)
                    Wiener.SetPixel(i, j, Color.FromArgb(255, A, A, A));

            }

问题是我在处理图像时遇到以下错误

  

对于Int32,值太大或太小。

开启

  

int A = lM + Convert.ToInt32(tm2);

知道问题是什么吗?

编辑:做了一些调试

lM保持0且lVAR保持0

2 个答案:

答案 0 :(得分:2)

tm2可能是一个大于最大Int32值或低于最小Int32值的值...我会添加一个检查,类似于......

double AD = lM + Convert.ToInt32(tm2);
if((AD >= 0) && (AD < 255)) {
  int A = Convert.ToInt32(AD);
  Wiener.SetPixel(i, j, Color.FromArgb(255, A, A, A));
}

或类似的......

答案 1 :(得分:1)

有符号整数只能存储-2,147,483,648和2,147,483,647之间的值

如果您不需要负值,那么使用unsigned整数可以获得超过40亿的数字。

如果这还不够,您可以使用long类型,它可以存储更大的数字。

此外,NaN表示“非数字”,您应该使用调试器来查看该数字是如何计算的,确保您没有除以零或与其他NAN进行算术运算或做其他没有数学意义的事情。