图像处理-基本算法之对数变换

对数变换实现了图像灰度扩展和压缩的功能。它扩展低灰度值而压缩高灰度值,让图像的灰度分布更加符合人的视觉特征。

    代码如下:

[cpp] view plain copy print ?
  1. /******************************************************************************
  2. *   作用:     对数变换函数
  3. *   参数: pDst     输出图像的像素数组
  4. *   参数: pSrc     原始图像的像素数组
  5. *   参数: nWidth   原始图像宽度
  6. *   参数: nHeight  原始图像高度
  7. *   参数: a          控制参数,表示曲线的上下偏移量
  8. *   参数: b          控制参数,表示曲线的弯曲程度
  9. *   备注: 此函数对于彩色图同样适用
  10. ******************************************************************************/ 
  11. int LogTrans(BYTE* pDst, BYTE* pSrc, int nWidth, int nHeight, double a, double b) 
  12.     if (!pSrc || !pDst) 
  13.     { 
  14.         return EXIT_FAILURE; 
  15.     } 
  16.  
  17.     // 映射表,用于256种灰度变换后的值 
  18.     BYTE map[256]; 
  19.  
  20.     // 保存运算后的临时值 
  21.     double dTemp; 
  22.     int i, j; 
  23.     for (i = 0; i < 256; i++) 
  24.     { 
  25.         // 计算当前像素变换后的值 
  26.         dTemp = log((double)i + 1.0) / b + a; 
  27.  
  28.         // 如果超界则修改其值 
  29.         if (dTemp < 0) 
  30.             dTemp = 0.0; 
  31.         else if (dTemp > 255) 
  32.             dTemp = 255; 
  33.  
  34.         // 四舍五入 
  35.         map[i] = int(dTemp + 0.5); 
  36.     } 
  37.  
  38.     for (i = 0; i < nWidth * nHeight; i++) 
  39.     {    
  40.         for (j = 0; j < 4; j++) 
  41.             pDst[i*4+j] = map[ pSrc[i*4+j] ]; 
  42.     } 
  43.  
  44.     return EXIT_SUCCESS; 

你可能感兴趣的:(图像处理)