本文主要是介绍Kinect开发之简单姿势识别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
姿势(POSE)识别方案(含简单算法)
简析:身体以及各个关节点的位置定义了一个姿势。更具体的来说,是某些关节点相对于其他关节点的位置定义了一个姿势。 姿势的类型和复杂度决定了识别算法的复杂度。 通过关节点位置的交叉或者关节点之间的角度都可以进行姿势识别。
通过关节点交叉进行姿势识别就是对关节点进行命中测试。在上一篇博文中,我们可以确定某一个关节点的位置是否在 UI 界面上某一个可视化元素的有效范围内。我们可以对关节点做同样的测试。 但是需要的工作量要少的多, 因为所有的关节点都是在同一个坐标空间中, 这使得计算相对容易。 例如叉腰动作(hand-on-hip) , 可以从骨骼追踪的数据获取左右髋关节和左右手的位置。然后计算左手和左髋关节的位置。如果这个距离小于某一个阈值,就认为这两个点相交。那么,这样就变得简单多了。
但是,由于Kinect的精度问题,但即使通过一些平滑参数设置,从 Kinect 中获取的关节点数据要完全匹配也不太现实。另外,不可能期望用户做出一些连贯一致的动作, 或者保持一个姿势一段时间。 简而言之, 用户运动的精度以及数据的精度使得这种简单计算不适用。 因此, 计算两个点的长度, 并测试长度是否在一个阈值内是唯一的选择。角度原理也与之类似。
当两个关节点比较接近时, 会导致关节点位置精度进一步下降, 这使得使用骨骼追踪引擎判断一个关节点的开始是否是另一个关节点的结束点变得困难。比如,很难将手放在脸的前面,手放在头上, 和手捂住耳朵这几个姿势区分开来。 要摆出一个确切的姿势也很困难, 用户是否会按照程序显示的姿势来做也是一个问题。
一些姿势使用其他方法识别精度会更高。例如,用户伸开双臂和肩膀在一条线上这个姿势,称之为 T 姿势。可以使用节点相交技术,判断手、肘、以及肩膀是否在 Y 轴上处于近乎相同的位置。另一种方法是计算某些关节点连线之间的角度。骨骼追踪引擎能够识别多达20个关节点数据。任何三个关节点就可以组成一个三角形。使用三角几何就可以计算出他们之间的角度。
实际上我们只需要根据两个关节点即可绘制一个三角形, 第三个点有时候可以这两个关节点来决定的。 知道每个节点的坐标就可以计算每个边长的值。 然后使用余弦定理就可以计算出角度了。公式如下图
为了演示使用关节点三角形方法来识别姿势, 考虑在健美中常看到了展示肱二头肌姿势。用户肩部和肘在一条线上并且和地面平行,手腕与肘部与胳膊垂直。在这个姿势中,可以很容易看到有一个直角或者锐角三角形。 我们可以使用上面所说的方法来计算三角形的每一个角度,如下图所示:
上图中, 组成三角形的三个关节点为。肩膀, 轴和手腕。根据这三个关节点的坐标可以计算三个角度。
有两种使用节点三角形的方法。 最明显的如上面的例子那样, 使用三个节点来构造一个三角形。 另一个方法就是使用两个节点, 第三个节点手动指定一
这篇关于Kinect开发之简单姿势识别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!