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

指数变换的基本表达式为:y=b c(x-a)-1

   其中参数bc控制曲线形状,参数a控制曲线的左右位置。

   指数变换的作用是扩展图像的高灰度级、压缩低灰度级。虽然幂次变换也有这个功能,但是图像经过指数变换后对比度更高,高灰度级也被扩展到了更宽的范围。

  代码如下:

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值