[心得] Motion Matching技术 个人理解分享

楼主: cjcat2266 (CJ Cat)   2019-10-30 06:13:37
※ [本文转录自 PlayStation 看板 #1TkBbFmr ]
作者: cjcat2266 (CJ Cat) 看板: PlayStation
标题: Re: [情报] CAPCOM将举办RE ENGINE研究会
时间: Wed Oct 30 06:12:28 2019
: 简单说,就是舍弃以往类似state machine,1对1的motion resource制作,
: 而是让演员录制一支5分钟的影片,
: 影片内容有规定必须遵照特定路线与动作来拍摄,以确保motion data的完整性。
: 然后在角色当下的动作完成时,会回去找该5分钟影片一祯一祯搜寻,
: 搭配玩家的指令输入,去找出最合适的那一祯动作,并迁移过去。
: 这是非常高价且奢侈的方式,基本上现世代主机游戏难以实现该作法,
: 但是荣耀战魂刚好是肢体表现为主的格斗游戏,有办法将所有资源通通拿来算motion,
: 因此非常可能是本世代唯一一片有办法使用该技术的作品。
: 推 lanstype: motion macthong有什么优点啊(门外汉看不懂 10/28 22:37
TLoU2也有用motion matching唷!
刚好敝人也有稍微涉猎MM,来献丑分享一下我的理解
将动画师做好的角色动作,让角色播放来符合移动路径,这个技术领域叫做locomotion
传统的作法是让动画师分别做好各个方向的行进动作
然后挑选方向符合移动路径的动作依序播放
例如一个角色要前进2公尺然后转身45度再前进1公尺,然后往左平移1公尺
传统的状态机式系统就会分析这个路径
然后让角色播放前进动作直到行进2公尺、接着播放转身动作直到旋转45度
最后再播放向左平移的动作直到移动1公尺
这其中牵涉的素材,就包括需要动画师制作前进、转身、和平移的动作
MM的做法则比较聪明
让动作撷取演员一次录取一段很长的动作,包含各种移动方式(前进、旋转、平移等)
然后MM系统则是从个数少、但单体资料量巨大的动作资料池中
寻找能够符合欲移动路径的动作片段
同时尽量减少角色当下动作与新动作片段的衔接断层
把这些片段串连起来播放,让角色用自然的动作依循理想路径移动
如此一来,动画师的工作便剩下协助动作撷取
然后再把动作素材的噪声清理一下,并将动作做一些微调以符合游戏视觉风格
程式设计师也不需要维护复杂的locomotion状态机
不过也如原文所说,这个"在巨大动作素材资料池中搜寻理想动作片段"是个效能瓶颈
约10年前Bungie雇用了原始MM paper作者要把MM用在Halo Reach上
结果因为当时硬件性能与优化技术不足而作罢
现在硬件性能与当时相比进步很多
开发者对动作资料的分析和优化技术也有了成长
所以MM不再是遥不可及的梦想,而是可以即时执行的技术了
接下来比较偏技术面
在巨大动作资料池中搜寻理想动作片段,有什么优化技术可以增加搜寻效率?
暴力解法就是每次需要新动作的时候,把整个资料池读一遍
找出符合理想移动路径、又与角色当下动作差异不会太大的片段挑出来
但是资料池非常大,这个暴力解是不切实际的,会花太多时间
其中一个优化方法,是把资料池切成很多小片段
然后把每一个片段的初始动作与移动路径撷取出来
动作可以预先编码成容易与其他动作辨识相似程度的格式
通常是把重要的关节位置座标和旋转角度编成多维向量
如双脚、骨盆三个关节位置和旋转总共有18或21个数字(看旋转是存成3个角度还是四元数)
这样就可以把动作编码成一个18维或21维的向量
两个动作的向量做内积,就可以得到一个能够与其他内积互相比较的"相似度"分数
同样的,也可以用类似方法把动作片段的行进路径进行编码
与理想路径比较,也可以得到相似度分数
所以现在寻找理想片段的工作,便成为经过编码后的动作与路径相似度的比较
但还是存在着被编码的动作片段过多的问题
对所有编码过后的动作和路径片段比较仍然会花太多时间
于是得借用游戏物理常用的空间加速资料结构技巧,快速选出少量比较理想的动作片段
然后只从这些少量片段中与角色当下动作和理想路径做评分比较,最后选出理想动作片段
简单来说,就是以角色当下动作编码向量为出发点
若一个动作片段的初始动作向量与角色当下动作向量"距离"差太多,就直接忽略这个片段
像是两个向量A与B的差A-B的长度太大,就直接忽略而省去取A和B的内积这个步骤
空间资料结构能够协助快速且大量筛选掉距离太远的向量
最后便只需要比较非常少数的动作向量与路径的相似度
然后最近MM延伸出了一个搭配机器学习(ML, machine learning)的变体
原理是透过ML预先分析动作资料池
生出能从角色当下动作与理想路径得出理想动作片段的类神经网络权重
如此得到的动作片段,完全是程序生成的结果,与ML分析的动作资料池已没有关系
也就是最终游戏所需要包含的素材,就只是类神经网络权重(量级大概就几MB)
大量的动作资料池已经不需要了
如此可以省去大量的动作资料空间(量级可以从几百MB高到甚至到几GB)
然而ML作法有个缺点,就是开发者在除错时
若发现角色的动作看起来怪怪的,唯一的线索就是人类无法解读的类神经网络权重
没办法直接得知会产生动作怪异的原因,是原本的动作资料池的哪个片段
或是在哪个ML环节中出错
以上!
作者: zxc9764315 (Norus)   2019-10-30 08:25:00
怎么觉得这技术的运算成本高到不行啊XD
楼主: cjcat2266 (CJ Cat)   2019-10-30 08:27:00
有空间加速结构就能把成本压到可接受范围ML版本则是与神经网络大小成正比,不会很贵,就只是一堆加权和而已
作者: zxc9764315 (Norus)   2019-10-30 08:55:00
ML会不会…不太好维护或是控制?对ML不太熟,我的既有印象要训练出一个合用的网络本身就是不太可控的成本
楼主: cjcat2266 (CJ Cat)   2019-10-30 09:02:00
ML的确不确定性很大,目前看到的应用都还是在研究阶段
作者: ddavid (谎言接线生)   2019-10-30 19:20:00
不知道如果采用非黑盒子的ML技术,正确率会掉多少
作者: coolrobin (泳圈)   2019-10-30 20:36:00
只能推了...想请问MM是否只适用在一般基础移动的动作,如果是复杂一点的运动方式像蹲下移动、跳跃、翻滚甚至是战斗这种是不是就不适合用MM的方式来做了呢? 另外非人型的是否也适用MM?
作者: kuku321 (halipapon)   2019-10-31 00:03:00
复杂动作一样可以 当然你说战斗要像DMC那种完全风格差异极大的特定动作的话 拍额外的影片也不是不行 不过成本上直接刻应该比较快 非人形比起收录 应该还是手作快吧XD不过以后training base够丰富的话 应该也不是不行
楼主: cjcat2266 (CJ Cat)   2019-10-31 01:52:00
特殊动作还是用状态机比较合适,MM可以是在"一般移动"状态下使用的动作系统非人形的确动作撷取有难度,四足动物也有其特有难度今年GDC有个讲座就是在讲要如何处理四足动物的MM系统直接把人形的MM系统套用在四足动物的动作资料上会有预想不到的滑步瑕疵,要另外处理
作者: metallican (钢铁人)   2019-10-31 01:59:00
太强啦!!
作者: dklassic (DK)   2019-10-31 02:19:00
满期待明年 GDC 能不能听到更多尤其是录制动画的见解,TLOU2 的 MM 的确看起来很精彩,应该在动作捕捉的规划上有很多额外的巧思?
作者: artpoet (灵魂之舞)   2019-10-31 10:32:00
作者: coolrobin (泳圈)   2019-10-31 22:26:00
感谢回答 m(_"_)m
作者: osanaosana (芋头一颗多少钱)   2019-11-03 09:43:00
作者: heavendemon   2019-12-16 05:09:00
push

Links booklink

Contact Us: admin [ a t ] ucptt.com