python 图像判断,清晰度(明暗),彩色与黑白实例


Posted in Python onJune 04, 2020

1,判断图像清晰度,明暗,

原理,Laplacian算法。偏暗的图片,二阶导数小,区域变化小;偏亮的图片,二阶导数大,区域变化快。

import cv2
 
def getImageVar(imgPath):
  image = cv2.imread(imgPath)
  img2gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
  imageVar = cv2.Laplacian(img2gray, cv2.CV_64F).var()
  return imageVar
 
imageVar = getImageVar("./lena.jpg")
print(imageVar)

python 图像判断,清晰度(明暗),彩色与黑白实例

输出结果:

2119.0913581351697

2,判断黑白或彩色图片

原理,通道变化

def is_color_image(url):
  im=Image.open(url)
  pix=im.convert('RGB')
  width=im.size[0]
  height=im.size[1]
  oimage_color_type="Grey Image"
  is_color=[]
  for x in range(width):
    for y in range(height):
      r,g,b=pix.getpixel((x,y))
      r=int(r)
      g=int(g)
      b=int(b)
      if (r==g) and (g==b):
        pass
      else:
        oimage_color_type='Color Image'
  return oimage_color_type

补充知识:求图片的平均亮度

图像相关开发中,有时我们需要知道和了解图片的 亮度 这一信息,例如判断图片是否曝光严重过度或者太黑什么都看不清。

那么怎么去获取到图片的 平均亮度 这一信息呢?

一、YUV 图片

一般相机的原始数据类型就是 YUV 格式,这种格式下很容易求得亮度,因为它的 Y 通道就是亮度通道,我们只需要求得 Y 通道的平均值就可以了。

由于 YUV 图片前 width * height 个字节存放的就是 Y 的值,所以其均值计算如下:

void calculate_average_brightness(const unsigned char* image, const int width, const int height, double* brightness) {
  int length = width * height;
  double sum;
  for (int i = 0; i < length; ++i) {
    sum += image[i];
  }
  brightness = sum / length; // brightness value: [0, 255]
}

注意这样计算得到的亮度值范围为 0~255,如果要归一化的话,再除以 255 即可。

二、RGB 图片

RGB 图片的计算理论和上述差不多,不过我们需要先求得 R、G、B 三个通道的均值。

RGB 图片的亮度计算公式为:

Y = 0.299 * R + 0.587 * G + 0.114 * B ​

以上这篇python 图像判断,清晰度(明暗),彩色与黑白实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
一篇不错的Python入门教程
Feb 08 Python
Python的IDEL增加清屏功能实例
Jun 19 Python
Diango + uwsgi + nginx项目部署的全过程(可外网访问)
Apr 22 Python
python自动化报告的输出用例详解
May 30 Python
PyCharm+PySpark远程调试的环境配置的方法
Nov 29 Python
Python八皇后问题解答过程详解
Jul 29 Python
python__name__原理及用法详解
Nov 02 Python
Python FFT合成波形的实例
Dec 04 Python
Python实现病毒仿真器的方法示例(附demo)
Feb 19 Python
keras 实现轻量级网络ShuffleNet教程
Jun 19 Python
python 多线程共享全局变量的优劣
Sep 24 Python
健身房被搭讪?用python写了个小米计时器助人为乐
Jun 08 Python
完美解决ARIMA模型中plot_acf画不出图的问题
Jun 04 #Python
Python使用Matlab命令过程解析
Jun 04 #Python
Python flask框架端口失效解决方案
Jun 04 #Python
Python实现列表中非负数保留,负数转化为指定的数值方式
Jun 04 #Python
Python新手学习装饰器
Jun 04 #Python
基于python 取余问题(%)详解
Jun 03 #Python
Python中关于logging模块的学习笔记
Jun 03 #Python
You might like
php中base64_decode与base64_encode加密解密函数实例
2014/11/24 PHP
PHP 设计模式系列之 specification规格模式
2016/01/10 PHP
利用php + Laravel如何实现部署自动化详解
2017/10/11 PHP
PHP封装的完整分页类示例
2018/08/21 PHP
PHP析构函数destruct与垃圾回收机制的讲解
2019/03/22 PHP
JavaScript窗口功能指南之在窗口中书写内容
2006/07/21 Javascript
[转]JS宝典学习笔记
2007/02/07 Javascript
网站页面自动跳转实现方法PHP、JSP(上)
2010/08/01 Javascript
什么是DOM(Document Object Model)文档对象模型
2012/03/05 Javascript
javascript学习笔记(四) Number 数字类型
2012/06/19 Javascript
给artDialog 5.02 增加ajax get功能详细介绍
2012/11/13 Javascript
javascript面向对象特性代码实例
2014/06/12 Javascript
javascript比较两个日期的先后示例代码
2014/12/31 Javascript
js实现顶部可折叠的菜单工具栏效果实例
2015/05/09 Javascript
JavaScript继承模式粗探
2016/01/12 Javascript
jQuery拖拽排序插件制作拖拽排序效果(附源码下载)
2016/02/23 Javascript
Bootstrap导航条可点击和鼠标悬停显示下拉菜单的实现代码
2016/06/23 Javascript
js仿腾讯QQ的web登陆界面
2016/08/19 Javascript
Actionscript与javascript交互实例程序(修改)
2016/09/22 Javascript
Javascript设计模式之装饰者模式详解篇
2017/01/17 Javascript
在vue中添加Echarts图表的基本使用教程
2017/11/22 Javascript
ios中视频的最后一桢问题解决
2019/05/14 Javascript
Element-UI 使用el-row 分栏布局的教程
2020/10/26 Javascript
Python多进程机制实例详解
2015/07/02 Python
使用python检测主机存活端口及检查存活主机
2015/10/12 Python
Flask框架中密码的加盐哈希加密和验证功能的用法详解
2016/06/07 Python
python中模块查找的原理与方法详解
2017/08/11 Python
python 多个参数不为空校验方法
2019/02/14 Python
python对象与json相互转换的方法
2019/05/07 Python
Sql面试题
2013/03/20 面试题
大学班级计划书
2014/04/29 职场文书
实习推荐信
2014/05/10 职场文书
保护黄河倡议书
2014/05/16 职场文书
公务员政审材料
2014/12/23 职场文书
年度考核个人总结
2015/03/06 职场文书
解决Navicat for MySQL 连接 MySQL 报2005错误的问题
2021/05/29 MySQL