空间曲线的参数方程

news2024/12/24 20:45:15

空间曲线的参数方程

二维直线

经过一点 P ( x 0 , y 0 ) P(x_0,y_0) P(x0y0)的方向向量为 n ( c o s θ , s i n θ ) n(cos\theta,sin\theta) n(cosθsinθ)的直线参数方程为:
[ x y ] = [ x 0 y 0 ] + t [ c o s θ s i n θ ] t ∈ [ 0 , 2 π ) \begin{bmatrix} x\\ y \end{bmatrix} =\begin{bmatrix} x_0\\ y_0 \end{bmatrix} +t\begin{bmatrix} cos\theta\\ sin\theta \end{bmatrix} \hspace{2em} t\in [0,2\pi) [xy]=[x0y0]+t[cosθsinθ]t[02π)

三维直线

经过一点 P ( x 0 , y 0 , z 0 ) P(x_0,y_0,z_0) P(x0y0z0)的单位方向向量为 n ( i , j , k ) n(i,j,k) n(i,j,k)的直线参数方程为:
[ x y z ] = [ x 0 y 0 z 0 ] + t [ i j k ] t ∈ [ 0 , 2 π ) \begin{bmatrix} x\\ y\\ z \end{bmatrix} =\begin{bmatrix} x_0\\ y_0\\ z_0 \end{bmatrix} +t\begin{bmatrix} i\\ j\\ k \end{bmatrix} \hspace{2em} t\in [0,2\pi) xyz = x0y0z0 +t ijk t[02π)

二维圆

经过圆心 P ( x 0 , y 0 ) P(x_0,y_0) P(x0y0),半径为 r r r,的圆参数方程为:

[ x y ] = [ x 0 y 0 ] + r [ c o s θ s i n θ ] θ ∈ [ 0 , 2 π ) \begin{bmatrix} x\\ y \end{bmatrix} =\begin{bmatrix} x_0\\ y_0 \end{bmatrix} +r\begin{bmatrix} cos\theta\\ sin\theta \end{bmatrix} \hspace{2em} \theta\in [0,2\pi) [xy]=[x0y0]+r[cosθsinθ]θ[02π)

三维圆

经过圆心 P ( x 0 , y 0 , z 0 ) P(x_0,y_0,z_0) P(x0y0z0),半径为 r r r,且该圆所在的平面正交的两个单位向量 e 1 ⃗ ( a x , a y , a z ) , e 2 ⃗ ( b x , b y , b z ) \vec{e_1}(a_x,a_y,a_z),\vec{e_2}(b_x,b_y,b_z) e1 (ax,ay,az),e2 (bx,by,bz)的圆参数方程为:

[ x y z ] = [ x 0 y 0 z 0 ] + r c o s θ [ a x a y a z ] + r s i n θ [ b x b y b z ] θ ∈ [ 0 , 2 π ) \begin{bmatrix} x\\ y\\ z \end{bmatrix}= \begin{bmatrix} x_0\\ y_0\\ z_0 \end{bmatrix} +rcos\theta\begin{bmatrix} a_x\\ a_y\\ a_z \end{bmatrix} +rsin\theta\begin{bmatrix} b_x\\ b_y\\ b_z \end{bmatrix} \hspace{2em} \theta\in [0,2\pi) xyz = x0y0z0 +rcosθ axayaz +rsinθ bxbybz θ[02π)

特殊情况下,当 e 1 ⃗ ( a x , a y , a z ) , e 2 ⃗ ( b x , b y , b z ) \vec{e_1}(a_x,a_y,a_z),\vec{e_2}(b_x,b_y,b_z) e1 (ax,ay,az),e2 (bx,by,bz)分别为 e 1 ⃗ ( 1 , 0 , 0 ) , e 2 ⃗ ( 0 , 1 , 0 ) \vec{e_1}(1,0,0),\vec{e_2}(0,1,0) e1 (1,0,0),e2 (0,1,0)时,公式(4) 简化为:

[ x y z ] = [ x 0 y 0 z 0 ] + r [ c o s θ s i n θ 0 ] θ ∈ [ 0 , 2 π ) \begin{bmatrix} x\\ y\\ z \end{bmatrix} =\begin{bmatrix} x_0\\ y_0\\ z_0 \end{bmatrix} +r\begin{bmatrix} cos \theta \\ sin \theta \\ 0 \end{bmatrix} \hspace{2em} \theta \in [0,2 \pi) xyz = x0y0z0 +r cosθsinθ0 θ[02π)

任意平面内的圆,可以先计算基准坐标系中的圆然后通过坐标变换 ,将问题转化为,转换为所求平面内的圆。

图形化表示:

请添加图片描述

请添加图片描述

如何快速求解 e 1 ⃗ ( a x , a y , a z ) , e 2 ⃗ ( b x , b y , b z ) \vec{e_1}(a_x,a_y,a_z),\vec{e_2}(b_x,b_y,b_z) e1 (ax,ay,az),e2 (bx,by,bz)

  1. 求解 e 1 ⃗ \vec{e_1} e1 ,将圆所在平面的法向量与坐标向量 i ⃗ \vec{i} i 叉乘,然后单位化即可得到,如果叉乘结果为0 ,就叉乘 j ⃗ \vec{j} j ,再者就叉乘 k ⃗ \vec{k} k
  2. 求解 e 2 ⃗ \vec{e_2} e2 ,就将法向量与 e 1 ⃗ \vec{e_1} e1 叉乘即可。

对应的python代码:

\sum_{s}^{}  {\textstyle \sum_{}^{}} # 对应的版本matplotlib                3.7.1           py311h06a4308_1
from matplotlib import pyplot as plt
import numpy as np

normal_direction = np.array([1, 1, 1])
radius = 1
center = np.array([1, 1, 1])
pi = 3.1415926
theta = np.array([])

for i in range(100):
    theta = np.append(theta, 2.0 * pi * i / 100)

theta = np.array(theta)
e1 = np.cross(normal_direction, [0, 1, 0])
if np.linalg.norm(e1) < 1e-10:
    e1 = np.cross(normal_direction, [0, 1, 0])

e2 = np.cross(normal_direction, e1)

# 单位化
e1_norm = e1 / np.linalg.norm(e1)
e2_norm = e2 / np.linalg.norm(e2)
size = np.size(theta)

x0 = center[0] * np.ones(size)
y0 = center[1] * np.ones(size)
z0 = center[2] * np.ones(size)

x = x0 + radius * e1[0] * np.cos(theta) + radius * e2[0] * np.sin(theta)
y = y0 + radius * e1[1] * np.cos(theta) + radius * e2[1] * np.sin(theta)
z = z0 + radius * e1[2] * np.cos(theta) + radius * e2[2] * np.sin(theta)

# 建立画布
fig = plt.figure()
ax = fig.add_subplot(projection='3d')
ax.set_xlim(-2, 6)
ax.set_ylim(-2, 6)
ax.set_zlim(-2, 6)

ax.plot3D(x, y, z, 'r')
plt.show()

print("YES PF!")

请添加图片描述

对应的MATLAB代码

Figure_1normal=[1 1 1]; %法向量n
radius=1; %圆的半径为1
center=[1 1 1]; %圆心的坐标
theta=(0:2*pi/100:2*pi)'; %theta角从0到2*pi

e1=cross(normal,[1 0 0]); %n与i叉乘,求取a向量
if ~any(e1) %如果a为零向量,将n与j叉乘
    e1=cross(normal,[0 1 0]);
end

e2=cross(normal,e1); %求取b向量
e1=e1/norm(e1); %单位化a向量
e2=e2/norm(e2); %单位化b向量

x0=center(1)*ones(size(theta,1),1);
y0=center(2)*ones(size(theta,1),1);
z0=center(3)*ones(size(theta,1),1);

x=x0+radius*e1(1)*cos(theta)+radius*e2(1)*sin(theta);%圆上各点的x坐标
y=y0+radius*e1(2)*cos(theta)+radius*e2(2)*sin(theta);%圆上各点的y坐标
z=z0+radius*e1(3)*cos(theta)+radius*e2(3)*sin(theta);%圆上各点的z坐标

plot3(x,y,z)
xlabel('x轴')
ylabel('y轴')
zlabel('z轴')

三维椭圆

在实际工程化的应用的时候,往往不是圆,而是退化成椭圆,甚至退化成一条直线。

工程中更多是使用椭圆模型,通过检测到的点来确定椭圆的参数,最后确定椭圆的中心点和方向向量。

三维椭圆的参数方程易知:
[ x y z ] = [ x 0 y 0 z 0 ] + a c o s θ [ a x a y a z ] + b s i n θ [ b x b y b z ] θ ∈ [ 0 , 2 π ) \begin{bmatrix} x\\ y\\ z \end{bmatrix} =\begin{bmatrix} x_0\\ y_0\\ z_0 \end{bmatrix} +acos\theta\begin{bmatrix} a_x\\ a_y\\ a_z \end{bmatrix} + bsin\theta\begin{bmatrix} b_x\\ b_y\\ b_z \end{bmatrix} \hspace{2em} \theta\in [0,2\pi) xyz = x0y0z0 +acosθ axayaz +bsinθ bxbybz θ[02π)
其中 a , b a,b ab分别表示为椭圆的长半轴长度,短半轴长度 。其余跟圆类似不作具体说明。

椭圆一般化方程为:
c 1 x 2 + c 2 x y + c 3 y 2 + c 4 x + c 5 y + c 6 = 0 c_1x^2+c_2xy+c_3y^2+c_4x+c_5y+c_6 = 0 c1x2+c2xy+c3y2+c4x+c5y+c6=0
可以看到至少使用五个不同点可以确定这六个参数。

一般情况是点的个数远超过5个,处理步骤为:

  1. 首先使用RANSAC筛选异常点

  2. 构建误差 d i = c 1 x 2 + c 2 x y + c 3 y 2 + c 4 x + c 5 y + c 6 d_i = c_1x^2+c_2xy+c_3y^2+c_4x+c_5y+c_6 di=c1x2+c2xy+c3y2+c4x+c5y+c6

  3. 构建代价函数,使用最小二乘求解// 或者SVD分解
    c i = a r g m i n Σ d j 2 s , t { ∑ i = 1 6 c i 2 = 1 i ∈ [ 1 , 6 ] , j ∈ [ 1 , n ] {c_i} = argmin\Sigma d_j^2 \hspace{2em} s,t \left\{\begin{matrix} \hspace{1em} \sum_{i=1}^{6}c_i^2 = 1 \\ \hspace{1em} i\in[1,6], \\ \hspace{1em}j\in [1,n] \end{matrix}\right. ci=argminΣdj2s,t i=16ci2=1i[1,6],j[1,n]

  4. 假设获得 c i c_i ci ,求解对应的圆心和法向量

    使用二次型构造,对称矩阵,进行分解,则特征值满足:
    λ 1 ≥ λ 2 > 0 > λ 3 \lambda_1 \ge\lambda_2>0>\lambda_3 λ1λ2>0>λ3
    如果不满足,改变构造的对称矩阵的符号,重新求解对特征值

    这里直接给出结论:

    H H H为分解矩阵后的特征向量组成的正交矩阵,法向量 n ⃗ \vec{n} n ,和中心点 P P P为:
    c o s 2 φ = λ 2 − λ 3 λ 1 − λ 3 n ⃗ = ± H [ − s i n φ 0 c o s φ ] P = ± H [ − λ 3 / λ 1 s i n φ 0 − λ 1 / λ 3 c o s φ ] cos^2\varphi = \frac{\lambda_2-\lambda_3}{\lambda_1-\lambda_3} \\ \\ \vec{n} = \pm H\begin{bmatrix} -sin\varphi \\ 0 \\ cos\varphi \end{bmatrix} \\ \\ P=\pm H \begin{bmatrix} -\sqrt{\lambda_3/\lambda_1}sin\varphi \\ 0 \\ \sqrt{-\lambda_1/\lambda_3}cos\varphi \end{bmatrix} cos2φ=λ1λ3λ2λ3n =±H sinφ0cosφ P=±H λ3/λ1 sinφ0λ1/λ3 cosφ

参考链接:

  1. 空间曲线参数方程
  2. 空间圆的方程

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/975046.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何创建一个自己的sphinx文档网站

文章目录 前言一、操作步骤1.安装anaconda2.启动python3.8环境3.安装Sphinx4.创建文件夹5.初始化环境6. 编译7.文件夹搭查看8.搭建nginx查看8. 更换主题9.错误修复10.这里提供两个模板1.Demo_md2.Demo_rst前言 最近看到公司的文档中心,突然想起,为什么不为自己创建一个文档中…

maven依赖,继承

依赖的范围 compile引入的依赖 对main目录下的代码有没有效&#xff0c;main目录下的代码能不能用compile引入的依赖中的类等 以test引入的依赖&#xff0c;在main中是否可以使用 provided&#xff08;已提供&#xff09;&#xff0c;有了就不要带到服务器上&#xff0c;打包…

OLED透明屏原彩优势和特点解析:开创显示技术新时代

OLED透明屏 原彩作为一项领先的显示技术&#xff0c;正以其卓越的性能和创新的设计特点引起广泛关注。 本文将通过深入探讨OLED透明屏 原彩的优势和特点、应用领域、技术发展以及未来前景等方面内容&#xff0c;并结合具体数据、报告和行业动态&#xff0c;为读者提供专业可信…

Dubbo 接口测试原理及多种方法实践总结

1、什么是 Dubbo&#xff1f; Dubbo 最开始是应用于淘宝网&#xff0c;由阿里巴巴开源的一款优秀的高性能服务框架&#xff0c;由 Java 开发&#xff0c;后来贡献给了 Apache 开源基金会组织。 下面以官网的一个说明来了解一下架构的演变过程&#xff0c;从而了解 Dubbo 的诞…

ClickHouse进阶(八):Clickhouse数据查询-2- Join子句

进入正文前&#xff0c;感谢宝子们订阅专题、点赞、评论、收藏&#xff01;关注IT贫道&#xff0c;获取高质量博客内容&#xff01; &#x1f3e1;个人主页&#xff1a;含各种IT体系技术,IT贫道_Apache Doris,大数据OLAP体系技术栈,Kerberos安全认证-CSDN博客 &#x1f4cc;订阅…

Unity3D开发流程及注意事项

使用Unity3D开发游戏需要遵循一定的流程和注意事项&#xff0c;以确保项目的顺利进行并获得良好的结果。以下是一般的游戏开发流程以及一些注意事项&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流合作。 游…

【笔记】软件测试的艺术

软件测试的心理学和经济学 测试是为发现错误而执行程序的过程&#xff0c;所以它是一个破坏性的过程&#xff0c;测试是一个“施虐”的过程。 软件测试的10大原则 1、测试用例需要对预期输出的结果有明确的定义 做这件事的前提是能够提前知晓需求和效果图&#xff0c;如果不…

测评补单成为亚马逊、速卖通等跨境电商趋势:解析需求背后的原因

今天就不分享测评技术知识点了&#xff0c;来聊一聊如今做跨境电商为什么对测评补单有这么大的需求。 如今在跨境电商行业&#xff0c;测评补单的需求日益增长&#xff0c;尽管平台一直对其进行禁止。这主要是出于以下几方面的原因&#xff0c;使得测评越来越成为一种趋势&…

方案展示 | RK3588开发板Linux双摄同显方案

iTOP-RK3588开发板使用手册更新&#xff0c;后续资料会不断更新&#xff0c;不断完善&#xff0c;帮助用户快速入门&#xff0c;大大提升研发速度。 RK3588开发板载4路MIPI CAMERA摄像头接口、MIPI CSI DPHY的4.5Gbps、2.5Gops的MIPI CSI CPHY&#xff0c;四路同时输入&#xf…

每天一个工业通信协议(2)2023.8.28 (CAN协议)

文章目录 参考资料1.CAN协议介绍2.CAN的特点3.CAN的通信单元始终处于错误的三种状态之一4.CAN协议的基本概念5.CAN协议的两种ISO标准的不同6.CAN协议6.1 帧的种类6.2 数据帧6.3 遥控帧6.4 错误帧6.5 过载帧参考资料 瑞萨电子《CAN入门书》 1.CAN协议介绍 答: CAN 是 Contro…

编程学习的方向与赛道的选择没有最优解的

听人劝、吃饱饭,奉劝各位小伙伴,不要订阅该文所属专栏。 作者:不渴望力量的哈士奇(哈哥),十余年工作经验, 跨域学习者,从事过全栈研发、产品经理等工作,现任研发部门 CTO 。荣誉:2022年度博客之星Top4、博客专家认证、全栈领域优质创作者、新星计划导师,“星荐官共赢计…

超越传统营销:海外网红带货能力的6大关键特质!

随着社交媒体的崛起和全球互联网的普及&#xff0c;海外网红已经成为了商业领域中不可忽视的力量。这些具有强大带货能力的网红不仅仅是广告代言人&#xff0c;更是品牌营销的重要合作伙伴。他们凭借其独特的魅力和行动力&#xff0c;在市场中掀起了一股风潮。社交媒体里网红那…

ChatGPT可以生成Windows密钥

ChatGPT 可以回答许多问题、生成和修改代码&#xff0c;最近还可以生成 Windows 10 和 Windows 11 的许可证密钥。自从 OpenAI 的 ChatGPT 推出以来&#xff0c;人工智能已成为许多用户面临的挑战。 他们不断地试图削弱这种智力&#xff0c;或者想尝试它的局限性和可能性。例如…

国内较好的iPaaS供应商有哪些?

iPaaS是什么 iPaaS&#xff0c;全称Integration Platform as a Service&#xff0c;集成平台即服务。 集成一般说的是系统集成&#xff08;System Integration&#xff09;&#xff0c;通常是指将软件、硬件与通信技术组合起来为用户解决信息处理问题的业务&#xff0c;集成的…

城市小车的优势,用五菱宏光mini,轻松应对城市拥堵与环保挑战。

掌握五菱宏光mini的驾驶技巧&#xff0c;让拥堵不再困扰你 合理利用车辆尺寸&#xff0c;轻松穿梭于城市道路 五菱宏光mini的尺寸小巧&#xff0c;长度不到3米&#xff0c;宽度不到1.5米&#xff0c;让你可以在狭窄的城市街道上轻松穿梭。掌握这一技巧&#xff0c;让你在拥堵…

MySQL 如何避免 RC 隔离级别下的 INSERT 死锁?

本文分析了 INSERT 及其变种&#xff08;REPLACE/INSERT ON DUPLICATE KEY UPDATE&#xff09;的几个场景的死锁及如何避免。 作者&#xff1a;张洛丹&#xff0c;DBA 数据库技术爱好者~ 爱可生开源社区出品&#xff0c;原创内容未经授权不得随意使用&#xff0c;转载请联系小编…

Python类的方法

Python类的方法主要分为实例方法、类方法和静态方法三种。 1 实例方法 以self作为第一个参数的方法&#xff0c;就是类的实例方法。该方法由类的实例调用&#xff0c;Python会把调用该方法的实例对象传递给self。 如下代码定义了一个名为A的类。 class A:def __init__(self…

无频闪护眼灯哪个好?什么是无频闪

随着科技的不断发展&#xff0c;工作时使用电子设备越来越普遍,如何保护我们的眼睛不受蓝光、频闪等危害就变得极其重要了。护眼台灯&#xff0c;顾名思义就是保护眼睛的台灯&#xff0c;其工作原理是在光源处使用特殊的防蓝光灯珠&#xff0c;并通过控制电流的稳定性来达到防频…

【STM32】文件系统FATFS与Flash的初步使用

文件系统简介 简介可以不看&#xff0c;直接看移植步骤 文件系统是介于应用层和底层间的模糊层。底层提供API&#xff0c;比如说使用SDIO或者SPI等读写一个字节。文件系统把这些API组合包装起来&#xff0c;并且提供一些列函数&#xff0c;我们可以使用这些函数进行更进一步的…

开发指导—利用组件插值器动画实现 HarmonyOS 动效

一. 组件动画 在组件上创建和运行动画的快捷方式。具体用法请参考通用方法。 获取动画对象 通过调用 animate 方法获得 animation 对象&#xff0c;animation 对象支持动画属性、动画方法和动画事件。 <!-- xxx.hml --><div class"container"> <di…