1.粗粒化分子动力学的粒源实现及源码修改
2.比李峋还要好看的爱心代码飘散效果
3.7.AMCL包源码分析 | 粒子滤波器模型与pf文件夹(三)
4.5.AMCL包源码分析 | 粒子滤波器模型与pf文件夹(一)
5.unity里这种闪电/脉冲波特效怎么做?怎么更改粒子特效的旋
6.2022的七夕,奉上7个精美的码修表白代码,同时教大家快速改源码自用
粗粒化分子动力学的改粒实现及源码修改
粗粒化分子动力学(CGMD)是一种提升时间空间计算尺度的算法,通过简化全原子模型为粗粒化粒子模型,代码大全使用代表性珠子代替原子,粒源以及粗粒化力场进行牛顿力学计算,码修跟踪eco源码显著降低计算成本,改粒尽管牺牲了一些原子级信息,代码大全但在更大尺度上的粒源计算预测效果较好。CGMD在有机体领域研究较多,码修但对于金属等材料的改粒研究和力场开发相对不足。本文总结了过去的代码大全研究经历和发现。
一、粒源粗粒化实现原理
CGMD依托分子动力学计算框架,码修需要计算粒子间的改粒相互作用势进行牛顿迭代以获取粒子轨迹和相互作用力。建模和势函数是必须的,计算算法可直接沿用MD算法。金属粗粒化建模需要保持原有晶体结构,并使整体能量不变。以fcc铜为例,每个粗粒化珠子代表八个铜原子,建立粗粒化晶胞。势函数修改遵循总势能不变、粒子间对势不变的准则,总能量不变是粗粒化体系的基本前提,势函数修改简化计算假设。
二、粗粒化实现过程
粗粒化晶胞建模可使用atomsk工具或在lammps内部,调整晶胞晶格常数和原子质量。势函数修改较为复杂,javassm源码以EAM势函数为例,需要调整势函数文件,包括元素原子序数、质量、晶格常数和类型声明,势函数矩阵的调整,以及通过插值方法获取未知点值,确保粗粒化珠子在不同距离上具有相同的势能。同时需要修改Nr和cutoff参数。
三、lammps源码修改
lammps源码修改集中在pair系列文件,对eam势函数文件进行调整,通过修改计算势能的函数,确保计算结果与粗粒化程度一致。将计算结果写入到force头文件中,方便调用。编译修改后的lammps源码,进行算例测试,验证计算结果。
四、结果验证
对单晶铜单轴拉伸算例进行计算,对比原MD结果。发现CGMD计算出现失真现象,原因在于使用的势函数过于粗糙。更换更精确的mishin势后,精度显著提高,但仍存在误差。分析误差原因,模型过小导致计算结果失真,源码中医而非单纯精度问题。线性插值方法精度较低,考虑使用更高精度的插值法进行势函数修改。
五、结论
实现CGMD计算工具的过程并不复杂,但需要考虑多个实现思路。CGMD在金属材料研究领域的应用前景良好,通过调整算法和参数,可以进一步提升计算精度和效率。后续研究可能涉及更高级的插值方法、更精确的势函数和对CGMD算法的优化。
比李峋还要好看的爱心代码飘散效果
效果. 爱心飘散代码
源代码链接1: pan.xunlei.com/s/VNvzxj...
源代码链接2: pan.quark.cn/s/0af1e...
源代码链接3: drive.uc.cn/s/e5b1fe7...
效果. 粒子爱心代码
手机版打开入口: loveyou.gitee.io/8/
源代码链接1: pan.xunlei.com/s/VNvtj1...
源代码链接2: pan.quark.cn/s/0af1e...
源代码链接3: drive.uc.cn/s/0af1e...
效果. 3d立体爱心代码
源代码链接1: pan.xunlei.com/s/VNvu8U...
源代码链接2: pan.quark.cn/s/ceca...
源代码链接3: drive.uc.cn/s/8f4a5d...
效果. 会缩放的爱心代码
手机版打开入口: loveyou.gitee.io/love...
源代码链接1: pan.xunlei.com/s/VNvtiT...
源代码链接2: pan.quark.cn/s/dec...
源代码链接3: drive.uc.cn/s/cf...
效果1. 流星雨爱心代码
手机版打开入口: loveyou.github.io/lov...
源代码链接1: pan.xunlei.com/s/VNvthO...
源代码链接2: pan.quark.cn/s/d0e...
源代码链接3: drive.uc.cn/s/6fe8c...
效果2. "i love you"代码
源代码链接1: pan.xunlei.com/s/VO1t2i...
源代码链接2: pan.quark.cn/s/fef...
源代码链接3: drive.uc.cn/s/1bea9...
效果3. "i love you"代码
源代码链接1: pan.xunlei.com/s/VO1t2l...
源代码链接2: pan.quark.cn/s/cf3...
源代码链接3: drive.uc.cn/s/6eda8...
效果. 送给我的公主殿下代码
源代码链接1: pan.xunlei.com/s/VNvuAB...
源代码链接2: pan.quark.cn/s/3efdbbf0...
源代码链接3: drive.uc.cn/s/e8d...
效果. 我永远为你着迷代码
源代码链接1: pan.xunlei.com/s/VNvtie...
源代码链接2: pan.quark.cn/s/ad...
源代码链接3: drive.uc.cn/s/ec4aa...
效果1. xxx, 生日快乐代码
源代码链接1: pan.xunlei.com/s/VNvtfA...
源代码链接2: pan.quark.cn/s/3e0fe...
源代码链接3: drive.uc.cn/s/f...
效果2. 祝亲爱的 生日快乐代码
源代码链接1: pan.xunlei.com/s/VNvuim...
源代码链接2: pan.quark.cn/s/f2b...
源代码链接3: drive.uc.cn/s/bcefee0...
效果3. 祝xxx生日快乐代码
源代码链接1: pan.xunlei.com/s/VNvtg-...
源代码链接2: pan.quark.cn/s/9fd...
源代码链接3: drive.uc.cn/s/6fb...
效果4. 祝你 生日快乐 (可以改成ta的名字)代码
源代码链接1: pan.xunlei.com/s/VNvtfI...
源代码链接2: pan.quark.cn/s/...
源代码链接3: drive.uc.cn/s/9ba9a...
效果5. xxx, 祝你生日快乐代码
源代码链接1: pan.xunlei.com/s/VNvuih...
源代码链接2: pan.quark.cn/s/ff...
源代码链接3: drive.uc.cn/s/f0...
效果6. 生日快乐带声音代码
源代码链接1: pan.xunlei.com/s/VNvuiv...
源代码链接2: pan.quark.cn/s/add...
源代码链接3: drive.uc.cn/s/ade2...
效果7. 生日快乐粒子特效代码
源代码链接1: pan.xunlei.com/s/VNvuit...
源代码链接2: pan.quark.cn/s/ed...
源代码链接3: drive.uc.cn/s/fc...
效果8. 生日快乐代码
源代码链接1: pan.xunlei.com/s/VNvuiv...
源代码链接2: pan.quark.cn/s/add...
源代码链接3: drive.uc.cn/s/ade2...
效果1. xxx, 我喜欢你代码
源代码链接1: pan.xunlei.com/s/VNvu8l...
源代码链接2: pan.quark.cn/s/bf...
源代码链接3: drive.uc.cn/s/efe6d...
效果2. 我爱你代码
源代码链接1: pan.xunlei.com/s/VNvu8l...
源代码链接2: pan.quark.cn/s/bf...
源代码链接3: drive.uc.cn/s/efe6d...
效果3. love to you代码
源代码链接1: pan.xunlei.com/s/VNvu8l...
源代码链接2: pan.quark.cn/s/bf...
源代码链接3: drive.uc.cn/s/efe6d...
效果4. 亲爱的,生日快乐 (可以改成ta的名字)代码
源代码链接1: pan.xunlei.com/s/VNvu8l...
源代码链接2: pan.quark.cn/s/bf...
源代码链接3: drive.uc.cn/s/efe6d...
效果5. zws (可以改成ta的名字)代码
源代码链接1: pan.xunlei.com/s/VNvu8l...
源代码链接2: pan.quark.cn/s/bf...
源代码链接3: drive.uc.cn/s/efe6d...
7.AMCL包源码分析 | 粒子滤波器模型与pf文件夹(三)
在上一讲中,我们深入探讨了pf.cpp文件,它将Augmented-MCL算法和KLD-sampling算法融合使用。重点在于pf_pdf_gaussian_sample(pdf)函数、pf_init_model_fn_t初始化模型以及pf->random_pose_fn方法进行粒子初始化。粒子的插入和存储采用kd树数据结构,同时kd树也表达直方图的k个bins,通过叶子节点数展现。
本讲聚焦kd树在粒子滤波器模型中的作用(pf_kdtree.cpp)、概率密度函数pdf与特征值分解的关系(eig3.cpp、pf_vector.cpp)以及如何利用pdf生成随机位姿(pf_pdf.cpp),同时解释kd树与直方图的对应关系。
在概率密度函数pdf的创建中,我们首先定义一个高斯PDF结构体pf_pdf_gaussian_t,包含均值和协方差的描述,接着进行协方差矩阵的分解,通过Housholder算子和QR分解完成特征值分解过程。bedrockserver源码
通过pdf结构体实现随机位姿的生成,具体在pf_pdf.cpp中pf_pdf_gaussian_sample函数实现,使用无均值带标准差的高斯分布进行生成。
kd树数据结构在pf_kdtree.cpp中定义,包括节点和树的初始化,以及新位姿的插入。kd树的插入依据树的性质,通过计算max_split、中位数和分支点维数来定位新节点位置。查找节点和计算给定位姿权重则通过kd树结构实现,最终将树中叶子节点打标签,以统计特性如均值和协方差计算整个粒子集。
kd树在AMCL中承担直方图功能,以叶子节点数目表示bin个数(k),概率密度函数pdf依赖于输入的均值和协方差生成,用于随机位姿的产生。此外,kd树还用于判断粒子集是否收敛。最后,kd树表达直方图的过程在pf.cpp中pf_update_resample函数中实现,而pf_resample_limit函数用于设定采样限制。
kd树在粒子滤波器模型中的作用包括存储粒子样本集、查找和插入新位姿,以及统计特性计算。概率密度函数pdf的使用除了初始化粒子位姿外,还有判断粒子收敛的作用。下一讲将探讨amcl_node.cpp的处理内容,包括初始位姿、激光数据和坐标系转换,gpcopy源码以及粒子滤波器pf的运用。
5.AMCL包源码分析 | 粒子滤波器模型与pf文件夹(一)
粒子滤波器这部分内容较为复杂,涉及众多理论与数据结构,我们将分多个部分进行介绍。本部分内容主要对pf文件夹进行简要分析,包括蒙特卡罗定位在pf中的代码实现、KLD采样算法的理论介绍及其在pf中的具体实现。
pf文件夹主要由以下部分组成:3✖3对称矩阵的特征值和特征向量的分解、kdtree的创建与维护方法、Gaussian模型与概率密度模型采样生成粒子、三维列向量、三维矩阵、实现pose的向量运算、局部到全局坐标的转换以及全局坐标到局部坐标的转换。
接下来,我们将对各个头文件进行简要分析。
粒子滤波器是AMCL定位的理论基础,属于粒子滤波的一种。关于粒子滤波的原理及代码效果演示,可以参考相关资料。
AMCL包中的粒子滤波器作用如下:首先,参考pf.cpp中的pf_update_action函数,了解sample_motion_model代码实现;其次,参考pf.cpp中的pf_update_sensor函数,了解measurement_model的代码实现。
AMCL引入KLD采样理论,对蒙特卡罗定位进行再次改进。参考《概率机器人》第8章,讨论粒子滤波器的效率及采样集大小的重要性。KLD采样是蒙特卡罗定位的一个变种,它能随时间改变粒子数,降低计算资源的浪费。
3.1 KLD_Sampling_MCL算法介绍:算法将以前的采样集合、地图和最新的控制及测量作为输入,要求统计误差界限err和sigma。在满足统计界限之前,KLD采样将一直产生粒子。算法产生新粒子,直到粒子数M超过Mx和使用者定义的最小值Mx(min)。
3.2 KLD采样算法在AMCL包中的具体应用:代码在pf.cpp中的pf_update_resample函数中实现。接下来,我们将详细分析pf文件夹里每个CPP文件的代码逻辑。
unity里这种闪电/脉冲波特效怎么做?怎么更改粒子特效的旋
了解Unity中闪电或脉冲波特效的制作方法,首先可以参考一篇基于物理原理的闪电动画渲染教程,网址为gamma.cs.unc.edu/LIGHTN...。通过电解质击穿模型(Dielectric Breakdown Model)模拟闪电,其形状符合分型图形特性。因此,可以采用拉普拉斯增长模型或泊松增长模型来模拟闪电的形状。在场景中放置多个电荷,通过求解Laplace方程得到周围的电势。电势与空气被击穿的概率相关,概率公式中n表示相邻栅格个数,而eta参数则用于调节闪电的分叉数量,增大eta值会使分叉减少。
闪电的渲染使用的是APSF方法(Atmospheric Point Spread Function)。具体实现可以参考cs.cmu.edu/~ILIM/public...。另外,有几个采用此方法的演示案例可以供参考,且这些案例通常都提供源代码。包括闪电生成器LumosQuad(版本0.1),基于自适应网格的快速闪电模拟:Fast Animation of Lightning Using an Adaptive Mesh,以及基于简单随机的闪电渲染方法:cs.uccs.edu/~ssemwal/IA...
的七夕,奉上7个精美的表白代码,同时教大家快速改源码自用
迎接年的七夕情人节,程序员们展现独特表白方式,不再只是言语,而是代码的深情。这里有七个精心打造的表白代码示例,教你如何快速自用,让你的表白更加别具一格。 在线版情人节粒子效果文字表白:点击屏幕,粒子文字动态变化,高级撩妹。只需在github.com/tsunghanjack/...找到`main.js`中的文字路径进行替换,即可个性化你的表白。 卡通滚动表白:通过漫画形式讲述爱情故事,触动心灵。改动源码中路径,/post-images/...,或直接使用在线版本,将生活点滴融入表白。 敲代码秀操作表白:修改前端css注释部分,适合对css有一定了解的人。编译命令在文档中提供,调整后在`dist`目录可见。 爱情故事代码:小白也能理解的表白,只需替换`/index.html`下的文字,展现你的深情。 时间进行时表白:漂浮爱心和时间显示,情感随秒跳动,主要改动文字内容。 满屏爱心表白:爱心飘动和表白文字,适合快速表白,只需获取源码。 爱情树表白:记录爱情历程,改动文字内容,动效和情话搭配,打动人心。 想要获取5、6、7的源码,关注微信公众号编程达人,回复“”。博主奇想派分享这些代码,带你展现程序员的独特浪漫。 原文作者:奇想派,更多编程达人的故事,尽在微信公众号编程达人。 原创提醒:你的赞赏是我们的动力,记得关注、点赞和转发哦!UE4:Niagara扩展CameraQuery支持CPU获取ViewSize
在使用UE4中的Niagara系统进行粒子系统开发时,遇到过一个需求:需要在CPU粒子系统中获取ViewSize参数,而该参数在CameraQuery组件中仅提供了一个支持GPU的方法。为了解决这个问题,我们探究了如何在Niagara系统中实现CPU获取ViewSize的方法。
首先,创建一个NiagaraScript并添加CameraQuery节点,目的是获取ViewSize参数。在MapGet节点中拉出一个Get方法,可以看到该方法支持CPU还是GPU。然而,由于添加了一个不支持的方法,编译时会报错。因此,我们需要实现一个在CPU粒子系统中获取ViewSize的解决方案。
通过查看CameraQuery的源码,发现GetViewPropertiesGPU函数在注释中被标记为CPU模拟实现,实际并未获取任何数据。进一步研究其他CPU函数的实现,我们了解到数据实际上是从Context的FCameraDataInterface_InstanceData中获取的。通过VectorVM::FExternalFuncRegisterHandler的方式,将获取到的值传递到输出pin,完成了数据从实例数据到输出的传递。
接着,关注到UNiagaraDataInterfaceCamera::GetCameraProperties函数中的完整流程,它更详细地展示了如何添加输出、获取值和赋值的操作。通过分析FCameraDataInterface_InstanceData的初始化和PerInstanceTick函数,我们了解到摄像机参数是通过从World和PlayerController获取的,而这些操作在Tick函数中进行。确认了摄像机参数的获取过程合理,并支持编辑器模式下的正常获取。
在GetFunctions函数中,添加输出和方法的定义时,需要注意函数名、支持CPU/GPU的标志以及是否为成员函数等细节。在GetFunctionHLSL中,只关注CPU方法的实现,通过函数的DefinitionName获取HLSL代码。
为了在CameraQuery中增加获取ViewSize的方法,我们需要在FCameraDataInterface_InstanceData结构体中增加相应的参数,并在PerInstanceTick函数中进行赋值。同时,修改GetFunctions和GetFunctionHLSL以支持CPU粒子系统。最后,通过绑定GetVMExternalFunction完成方法的实现。
实现后,可以通过任意的Material进行调试,并在编辑器中查看结果,验证方法的正确性。这样,我们不仅解决了获取ViewSize的需求,还为Niagara系统的CPU粒子系统增加了更多灵活性。