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

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

相关文章

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

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

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

Java 继承和多态的作用及好处

《Java继承和多态的作用及好处》文章讲解Java继承与多态的概念、语法及应用,继承通过extends复用父类成员,减少冗余;多态实现方法重写与向上转型,提升灵活性与代码复用性,动态绑定降低圈复杂度... 目录1. 继承1.1 什么是继承1.2 继承的作用和好处1.3 继承的语法1.4 子类访问父类里面的成

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

SpringBoot 中 CommandLineRunner的作用示例详解

《SpringBoot中CommandLineRunner的作用示例详解》SpringBoot提供的一种简单的实现方案就是添加一个model并实现CommandLineRunner接口,实现功能的... 目录1、CommandLineRunnerSpringBoot中CommandLineRunner的作用

Java计算经纬度距离的示例代码

《Java计算经纬度距离的示例代码》在Java中计算两个经纬度之间的距离,可以使用多种方法(代码示例均返回米为单位),文中整理了常用的5种方法,感兴趣的小伙伴可以了解一下... 目录1. Haversine公式(中等精度,推荐通用场景)2. 球面余弦定理(简单但精度较低)3. Vincenty公式(高精度,

$在R语言中的作用示例小结

《$在R语言中的作用示例小结》在R语言中,$是一个非常重要的操作符,主要用于访问对象的成员或组件,它的用途非常广泛,不仅限于数据框(dataframe),还可以用于列表(list)、环境(enviro... 目录1. 访问数据框(data frame)中的列2. 访问列表(list)中的元素3. 访问jav

Kotlin运算符重载函数及作用场景

《Kotlin运算符重载函数及作用场景》在Kotlin里,运算符重载函数允许为自定义类型重新定义现有的运算符(如+-…)行为,从而让自定义类型能像内置类型那样使用运算符,本文给大家介绍Kotlin运算... 目录基本语法作用场景类对象数据类型接口注意事项在 Kotlin 里,运算符重载函数允许为自定义类型重

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小