Vellum —— Vellum Solver

2023-12-08 02:44
文章标签 vellum solver

本文主要是介绍Vellum —— Vellum Solver,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

Solver

Collision

Forces

Advanced

Secondary Constraint Pass

Multi-Pass Solve

Motion

Sleeping

Grain Collisions 

Fluids

Minimal Solver


        Vellum Solver SOP是DOP的封装,以简化vellum的解算;第一个端口是geometry,第二个端口是相同点数的且点对点(点号或id)的约束;第三个端口是碰撞体,碰撞体的拓扑结构应不变;另外,还可识别一些packed的几何体类型;还可在节点内,添加force、constraint property等节点;

Solver

  • Substeps,对快速运动或突然的力,应增加此值;如vellum太拉伸,增加到2或5是个好的开始;
  • Constraint Iterations,每子步内执行的迭代数,非常刚性的约束要求更多的迭代来收敛;最远点间的边数,是好的起点;
  • Smooth Iterations,默认约束迭代使用Gauss-Seidel方式(收敛快),但由于刚性太高或不可能的配置会无法完全收敛;此迭代使用Jacobi方式(收敛慢),误差会均匀分布;

Collision

  • Collision Passes,执行的碰撞检测数,在约束迭代间交替执行;因为碰撞代价高,最好最小化;
  • Post Collision Passes,所有约束被执行后,最后的碰撞检测;“number of stacked layers + 2” 是很好,可完全传播堆叠层;
  • Polish Passes,在任何碰撞过程中,可能无法完全解析,额外的碰撞将运行(非常便宜);
  • Layer Shock,整数点属性layer标记为不同的层,层越高越轻;

Forces

  • Velocity Damping,直接缩放速度,可快速阻尼;

Advanced

  • Target,pin约束的目标路径;
  • Integration,一阶对弯曲运动会被约束阻尼,二阶可恢复更多的弯曲运动,保持更多能量;但碰撞被检测,会退回到一阶,避免过度弹跳;
Secondary Constraint Pass
  • 单独解算更新的次要约束,否则在主pass内解析;
  • 对一些昂贵的约束,可低频率解算以提高性能,如低弯曲刚性的丝绸,可低频率解算弯曲约束;
  • 对约束拓扑内频率变化的(会导致解算器重排序约束解算,抖动),如四面体有机组织stitch在一起滑动,由于滑动约束变化,四面体可能会轻微抖动,可将stitch约束移到此pass,设置Solve Frequency为1,保持相同刚性,会消除此种抖动;
Multi-Pass Solve
  • 重复子步直到条件满足;
  • 当前条件会修复由禁用点引起的问题,禁用点导致几何体被捕获和导致未禁用点生成拉伸;由于碰撞优先于约束,结果是布料或头发拉伸;如检测到拉伸过大,与自动禁用点相邻的点将被禁用;然后重复解算,以期望free几何体;
  • notconverged(detail),disableself,disableexternal;

Collision

  • Disable Failed Collisions,点碰撞失败后,会被标记为禁用,从而可无碰撞移动;
  • Reset Collided Points,如点被检测到不再tangled状态并连接到非禁用点,将重新激活;
  • Initialize Overlap Distances,创建overlap_self、overlap_external属性(如存在将不会初始化),初始解算避免重叠;
  • Update Overlap Distances,更新overlap_self、overlap_external属性,以反映当前配置;
  • Tetrahedral Open Faces,四面体非共享面将生成碰撞几何体,如同时使用triangle shell 和 tetrahedral mesh,则此操作多余;
Motion
  • Max Acceleration,加速度限制避免过于服从非现实的力;
  • Fallback to First Order Integration on Collision,如点超过最大加速度,二阶预测可能错误,通常为反弹;
    • Grain/Fluid粒子总是会考虑退回一阶,不仅仅是碰撞情况下;
  • Limit Acceleration in Velocity Update,限制速度;
  • Limit Displacement on Collision,在碰撞时限制粒子移动;
  • Disable Broken Welds,当断开焊接点时,如表面没有分离,可能会爆开,此选项设置disableself属性,避免自碰撞;可能使分层布料穿插;
  • Normalize Stress,归一化应力计算,以便子步的更改,计算的值更加可预测;

  • Breaking Frequency,测试约束断开,断开约束会改变拓扑,会减慢解算;

  • Sliding Method,attach、stitch滑动的模式;

    • Closest Point速度快但会跳过凹陷, 

    • Traverse Polygons速度慢会处理凹陷;

    • Traverse Triangles(Optimized)比上一个快很多倍,但仅适用于三角形目标;

Sleeping
  • 粒子速度小于阈值,达到指定长的时间,即会停止(stopped=1);
  • 再次唤醒粒子,可使用POP Awaken节点;
Grain Collisions 
  • grain使用单独的碰撞pass,来处理grain间的碰撞,与POP Grains类似;
    • Search Scale,粒子pscale的缩放值,用于搜索范围;也影响在打簇内的吸引力范围;
    • Max Neighbors,搜索范围内的最大粒子数,如勾选OpenCL Neighbor Search参数(考虑所有范围内的点),则此参数忽略;
    • Assume Uniform Radius,pscale属性确定每粒子的半径,如所有粒子半径相同,则更快的用于查找邻居;
    • Ignore Neighbors with Same Name or Piece,忽略具有相同非空name属性或非负piece属性的邻居;可创建仅与其他簇交互的单独簇,通常与‘shape match约束’结合使用,以获得刚性;
    • Enable Constraint Averaging,当多个粒子同时碰撞时,平均化所有约束,以确保稳定;
    • Repulsion Weight,粒子碰撞力的权重,值为0粒子不碰撞;repulsionweight点属性缩放;
    • Attraction Weight,粒子粘连在一起的权重,值为0粒子不打簇;attractionweight点属性缩放;
    • Enable Mass Shock,根据粒子相对重力的位置,缩放粒子的质量;更高的粒子更轻,以使堆叠的粒子快速收敛,更稳定;
    • Shock Scaling Power,缩放量,值越高粒子间对比就越高,过高的值会使高粒子非常轻,会使系统不稳定;
    • Shock Axis,堆叠方向,通常与重力相反;
Fluids
  • 使用density约束,来保持流体不可压缩性,且提供viscosity、surface tension;phase属性非零;
    • Kernel Radius Scale,内核半径缩放,影响由表面张力产生的水滴大小;
    • Viscosity,粘度,与viscosity属性相乘;对不同phase值的粒子,粘性会独立解析;
    • SDF Collision Viscosity,与SDF碰撞接触的流体粘度,仅当Enable Minimal Solver时才有效;
    • Viscosity Solver,执行粘度解算的类型,Explicit快但不稳定(对高粒子数、高粘度,或低子步),Implicit慢但稳定(对高粒子数和粘度值);
    • Viscosity Tolerance,使用Implicit时的粘度容差,越低精度越高(更多迭代);
    • Max Viscosity Iterations,使用Implicit时的最大迭代数;
    • Surface Tension,表面张力,值越高会减低曲率,以形成水滴;与surfacetension属性相乘,对不同phase值的粒子,张力会独立解析;
    • Spatial Sort Interval,grain、fluid会执行许多涉及附近点的计算,通常空间中附近的点在内存中也靠近会大大的提高性能,此选项时按指定间隔帧对粒子排序;

      • 排序会改变点号,应在解算前添加id属性;

Minimal Solver
  • 被限制的解算器版本(被vellum brush使用),允许布料和其他柔体,与静态几何体快速交互;不适用于动态碰撞体,不建议用户使用;

OpenCL

  • OpenCL Graph Coloring,使用快速并行的OpenCL算法,对四面体可能需要多十倍的内存;
  • OpenCL Neighbor Search,使用OpenCL搜索grain、fluid邻居,比CPU更快,但可能使用更多的内存;

案例:VellumSmokeSheet(使用vellum作为碰撞体生成的速度场,来驱动vellum)

这篇关于Vellum —— Vellum Solver的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/468263

相关文章

LeetCode - 37. Sudoku Solver

37. Sudoku Solver  Problem's Link  ---------------------------------------------------------------------------- Mean:  求解数独. analyse: 只是9宫格的数独,而且测试数据都不难,所以可以直接使用递归求解,类似于N-Queue问题. 但如果宫格

Caffe学习系列(7):solver及其配置(学习率)

转自:http://www.cnblogs.com/denny402/p/5074049.html solver算是caffe的核心的核心,它协调着整个模型的运作。caffe程序运行必带的一个参数就是solver配置文件。运行代码一般为 caffe train --solver=*_slover.prototxt 在Deep Learning中,往往loss function是非凸的,没有解

LeetCode | Sudoku Solver

You may assume that there will be only one unique solution. A sudoku puzzle… …and its solution numbers marked in red. 数独问题,暴力深搜。 注意在找到解之后,要及时return,以及在第某一行无解的时候,要及时return,这样剪枝才不会导致超时。 class S

37. Sudoku Solver 回溯

Write a program to solve a Sudoku puzzle by filling the empty cells. Empty cells are indicated by the character '.'. You may assume that there will be only one unique solution. 回溯问题: 思路:

【工具笔记】Microsoft数学求解器Math Solver

【工具笔记】Microsoft数学求解器Math Solver 工具笔记用于记录各种有用的工具,这里记录的是一个由Microsoft提供的数学求解器Math Solver。 可以用于求解代数,三角学,微积分,矩阵等各种数学问题,并且可以获取分步解释,查看如何解决问题并获取数学概念的定义,立即画出任何公式以可视化函数并了解变量之间的关系。还会搜索出相关的视频,练习题,类似问题等。 Math S

LeetCode第37之Sudoku Solver

主要思路:回溯法,每个‘.’的位置遍历“1-9”,如果满足则继续下一个位置,如果遍历完“1-9”仍不满足则将该位置改为‘.’,然后回溯到上一个位置。 缺点就是运行时间有点长。 C++代码: #include <iostream>#include <vector>using namespace std;//打印board矩阵void print_vec(vector<vector<cha

LeetCode Sudoku Solver

Write a program to solve a Sudoku puzzle by filling the empty cells. Empty cells are indicated by the character '.'. You may assume that there will be only one unique solution. A sudoku p

Mode Solver ------- Mesh size 对仿真结果的影响

Mesh size 对仿真结果的影响 引言正文 引言 在 FDE Solver ------ Straight Si waveguide simulation 硅直波导仿真(完美版) 一文中我们介绍了硅直波导的仿真。在 DE Solver ------ Simulation mesh settings 仿真网格设定(完美版) 一文中我们介绍如何设定仿真网格,在 Lumerical

hdu 5451 Best Solver(矩阵乘法+数论)

题目链接:hdu 5451 Best Solver 解题思路 因为取模的数很小,所以暴力找打循环节,然后求解。 代码 #include <cstdio>#include <cstring>#include <cmath>#include <vector>#include <set>#include <algorithm>using namespace std;const int

Leetcode 037 Sudoku Solver(递归)

题目连接:Leetcode 037 Sudoku Solver 解题思路:预处理出每个'.'可能的数值,然后处理一些直观的解,比如某个位置只有一种可能的数字;或者是它所在的一行,一列或者块,只有它可能为这个数字。 剩下的位置都是有多种可能,它们的取值和其它位置相关联。这里的解决方法是暴力求解,枚举每个位置的值,然后递归,直到所有位置都被赋值并且没有冲突时,答案可知。 class Soluti