您好,欢迎访问三七文档
一、算法的时间复杂性T(n):利用某算法处理一个问题规模为n的输入所需要的时间。空间:为了解求问题的实例而执行的计算步骤所需要额内存空间(或字)数目,不包括用来存储输入的空间。算法空间复杂性不可能超过运行时间的复杂性。元运算:对于任何计算步骤,不管输入数据或执行的算法,它的代价总是以一个时间常量为上界,则称该计算步骤为元运算。基于比较的排序问题的最优算法:我们通常把在O(nlgn)时间内用元素比较法排序的任何算法,称为基于比较的排序问题的最优算法。一般来说,如果可以证明任何一个求解问题A的算法必定是Ω(f(n)),那么我们把在O(f(n))时间内求解任何问题A的任何算法都称为问题A的最优算法。算法设计原则:正确性确定性清晰性。算法的要素:1.待解问题的描述2.算法设计的任务3.算法分析。二、关系运算:指的是用于检验两个几何对象的特定的拓扑空间关系的逻辑方法。两步确定两条线段是否相交:1.快速排斥实验(矩形不相交)2.跨立实验(判断线段P1P2是否和Q1Q2跨立依据是:(P1-Q1)*(Q2-Q1)*(Q2-Q1)*(P2-Q1)=0.)判断点是否在多边形内常用算法:1.射线法(又叫奇偶测试法)2.转角法。线段在多边形内的一个重要条件是线段的两个端点都在多边形内,第二个必要条件是线段和多边形的所有边都不内交。线段在多边形内判断步骤:1.先求出所有和线段相交的多边形的顶点2.然后按照X-Y坐标排序(X坐标小的排在前面,对于X坐标相同的点,Y坐标小的排在前面,这种排序准则也是为了保证水平和垂直情况的判断正确),这样相邻的两个点就是在线段上相邻的两交点,如果任意相邻两点的中点也在多边形内,则该线段一定在多边形内。计算线段或直线与线段的交点:设一条线段为L0=P1P2,另一条线段或直线为L1=Q1Q2,要计算的就是L0和L1的交点:第一步:首先判断L0和L1是否相交2.若L1不平行与Y轴,则交点横坐标为P1的横坐标,代入到L1的直线方程中可以计算出交点纵坐标。第三步:若L1平行于y轴,则第四步:若L0平行于x轴,有2种情况,第五步:若L1平行于x轴,则,第六步:若L1和L0斜率均存在,则。中心点的计算:多边形的中心点(又叫质心或重心)可以通过将多边形分割成为三角形,求取三角形的中心点,然后将三角形的中心点加权求和取得。三点画圆:算法关键是求取圆心和园半径:第一步:求取圆心,第二步:求取半径R,R=((xa-xp)^2+(ya-yp)^2)^1/2。p是圆心。四、矢量线栅格化三种方法:八方向栅格化、全路径栅格化、恒密度栅格化。矢量面格式向栅格面格式转换又称为多边形填充,就是在矢量表示的多边形边界内部的所有栅格点上赋以相应的多边形编码,从而形成栅格数据阵列。方法有:内部点扩散算法(种子,八方向扩散)、射线算法和扫描算法、边界代数算法(积分、拓扑)。栅格数据矢量化有4个基本步骤:1.边界提取2.边界线追踪3.拓扑关系生成4.去除多余点及曲线圆滑。细化算法:栅格数据需要细化,以提取其中轴线,因为:1.中轴线是栅格数据曲线的标准化存储形式2.实现细化是将栅格曲线矢量化的前提3.在有些算法中可以提高计算精度。细化算法可分两大类:第一大类是基于距离变换,首先得到骨架像元,然后跟踪距离变换图中的“山脊线”,并将其作为中轴线;第二类是基于在不破坏栅格拓扑连通性的前提下,按对称的原则删除影像边缘的栅格点。四例:1.用距离变换法搜寻中轴线(减细)2.最大数值计算法(V值4、1)3.经典的细化算法4.边缘跟踪剥皮法.多边形栅格转矢量的双边界搜索算法:基本思想:通过边界提取,将左右多边形信息保存在边界点上,每条边界弧段由两个并行的边界链组成,分别记录该边界弧段的左右多边形编号。具体步骤:1.边界点和结点提取2.边界线搜索与左右多边形信息记录3.多余点去除。多边形栅格转矢量的单边界搜索算法:单边界搜索算法时通过对传统的区域跟踪算法进行改进而形成的,传统区域跟踪算法中,对区域的描述由两部分组成:区域外轮廓和内部孔洞。单边界搜索算法流程:1.跟踪、搜索第一层所有的区域并记录外轮廓和内部孔洞信息2.根据跟踪到的孔洞信息找出下一层中未跟踪过的区域的外轮廓跟踪起始点(即找出一个新区域)3.跟踪找到的新区域并记录其外轮廓和内部孔洞信息4.重复23步,直到该层所有区域都已被跟踪完毕5重复2到3步,直到整幅图像内所有区域都已被跟踪完毕。五、道格拉斯-普克法优点是具有最小的线性位移,压缩效果占优,缺点是需对整条曲线完成数字化后方能进行压缩,且计算工作量较大。光栏法原理:它按照预先定义的一个扇形(“喇叭口”),根据曲线上各节点是在扇形外还是在扇形内,决定节点是保留还是舍去。其优点是光栏法不仅算法严密,能按给定阈值保留曲线特征点,并按时处理,运算量小,占用内存少。链式编码:多边形边界可定义为:由某一原点开始并按某些基本方向确定的单位矢量链。(东0东南1东北7)游程长度编码:游程指相邻同值网格的数量,游程长度编码结构是逐行将相邻同值的网格合并,并记录合并后网格的值及合并网格的长度,其目的是压缩栅格数据量,消除数据间的冗余。块式编码:块式编码是将游程长度编码扩大到二维的情况,把多边形范围划分成由像元组成的正方形,然后对各个正方形进行编码。差分映射法:就是选择某一参照值对有关栅格的属性值进行求差运算,根据差值得到一个新的栅格数据层。(分行选取和全区选取)拓扑关系左转算法描述如下:1.顺序取一个结点作为起始结点,取完为止;取过该结点的方位角最小的未使用过的或仅使用一次,且使用过的方向与本次相反的弧段作为起始弧段。2.取这条弧段的另一个结点,找这个结点关联的弧段集合中的本条弧段的下一条弧段,如果本条弧段是最后一条弧段,则取弧段集合的第一条弧段,作为下一条弧段。3.判断是否回到起点,如果是,则形成了一个多边形,记录下它,并且根据弧段的方向,设置组成该多边形的左右多边形信息;否则转2。4.取起始点上开始的,刚才所形成多边形的最后一条边作为新的起始弧段,转2;若这条弧段已经使用过两次,即形成了两个多边形,转1。岛的判断问题算法如下:1.计算所有多边形的面积2.分别对面积为正的多边形和面积为负的多边形排序,分别形成正多边形和负多边形集合。3.如果负多边形集合的个数为1,结束程序;否则,从面积为正的多边形集合中,顺序取出一个多边形,如果正多边形已经都被访问过,则程序结束。4.依次从负多边形集合中取出负多边形,判断当前取出的正多边形是否包含该多边形,如果包含,就将该负多边形加入当前取出的正多边形中,形成复杂多边形,设置负多边形的组成弧段的拓扑信息,并从负多边形集合中删除该负多边形。当所有负多边形都被访问一遍后转3.六、直线方程的所有形式:P(t)=P0+tVl=P0+t(P1-P0)=(1-t)P0+tP1。(y0-y1)x+(x1-x0)y+(x0y1-x1y0)=0。P(t)=(x0+tcosΘ,y0+tsinΘ)点到直线距离计算公式:d(P,L)=((y0-y1)x+(x1-x0)y+(x0y1-x1y0))/((x1-x0)^2+(y1-y0)^2)^1/2.三角形面积计算公式:A=1/2*bh,A=1/2*absinΘ,A=(s(s-a)(s-b)(s-c))1/2,s=1/2*(a+b+c),A=1/4*(4a2b2-(a2+b2-c2)2)1/2,A=b2/2(cotΘ+cotβ)。A=1/2|v*w|=1/2|(v1-v0)(v2-v0)|,2A=(x1-x0)(y2-y0)-(x2-x0)(y1-y0)。四边形面积计算公式:A=((s-a)(s-b)(s-c)(s-d))1/2,A(v0v1v2v3)=|(v1-v0)*(v3-v0)|,A=(x1-x0)(y3-y0)-(x3-x0)(y1-y0),A=1/2|(v2-v0)*(v3-v1)|,2A=(x2-x0)(y3-y1)-(x3-x1)(y2-y0)。任意二维平面多边形面积计算方法与公式:A多边形=ΣA(Δi),Δi=ΔPViVi+1,注意:对于一个逆时针多边形,当点P在边ViVi+1的左边,则Δi的面积是正的;相反,当点P在边ViVi+1的右边,并且位于多边形外部,则Δi的面积是负的。如果是一个顺时针多边形,则符号相反,并且内部的三角形面积为负的。七、空间索引:就是指依据空间对象的位置和形状或空间对象之间的某种空间关系,按一定的顺序排列的一种数据结构,其中包括空间对象的概要信息。B树的定义:一个m阶的B树,或为空树,或是为满足下列特征的m叉树。(1)树中每个结点至多有m棵子树;(2)若根结点不是叶子结点,则至少有两颗子树;(3)除根之外的所有非终端结点至少有[m/2]棵子树;(4)所有的非叶结点中包含下列信息数据:(A0,K1,A1,D1,K2,A2,D2,...,Kn,An,Dn)式中Ki(i=1,2…n)为关键字,且KiKi+1(i=0,…n)为指向子树根节点的指针,且指针Ai-1所指的子树中所有结点的关键字均小于Ki(i=1,…n);An所指的子树中所有结点的关键字均大于Kn;Dn为数据指针,指向关键字Kn所在的数据记录。K,A,D称为结点的一个元素。(5)所有的叶子结点都出现在同一层次上,并且不带信息(可以看作是外部结点查询失败的结点,实际上这些结点不存在,指向这些结点的指针为空)。插入算法:设将元素K,A,D插入B树中。(1)首先在树中查找K,若查找到,算法结束(假定B树中不容许有相同的关键字存在)。若没有查到,设最后查到的结点为N。将关键字K插入结点N中,若结点N的元素的个数小于等于m-1,将A指向叶结点,插入结束,若结点N的元素关键字的个数为m,则需分裂结点N。(2)设插入关键字K后的结点情况如下:(A0,K1,A1,D1,K2,A2,D2….Km,Am,Dm)创建一新结点L,将N中的第[m/2+1]以及其后的所有元素,共m-[m/2]个元素移入新结点L中。再将元素K[m/2],A[m/2],D[m/2]移出N,插入结点N的父结点。N的父结点还可能需要分裂,最坏的情况是分裂一直延续到根结点,最后产生新的根结点,树高增加1。当插入操作引起了s个结点的分裂时,磁盘访问的次数为h(读取搜索路径上的结点)+2s(回写两个分裂出的新结点)+1(回写新的根结点或插入后没有导致分裂的结点)。因此,所需要的磁盘访问次数是h+2s+1,最多可达3h+1。R树的定义:设M为结点中单元的最大数目,m(1=m=M/2)为非根结点中单元个数的下限。(1)每个叶子结点包含的单元个数介于m与M之间,除非它同时是根结点。(2)每个叶子结点中的单元(I,SpatialObjectID)中,I是包含该n维空间对象的MBR,SpatialObjectID是该空间对象的ID。(3)每个非叶子结点的子结点树介于m到M之间,除非它同时是跟结点。(4)每个非叶子的结点的单元(I,PointerToChild)中,I是包含子结点的MBR,PointerToChild是指向子结点的指针。通过该指针能访问到子结点。(5)根结点最少有两个字结点,除非它同时是叶子的结点。(6)所有的叶子结点都处于树的同一层上。插入算法:新空间对象的插入操作:(1)为新的空间对象,寻找一个合适的叶子结点(2)将新的空间对象记录到叶子的结点中,(3)调整树的结构(4)生成新的根结点。选择合适的叶子结点:(1)初始化(2)判断是否为叶子结点(3)选择合适的子树。调整树的结构:(1)初始化(2)判断是否是根结点(3)调整父结点相应单元的I(4)根据需要进一步分裂父结点。常规四叉树缺点:所占的内外存空间比较大,原因在于它不仅要记录每个结点值,还需记录结点的一个前趋结点及四个后继结点,以反映结点之间的联系。对栅格数据进行运算时,还要作遍历树结点的运算。这样就增加了操作的复杂性。线性四叉树的基本思想和优缺点:线性四叉树不像常规四叉树那样存储树中各个结点及其相互间关系,而是通过编码四叉树的叶结点来表示数据块的层次和空间关系。叶结点都具有一个反
本文标题:GIS算法基础重点
链接地址:https://www.777doc.com/doc-4252426 .html