标题:如何编写已知数据生成等高线程序?
只看楼主
曾震
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2011-9-8
得分:0 
你说的这个问题,比如有多个等高环的问题,比如很近的两个点,它们海拔高度相等,如何确定它们是否是在同一个等高线上的问题是吧?这个是由于使用者所选用的高程的问题,而不是软件的问题,如果高程差选的太大,这个驼峰状就显示为独峰状了,显示不了那么详细了。所以这个不是编程考虑的问题,只要把握一点就是等高线不能交叉就对了!所以这里首先有一个选项就是要求使用者填写高程,由这个高程决定等高线所反映信息的详细程度。
2011-10-22 19:23
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
得分:0 
哦,指定高程,似乎有点苗头。弄点数据来测试一下嘛。

授人以渔,不授人以鱼。
2011-10-22 19:39
曾震
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2011-9-8
得分:0 
我说过了,是真的没有数据,你可以自己先设定一些数据试试!我一般是有设想,然后编程程序,然后再应用!不过我倒是可以编一些数据,我不会上传文件!
2011-10-22 19:53
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
得分:0 
我自己编,编一个一个同心圆,那也没意思。要编就弄有点现实基础的数据。

授人以渔,不授人以鱼。
2011-10-22 19:55
曾震
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2011-9-8
得分:0 
我是真的弄不出来,编也编不出来啊!我用的哪些数据明年年底能出来就不错了!
2011-10-22 20:03
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
得分:0 
你提醒我了,用高程控制,我知道大概怎么写了。有数据就可以实现,但我不想闭门造车,因为实际的数据跟想象的数据可能有很多区别的,走错路就冤枉了。

授人以渔,不授人以鱼。
2011-10-22 20:12
曾震
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2011-9-8
得分:0 
如果有特殊情况就是有断层或者是悬崖的地方特殊。程序对我们来说是一个工具,所以我现在只是设想我要用的工具的功能,实际数据是真的没有。我倒是真想给你弄一套有典型意义的数据出来,至于我的那套数据还得自己到资料室一个点一个点的收集,那是我明年的工作计划。如果我遇到典型的快捷的数据我绝对会给你传过去。能不能指点一下程序怎么编啊?我手上的资料比你也多不到哪去,一切都还是构想,我在想办法从网上或者是一些教材上看能不能给你搜集一套典型的数据。

[ 本帖最后由 曾震 于 2011-10-22 20:27 编辑 ]
2011-10-22 20:25
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
得分:0 
过几天我再想想这个问题,你最好能弄点数据。画图不难的,我认为关键是效率,最好用大量数据来测试。

授人以渔,不授人以鱼。
2011-10-22 20:31
曾震
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2011-9-8
得分:0 
好的,我想办法赶紧弄点现成的有典型意义的数据。
2011-10-22 20:33
曾震
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2011-9-8
得分:0 
                             如何根据离散点自动绘制等值线(等高线)之 三角形法
 
   
  
 

自动绘制等值线的方法从技术方向上看可以分为两大类,插值和曲线拟合.其中曲线拟合总的来说效果不如插值算法经典和应用广泛,效果也较逊色.这里着重介绍插值算法.

其中插值算法中,按照方式不同分为离散点客观化和三角网方式.两者区别在于三角网计算主要在生成三角网过程,省去了插值到格点的过程.而客观分析过程则是将离散点分析到格点后再内插到细网格,然后大多利用追踪法生成等值线,也有在这里再使用曲线拟合.

1、三角形算法

a、首先生成delaunay三角形,这一点在我的帖子"delaunay triangulation之丰衣足食“内有源程序,大家可以参考。

b、随后需要在三角形的边上插补等值点。要确定某个三角形的边上是否有等值点,需要进行判断和处理。注意:如果某原始数据点和等值线值相同,将该点改变一个微量。如果一个三角形三顶点的值相同则各边无等值点。如果一个三角形的任意边两端点(A、B〕的Z值(Za、Zb)满足满足(Zd-Za)*(Zd-Zb)<0,其中Zd代表等值线的值,则该边必有等值点,其平面位置是Xd=Xa+(Xb-Xa)*(Zd-Za)/(Zd-Za) ,  Yd=Ya+(Yb-Ya)*(Zd-Za)/(Zb-Za)。每个三角形上不可能三边都有同值的等值点,另一边上必定有同值的等值点。

c、等值点的追踪。

为了能将内插的等值点顺序追踪排列,绘出等值线,还必须找出相互重叠的环形网内所计算的等值点间的平面位置关系。因每个环形网都是由多个三角形组成的,我们先简单分析一下单个三角形中存在等值点的情况。由于不必考虑等值线穿过端点,如果一个三角形的边上存在等值点的话,只可能在某两条边上存在等值点,而不可能三条边上同时都有。也就是说,只要三角形一边上存在等值点,则其余的两条边中必有一边存在等值点。
  根据上面的约定,我们再研究等值线穿过任一环形网中两条及两条以上相邻的径边时,可能出现的几种情形:
  ① 等值线不通过环形网的界边。在这个环形网中,必然所有的径边上都存在等值点,如果这个环形网由非边界点联结而成,内插的等值点就可顺序连接为一条闭合曲线(图5(a));若此环形网由边界点联成,那么这些等值点则连成一条开口曲线(图5(b))。
  ② 等值线通过环形网的界边,且次数不超过两次。这是最常见的一种情形,如图5(c)、5(d)所示。相邻径边上内插的等值点顺序排列,点数至少为两个,其起点为环形网的入口点,终点为环形网的出口点。
  ③ 等值线四次通过环形网的界边。环形网中内插的等值点分为两部分顺序排列,每个部分都包括一个入口点和一个出口点,这个网所在的位置应该是地形的鞍部

由于离散点环形联网是沿同一方向(逆时针)进行的,环形网中相邻径边上内插的等值点所排列的顺序,也相应围绕中心点位逆时针旋转。从对图形的分析中,我们还注意到,如果等值点不是位于边界上的话,那么一个环形网的入口点,必然是另一个环形网的入口点;一个环形网的出口点,也必然是另一个环形网的出口点;而内插入口点(或出口点)的径边的两个端点,就是联结这两个环形网的中心点。利用这个原理,我们就可以成功地设计出等值线的追踪方案,且在追踪等值线时,只需将各环形网中内插的等值点进行单向比较,即入口点对入口点比较,出口点对出口点比较。  联网结束后,凡是没能联成闭合环形网的离散点,即为绘图区域的边界点,而在两个边界点连接的边上内插的等值点,就是开曲线的线头。找到线头后,根据上述原理,就可顺序追踪出各条开曲线的全部等值点。对于闭曲线来说,任一环形网中内插等值点中的起点都可作为线头,按上述方法追踪,直至又回到该点为止。等值线追踪完成后,即可进行曲线的光滑输出。目前,常用的是样条插值。这方面的例子很多,不再详述。

 
(摘自网站:机电之家)
 
2011-10-23 14:25



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-353120-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.448627 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved