现代数字图像处理—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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • laravel 常用文档

    laravel 常用文档

    2021年10月22日
    44
  • 国内it软件外包公司排行榜是怎么样的「建议收藏」

    国内it软件外包公司排行榜是怎么样的「建议收藏」国内it软件外包公司排行榜是怎么样的由于互联网技术的快速发展,特别是手机移动端的的普及,使得企业越来越需要开发自己自己的软件,但是软件开发人才缺口很大,企业没有这个技术实力去开发自己的软件,对于中小企业也不好招人,而这软件外包开发公司就可以帮助企业实现目标,这其中鱼龙混杂,让不少想要软件外包开发的企业难以选择,那么国内软件外包公司排行榜是怎么样的呢?下面为大家介绍华盛恒辉排名…

    2022年6月11日
    93
  • linux oracle修改密码_linux 更改用户密码

    linux oracle修改密码_linux 更改用户密码Linux环境中修改Oracle用户密码第一步:[root@localhost~]#[color=green]su-oracle[/color]第二步:[oracle@localhost~]$[color=green]sqlplus/nolog;[/color]第三步:SQL>…

    2022年7月28日
    31
  • c3pool网页挖矿_actin

    c3pool网页挖矿_actin煤矿工地可以看成是由隧道连接挖煤点组成的无向图。为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处。于是矿主决定在某些挖煤点设立救援出口,使得无论哪一个挖煤点坍塌之后,其他挖煤点的工人都有一条道路通向救援出口。请写一个程序,用来计算至少需要设置几个救援出口,以及不同最少救援出口的设置方案总数。输入格式输入文件有若干组数据,每组数据的第一行是一个正整数 N,表示工地的隧道数。接下来的 N 行每行是用空格隔开的两个整数 S 和 T,表示挖煤点 S 与挖煤点 T 由隧道直接连

    2022年8月9日
    11
  • 21.shell语言之if条件判断语句

    21.shell语言之if条件判断语句shell的if语法和C语言等高级语言非常相似,唯一需要注意的地方就是shell的if语句对空格方面的要求比较严格(其实shell对所有语法的空格使用都比较严格)。注意:1、[]表示条件测试。注意这里的空格很重要。要注意在’[‘后面和’]’前面都必须要有空格2、在shell中,then和fi是分开的语句。如果要在同一行里面输入,则需要用分号将他们隔开。3、注意if判断中对于变量的处理,需要加引号,以免一些不必要的错误。

    2022年7月11日
    20
  • Visio2013 Professional专业版密钥

    Visio2013 Professional专业版密钥Visio2013密钥专业版:VisioProfessional2013KEYC2FG9-N6J68-H8BTJ-BW3QX-RM3B32NYF6-QG2CY-9F8XC-GWMBW-29VV8FJ2N7-W8TXC-JB8KB-DCQ7Q-7T7V3VXX6C-DN3HQ-3CRXG-RF4KT-YG7V3B3C7Q-D6NH2-2VRFW-HHWDG-FVQB6转载自:https://blog.csdn.net/alittleyatou/article/detail.

    2022年6月24日
    64

发表回复

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

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