这个用例主要介绍利用三种算法对含有blob的图像进行检测,blob 或者叫斑点,就是在一幅图像上,暗背景上的亮区域,或者亮背景上的暗区域,都可以称为blob。主要利用blob与背景之间的对比度来进行检测。这个用例介绍了三种算法;

Laplacian of Gaussian (LoG)

这是速度最慢,但是最准确的一种算法,简单来说,就是对一幅图先进行一系列不同尺度的高斯滤波,然后对滤波后的图像做Laplacian运算,将所有的图像进行叠加,局部最大值就是所要检测的blob,这个算法对于大的blob检测会很慢,还有就是该算法适合于检测暗背景下的亮blob。

Difference of Gaussian (DoG)

这是LoG算法的一种快速近似,对图像进行高斯滤波之后,不做Laplacian运算,直接做减法,相减后的图做叠加,找到局部最大值,这个算法的缺陷与LoG类似。

Determinant of Hessian (DoH)

这是最快的一种算法,不需要做多尺度的高斯滤波,运算速度自然提升很多,这个算法对暗背景上的亮blob或者亮背景上的暗blob都能检测。缺点是小尺寸的blob检测不准确。

P.S. LoG 和 DoG 如果想检测亮背景上的暗blob,可以将图像做反相,这样亮背景就变成了暗背景,而暗blob就变成了亮blob,然后就可以用这两个算法了,检测完之后再反回来就好了。

  1. from matplotlib import pyplot as plt
  2. from skimage import data
  3. from skimage.feature import blob_dog, blob_log, blob_doh
  4. from math import sqrt
  5. from skimage.color import rgb2gray
  6. image = data.hubble_deep_field()[0:500, 0:500]
  7. image_gray = rgb2gray(image)
  8. plt.imshow(image)
  9. blobs_log = blob_log(image_gray, max_sigma=30, num_sigma=10, threshold=.1)
  10. # Compute radii in the 3rd column.
  11. blobs_log[:, 2] = blobs_log[:, 2] * sqrt(2)
  12. blobs_dog = blob_dog(image_gray, max_sigma=30, threshold=.1)
  13. blobs_dog[:, 2] = blobs_dog[:, 2] * sqrt(2)
  14. blobs_doh = blob_doh(image_gray, max_sigma=30, threshold=.01)
  15. blobs_list = [blobs_log, blobs_dog, blobs_doh]
  16. colors = ['yellow', 'lime', 'red']
  17. titles = ['Laplacian of Gaussian', 'Difference of Gaussian',
  18. 'Determinant of Hessian']
  19. sequence = zip(blobs_list, colors, titles)
  20. fig,axes = plt.subplots(1, 3, sharex=True, sharey=True, subplot_kw={'adjustable':'box-forced'})
  21. axes = axes.ravel()
  22. for blobs, color, title in sequence:
  23. ax = axes[0]
  24. axes = axes[1:]
  25. ax.set_title(title)
  26. ax.imshow(image, interpolation='nearest')
  27. for blob in blobs:
  28. y, x, r = blob
  29. c = plt.Circle((x, y), r, color=color, linewidth=2, fill=False)
  30. ax.add_patch(c)
  31. plt.show()

参考来源: http://scikit-image.org/docs/dev/auto_examples/

原图:

效果图:

Python: scikit-image Blob detection的更多相关文章

  1. Python 操作 Azure Blob Storage

    笔者在<Azure 基础:Blob Storage>一文中介绍了 Azure Blob Storage 的基本概念,并通过 C# 代码展示了如何进行基本的操作.最近笔者需要在 Linux ...

  2. 【数字图像分析】基于Python实现 Canny Edge Detection(Canny 边缘检测算法)

    Canny 边缘检测算法 Steps: 高斯滤波平滑 计算梯度大小和方向 非极大值抑制 双阈值检测和连接 代码结构: Canny Edge Detection | Gaussian_Smoothing ...

  3. YOLO object detection with OpenCV

    Click here to download the source code to this post. In this tutorial, you’ll learn how to use the Y ...

  4. opencv中的vs框架中的Blob Tracking Tests的中文注释。

    经过2天的努力终于算是大概弄清楚了opencv中的vs框架是大概是如何工作的了,下面贴一下我自己写的代码注释.非常详细.对初学者有帮助.尤其详细分析了RunBlobTrackingAuto()函数,在 ...

  5. Python库资源大全

    转载地址:https://zhuanlan.zhihu.com/p/27350980 本文是一个精心设计的Python框架.库.软件和资源列表,是一个Awesome XXX系列的资源整理,由BigQu ...

  6. python实战===2017年30个惊艳的Python开源项目 (转)

    本文转自:http://www.sohu.com/a/216723120_115128 摘要:本文来自Mybridge,介绍了过去一年里30个惊艳的Python开源项目.点击每一个都可以在GitHub ...

  7. Python开源项目Top30

    原文地址:https://www.cnblogs.com/stoker/p/9101825.html No 1:Home-assistant (v0.6+) 基于Python 3的开源家庭自动化平台[ ...

  8. Python库资源大全【收藏】

    本文是一个精心设计的Python框架.库.软件和资源列表,是一个Awesome XXX系列的资源整理,由BigQuant整理加工而成,欢迎扩散.欢迎补充! 对机器学习.深度学习在量化投资中应用感兴趣的 ...

  9. Python API vs C++ API of TensorRT

    Python API vs C++ API of TensorRT 本质上,C++ API和Python API应该在支持您的需求方面接近相同.pythonapi的主要优点是数据预处理和后处理都很容易 ...

随机推荐

  1. VueJS组件之全局组件与局部组件

    全局组件 所有实例都能用全局组件. HTML <!DOCTYPE html> <html> <head> <meta charset="utf-8& ...

  2. 获取input光标的x和y轴

    http://blog.csdn.net/kingwolfofsky/article/details/6586029 index.html <!DOCTYPE html> <html ...

  3. beego介绍

    beego 简介 beego 是一个快速开发 Go 应用的 HTTP 框架,他可以用来快速开发 API.Web 及后端服务等各种应用,是一个 RESTful 的框架,主要设计灵感来源于 tornado ...

  4. 多媒体开发之---h264 图像参数级语义

    (四)图像参数集语义 pic_parameter_set_rbsp( ) {       // pic_parameter_set_id 用以指定本参数集的序号,该序号在各片的片头被引用.    pi ...

  5. C++刷题——2736: 指针练习--输出最大值

    Description 採用指针法,输出10个整型数中的最大值和最小值 Input 10个整数 Output 最大值和最小值 Sample Input 2 6 3 8 1 5 7 0 4 9 Samp ...

  6. iOS中对于多个按钮,选中其中一个,其他按钮选中状态为NO

      第一,定义一个全局的按钮变量 /** *  按钮选中,中间值 */ @property (nonatomic,strong) UIButton *selectedBtn; 第二,添加多个按钮到sc ...

  7. 50道JAVA基础编程练习题 - 题目

    50道JAVA基础编程练习题[1]题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? [2]题目:判断 ...

  8. 九度OJ 1050:完数 (数字特性)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:7535 解决:3125 题目描述: 求1-n内的完数,所谓的完数是这样的数,它的所有因子相加等于它自身,比如6有3个因子1,2,3,1+2+ ...

  9. mysql系列之1.mysql基础

    非关系型(NOSQL)数据库 键值存储数据库: memcached  /  redis  /  memcachedb  /  Berkeley db 列存储数据库: Cassandra  /  Hba ...

  10. 【题解】CF359B Permutation

    [题解]CF359B Permutation 求一个长度为\(2n\)的序列,满足\(\Sigma |a_{2i}-a_{2i-1}|-|\Sigma a_{2i}-a_{2i-1}|=2k\) 这种 ...