关于Unity四种合批技术详解

文章目录

  • 一.静态合批(StaticBatching)
      • 1.启用静态合批
      • 2.举例说明
      • 3.静态合批的限制
      • 4.静态合批的优点缺点
      • 5.动态指定物品合批
  • 二.动态合批(Dynamic Batching)
      • 1.启用动态合批
      • 2.合批规则
      • 3.举例说明
      • 4.使用限制
  • 三.GPU Instancing
      • 1.启用GPU Instancing
      • 2.启用限制
      • 3.举例说明
  • 四.SRP Batcher
      • 1.兼容性
      • 2.工作原理
      • 3.开启SRP Batcher
      • 4.例子
  • 五.总结
      • 1.优先级
      • 2.四种合批的区别
      • 3.合批失败信息汇总

Unity中Batching大致可以分为StaticBatching(静态合批),DynamicBatching(动态合批),SRPBatching与GPUInstancing四大类,
这里记录一下这几种拿批的细节


一.静态合批(StaticBatching)

静态合批是Unity的一种优化技术, 本质是将相同材质并且始终不动的的Mesh合并成为一个大Mesh
然后由CPU合并为一个批次发送给GPU处理,从而减少DrawCall带来的消耗.

1.启用静态合批

可以通过 Project Settings > Player > Other Settings > Static Batching 开启动态合批
在这里插入图片描述

选中在场景中物体后在Inspector面板中勾选Static
在这里插入图片描述

Unity会将场景中所有的Mesh合并成一个Mesh,但总顶点数不超过2的16次幂

2.举例说明

当前场景中创建4个圆柱体时场景中的DrawCall是5.
在这里插入图片描述

我们勾选场景中的静态选项时
在这里插入图片描述

可以现发Draw减少到了2
在这里插入图片描述

将基中两个改为材质B,会发现DrawCall增加到3
在这里插入图片描述

3.静态合批的限制

单次合批最多可以合并64000个顶点,所以需要静态合批的物体需要有网格且处于激活状态.网格读写需要是开启的.
然后Unity会在各个MeshFilter组件中收集Mesh将其合并.
我们可以通过打开Windows > Analysis > Frame Debugger 查看静态合批详细内容
在这里插入图片描述

4.静态合批的优点缺点

1):优点
__可以优化DrawCall
__可能使用使用光照贴图
2):缺点
__因为有合并网格的操作所以性能开销会变大
__静态物品不得合批旋转等

5.动态指定物品合批

在满足以条件的情况下,可以使用以下API动态设置批处理
在这里插入图片描述


二.动态合批(Dynamic Batching)

与静态拿批不同,动态合批是的物体是可以运动的,但是需要符合Unity内部执行的步骤,我们需要其规则去开发.

1.启用动态合批

可以通过 Project Settings > Player > Other Settings > Dynamic Batching 开启动态合批
在这里插入图片描述

2.合批规则

1): 需要使用相关的材质
2): 支持不同Mesh网格之间的合批
3): 单个网个最多支持225个顶点,未来可能会调整.

3.举例说明

1): 例子如图我们创建了一球体使用材质A,以发现只用了了一个Batches:(场景默认用了1个)
在这里插入图片描述

2): 复制多个,下显示为7 合批失败.
在这里插入图片描述

3): 为什么呢,因为球体的点数是远超过225个顶点的
在这里插入图片描述

4): 当我们使用球体在相同材质下不段创建时,会发现Batch将不断上升
在这里插入图片描述

5): 当我们将球体Mesh换成圆柱体(88个顶点)时发现,合批成功了
在这里插入图片描述

6): 当我们使用圆柱体在相同材质下不段创建时,会发现Batch将没有变化
在这里插入图片描述

7): 当我们在上面动态创建的基础上再去修修改材质参数时,合批也将会被打断
在这里插入图片描述

8): 当我们使用的Shader中存在多个Pass时也会导致合批失败
在这里插入图片描述

9):当场景中只有一个灯光时可以成功合批
在这里插入图片描述

当场景中存在多个灯光如图(红色绿色)时,合批将会被打断
在这里插入图片描述

10).我们可以通过打开Windows > Analysis > Frame Debugger 查看合批详细内容
在这里插入图片描述

11): 在此可以查看合批失败的原因
在这里插入图片描述

4.使用限制

1): 拿批Mesh点数不超过225
2): 不同Mesh相同材质可以合批
3): 相同材质复制出来的材质实例不能合批(修改实例中材质参数会自动创建材质实例)
4): 照片贴图材质必须使用相同光照贴图位置
5): 采用具有多个Pass的Shader将无法合批
6): 合批成功的对像只受一个光照影响
7): 延迟渲染不支持动态合批操作
8): 收集合批信息将加大CPU负担


三.GPU Instancing

GPU Instancing也是Unity提供的一种优化方案,其本质是使用一个DrawCall渲染多个相同材质的网格对像.
从而减少CPU和GPU的开销.比较适合场景中大量重复的物体如树木和草地等.

1.启用GPU Instancing

选择对像后在Inspector面板中勾选Enable GPU Instancing 即可以启用.
在这里插入图片描述

2.启用限制

1.会合并使用相同材质和Mesh的对象
2.材质需要支持GPU Instancing,例如默认标准材质就有
3.Tranform信息需要有所不同,(完全重合了渲染出来也没有意义)
4.未使用SRP Batcher,如有会优先使用SRP Batcher.(在URP渲染管线中是默认开启的)
5.粒子对像不能合批
6.使用MaterialPropertyBlocks的游戏不能合批
7.Shader必须是使用compatible的

3.举例说明

在场景中创建4个圆柱体使用标准材质
在这里插入图片描述

选择材质勾选Enable GPU Instancing 后再看,合批成功
在这里插入图片描述

可以通过打开Windows > Analysis > Frame Debugger 查看合批详细内容
在这里插入图片描述


四.SRP Batcher

SRP Batcher是Unity提供的一种渲染优化技术,它可以将多个网格合并成单个批次进行渲染,从而提高性能。
与其他合批不同,SRP Batcher将未改变属性的Mesh缓存起来,从而减少消耗

1.兼容性

1): 不支持内置渲染管线,支持通用(URP)/高清(HDRP)/自定义(SRP)渲染管线
2): 不使用MaterialPropertyBlocks.
3): 着色器必须兼容SRP Batcher

2.工作原理

在标准的渲染流程下,CPU需要收集所有场景物体的参数,场景中的材质越多CPU提交给GPU的数据就越多.
而在SRP中流程下GPU拥有数据管理的"生命权",管理大量不同材质但Shader变动较小的的内容
让数据在GPU中持久存在,从而减少消耗.

3.开启SRP Batcher

在Package Manager中导入Universal RP(通用渲染管线)
在这里插入图片描述

创建通用渲染管线
在这里插入图片描述

然后按以下步骤添加通用渲染管线
在这里插入图片描述

4.例子

在场景中创建四个圆柱体
在这里插入图片描述

运行后会发现已被SRP Batch合并,因为SRP默认是开启的
在这里插入图片描述

关闭SRP Batch选项
在这里插入图片描述

则会分成4个Bathc进行渲染

在这里插入图片描述


五.总结

1.优先级

1): 静态合批会优先使用,如果还兼容SRP Batcher则会同时使用
2): 动态物体会优先使用SRP Batcher
3): 非静态且不支持SRP Batcher才会检查启启用GPU Instancing
4): 以上都不支持才会使用Dynamic Batching
即: Static Batching > SRP Batcher > GPU Instancing > Dynamic Batching

2.四种合批的区别

Static BatchingDynamicBatchingGPUInstancingSRPBatching
原理离线合并网格运行时合并网格切换矩阵变换渲染相同物体使用大块常量缓冲区避免切换上下文
目的降低SetPass calls降低Drawcall降低Drawcall降低SetPass calls
优点限制少自动性能极好相同Shader不同材质加速
缺点加大包体,加大内容,要求同材质加大CPU消耗,对顶点与材质有要求要求相同物体只能用于SRP
要求相同Mesh
要求相同材质
要求相同Shader
要求Shader兼容
适用情形静态场景小物体,特效,UI动态大量相同物体较为广泛,特效和蒙皮网格除外

3.合批失败信息汇总

  1. “An object is affected by multiple forward lights.” 此物体受到多个前向灯光的影
  2. “Objects have different materials.” 此物体有不同的材质
  3. “An object is using a multi-pass shader.” 此物体使用了多pass着色器
  4. “An object has odd negative scaling.” 此物体Trasform的Scale使用了负数
  5. “Either objects have different \”Receive Shadows\“ settings, or some objects are within the shadow distance, while some other objects are not.” 此物体接收阴影的设置不同,或者物体有不同的的阴影距离设置
  6. “Objects are affected by different forward lights.” 此物体受到不同的前向灯光影响
  7. “Objects are on different lighting layers.” 物体在不同的Lighting Layer上
  8. “Objects have different \”Cast Shadows\“ settings.” 此物体有不同的投影体设置
  9. “Objects either have different shadow caster shaders, or have different shader properties / keywords that affect the output of the shadow caster pass.” 此物体有不同的投影着色器设置或者有不同的着色器属性或者关键字影响Shadow Caster Pass的输出
  10. “The shader explicitly disables batching with the \”DisableBatching\“ tag.” 着色器中显式设置了DisableBatching的标记
  11. “Objects have different MaterialPropertyBlock set.” 此物体有不同的MaterialPropertyBlock的属性集
  12. “Non-instanced properties set for instanced shader.” Instanced的着色器有非instanced属性集
  13. “Objects are lightmapped.” 物体使用了不同的LightMap或者虽然使用相同的LightMap但使用的UV不同
  14. “Objects are affected by different light probes.” 此物体受到不同的光照探针影响
  15. “Objects are shadowed by baked occlusions and have different occlusion factors.” 此物体烘焙了遮挡,并且设置了不同的遮挡因子
  16. “Objects are affected by different reflection probes.” 此物体受到不同的反射探针影响
  17. “Rendering different meshes or submeshes with GPU instancing.” 使用GPU实例化渲染不同的网格或子网格
  18. “Objects have different batching-static settings.” 此物体有不同的静态合批设置
  19. “Objects belong to different static batches.” 此物体归属不同的Static Batches
  20. "Dynamic Batching is turned off in the Player Settings or is disabled temporarily in the current context to avoid z-fighting.” 在Player Settings中关闭了动态合批,或者在当前的环境中为了避免深度冲突而临时关闭了合批
  21. “There are too many indices (more than 32k) in a dynamic batch.” 动态合批中有太多的索引(大于32k)
  22. “A mesh renderer has additional vertex streams. Dynamic batching doesn‘t support such mesh renderers.” Mesh Renderer具有其他顶点流。动态批处理不支持此类网格渲染器。
  23. “A submesh we are trying to dynamic-batch has more than 300 vertices.” 动态合批超过300个顶点
  24. “A submesh we are trying to dynamic-batch has more than 900 vertex attributes.” 动态合批超过900个顶点属性
  25. “This is the first draw call of a new shadow cascade.” 新阴影级联的第一次绘制调用
  26. “The material doesn‘t have GPU instancing enabled.” 材质未启用GPU Instancing功能
  27. “Objects are rendered using different rendering functions. This can happen if the type of renderer is different (eg Mesh/Skinned Mesh) or when using different settings within the same renderer, such as Sprite Masking.” 使用不同的渲染。如果渲染器的类型不同(例如网格/蒙皮网格),或者在同一渲染器中使用不同的设置(例如精灵遮罩),则可能会发生这种情况。
  28. “Objects have different batching keys. This is usually caused by using different vertex streams on Particle Systems, or by mixing Lines and Trails, or by mixing lit and unlit geometry.” 此对象具有不同的Batching Keys。 这通常是由于在粒子系统上使用不同的顶点流,或混合线和轨迹,或混合Lit和Unlit的几何体造成的。"
  29. “Mesh uses 32 bit index buffer.” Mesh使用了32位的索引缓冲
  30. “Submesh has non-zero base vertex.” 子网格对象有非0的基础顶点, submesh.BaseVertexLocation != 0
  31. “The previous instanced draw call has reached its maximum instance count.” 先前的InstanceDrawCall已经达到了Instance的最大数量
  32. “Motion Vector rendering doesn‘t support batching.” Motion Vector的渲染不支持Batching
  33. “When using late latching, children of an XR late latched GameObject do not use batching.” 使用late latching时,XR late latched GameObject的子级不能合批
  34. “Objects have different bounds and bounds instancing is disabled.” 对象具有不同的包裹体,那么包裹体实例化被禁用
  35. “SRP: Node have different shaders.” 节点具有不同的着色器
  36. “SRP: Node use multi-pass shader” 节点使用了多Pass着色器
  37. “SRP: Node use different shader keywords” 节点使用了不同的着色器关键字
  38. “SRP: End of the batch flush” Batch Flush结束
  39. “SRP: Node is not compatible with SRP batcher” 节点与SRP Batcher不兼容
  40. “SRP: Node material requires device state change” 节点材质需要改变渲染设备状态
  41. “SRP: First call from ScriptableRenderLoopJob” ScriptableRenderLoopJob第一次调用
  42. “SRP: This material has custom buffer override” 材质有自定义重写的Buffer

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/395141.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

uniapp h5本地预览pdf教程 (含白屏|跨域解决方案)

第一步 下载pdf.js 很多pdf.js版本在真机ios环境都会白屏 经测试后2.5.207版本比较稳定,Android和IOS环境PDF文件都能加载成功 下载地址 https://github.com/mozilla/pdf.js/releases/tag/v2.5.207https://github.com/mozilla/pdf.js/releases/tag/v2.5.207第二步 解…

C++(week15): C++提高:(五)Redis数据库

文章目录 零、Redis的安装、API1.redis、hiredis、redis-plus-plus安装2.HiRedis的API 一、Redis数据库的基本概念1.关系型数据库与非关系型数据库的区别2.非关系型数据库的分离3.Redis的概念4.Redis的特性5.Redis的优点 二、Redis常用命令三、Redis的五大数据类型及其命令1.st…

c++初阶-----STL---list

作者前言 🎂 ✨✨✨✨✨✨🍧🍧🍧🍧🍧🍧🍧🎂 ​🎂 作者介绍: 🎂🎂 🎂 🎉🎉&#x1f389…

Datawhale AI夏令营第四期 魔搭-AIGC方向 task01笔记

目录 赛题内容 可图Kolors-LoRA风格故事挑战赛 baseline要点讲解(请配合Datawhale速通教程食用) Step1 设置算例及比赛账号的报名和授权 Step2 进行赛事报名并创建PAI实例 Step3 执行baseline Step4 进行赛题提交 微调结果上传魔搭 lora 调参参数介绍及 SD 的基础知识点…

ICETEK-DM6437-AICOM——CPU定时器及直流电机控制中断控制

一、设计目的: 1.1 CPU定时器程序设计; 1.2 2直流电机程序设计; 1.3 外中断。 二、设计原理: 2.1 定时器的控制: 在DM6437(是一种数字信号处理器,DSP)上使用其内部定时器和中断来…

JESD204B/C协议学习笔记

JESD204B基础概念 204B包含传输层,链路层,物理层。 应用层是对 JESD204B 进行配置的接口,在标准协议中是不含此层,只是为了便于理解,添加的一个层。 协议层指工程中生成的IP核JESD204B,负责处理输入的用户…

Java网络编程——简单的 API 调用

Get请求 - 无参数 上一章我们学习了网络的基本概念,我们知道 URL 能输入到浏览器地址栏中被打开, 那么能不能在程序中发送请求,获取结果呢? 例如“中国科学技术大学”的网站(https://www.ustc.edu.cn/)&a…

探索设计模式:观察者模式

探索设计模式:观察者模式 🧐观察者模式简介:gem:核心概念:rainbow:观察者模式的优点:truck:实现步骤1. 定义主题接口2. 实现观察者接口3. 具体主题实现4. 具体观察者实现5. 调用 :triangular_flag_on_post:总结 在实际开发过程中,设计模式的作…

【Hot100】LeetCode—124. 二叉树中的最大路径和

1- 思路 使用递归 dfs 实现① 递归思路:每次递归返回值为 , root.valMath.max(left,right) 从 左右孩子中挑选一个大的。② 递归公式:定义 sum,sum root.val left right 2- 实现 ⭐124. 二叉树中的最大路径和——题解思路 cl…

【矩阵对角线求和】求一个3*3矩阵对角线元素之和

求一个3*3矩阵对角线元素之和&#xff0c;使用C语言实现 具体代码&#xff1a; #include<stdio.h>int main(){float a[3][3],sum0;printf("请输入3x3矩阵的元素&#xff08;按行输入&#xff09;&#xff1a;\n");for(int i0;i<3;i){for(int j0;j<3;j)…

Java、PHP、Node 操作 MySQL 数据库常用方法

一、Java 操作 MySQL 数据库 1、Java 连接 MySQL 数据库 1. 使用 JDBC 驱动程序连接 使用这种方式&#xff0c;首先需要导入 MySQL 的 JDBC 驱动程序依赖&#xff0c;然后通过 Class.forName() 方法加载驱动程序类。其创建连接的过程相对直接&#xff0c;只需提供准确的数据库…

Tech Talk: SSD架构与功能模块详解

在之前的系列文章中&#xff0c;我们介绍了固态硬盘的系列知识&#xff0c;包括闪存的介质、原理&#xff0c;以及作为SSD大脑的控制器设计&#xff0c;本文将详细介绍SSD架构以及功能模块。 SSD架构简介 ◎SSD架构示意图 如上图所示&#xff0c;典型的SSD架构包括主机接口、SS…

点亮童梦思考之光,神秘伙伴震撼登场!

本文由 ChatMoney团队出品 介绍说明 咱们来聊聊“十万个为什么”机器人&#xff0c;这对小朋友来说&#xff0c;好处可多了去啦&#xff01; 小朋友们天生好奇&#xff0c;满脑子都是问号。 这个机器人就像个啥都懂的知识达人&#xff0c;不管他们问啥&#xff0c;都能给出答…

JVM知识总结(类加载器)

文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 类加载器 Bootstrap引导类加载器 引导类加载器也被称为启动类加载…

麦田物语第二十天

系列文章目录 麦田物语第二十天 文章目录 系列文章目录一、构建地图信息系统二、生成地图数据 一、构建地图信息系统 我们上一节课已经做好了鼠标的显示&#xff0c;这节课需要构建地图的一些信息&#xff0c;例如&#xff1a;可挖坑&#xff0c;可丢弃物品等地区。我们点击地…

c语言学习,isdigit()函数分析

1&#xff1a;isdigit() 函数说明&#xff1a; 检查参数c&#xff0c;是否为0到9阿拉伯数字 2&#xff1a;函数原型&#xff1a; int isdigit(int c) 3&#xff1a;函数参数&#xff1a; 参数c&#xff0c;为检测整数 4&#xff1a;返回值&#xff1a; 参数c是阿拉伯码字符&…

【机器学习第8章——集成学习】

机器学习第8章——集成学习 8.集成学习8.1个体与集成弱分类器之间的关系组合时&#xff0c;如何选择学习器怎么组合弱分类器boosting和Bagging 8.2 BoostingAdaBoost算法步骤训练过程 8.3 Bagging与随机森林随机采样(bootstrap)弱学习器结合策略方差与偏差算法流程随机森林 8.4…

中职云计算实训室

一、实训室建设背景 随着信息技术的飞速发展&#xff0c;云计算已成为推动数字化转型、促进经济社会发展的重要力量。《中华人民共和国国民经济和社会发展第十四个五年规划和2035年远景目标纲要》明确提出&#xff0c;要加快数字化发展&#xff0c;建设数字中国。云计算作为数…

NLP——Transfromer 架构详解

Transformer总体架构图 输入部分&#xff1a;源文本嵌入层及其位置编码器、目标文本嵌入层及其位置编码器 编码器部分 由N个编码器层堆叠而成 每个编码器层由两个子层连接结构组成 第一个子层连接结构包括一个多头自注意力子层和规范化层以及一个残差连接 第二个子层连接结构包…

基于Java中的SSM框架实现远程同步课堂系统项目【项目源码+论文说明】计算机毕业设计

基于Java中的SSM框架实现远程同步课堂系统演示 远程同步课堂系统设计与实现 摘要&#xff1a;在这样一个网络数据大爆炸的时代&#xff0c;人们获取知识、获取信息的通道非常的多元化&#xff0c;通过网络来实现数据信息的获取成为了现在非常常见的一种方式&#xff0c;而通过…