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


相关推荐

  • activiti 生命周期_activiti教程

    activiti 生命周期_activiti教程activiti工作流的web流程设计器整合视频教程SSM和独立部署本视频为activiti工作流的web流程设计器整合视频教程整合Acitiviti在线流程设计器(Activiti-Modeler5.21.0官方流程设计器)本视频共讲了两种整合方式1.流程设计器和其它工作流项目分开部署的方式2.流程设计器和SSM框架项目整合在一起的方式视频大小…文章风火轮12017-04-0511…

    2022年7月21日
    16
  • WPF Window 窗口获得焦点和失去焦点事件

    WPF Window 窗口获得焦点和失去焦点事件Window窗口获得焦点和失去焦点事件(窗口变为背景窗口、窗口切换等都引起窗口焦点失去)Activated获得焦点事件和Deactivated失去焦点的事件:Activated:获得焦点(首次打开软件时;由别的软件切换回当前软件时;点击当前软件在任务栏的按钮时)Deactivated:失去焦点,与Activated正好相反,(Deactivated=de+activated)使用方法有两种:第一种是在XAML中声明,然后在后台书写执行代码:<W…

    2022年6月23日
    27
  • Laravel 中如何区别 Model 或者是 Builder?

    Laravel 中如何区别 Model 或者是 Builder?

    2021年11月9日
    26
  • 网线的交叉线和直通线原理

    网线的交叉线和直通线原理转载自 http://yxy73622.blog.163.com/blog/static/1733173742012231114013341/正线(标准568B):两端线序一样,线序是:白橙,橙,白绿,蓝,白蓝,绿,白棕,棕。反线(568A):一端为正线的线序,另一端为:白绿,绿,白橙,蓝,白蓝,橙,白棕,棕。T568A标准连线顺序从左到右依次为:1-绿白、2-绿、3-橙白、4

    2022年6月19日
    31
  • Android ConstraintLayout布局详解[通俗易懂]

    Android ConstraintLayout布局详解[通俗易懂]前言之前在使用AndroidStudio新建项目的时候,发现MainActivity的默认布局从RelativeLayout变成了ConstraintLayout。当时就对这个ConstraintLayout很好奇,就研究了一下。发觉确实很强大,在此做个总结。ConstraintLayout定义什么是ConstraintLayout呢?ConstraintLayout是Google在2016年的

    2022年5月5日
    88
  • pycharm中格式化快捷键是什么_pycharm复制代码

    pycharm中格式化快捷键是什么_pycharm复制代码(1)快捷键:Ctrl+Alt+L可以将代码格式工整化(2)鼠标点击

    2022年8月25日
    14

发表回复

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

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