- 1、本文档共22页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
计算几何常用算法概览
本站原创:怒火之袍
一、引言
??? 计算机的出现使得很多原本十分繁琐的工作得以大幅度简化,但是也有一些在人们直观看来很容易的问题却需要拿出一套并不简单的通用解决方案,比如几何问题。作为计算机科学的一个分支,计算几何主要研究解决几何问题的算法。在现代工程和数学领域,计算几何在图形学、机器人技术、超大规模集成电路设计和统计等诸多领域有着十分重要的应用。在本文中,我们将对计算几何常用的基本算法做一个全面的介绍,希望对您了解并应用计算几何的知识解决问题起到帮助。
二、目录
??? 本文整理的计算几何基本概念和常用算法包括如下内容:
??? 矢量的概念
???三、算法介绍
??? 矢量的概念:
??? 如果一条线段的端点是有次序之分的,我们把这种线段成为有向线段(directed segment)。如果有向线段p1p2的起点p1在坐标原点,我们可以把它称为矢量(vector)p2。
??? 矢量加减法:
??? 设二维矢量P = ( x1,y1 ) ,Q = ( x2 , y2 ) ,则矢量加法定义为: P + Q = ( x1 + x2 , y1 + y2 ),同样的,矢量减法定义为: P - Q = ( x1 - x2 , y1 - y2 )。显然有性质 P + Q = Q + P , P - Q = - ( Q - P )。
??? 矢量叉积:
??? 计算矢量叉积是与直线和线段相关算法的核心部分。设矢量P = (x1,y1) ,Q = (x2,y2),则矢量叉积定义为由(0,0)、p1、p2和p1+p2所组成的平行四边形的带符号的面积,即:P × Q = x1*y2 - x2*y1,其结果是一个标量。显然有性质 P × Q = - ( Q × P ) 和 P × ( - Q ) = - ( P × Q )。一般在不加说明的情况下,本文下述算法中所有的点都看作矢量,两点的加减法就是矢量相加减,而点的乘法则看作矢量叉积。
??? 叉积的一个非常重要性质是可以通过它的符号判断两矢量相互之间的顺逆时针关系:
??? 若 P × Q 0 , 则P在Q的顺时针方向。??? 若 P × Q 0 , 则P在Q的逆时针方向。??? 若 P × Q = 0 , 则P与Q共线,但可能同向也可能反向。
??? 折线段的拐向判断:
??? 折线段的拐向判断方法可以直接由矢量叉积的性质推出。对于有公共端点的线段p0p1和p1p2,通过计算(p2 - p0) × (p1 - p0)的符号便可以确定折线段的拐向:
??? 若(p2 - p0) × (p1 - p0) 0,则p0p1在p1点拐向右侧后得到p1p2。
??? 若(p2 - p0) × (p1 - p0) 0,则p0p1在p1点拐向左侧后得到p1p2。
??? 若(p2 - p0) × (p1 - p0) = 0,则p0、p1、p2三点共线。
??? 具体情况可参照下图:
???
??? 判断点是否在线段上:
??? 设点为Q,线段为P1P2 ,判断点Q在该线段上的依据是:( Q - P1 ) × ( P2 - P1 ) = 0 且 Q 在以 P1,P2为对角顶点的矩形内。前者保证Q点在直线P1P2上,后者是保证Q点不在线段P1P2的延长线或反向延长线上,对于这一步骤的判断可以用以下过程实现:
??? ON-SEGMENT(pi,pj,pk)
??? if min(xi,xj)=xk=max(xi,xj) and min(yi,yj)=yk=max(yi,yj)
??????? then return true;
??? else return false;
??? 特别要注意的是,由于需要考虑水平线段和垂直线段两种特殊情况,min(xi,xj)=xk=max(xi,xj)和min(yi,yj)=yk=max(yi,yj)两个条件必须同时满足才能返回真值。
??? 判断两线段是否相交:
??? 我们分两步确定两条线段是否相交:
??? (1)快速排斥试验
??? 设以线段 P1P2 为对角线的矩形为R, 设以线段 Q1Q2 为对角线的矩形为T,如果R和T不相交,显然两线段不会相交。
??? (2)跨立试验??? 如果两线段相交,则两线段必然相互跨立对方。若P1P2跨立Q1Q2 ,则矢量 ( P1 - Q1 ) 和( P2 - Q1 )位于矢量( Q2 - Q1 ) 的两侧,即( P1 - Q1 ) × ( Q2 - Q1 ) * ( P2 - Q1 ) × ( Q2 - Q1 ) 0。上式可改写成( P1 - Q1 ) × ( Q2 - Q1 ) * ( Q2 - Q1 ) × ( P2 - Q1 ) 0。当 ( P1 - Q1 ) × ( Q2 -
您可能关注的文档
- 机械制造工艺学复习解决方案.doc
- 机械制造技术基础解决方案.doc
- 鸡传染性支气管炎病毒的分离与鉴定解决方案.doc
- 基本初等函数专项训练(含)经典题解决方案.doc
- 基本群的解决方案.doc
- 基础护理学及(各章)解决方案.doc
- 基础会计学第次作业解决方案.doc
- 基础会计学课后习题—全部(给学生)定稿解决方案.doc
- 基础会计学模拟解决方案.doc
- 基础教程变电箱模型制作流程解决方案.doc
- 2025年成都市玩偶生产荧光涂鸦互动玩偶开发可行性研究报告.docx
- 2025年成都市海绵生产用于体育馆室外运动场地透水改造可行性研究报告.docx
- 2025年天津市体操鞋企业团建运动应用报告.docx
- 2025年上海市溶洞极限运动(速降)场地开发可行性研究报告.docx
- 2025年上海市涵洞工程施工技术应用可行性研究报告.docx
- 2025年上海市体育场馆设施扎带安全防护可行性研究报告.docx
- 2025年上海市牦牛育肥产业园区建设可行性研究报告.docx
- 2025年旅拍宠物陪伴拍摄项目可行性研究报告.docx
- 2025年上海市进口食品节庆主题快闪店可行性研究报告.docx
- 2025年上海市洗选厂尾矿综合利用产业化可行性研究报告.docx
文档评论(0)