原理


什么是反向投影?



  • 反向投影是一种记录给定图像中的像素点如何适应直方图模型像素分布的方式。
  • 简单的讲, 所谓反向投影就是首先计算某一特征的直方图模型,然后使用模型去寻找图像中存在的该特征。
  • 例如, 你有一个肤色直方图 ( Hue-Saturation 直方图 ),你可以用它来寻找图像中的肤色区域:


反向投影的工作原理?



  • 我们使用肤色直方图为例来解释反向投影的工作原理:
  • 假设你已经通过下图得到一个肤色直方图(Hue-Saturation), 旁边的直方图就是 模型直方图 ( 代表手掌的皮肤色调).你可以通过掩码操作来抓取手掌所在区域的直方图:

反投影Python 反投影原理_反投影Python

反投影Python 反投影原理_反向投影_02

  • 下图是另一张手掌图(测试图像) 以及对应的整张图像的直方图:

反投影Python 反投影原理_直方图_03

反投影Python 反投影原理_直方图_04

  • 我们要做的就是使用 模型直方图 (代表手掌的皮肤色调) 来检测测试图像中的皮肤区域。以下是检测的步骤
  1. 对测试图像中的每个像素 (
  2. 反投影Python 反投影原理_直方图_05

  3. ),获取色调数据并找到该色调(
  4. 反投影Python 反投影原理_工作原理_06

  5. )在直方图中的bin的位置。
  6. 查询 模型直方图 中对应的bin -
  7. 反投影Python 反投影原理_工作原理_06

  8. - 并读取该bin的数值。
  9. 将此数值储存在新的图像中(BackProjection)。 你也可以先归一化 模型直方图 ,这样测试图像的输出就可以在屏幕显示了。
  10. 通过对测试图像中的每个像素采用以上步骤, 我们得到了下面的 BackProjection 结果图:
  11. 使用统计学的语言, BackProjection 中储存的数值代表了测试图像中该像素属于皮肤区域的 概率 。比如以上图为例, 亮起的区域是皮肤区域的概率更大(事实确实如此),而更暗的区域则表示更低的概率(注意手掌内部和边缘的阴影影响了检测的精度)。