博客
关于我
009 自动聚焦-图像清晰度评价
阅读量:667 次
发布时间:2019-03-15

本文共 1214 字,大约阅读时间需要 4 分钟。

Sobel算子

x方向和y方向的Sobel算子

在这里插入图片描述
较小的定距离下,越清晰的图片,像素点差距越大,所以Sobel算子处理后的像素和越大的越清晰

清晰度评价(Python实现)

import cv2 as cvimport numpy as npimport matplotlib.pyplot as pltimport mathimg = cv.imread('../images/girl.jpg')# gray_img = cv.cvtColor(img, cv.COLOR_BGR2GRAY)def sum_sobel(src):    """    src: src input image    ddepth: output image depth, -1 mean same as input    dx: order of the derivative x    dy: order of the derivative y    """    dst = cv.Sobel(src, -1, 1, 0)    rows, cols, _ = dst.shape    return math.ceil(sum(cv.sumElems(dst)) / rows / cols)def my_blur(src, n):    dst = src    for _ in range(n):        dst = cv.blur(src, (8, 8))        src = dst    return dstfig, ax = plt.subplots(2, 2, figsize=(5, 5))def plot(src, num, n, index):    title = 'origin' if index == 0 else str(n) + ' times blur'    title = title + '(' + str(num) + ')'    ii = int(index / 2)    jj = int(index % 2)    ax[ii][jj].set_title(title)    ax[ii][jj].imshow(cv.cvtColor(src, cv.COLOR_BGR2RGB))val = sum_sobel(img)plot(img, val, 0, 0)times = [3, 6, 9]for i in range(len(times)):    blur_img = my_blur(img.copy(), i + 1)    val = sum_sobel(blur_img)    plot(blur_img, val, times[i], i + 1)[axi.axis('off') for axi in ax.ravel()]plt.show()

在这里插入图片描述

转载地址:http://khfqz.baihongyu.com/

你可能感兴趣的文章
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>
MYSQL 幻读(Phantom Problem)不可重复读
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
查看>>
MySQL 快速创建千万级测试数据
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
MySql 手动执行主从备份
查看>>
Mysql 批量修改四种方式效率对比(一)
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>