相切于球体上定点的平面

文章目录


1.问题描述

该问题同二维平面上求解过圆上一点的直线问题类似。

2.已知条件

已知球体表面上一点P, 球心C,求球面上P点的切面M。

3.求解

令向量 n = P − C n = P-C n=P−C,则 u = ( n y , − n x , 0 ) , v = u × n u=(n_y,-n_x,0),v=u\times n u=(ny,−nx,0),v=u×n

平面 M = P + t ⋅ u + m ⋅ v M = P+t\cdot u +m\cdot v M=P+t⋅u+m⋅v

4.Code

matlab 复制代码
close all;
clear;


rng default;

C = rand(1,3);
r = rand();
t = rand(1,2)*pi;
P = C + [r*cos(t(1))*sin(t(2)), r*sin(t(1))*sin(t(2)), r*cos(t(2))];

t = linspace(0, 2*pi, 50);
u = linspace(0, 2*pi, 50);
[t,u] = meshgrid(t,u);

x = C(1) + r*cos(t).*sin(u);
y = C(2) + r*sin(t).*sin(u);
z = C(3) + r*cos(u);

n = normalize(P - C,'norm');
m = [0, n(3), -n(2)];
l = cross(m,n);
c1 = linspace(-1,1,20);
c2 = linspace(-1,1,20);
[c1,c2] = meshgrid(c1,c2);
xx = P(1) + c1*m(1) + c2*l(1);
yy = P(2) + c1*m(2) + c2*l(2);
zz = P(3) + c1*m(3) + c2*l(3);


figure;
mesh(x,y,z);
axis equal
hold on
mesh(xx,yy,zz)
hold on
scatter(P(1),P(2), P(3),'filled')
相关推荐
你撅嘴真丑11 小时前
第九章-数字三角形
算法
uesowys11 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder11 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮12 小时前
AI 视觉连载1:像素
算法
智驱力人工智能12 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥13 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风13 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風13 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT0613 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
Σίσυφος190014 小时前
PCL 法向量估计-PCA邻域点(经典 kNN 协方差)的协方差矩阵
人工智能·线性代数·矩阵