当前位置: 首页 > news >正文

VTK 距离可视化 PolyDataDistance DistancePolyDataFilter

1.vtkDistancePolyDataFilter

该接口主要用于计算两个vtkPlyData数据集之间的距离。使用vtkImplicitPolyDataDistance在第一个输入的每个点上计算到第二个输入的有符号距离。可选地,可以计算第二个输入中每个点到第一个输入的有符号距离。这可以通过调用ComputeSecondDistanceOn()来启用。

SignedDistanceOff()设置后,可计算无符号的距离值。


2. vtkImplicitPolyDataDistance

 它用于计算点到PolyData数据的距离。通过vtkCellLocator找到最近点,并利用vtkCell的EvaluatePosition方法确定距离。文章还列举了关键参数如EvaluateFunction、SetTolerance等 ;

用于计算输入vtkPolyData上从点x到最近点p的距离。函数的符号被设置为最近曲面点的角加权伪法线与向量x - p之间的点积的符号。几何图形内部的点具有负的距离,外部的点具有正的距离,而输入vtkPolyData上的点具有零的距离。函数的梯度是最近点的角加权伪正规。

3.vtkDistancePolyDataFilter 样例,计算两个 polydata 距离,并显示

 

4.vtkImplicitPolyDataDistance 样例,计算点到polydata 距离,并显示 

vtkImplicitPolyDataDistance* imp = vtkImplicitPolyDataDistance::New();
imp->SetInput(src);
 
// Calculate distance from points.
int numPts = mesh->GetNumberOfPoints();
 
vtkDoubleArray* pointArray = vtkDoubleArray::New();
pointArray->SetName("Distance");
pointArray->SetNumberOfComponents(1);
pointArray->SetNumberOfTuples(numPts);
 
for (vtkIdType ptId = 0; ptId < numPts; ptId++)
{
  double pt[3];
  mesh->GetPoint(ptId, pt);
  double val = imp->EvaluateFunction(pt);
  double dist = SignedDistance ? (NegateDistance ? -val : val) : fabs(val);
  pointArray->SetValue(ptId, dist);
}

 

 

相关文章:

  • 使用 FFmpeg 剪辑视频指南
  • 分布式光纤声波振动技术在钻井泄漏检测中的应用
  • 【UCB CS 61B SP24】Lecture 4 - Lists 2: SLLists学习笔记
  • 在PyCharm中运行Jupyter Notebook的.ipynb文件及其pycharm软件的基础使用
  • 前端循环全解析:JS/ES/TS 循环写法与实战示例
  • windows解压多个文件夹内的zip文件脚本
  • 计算机三级网络技术知识汇总【4】
  • 1005 K 次取反后最大化的数组和(贪心)
  • Electron通过ffi-napi调用dll导出接口
  • MacOS安装Emacs
  • 【Mermaid图表渲染错误分析与解决方案之关键字错误】
  • 读书笔记:要点提炼《基于大模型的RAG应用开发与优化——构建企业级LLM应用》(严灿平)
  • 计算机科学与技术
  • GPT2 模型训练
  • 本地文件共享——HFS
  • Linux线程池
  • 第3章 3.2 配置系统 .NET Core配置系统
  • 【C++委托与事件】函数指针,回调机制,事件式编程与松耦合的设计模式(上)
  • 孤独症项目(3)
  • 【开源】编译器,在线操作
  • 中国海警登临铁线礁开展维权行动并展示五星红旗
  • 时隔七年,上合组织国家电影节再度在中国举办
  • 习近平在气候和公正转型领导人峰会上的致辞(全文)
  • 央行副行长:上海国际金融中心建设是我国参与国际金融竞争的核心载体
  • 印控克什米尔发生恐袭事件,外交部:中方反对一切形式的恐怖主义
  • 王毅将出席中国一中亚外长第六次会晤、金砖国家外长会晤和第十五次金砖国家安全事务高级代表会议