- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于大规模粒子系统的实时喷泉模拟_计算机论文.doc
基于大规模粒子系统的实时喷泉模拟_计算机论文
基于大规模粒子系统的实时喷泉模拟_计算机论文
摘 要 本文实现了一种新的喷泉模拟方法,与传统的在CPU上实现算法不同的是,本文算法完全基于计算机图形硬件(GPU)来实现,利用图形硬件的大规模并行计算能力,显著的增加了模拟喷泉的粒子数量,提高了渲染速度,同时减轻了CPU的负载,使整个三维场景的绘制更加高效。
关键词 粒子系统;GPU;实时;喷泉模拟 0 引言
自然景物的模拟一直是计算机图形学的研究热点之一。粒子系统被公认为是模拟自然景物中运动模糊物体非常有效的一种图形生成算法。目前,在这一领域已经有较多的算法和理论,1983年,Reeves 首先提出了粒子系统为模糊物体建模的方法[1]。1990年,Karl Sims在超级计算机上实现了粒子系统的并行算法[2]。随着计算机图形硬件的快速发展,图形处理器(GPU)的计算能力大大增强,在GPU上进行大规模的并行计算成为可能[3]。 2004年,Lutz latta在个人计算机的GPU上实现了并行的粒子系统,能实时处理1,000,000个粒子,并首次提出了大规模粒子系统的概念[4,5]。 2006年,许楠等也在GPU上实现了大规模的粒子系统,用26万个粒子实现了对雨景的模拟[6]。
喷泉的模拟是粒子系统的典型应用,最近对喷泉的研究比较活跃,马骏等利用粒子系统,采用离线渲染的方法来模拟喷泉[7,8],赵静谧以粒子系统为基础,采用Line方式渲染粒子,结合纹理映射实现了喷泉的实时模拟,其实现的喷泉,粒子数量较小,速度只有20帧/秒[9]。方建文等利用了GPU的硬件加速功能,以CPU和GPU相结合,实现了对喷泉的实时模拟,在粒子规模小于10,000个的情况下能满足实时的要求[10]。
在做虚拟校园时,我们要模拟一个较大的喷泉,由三组喷泉组成,共72个水柱,为了逼真的模拟喷泉效果,本文采用完全基于GPU的大规模粒子系统,在普通的计算机上,用了大约76,500个粒子,利用GPU大规模并行计算的能力,实现了喷泉的实时模拟。
1 粒子系统简介
1.1经典粒子系统介绍[1]
粒子系统的绘制包括以下几个步骤:
(1)粒子的产生:产生新的粒子加入系统中;
(2)粒子的初始化:设置每个粒子的属性,如初始位置、方向、颜色、透明度、生命周期等;
(3)粒子的消亡:从系统中删除那些已经超过生命周期的粒子;
(4)粒子的运动:按粒子的动态属性改变位置和其它属性;
(5)粒子的绘制:绘制并显示由有生命的粒子组成的图形。
上述几个步骤不停循环,形成了物体动态变化过程。
1.2 大规模粒子系统介绍
大规模粒子系统是相对经典的粒子系统而言,由于经典的粒子系统在数量上受到10,000个粒子的限制,而完全在图形硬件(GPU)上实现的粒子系统,在处理1,000,000个粒子的时候仍能满足实时的要求,这种完全在图形硬件上实现的粒子系统被称为大规模粒子系统。
大规模的粒子系统采用并行算法,提高了并行处理能力,主要在GPU上实现,减轻了CPU的负载,提高了GPU的利用率,大大减小了CPU到GPU的数据传输,从而极大的改善了粒子系统的实时性。下面详细介绍如何用大规模粒子系统来实时模拟一个真实的喷泉。
2 喷泉的模拟
喷泉由多个水柱组成,每个水柱可看成由很多个小水珠组成,每个小水珠可由一个粒子来模拟,本文称之为喷泉粒子。喷泉的模拟按图1所示的步骤进行:
图1 喷泉粒子处理流程图
2.1 喷泉粒子的属性和存储
喷泉粒子由位置(Position)、生存时间(Tol)、速度(Velocity)、颜色组成。
图2 粒子属性存储示意图
这些属性如图2所示,均以Texture的形式存储在显存中,Texture是由Pixel组成的矩阵,每个Pixel由RGRB四个浮点数分量组成,GPU处理数据时,一次可以输入一个或多个Texture,处理后输出一个Texture,结合硬件的特点,便于并行处理,我们把这三组数据保存在不同的Texture中,就有了图2所示的三组Texture。每组两个Texture,循环的用做输入和输出,称之为双缓存。
2.2 喷泉粒子的产生
在GPU编程中,存储空间的分配和回收不如CPU对内存的管理那么方便,不太适合动态分配,因此创建固定大小的Texture,比如1024 * 256个像素,先在内存中建立一个索引表,为Texture的每一个Pixel设置一个标志,表示这个Pixel是否保存有效的粒子信息。这个索引表的初始值全部为零,表示场景中没有任何粒子,分配新粒子时,从索引表中找到为零的值,然后设置各个Texture对应的Pixel的值,再把索引标志的值设为1。
产生新粒子时,按预先设置的产生粒子的速度和与上次产生粒子的时间间隔,可计算出本次应该产生
您可能关注的文档
- 基于RBF神经网络的四声自动识别及应用_计算机论文.doc
- 基于RED算法的拥塞控制的研究_计算机论文.doc
- 基于RFID技术的仓储物流入库流程设计_计算机论文.doc
- 基于RFID电子标签的物流控制系统的设计_计算机论文.doc
- 基于ROR的网络订餐系统的设计与实现_计算机论文.doc
- 基于SDH传输网络的POS与EOS接入技术比较_计算机论文.doc
- 基于SemRank的CWME专家权威度计算方法研讨_计算机论文.doc
- 基于SIP的远程多媒体教学系统的设计与研究_计算机论文.doc
- 基于SNMP的统一网管框架的设计与实现_计算机论文.doc
- 基于SNMP的网络拓扑发现_计算机论文.doc
- 基于完善我国建设工程招投标制度的思考_工程建筑论文.doc
- 基于定位服务的移动电子商务发展分析_电子机械论文.doc
- 基于密钥矩阵序列的视频乱序加密方法_计算机论文.doc
- 基于对手思维建模的分布式入侵检测模型_计算机论文.doc
- 基于小波变换图像压缩的量化技术研究_计算机论文.doc
- 基于局域网的多媒体教学系统的设计与实现 _计算机论文.doc
- 基于建设和谐社会的电信普遍服务策略研究_通信学论文.doc
- 基于性能的抗震设计理论研究综述_工程建筑论文.doc
- 基于房地产投资项目工程造价全过程的有效控制与管理分析探讨_工程建筑论文.doc
- 基于扩展XQuery引擎的空间数据流查询方法研究_计算机论文.doc
文档评论(0)