opencv矩阵转eigen_OpenCV人脸识别Eigen算法源码分析-程序员宅基地

技术标签: opencv矩阵转eigen  

1 理论基础

学习Eigen人脸识别算法需要了解一下它用到的几个理论基础,现总结如下:

1.1 协方差矩阵

首先需要了解一下公式:

共公式可以看出:均值描述的是样本集合的平均值,而标准差描述的则是样本集合的各个样本点到均值的距离之平均。以一个国家国民收入为例,均值反映了平均收入,而均方差/方差则反映了贫富差距,如果两个国家国民收入均值相等,则标准差越大说明国家的国民收入越不均衡,贫富差距较大。以上公式都是用来描述一维数据量的,把方差公式推广到二维,则可得到协方差公式:

协方差表明了两个随机变量之间的相关性,值为正说明两者是正相关的,值为负说明两者是负相关的,值为零说明两者不相关,举一个简单的小例子,假设一个人用4个维度身高、体重、距离屋顶的高度、每天画画的时间来表示:身高取样X=[1 2 3 4 5 6 7 8 9],体重取样Y=[11 12 13 14 15 16 17 18 19],距离屋顶的高度取样Z=[9 8 7 6 5 4 3 2 1],每天画画时间L=[1 1 1 1 1 1 1 1 1],则有cov(X,Y)=7.5,cov(X,Z)=-7.5,cov(X,L)=0,结果很明显X和Y协方差为正数两者正相关,X和Z协方差为负数两者负相关,X和L协方差为0,说明它们不相关。以上例子每一个随机变量都可以表示一个维度,我们计算了部分维度之间的协方差,计算所有维度之间的协方差并组织成矩阵的形式,就有了协方差矩阵的概念:Cnxn=[ci,j]=[cov(Dimi,Dimj)]   i,j=1,2,…,n,Dimi表示第i个维度向量。以Matlab协方差矩阵为例,将X,Y,Z,L分别作为1,2,3,4个维度,则有c1,1=7.5,c1,2=7.5,c1,3=-7.5,c1,4=7.5……,所以协方差矩阵为:

在Matlab中可以把矩阵的每行看做是4个随机变量的一组取样样本,每列看做是一个维度,则可以直接用con函数求得4个维度的协方差矩阵:

1.2 Jacobi迭代法求对称矩阵特征向量及特征值

雅可比迭代法的基本思想是:通过一组平面旋转变换(相似正交变换)化对称矩阵A为对角矩阵,进而求出A的特征值与特征向量。由线性代数理论可知:若矩阵A是实对称矩阵,则一定存在正交矩阵U,使得UT*A*U=D,其中D对角矩阵,其主对角线元素λi是A的特征值,正交矩阵U的第i列是A对应特征值λi的特征向量。于是求对称矩阵A的特征值问题转化为寻找正交矩阵U,使得UT*A*U为对角矩阵,这个问题的困难在于如何构造U,为此我们先看一下平面上的旋转变换:

则有:

其中:

上述推导其实说明了一种构造正交矩阵P,并使得PT*A*P为对角矩阵的方法,可以将这种方法推广到nxn对角矩阵,首先引入n阶旋转矩阵(Givens矩阵)的概念:

平面旋转矩阵有如下性质:

(1)Upq为正交矩阵,即UpqT*Upq=E

(2)UTAU=B仍为对称矩阵,且B与A有相同的特征值

Jacobi迭代法,在每一次迭代时都是进行一次(2)中的转换,这里p、q分别是前一次的迭代矩阵A的非主对角线上绝对值最大元素的行列号,变换后元素值可以由以下公式求出:

由公式可以看出转换后矩阵相比原矩阵只是在p,q行和列的元素发生了改变,旋转角的计算过程和2维时一样,其意义是使得apq和aqp值为零,这样每次迭代都使得非对角线上绝对值最大的元素变为零,所以整个迭代的过程就是使对角线外元素逐步逼近于零,这是对角线上的元素即为原对称矩阵的特征值λi。在进行Jacobi迭代时,假如i次迭代时旋转矩阵为Ui,每次迭代对单位矩阵I依次左乘Ui,最终迭代结束后可得矩阵D=Uk…U2U1I,这里k为迭代次数,则可以证明D的列向量即为特征值λi对应的特征向量,证明如下:

上述推导过程中di为矩阵D的i列表示的列向量,由最后的等式及特征值定义,可以得知λi是A的特征值,di为对应的特征向量。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_35625324/article/details/112840577

智能推荐

《深入剖析Tomcat》阅读(三)-程序员宅基地

文章浏览阅读67次。这里要介绍下Tomcat的一个重要设计方法,Catalina设计方式。Servlet容器是一个复杂系统,但是,它有三个基本任务,对每个请求,servlet容器会为其完成以下三个操作:1.创建一个Request对象,用可能会在调用的Servlet中使用到的信息填充该request对象,如参数、头、cookie、查询字符串、URI等。 request对象是javax.servlet.S..._throw new ioexception(sm.getstring("requeststream.readline.toolong"));

es文件浏览器android看不到文件,es文件浏览器搜索不到电脑解决办法 es文件浏览器找不到电脑...-程序员宅基地

文章浏览阅读5.8k次。ES文件浏览器找不到电脑怎么办?ES文件浏览器是一款可以让手机访问电脑共享文件夹的手机软件,但是有些用户在用的时候发现ES文件浏览器搜索不到电脑,这怎么解决呢?下面请看详细的方法.[ES文件浏览器怎么连接电脑_访问电脑 ][ES文件浏览器怎么用_使用方法 ]win10更新后es用微软帐号无法访问电脑了,针对这个问题:那么具体设置方法如下:1、系统设置-账户-设置你的本地账户,必须使用短昵称(6字母..._es文件浏览器扫描不到电脑

ubuntu下pycharm无法使用中文输入法_pycharm无法打拼音-程序员宅基地

文章浏览阅读4.4k次。原文出处:https://xugaoxiang.com/2020/02/21/ubuntu-pycharm-chinese-input-method/软硬件环境ubuntu 19.10 64bitpycharm 2019.3.3搜狗linux版前言在最新的ubuntu系统上安装好了pycharm和搜狗拼音linux版本后,发现在pycharm里,居然无法使用中文输入。本文就来解决..._pycharm无法打拼音

TCP协议的三次握手和四次断开_三次握手 四次断开的例子有哪些-程序员宅基地

文章浏览阅读282次。通俗理解:但是为什么一定要进行三次握手来保证连接是双工的呢,一次不行么?两次不行么?我们举一个现实生活中两个人进行语言沟通的例子来模拟三次握手。引用网上的一些通俗易懂的例子,虽然不太正确,后面会指出,但是不妨碍我们理解,大体就是这么个理解法。第一次对话:老婆让甲出去打酱油,半路碰到一个朋友乙,甲问了一句:哥们你吃饭了么?结果乙带着耳机听歌呢,根本没听到,没反应。甲心里想:跟..._三次握手 四次断开的例子有哪些

STM32利用硬件I2C读取MPU6050陀螺仪数据-程序员宅基地

文章浏览阅读328次。参 数:GyroX GyroY GyroZ 陀螺仪X、Y、Z轴的数据,使用输出参数的形式返回,范 围:-32768~32767。参 数:AccX AccY AccZ 加速度计X、Y、Z轴的数据,使用输出参数的形式返回,范 围:-32768~32767。配置完MPU6050的各个功能寄存器,剩下的就是读取陀螺仪的数据了。电源管理寄存器1,取消睡眠模式,选择时钟源为X轴陀螺仪。电源管理寄存器2,保持默认值0,所有轴均不待机。配置寄存器,配置DLPF。

flume配置文件后不能跟注释!!_flume报错[error - org.apache.flume.sinkrunner$pollin-程序员宅基地

文章浏览阅读339次。说我这个文件打不开,我一查,后面有段注释,删了再跑?哟,正常了,原来如此~_flume报错[error - org.apache.flume.sinkrunner$pollingrunner.run(sinkrunner.j

随便推点

linux内容对齐的快捷键,linux第一波命令总结-程序员宅基地

文章浏览阅读500次。第一波命令总结1.1 ip 显示ip地址ip a == ip address1.2 ifconfig 显示ip地址1.3 mkdir make directory 创建目录1.4 ls list 显示目录内容-l 显示详细信息1.5 cd change directory 进入目录1.6 pwd print working directo..._linux中对齐a指令

2018微服务必学SpringBoot全套附源码讲义 17课_taotao spring boot 完整源码-程序员宅基地

文章浏览阅读288次。微服务必学SpringBoot高清视频教程附源码讲义 17课课程介绍:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导..._taotao spring boot 完整源码

使用Echarts.js绘制环形图(指定触发高亮事件)_echarts环形图hover事件-程序员宅基地

文章浏览阅读881次,点赞7次,收藏9次。1、tab选中不限时,环形图表中正常渲染环形图,以及对应的数据类型图例和指示文字。2、环形图hover时,高亮hover所在的图形区域,图形区域放大,并悬浮弹窗展示相关数据。3、在切换tab时,选中指定tab,则环形图中的对应数据图形进行高亮显示,图形区域放大,指示文字和指示线加粗处理。其余数据图形区域透明度降低处理。4、指定图形标题和图形区域颜色。5、设置图形最小占有区域。_echarts环形图hover事件

centos 9 编译安装 LAMP wordpress_centos9 make-程序员宅基地

文章浏览阅读870次,点赞15次,收藏29次。rw-r--r--. 1 root root 452383016 2月 21 19:20 mysql-8.2.0-linux-glibc2.17-x86_64.tar.xz。-rw-r--r--. 1 root root 452383016 2月 21 19:20 mysql-8.2.0-linux-glibc2.17-x86_64.tar.xz。-rw-------. 1 root root 1040 2月 17 16:57 anaconda-ks.cfg。_centos9 make

eclipse自动生成变量名快捷键_eclipse什么快捷键可以生成变量名-程序员宅基地

文章浏览阅读2.1w次,点赞11次,收藏10次。原创:http://blog.csdn.net/siphiababy/article/details/74179684 ctrl+2+L这个快捷键可自动补全代码,极大提升编码效率!注:ctrl和2同时按完以后释放,再快速按L。比如写这句代码:Graphics g = image.getGraphics();只需要先写方法image.getGraphics() 然后按ct..._eclipse什么快捷键可以生成变量名

Python爬虫入门——3.9 Scrapy爬虫实战_scrapy python 3.9-程序员宅基地

文章浏览阅读1.5k次。声明:搬运自“ 从零开始学Python网络爬虫 ”作者:罗攀,蒋仟机械工业出版社ISBN:9787111579991上一节我们讲了Scrapy框架的安装以及基本信息,这一节我们就开始使用Scrapy框架进行知乎数据的爬取。首先利用命令管理器创建一个知乎的项目项目。具体做法是在打开的命令管理器输入 ˚F:(我要创建项目的盘) cd F:\ soft_exercise \ pytho..._scrapy python 3.9

推荐文章

热门文章

相关标签