IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 模板匹配——弹性匹配 -> 正文阅读

[人工智能]模板匹配——弹性匹配

弹性匹配

基本概念

对于人脸匹配,可将人脸看做非刚性模型来匹配人脸结构。对该系统进行训练,采用人工标定人脸特征点,用局部特征描述方法(如Gabor jets)来提取每个特征点的特征。在多人中抽取这些特征点,可得到一种不变性规律——弹性串图,用于表示非刚性或者可变形事物。比较一个传图和新的人脸图像,采用迭代法找到每个弹性图特征点位置和特征之间的最小距离,即为弹性图匹配

在人脸姿态估计中,对每个姿势建立一个弹性图。输入新的人脸图像,将其与弹性图进行匹配,找到最大的匹配结果,作为该图的姿态。优点:采用弹性图匹配能够得到更加相似的结果;不足:姿态是离散的,因此需要很多弹性图来得到更合适的人脸姿态估计,其算法的时间复杂度也高。一个简单的人脸检测与识别系统如下:
在这里插入图片描述

Gabor滤波

Jets的定义

Gabor小波是以任意一个高斯函数作为窗函数的波函数。一个图像像素与不同方向和频率的 Gabor 核卷积后的系数集合称为一个 Jet。一个 jet 描述了图像 I ( x ) I(x) I(x) 给定图像 x = ( x , y ) x=(x,y) x=(x,y) 周围的一小块灰度值基于小波变换所得到的。
定义卷积为: J j ( x ? ) = ∫ I ( x ′ ? ) ? Ψ j ( x ? x ? ) d 2 x ′ ? \displaystyle J_j(\vec x)=\int I(\vec {x'})\cdot \Psi_j(x-\vec x)d^2\vec {x'} Jj?(x )=I(x )?Ψj?(x?x )d2x

Gabor 核函数为: Ψ j ( x ? ) = ∣ ∣ k j ? ∣ ∣ 2 σ 2 ? e x p { ? ∣ ∣ k j ? ∣ ∣ 2 ? ∣ ∣ x ? ∣ ∣ 2 2 σ 2 } ? [ e x p { i k j ? x ? } ? e x p { ? σ 2 2 } ] \displaystyle \Psi_j(\vec x)=\frac{||\vec {k_j}||^2}{\sigma^2}\cdot exp\{-\frac{||\vec {k_j}||^2\cdot||\vec x||^2}{2\sigma^2}\}\cdot[exp\{i\vec {k_j}\vec x\}-exp\{-\frac{\sigma^2}{2}\}] Ψj?(x )=σ2kj? ?2??exp{?2σ2kj? ?2?x 2?}?[exp{ikj? ?x }?exp{?2σ2?}]

其中波矢量为: k j ? = ( k j x k j y ) = ( k v ? c o s φ u k v ? s i n φ u ) \vec {k_j}= \left ( \begin{matrix} k_{jx} \\ k_{jy} \end{matrix} \right )=\left ( \begin{matrix} k_v\cdot cos\varphi_u \\ k_v\cdot sin\varphi_u \end{matrix} \right ) kj? ?=(kjx?kjy??)=(kv??cosφu?kv??sinφu??),其中 k v = 2 v + 2 2 ? π , φ v = u ? π / 8 \displaystyle k_v=2^{\frac{v+2}{2}}\cdot \pi,\varphi_v=u\cdot\pi/8 kv?=22v+2??π,φv?=u?π/8,其中频率系数 v = 0 , ? ? , 4 v=0,\cdots,4 v=0,?,4;方向系数 u = 0 , ? ? , 7 u=0,\cdots,7 u=0,?,7,这样形成40个相关系数来描述灰度图像中 x 点附近领域的特征。

而一个 Jet 定义为从每个像素点获得的40个复系数组成的集合 { J j } \{J_j\} {Jj?},即 J j = a j ? e i ? j \displaystyle J_j=a_j\cdot e^{i\phi_j} Jj?=aj??ei?j?,其中 a j a_j aj? 为复系数的幅值, ? j \phi_j ?j? 为复系数的相位,一个特征值就是一组系数 { J j } \{J_j\} {Jj?},两个 Jets 之间的相似性可以定义为:

S a ( J , J ′ ) = ∑ j = 1 N a j ? a j ′ ∑ j = 1 N a j 2 ? ∑ j = 1 N a ′ j 2 \displaystyle S_a(J,J')=\frac{\sum^N_{j=1}a_j\cdot a'_j}{\sqrt{\sum^N_{j=1}a^2_j}\cdot\sum^N_{j=1}{a'}^2_j} Sa?(J,J)=j=1N?aj2? ??j=1N?aj2?j=1N?aj??aj??,其中 N 代表 Gabor滤波器的个数。

使用Gabor小波的原因

Gabor小波变换核函数具有与人类大脑皮层简单细胞的二维反射区相同的特性,即能够捕捉到对应于空间频率(尺度)、空间位置及方向选择性的局部结构信息,被广泛地应用于图像分析和理解。Gabor 小波的特性使得其对于亮度和人脸表情的变化不敏感,对人脸识别有利。

相关的三幅图

1.首先定义好一幅人脸标号图,标号图的节点由先前选择好的脸部特征点组成,这些特征点选择在那些容易区分不同脸的位置。
样本图像标号图

2.将Gabor滤波在每一个特征点上的响应称之为 jet,将包含相应 jets的标号图称为人脸图,用来对人脸进行描述。
人脸图

3.对于每个节点,将其特征点的位置以及相应的 jet 进行存储,用节点与节点之间的距离来标定标号图的边缘。对于新的人脸图像,要自动定位特征点时,系统需要对普通人脸有一个代表性的描述。该描述需要涵盖具有较广相貌特征范围的人脸图像(如各种形状特征的眼睛、鼻子、嘴巴、胡须形状、肤色等)。

这一点的实现,要使用一批具有代表性的人脸标号图复合成人脸束图(the face bunch graph,FBG),每一个标号图有着同样的结构以及特征点人脸束图中:每一个节点为多个人脸标号图的对应节点的 Gabor 小波变换系数的集合,其每一条边为多个人脸标号图的对应边的平均。通过这样的方式,FBG则对各种人脸都具有代表性的描述。
人脸束图

由于人脸束图的构建是在离线状态下进行的,所以可通过手工方式确定用于构建人脸束图的人脸图像的特征点的位置。

步骤

1.创建人脸弹性束图

首先,需要一组模板图,提取模板图上每个特征点位置信息和特征值,并将其存储在人脸弹性束图结构中。人脸弹性束图可以看做是一个描述特征点的数据库,包含了平均的人脸信息,在新的人脸图定位特征点时,用作参考模板。

标准的人脸弹性属兔包含的特征点有:左眼、右眼、鼻梁、左眼眉、右眼眉、左眼内角、右眼内角、左眼外角、右眼外角、鼻尖、中鼻根、左鼻根、右鼻根、上嘴唇、下嘴唇、左嘴角、右嘴角、额头、额头左侧、额头右侧、左脸颊、右脸颊、下巴等。

模板图是经过预处理的人脸图,它包含了当前图上特征点的位置信息。在创建弹性束图使,按照模板图提供的特征点信息位置,通过 Gabor 小波滤波,得到对应的特征值。所有模板图的特征值都存储到人脸弹性束图中,该结构包含了人脸上的每一个特征点及其对应的一系列特征值。

2.创建人脸图

人脸图是用来表示人脸特征的数据结构,每一幅人脸都可以用一个人脸图来表示。人脸图包含了人脸的每一个特征点的位置信息以及该特征点所对应的特征值。

首先,确定特征点的位置——特征点的定位,两步:
A. 通过人脸弹性束图得到的平均人脸信息粗略估计特征点的大概位置;
B. 提取粗略估计位置处的特征值,与人脸弹性束图中的特征值比较以获得更准确的位置估计。然后,通过Gabor小波变换提取特征值。所有的特征信息构成一个人脸图。

搜索步骤:
(1)对每个特征点,从已知的FBG中位置信息定位每个特征点的粗略位置 ( x n , y n ) (x_n,y_n) (xn?,yn?)
(2)在以标准化的人脸图像中计算出 ( x n , y n ) (x_n,y_n) (xn?,yn?) 处的Gabor变换向量系数 J n J_n Jn?
(3)将 J n J_n Jn? 与FBG中该特征点的系数 J B m J^{Bm} JBm比较(m为聚集特征点束的数量),其中相似度最高的候选者为 J n ′ J'_n Jn?,计算其位置误差(即两者的欧式距离) d n = J n ′ ? J n d_n=J'_n-J_n dn?=Jn??Jn?,则特征点的精确位置修正为: ( x n ′ , y n ′ ) = ( x n , y n ) + d n (x'_n,y'_n)=(x_n,y_n)+d_n (xn?,yn?)=(xn?,yn?)+dn?
(4)反复第一步到第三部,可得到一副人脸图像上多个特征点的精确位置 ( x n ′ , y n ′ ) (x'_n,y'_n) (xn?,yn?),对应这些点求出其Gabor系数。

这样一副人脸图形FBG就可以用 n 个特征点的 Gabor 系数来表示人脸图像。

3.匹配

对 Jets 之间的相似度进行估计,然后将所有节点的相似性进行平均化,若采用Gabor滤波相应模型,则为: L ( G , G ′ ) = 1 n ∑ i = 1 S a ( J i , J i ′ ) \displaystyle L(G,G')=\frac{1}{n}\sum_{i=1}S_a(J_i,J'_i) L(G,G)=n1?i=1?Sa?(Ji?,Ji?),其中, J i , J i ′ J_i,J'_i Ji?,Ji?分布为图像 G , G ′ G,G' G,G 的第 i 个 Jets,n代表每一个人脸标号图的节点个数。

相似度量

使用以下度量,在FBG中找出与测试图像最相似的一个人脸描述图,

S B ( G I , B ) = 1 N ∑ n m a x m ( S a ( J n I , J n B m ) ) ? λ E ∑ e ( △ x e I ? △ x e B ) 2 ( △ x e B ) 2 \displaystyle S_B(G^I,B)=\frac{1}{N}\sum_n{max}_m(S_a(J^I_n,J^{Bm}_n))-\frac{\lambda}{E}\sum_e\frac{(\bigtriangleup x^I_e-\bigtriangleup x^B_e)^2}{(\bigtriangleup x^B_e)^2} SB?(GI,B)=N1?n?maxm?(Sa?(JnI?,JnBm?))?Eλ?e?(xeB?)2(xeI??xeB?)2?

其中,第二项用于描述标号图 G I G^I GI 与束图 B B B 对应边的相似度量,图的边 x e x_e xe? 由两节点间的空间位置决定,即 △ x e = x n ? x n ′ , ???? e = 1 , ? ? , E \bigtriangleup x_e=x_n-x'_n,\;\;e=1,\cdots,E xe?=xn??xn?,e=1,?,E;而 λ \lambda λ 用于决定局部特征点相似度的空间位置相似度两者的重要性,即调节两项的权重,需提供实验方法确定。

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-12-28 22:55:34  更:2021-12-28 22:56:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 23:32:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码