【NetTopologySuite类库】C#生成Delaunay三角网、生成凹包ConcaveHull

本文主要是介绍【NetTopologySuite类库】C#生成Delaunay三角网、生成凹包ConcaveHull,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

介绍

三角网

生成三角网的API地址:https://nettopologysuite.github.io/NetTopologySuite/api/NetTopologySuite.Triangulate.ConformingDelaunayTriangulationBuilder.html#methods

凹包

生成凹包的API地址:
https://nettopologysuite.github.io/NetTopologySuite/api/NetTopologySuite.Algorithm.Hull.ConcaveHull.html

构造一组点的凹壳。凹壳可能是包含所有输入点的非凸多边形。给定的一组点具有由数值目标参数确定的凹陷度不断增加的外壳序列。

凹壳是通过去除点的Delaunay三角剖分的最长外边缘来构建的,直到达到目标标准参数。

【可见此处的凹包是基于三角网生成的】

两个参数:

  • Maximum Edge Length Ratio:凹包的最长边缘的长度不大于该值。
  • Maximum Edge Length Factor:将“最大边长”确定为Delaunay三角剖分中最长和最短边长之差的一小部分。这会将“最大边长”标准化为无标度。值为1将生成凸包;值0产生最大凹度。

优选的参数是使用Maximum Edge Length Factor(最大边长比),因为它是无标度的和局部的(因此不需要对存在的凹陷总量进行假设)。可以通过直接设置“最大边长”来使用其他长度标准。

生成三角网示例

  1. 先用wkt创建一个多边形(如下图所示,绿色点为特意标注的多边形顶点)
var wkt = "polygon((0 0,0 6,3 6,3 5,5 5,5 3,2 3,2 2,5 2,5 1,6 1,6 0,2 0,2 -1,7 -1,7 -2,-1 -2,-1 -1,0 -1,0 0))";
var geo = new WKTReader().Read(wkt);

在这里插入图片描述
2. 利用上述多边形创建三角网(本质上是使用多边形的顶点)。

var wkt = "polygon((0 0,0 6,3 6,3 5,5 5,5 3,2 3,2 2,5 2,5 1,6 1,6 0,2 0,2 -1,7 -1,7 -2,-1 -2,-1 -1,0 -1,0 0))";
var geo = new WKTReader().Read(wkt);
var tri = new ConformingDelaunayTriangulationBuilder();
tri.SetSites(geo);
var tris = tri.GetEdges(GeometryFactory.Default);
//自行将tris输出成shp文件,如下图所示

在这里插入图片描述

生成凹包

默认参数

如介绍中所言,凹壳是通过去除点的Delaunay三角剖分的最长外边缘来构建的。

下面,使用默认参数生成面积最小(删掉的三角边最多,再删就会导致丢失顶点了)的凹包:

var gconcaveHull = new ConcaveHull(geo);
gconcaveHull.MaximumEdgeLength = 0;//默认值就是0
var geo_concaveHull = gconcaveHull.GetHull();

参数MaximumEdgeLength的默认值就是0,此时所有长度大于0的边,在不丢失顶点的情况都会被删掉。删掉这些边后形成的多边形就是凹包了:

在这里插入图片描述

参数MaximumEdgeLength=3

修改参数MaximumEdgeLength=3,即提高边被删除的底线,边长必须大于3,才会被删除。

如下图所示,箭头所指的边不再被删除。

当提高MaximumEdgeLength的值后,更多的边会被保留。
在这里插入图片描述

参数MaximumEdgeLengthRatio=0.4

除了通过参数MaximumEdgeLength设置具体的长度限制,

还可以通过参数MaximumEdgeLengthRatio设置无标度的比例限制。

例如设置0.4的容差:

gconcaveHull.MaximumEdgeLengthRatio = 0.4;

在这里插入图片描述
MaximumEdgeLengthRatio参数的作用方式:

  1. 找到所有最长边L
  2. 对于任意边长K,如果1- K / L > MaximumEdgeLengthRatio则删除边K,否则保留边K。
    通过计算,得到结果:L1应被删除,L2应被保留。

这篇关于【NetTopologySuite类库】C#生成Delaunay三角网、生成凹包ConcaveHull的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M