广告

只需要六步,用手机实现AR就这么简单?

2016-10-08 ARinChina 阅读:
图像在电子设备中的状态是一堆数字。特征点就是那些和周围数字值相差较大的点,检测方法一般有:FAST、Harris、SIFT、SURF、MSER 等。

深受孩子喜爱的宣传方式是怎么实现的呢?其实这个过程只需要六步:7LJednc

通过摄像头采集实时视频;7LJednc

将采集到的视频流数字化成图像,然后通过上文的特征点检测、特征点描述子生成、特征点匹配一系列处理,找到识别标识物;7LJednc

识别出标识物后,以标识物作为参考,确定要生成的动画在 AR 环境中的位置和方向,并确定提前存入手机中的标识图位置;7LJednc

标识物中的标识符号与预设的目标图进行匹配;7LJednc

程序根据标识物位置调整动画(虚拟信息)位置;7LJednc

动画(虚拟信息)被渲染进视频流。7LJednc

这就是 AR 的实现过程,今天将为大家解释六步中的“精华”——识别并跟踪标识物。7LJednc

牛奶瓶上的特点7LJednc

当消费者拿起手机扫描牛奶瓶时,手机是怎么判断这幅图是不是自己要找的目标呢?7LJednc

目标图是在开发这款 AR 应用时提前读入 app 的。启动 app 后,它就开始查找与标识图相同的帧。7LJednc

这就像警察在抓逃犯时,会在各交通要道设立排查点,将过往行人与逃犯照片进行对比,进行排查。警察在比对照片时,不会每根头发,每个毛孔都要进行比较。他们会关注嫌疑人的一些显著外貌特征,与这些特征相似度极高的人视为犯罪嫌疑人。7LJednc

20161008000047LJednc

同理,图像识别中的目标图也具有特征,我们将这些特征称为“特征点”。7LJednc

那么问题来了,如何找到这些点?7LJednc

图像在电子设备中的状态是一堆数字。特征点就是那些和周围数字值相差较大的点,检测方法一般有:FAST、Harris、SIFT、SURF、MSER 等。7LJednc

20161008000057LJednc

FAST 特征点检测法因检测速度快而深受研究者喜爱,具体遵循以下步骤:7LJednc

首先,从图像中选取一个像素,记作 P。如果我们想判断它是否为一个特征点,首先把 P 点的亮度值记作 I。再设定一个合适的阈值 t,用来控制特征点的选取。以 P 为圆心,3 个像素为半径做圆,这个圆的边界上有 16 个像素,如下图所示:7LJednc

20161008000067LJednc

如果这 16 个像素的像素值都比 I+t 大,或都比 I-t 小,那么 P 就是一个特征点。一般在实际检测中,这 16 个像素不用全部与 P 的亮度值进行比较,只要有 3/4 个以上的像素亮度值比 P+t 大或比 P-t 小,就可以认为 P 点为特征点。7LJednc

简单来说,特征点就是与周围反差较大的点,就像下图所示:7LJednc

20161008000077LJednc

找到特征点就可以识别了么?7LJednc

只知道检测到特征点还不行,必须知道两张图像中的特征是否一致。如何判断特征点是否一致,就需要借助特征点描述子了。7LJednc

特征点描述子是一种描述特征点的方法。比如,我们在挑西瓜时,会选根蒂蜷缩、敲起来声音浊响的青绿西瓜。这个挑瓜的过程就是描述的过程,挑瓜的依据就相当于生成的描述子。7LJednc

20161008000087LJednc

如果一个瓜和我们的挑瓜条件相似或相同,那么我们就判断它是一个好瓜。同样的如果一幅图像中有一个点和我们的描述子相似或相同,那么就可以判断它们为同一特征。7LJednc

找到了特征点描述子,接下来就是要在目标图和识别图之间进行匹配。7LJednc

20161008000097LJednc

判断两幅图是否为同一幅图的标准是人为控制的。我们既可以设置匹配率为 10% 以上的两幅图像是同一图像,也可以设置匹配率为 90% 以上。具体标准根据应用所需而定。7LJednc

目前,特征点匹配技术大概分为两类:一类是分别获取两幅图像的特征点及特征点描述子,根据一定的搜索策略对这些特征点和描述子进行计算,最终获得最优极值点即为匹配结果;另一类是只获取参考帧图像的特征点信息,并利用它在当前帧上寻找最优匹配,这种匹配的最大优点是只需提取参考帧的特征点,节约了一半的特征点提取时间。
发现目标要盯紧7LJednc

从文章开头的视频中可以看到,当小孩拿着 iPad 转动时,生成的动画会保持不动。给我们一种“动画和牛奶是一个整体”的错觉。要想达到这种效果,需要对视频流中的图像进行特征点跟踪。7LJednc

特征跟踪有两种方式,一种是对视频流中的每一帧图像,进行特征点匹配。另一种则在第一幅图像中,寻找可能的特征位置,然后在后续的图像中搜索它们的对应位置。显然,这类“先检测后跟踪”的方法适合用在视频跟踪应用中。7LJednc

20161008000107LJednc

在跟踪过程中,相邻两帧经过匹配后,得到当前帧的目标特征点。由于得到的目标特征点中存在不稳定特征点,因此需要将这些不稳定的点剔除。7LJednc

但又出现了一个新的问题,即随着跟踪的进行,有效特征点会逐渐减少。尤其是在跟踪过程中当目标姿态发生了大幅度变化时,经常会出现目标的特征点急剧减少甚至消失的情况,这样会导致跟踪效果不好甚至跟踪失败。7LJednc

这就像卖水果的小商贩经常会挑出好的水果摆放在最前面,随着客人的购买,再继续往上添加。7LJednc

解决特征点减少问题的方法和卖水果是一样的。只需扩大范围搜索重新提取特征点,即当前时刻目标物中得到的特征点的个数小于一定的阈值时,扩大跟踪面积重新提取特征点,将重新提取到的特征点用在接下来的跟踪过程中。7LJednc

20161008000117LJednc

农场中一头奶牛悠闲地吃着草,一个卡通小人儿在和消费者聊着天。出现这一切,都源于一个简单的牛奶瓶。消费者通过手机或平板扫描牛奶瓶身上的图案,就会呈现一个虚拟农场,可以选择各种小动物,并和它们进行互动。7LJednc

在跟踪的同时还需要完成一件事情,那就是渲染动画。动画必须和识别图位置保持一致才能达到融合效果。7LJednc

目前手机端 AR 应用开发多数是采用这种图像法,这种方法已经被模式化。开发者不用考虑上述这些底层实现,可以使用一些插件来实现。常用插件国外的有 Vuforia、Metaio 等,国内有 HiAR、EasyAR、VoidAR 等。7LJednc

201606300001237LJednc

本文为EDN电子技术设计 原创文章,禁止转载。请尊重知识产权,违者本司保留追究责任的权利。
  • 微信扫一扫
    一键转发
  • 最前沿的电子设计资讯
    请关注“电子技术设计微信公众号”
您可能感兴趣的文章
  • 剖析七种面向物联网的定位技术 在全球定位技术方面,GPS应用已非常成熟和广泛,但有一个遗憾是,它不支持室内定位。万物互联大背景下的定位要求是广连接、大范围、高并发和高精度,这就衍生了对定位技术的新需求。
  • 苹果不支持北斗?或是这个原因! 近日,随着北斗三号全球卫星导航系统正式开通,一个热门话题在网上发酵开来:苹果到底有没有用上北斗导航系统?这个问题看似简单,但背后却缺乏充分的证据,而导致众网友正反方各执一词,争论得喋喋不休。 今天,EDN就想综合性地分析下,苹果到底支不支持北斗?如果不支持的话,那背后的原因又到底是什么?
  • 透明电视是如何实现的? 最近深圳地铁6号、10号线,北京地铁6号线的列车玻璃窗上,出现透明显示屏的新闻挺抓人眼球,这些与车窗融为一体的透明显示屏不仅能够显示天气、站点信息,还能上网、看视频、逛网店。加上小米在前不久的10周年发布会上推出了售价5万元的透明电视,又让“透明显示”技术的热度升了温,实际上,透明显示技术的发展少说也有10年往上了……
  • 利用纸基生物燃料电池为一次性电子产品供电 锂离子电池存在的安全隐患以及可能对环境造成的不良影响,驱使厂商寻求成本更低且可持续的替代方案。纸基超薄便携式生物燃料电池系统使用生物催化剂代替化学或昂贵的金属催化剂,将天然基材转化为电力。
  • 运营商喊话:电子行业亟需解决的5G三大难题 2019年6月份开始中国的5G牌照正式发放以来,中国5G已经初具规模,整个5G的商用全面加速、新基建更是开启了5G建设提速的窗口。 但对于运营商来说,仍有三大技术难题亟需解决。
  • LoRa不符合工信部技术要求?答案正相反! 去年底,继《中华人民共和国工业和信息化部公告2019年第52号》(进一步规范微功率短距离无线电发射设备的管理)发布后,有多家媒体揣测,这一规范是针对LoRa所制定,LoRa恐怕要凉凉了。在“2020 LoRa创新应用论坛”上,Semtech公司就此给出了官方解答。
相关推荐
    广告
    近期热点
    广告
    广告
    广告
    可能感兴趣的话题
    广告
    向右滑动:上一篇 向左滑动:下一篇 我知道了