灰度非线性变换之c++实现(qt + 不调包)

    本章介绍灰度非线性变换,具体内容包括:对数变换、幂次变换、指数变换。他们的共同特点是使用非线性变换关系式进行图像变换。

1.灰度对数变换

    变换公式:y = a + log(1+x) / b,其中,a控制曲线的垂直移量;b为正常数,控制曲线的弯曲程度。其取值对函数曲线的影响见下图:

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

    代码实现(代码是我以前自学图像处理时写的,代码很粗糙没做任何优化,但很好理解)

    此代码中“origiin”一般为灰度图片,彩色图片转灰度图片,可参考我的一篇博客:彩色图转灰度图之c++实现(qt + 不调包)_天竺街潜水的八角的博客-CSDN博客

/*对数变化函数*/
/*a1为控制参数,表示曲线的上下偏移量   b1为控制参数,表示曲线的弯曲程度*/
QImage* MainWindow::LogTrans(QImage* origiin,float a1, float b1)
{
    QImage* newImage = new QImage(origiin->width(), origiin->height(), QImage::Format_ARGB32);

    QColor oldColor;
    int r, g, b;
    for(int y = 0; y < newImage->height(); y++)
    {
        for(int x = 0; x < newImage->width(); x++)
        {
            oldColor = QColor(origiin->pixel(x,y));
            r = (log(oldColor.red() + 1.0))/b1+ a1;
            g = (log(oldColor.green() + 1.0))/b1+ a1;
            b = (log(oldColor.blue() + 1.0))/b1+ a1;
            r = qBound(0, r, 255);
            g = qBound(0, g, 255);
            b = qBound(0, b, 255);
            newImage->setPixel(x, y, qRgb(r, g, b));
        }
    }
    return newImage;
}

2.灰度幂次变换

    变换公式:y=cx^{r}+b,其中c和r都是为正数,当r=1的时候幂次变换变成线性变换,由于图像的像素值范围在0-255之间,所以一般公式会变换成:y=255c(\frac{x}{255})^{r}+b,当r<1的时候,变换函数曲线在正比函数上方,此时扩展低灰度级,压缩高灰度级,使图像变亮;当r>1的时候,变换函数曲线在正比函数下方,此时扩展高灰度级,压缩低灰度级,使图像变暗。其取值对函数曲线的影响见下图:

    灰度幂次变换一般用于显示设备的伽马校正中。

    代码实现(代码是我以前自学图像处理时写的,代码很粗糙没做任何优化,但很好理解)

    此代码中“origiin”一般为灰度图片,彩色图片转灰度图片,可参考我的一篇博客:彩色图转灰度图之c++实现(qt + 不调包)_天竺街潜水的八角的博客-CSDN博客

/*幂次变化函数*/
/*b1为控制参数,表示曲线的上下偏移量  c1为控制参数,表示曲线的弯曲程度  r1为控制参数,表示函数的幂次*/
QImage* MainWindow::PowerTrans(QImage* origiin,float b1, float c1, float r1)
{
    QImage* newImage = new QImage(origiin->width(), origiin->height(), QImage::Format_ARGB32);

    QColor oldColor;
    int r, g, b;
    for(int y = 0; y < newImage->height(); y++)
    {
        for(int x = 0; x < newImage->width(); x++)
        {
            oldColor = QColor(origiin->pixel(x,y));
            r = c1 * pow(oldColor.red() /255.0, r1) * 255 + b1;
            g = c1 * pow(oldColor.green() /255.0, r1) * 255 + b1;
            b = c1* pow(oldColor.blue() /255.0, r1) * 255 + b1;
            r = qBound(0, r, 255);
            g = qBound(0, g, 255);
            b = qBound(0, b, 255);
            newImage->setPixel(x, y, qRgb(r, g, b));
        }
    }
    return newImage;
}

3.灰度指数变换

    变换公式:y=b^{_{c(x-a)}}-1,其中,参数b、c控制曲线形状,参数a控制曲线的左右位置。指数变换的曲线可见下图:

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

    代码实现(代码是我以前自学图像处理时写的,代码很粗糙没做任何优化,但很好理解)

    此代码中“origiin”一般为灰度图片,彩色图片转灰度图片,可参考我的一篇博客:彩色图转灰度图之c++实现(qt + 不调包)_天竺街潜水的八角的博客-CSDN博客

/*指数变化函数*/
/*a1为控制参数,表示曲线的左右偏移量  b,c为控制参赛,表示曲线的弯曲程度*/
QImage* MainWindow::ExpTrans(QImage* origiin,float a1, float b1, float c1)
{
    QImage* newImage = new QImage(origiin->width(), origiin->height(), QImage::Format_ARGB32);

    QColor oldColor;
    int r, g, b;
    for(int y = 0; y < newImage->height(); y++)
    {
        for(int x = 0; x < newImage->width(); x++)
        {
            oldColor = QColor(origiin->pixel(x,y));
            r = pow(b1, c1*(oldColor.red()-a1) ) - 1;
            g =  pow(b1, c1*(oldColor.green()-a1))  - 1;
            b = pow(b1, c1*(oldColor.blue() -a1))  - 1;
            r = qBound(0, r, 255);
            g = qBound(0, g, 255);
            b = qBound(0, b, 255);
            newImage->setPixel(x, y, qRgb(r, g, b));
        }
    }
    return newImage;
}

4.下载路径

   整个系列链接: https://blog.csdn.net/m0_59023219/category_12425183.html

   内容介绍:

  [1]根据算法原理,编写纯c++源码,不调用外源库opencv 等;
  [2]包括各种图像处理的基本算法,包含腐蚀膨胀,缩放,转置,镜像,平移,均衡变化,灰度拉升,灰度阈值,灰度非线性,转灰度,灰度线性,旋转,简单平滑,高斯平滑,轮廓跟踪,种子算法,hough直线检测,拉普拉斯,带方向边缘检测,常规边缘检测(梯度算子、Roberts算子和Sobel算子),中值滤波,反色操作等;
  [3]程序中有完整的注释,便于大家很好理解代码。

   代码下载路径:基于QT的C++多种图像处理基本算法源码

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值