闲聊叉积在计算几何中一些作用

2023-11-02 16:30

本文主要是介绍闲聊叉积在计算几何中一些作用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

定义

两个向量的叉积写作a×b,可以定义为

a×b=absinθn

其中θ表示a和b之间的角度(0°≤θ≤180°)。它位于这两个矢量所定义的平面上。而n是一个与a、b所在平面均垂直的单位矢量。矢量叉积是计算几何算法的核心部分,具有重要的几何意义。

一、计算多边形面积

设多边形有n个顶点V0(X0, Y0), V1(X1, Y1)... Vn-1(Xn-1, Yn-1),从原点O(0,0)与每条边做三角形,计算的面积和就是多边形面积。三角形面积可以用叉积计算,比如OV0V1面积为:

S0=0.5*OV0×OV1=0.5*(X0Y1-X1Y0)

于是多边形面积总和为:

S= 0.5*(X0Y1-X1Y0 + X1Y2-X2Y1 +… + Xn-1Y0-X0Yn-1)

  = 0.5*( X0Y1-X1Y0+X0Y0-X1Y1 + X1Y2-X2Y1+X1Y1-X2Y2 +… Xn-1Y0-X0Yn-1+Xn-1Yn-1-X0Y0)

  = 0.5*(Yi+Yi+1)(Xi-Xi+1)  i=0...n-1

二、判断两线段是否相交

判断线段是否相交一般分两步进行:

1. 快速排斥

设有线段P1P2和Q1Q2,以线段 P1P2 为对角线的矩形为R, 以线段 Q1Q2 为对角线的矩形为T,如果R和T不相交,显然两线段不会相交,否则进入第二步。

2. 跨立实验

如果两线段相交,那么两线段必然相互跨立对方。即

P1, P2分别在Q1Q2两边 :

(P1-Q1)×(Q2-Q1)*(P2-Q1)×(Q2-Q1)<=0

Q1, Q2分别在P1P2两边:

(Q1-P1)×(P2-P1)*(Q2-P1)×(P2-P1) <=0

上面跨立实验需要4次叉积和两次乘法运算,可以这样改进:

如下图,Q1Q2在P1P2左边,

绘图3

此时(Q1-Q2)×(P2-P1)与(P1-Q1)×(Q1-Q2)异号,

当Q1Q2向右移动后,如图所示,

(Q1-Q2)×(P2-P1)与(P1-Q1)×(Q1-Q2)同号,而且(P1-Q1)×(Q1-Q2)/(Q1-Q2)×(P2-P1),刚好等于|P1O|/|P1P2|,由此关系还可以计算交点的位置。

Q1Q2继续右移,如图所示:

交点超出P2,(P1-Q1)×(Q1-Q2)/(Q1-Q2)×(P2-P1)>1

因此,若P1 , P2跨立在Q1Q2,则有

(P1-Q1)×(Q1-Q2)/(Q1-Q2)×(P2-P1)在[0, 1]范围内。

同理,若Q1, Q2跨立P1P2,则有

(P2-P1)×(P1-Q1)/(Q1-Q2)×(P2-P1)在[0, 1]范围内。

这样只需要3次叉积运算就能算出线段是否相交,而且还可以顺便得到相交点的位置!

 

参考:

http://zh.wikipedia.org/wiki/%E5%8F%89%E7%A7%AF

http://dev.gameres.com/Program/Abstract/Geometry.htm

转载于:https://www.cnblogs.com/coderkian/p/3535303.html

这篇关于闲聊叉积在计算几何中一些作用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

JAVA transient 关键字作用详解

《JAVAtransient关键字作用详解》Java的transient关键字用于修饰成员变量,使其不参与序列化过程,通过自定义序列化方法,可以手动控制transient变量的序列化行为,本文给大... 目录一、transient关键字作用二、原理详解三、典型使用场景四、代码示例五、注意事项六、与 stat

Spring Boot/Spring MVC核心注解的作用详解

《SpringBoot/SpringMVC核心注解的作用详解》本文详细介绍了SpringBoot和SpringMVC中最常用的15个核心注解,涵盖了请求路由映射、参数绑定、RESTfulAPI、... 目录一、Spring/Spring MVC注解的核心作用二、请求映射与RESTful API注解系列2.1

C#中的sealed修饰符的作用详解

《C#中的sealed修饰符的作用详解》在C#中,sealed修饰符的作用是“密封”用来阻止类被继承,或者阻止方法/属性在派生类中被重写,接下来通过本文给大家介绍C#中的sealed修饰符的作用详解,... 目录✅ 1.sealed用于类(class)作用:示例:✅ 2.sealed用于方法或属性(必须与

Spring的基础事务注解@Transactional作用解读

《Spring的基础事务注解@Transactional作用解读》文章介绍了Spring框架中的事务管理,核心注解@Transactional用于声明事务,支持传播机制、隔离级别等配置,结合@Tran... 目录一、事务管理基础1.1 Spring事务的核心注解1.2 注解属性详解1.3 实现原理二、事务事

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Python文本相似度计算的方法大全

《Python文本相似度计算的方法大全》文本相似度是指两个文本在内容、结构或语义上的相近程度,通常用0到1之间的数值表示,0表示完全不同,1表示完全相同,本文将深入解析多种文本相似度计算方法,帮助您选... 目录前言什么是文本相似度?1. Levenshtein 距离(编辑距离)核心公式实现示例2. Jac

Python中经纬度距离计算的实现方式

《Python中经纬度距离计算的实现方式》文章介绍Python中计算经纬度距离的方法及中国加密坐标系转换工具,主要方法包括geopy(Vincenty/Karney)、Haversine、pyproj... 目录一、基本方法1. 使用geopy库(推荐)2. 手动实现 Haversine 公式3. 使用py

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断