现代数字图像处理—lena图像处理

现代数字图像处理—lena图像处理实现幂律变换,对lena图像(灰度)进行处理,观察在不同gamma数值下图像的变化和特点。观察lena图像的直方图,实现lena图像的直方图均衡,观察效果。

大家好,又见面了,我是你们的朋友全栈君。

  1. 实现幂律变换,对lena图像(灰度)进行处理,观察在不同gamma数值下图像的变化和特点。
  2. 观察lena图像的直方图,实现lena图像的直方图均衡,观察效果。

代码及内容展示和分析:

1.1选用c*log(x,base)来处理lena的每一个像素,并取不同的参数和底数

import cv2 as cv

import numpy as np

import math

Lena = cv.imread(‘lena.jpeg’,0)

q = lambda x,a,b:a*math.log(1+x,b)

bases = [2,math.exp(1),10]

params = [10,20,30]

lena_all = [[np.uint8([[q(b,param,base)for b in a]for a in lena])for

            param in params]for base in bases]

[[cv.imshow(f’{bases[a]}-{params[b]}’,lena_all[a][b])for b in range

            (len(lena_all[0]))]for a in range(len(lena_all))]

[[cv.imwrite(f’{bases[a]}-{params[b]}.jpeg’,lena_all[a][b])for b in

range(len(lena_all[0]))]for a in range(len(lena_all))]

if cv.waitKey() == ord(‘A’):

cv.destroyAllWindows()

(1)当底数为2,参数选择[10,20,30]时,效果图如下:

现代数字图像处理---lena图像处理

                        Fig.1-1                                       Fig.1-2                                     Fig.1-3

(2)当底数为自然对数e,参数选择[10,20,30]时,效果图如下:

 现代数字图像处理---lena图像处理

                     Fig.1-4                                        Fig.1-5                                            Fig.1-6

(3)当底数为10,参数选择[10,20,30]时,效果图如下:

 现代数字图像处理---lena图像处理

分析:使用对数处理图像时,图像会变暗,使用修正参数可使图像亮度增加。

1.2选用x^a的形式处理lena的每一个像素

import cv2 as cv

import numpy as np

Lena = cv.imread(‘lena.jpeg’,0)

q = lambda x,a:pow(x,a)

power = [0.4,0.6,0.8,1.1,1.6,2.1]

lena_1 = lena/255

lena_all = [np.float32([[q(b,power)for b in a]for a in lena_1])for

 power in powers]

lena_re_255 = [np.uint8(a*255)for a in lena_all]

[cv.imshow(f’{a+1}’,lena_re_255[a])for a in range(len(lena_re_255))]

[cv.imwrite(f’{a+1}.jpeg’,lena_re_255[a])for a in range(len

(lena_re_255))]

If cv.waitKey() == ord(‘A’):

cv.destroyAllWindows()

(1)当幂次选定[0.4,0.6,0.8]小于1的幂次时:

 现代数字图像处理---lena图像处理

                      Fig.1-10                                          Fig.1-11                                   Fig.1-12

(2)当幂次选定[1.1,1.6,2.1]大于1的幂次时:

现代数字图像处理---lena图像处理

                        Fig.1-13                                     Fig.1-14                                    Fig.1-15

分析:当幂次小于1时,越小则图像的亮度越高;当幂次大于1时,越大则图像的亮度越低。

2.lena直方图及其均衡化

import cv 2 as cv

import matplotlib.pyplot as plt

lena = cv.imread(‘lena.jpeg’,0)

lena_equ = cv.equalizeHist(lena)

cv.imshow(‘1’,lena)

cv.imshow(‘2’,lena_equ)

cv.imwrite(‘lena_equ.jpeg’,lena_equ)

plt.figure(‘原始直方图:‘)

plt.hist(lena.ravel(),256)

plt.figure(‘均衡后直方图:‘)

plt.hist(lena_equ.ravel(),256)

plt.show()

if cv.waitKey() == ord(‘A’):

    cv.destroyAllWindows()

(1)Lena原始图和均衡后的lena图

 现代数字图像处理---lena图像处理

                                             Fig.2-1                                                            Fig.2-2

(2)Lena的直方图和均衡后的直方图

 现代数字图像处理---lena图像处理

                                                                            Fig.2-3  

现代数字图像处理---lena图像处理

Fig.2-4

分析:均衡后的lena图的亮度要比原始图稍微暗一点;均衡后的直方图灰度分布更加均匀一点。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/150953.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月19日 上午8:36
下一篇 2022年6月19日 上午8:36


相关推荐

  • 阿里云短信平台实现手机验证码登录_在线云短信验证码

    阿里云短信平台实现手机验证码登录_在线云短信验证码阿里云短信平台实现手机验证码登录首先创建一个工具类工具类AliyunMessageUtil代码如下所示:publicclassAliyunMessageUtil{ privatestaticfinalStringproduct=”Dysmsapi”; //产品域名,开发者无需替换 privatestaticfinalStringdomain=”dysmsapi.aliyuncs.com”; //此处需要替换成开发者自己的AK(在阿里云访问控制台寻找)TOD

    2025年7月12日
    3
  • git删除本地分支和远程分支_git删除远程分支

    git删除本地分支和远程分支_git删除远程分支git上面的分支开发完成以后,完成了他的历史使命,就可以删除了。1.删除本地分支查看本地分支gitbranchadd_jvm_config_and_exception_loghdfs_config_in_zk*mastersubBucket删除已经merge的本地分支gitbranch-dadd_jvm_config_and_exception_log…

    2022年10月9日
    5
  • matlab编写一个求和循环函数_matlab累加求和

    matlab编写一个求和循环函数_matlab累加求和matlab求和的出错symsum是符号运算,要先用syms定义符号变量用法详见docsymsummatlab求和.符号运算通过符号运算把这个式子拆开什么意思呢?sum(sum(B.*W))即可运算出再问:亲的回答非常好,但是你回答的里面w只有一个,我想变成W11,W12,W13…..这样加起来的一个式子。还有如何一次matlab中for循环如何改为sum求和sum(u1(1:N-1))再问…

    2022年10月7日
    4
  • compass 制作精灵图

    compass 制作精灵图用compass快速制作精灵图1.现在images文件夹新建一个文件夹装各种小图标,命名为Icon;2.然后再sass文件加上这几句命令:@import”compass/utilities/sprites” ; //导入compass精灵模块;$Icon-spacing:5px; //设置生成的精灵图里面每个小图标的间距是5px;如果只是想设置某个图标的间距可以这样做:

    2022年5月3日
    44
  • 2.6 备份一体机管理 52XX

    2.6 备份一体机管理 52XX 一、一体机操作命令2.6.1NBU进程管理查看nbu进程nbu-a:~#su–adminnbu-a.Main_Menu>Supportnbu-a.Support>Proces

    2022年7月2日
    31
  • transferTo方法

    transferTo方法在文件上传的时候 MultipartFil 中的 transferTo dest 方法只能使用一次 并且使用 transferTo 方法之后不可以在使用 getInputStre 方法 否则再使用 getInputStre 方法会报异常 java lang IllegalState Filehasbeenm cannotberead 使用 transferTo dest 方法将上传文件写到服务器上指定的文件 原因文件流只可以接收读取一次 传

    2026年3月26日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号