三维空间中圆的参数方程

三维空间中,以点三维空间中圆的参数方程_第1张图片为圆心、以向量三维空间中圆的参数方程_第2张图片为法向量、半径为 r 的圆(见下图),

三维空间中圆的参数方程_第3张图片

它的参数方程为:
三维空间中圆的参数方程_第4张图片

三维空间中圆的参数方程_第5张图片

三维空间中圆的参数方程_第6张图片

其中,三维空间中圆的参数方程_第7张图片三维空间中圆的参数方程_第8张图片分别对应单位向量三维空间中圆的参数方程_第9张图片三维空间中圆的参数方程_第10张图片,它们既垂直于三维空间中圆的参数方程_第11张图片,又互相垂直;随着三维空间中圆的参数方程_第12张图片从0变化到三维空间中圆的参数方程_第13张图片
,通过参数方程可以得到圆上每一个点的坐标。

三维空间中圆的参数方程_第14张图片三维空间中圆的参数方程_第15张图片是满足既垂直于三维空间中圆的参数方程_第16张图片,又互相垂直的任意单位向量。怎么样快速得到满足条件的三维空间中圆的参数方程_第17张图片三维空间中圆的参数方程_第18张图片呢?这时候应该充分利用叉乘运算的特点,因为两个向量的叉乘结果只要不为零,叉乘结果总是垂直于原来的这两个向量。具体如下:

三维空间中圆的参数方程_第19张图片的方法:三维空间中圆的参数方程_第20张图片叉乘坐标向量三维空间中圆的参数方程_第21张图片。如果叉乘结果不为零,那么它必然垂直于三维空间中圆的参数方程_第22张图片,把它单位化后就得到三维空间中圆的参数方程_第23张图片;如果叉乘结果恰好为零,再用三维空间中圆的参数方程_第24张图片叉乘剩下两个坐标向量三维空间中圆的参数方程_第25张图片三维空间中圆的参数方程_第26张图片中任意一个,单位化叉乘结果,得到三维空间中圆的参数方程_第27张图片

三维空间中圆的参数方程_第28张图片的方法:三维空间中圆的参数方程_第29张图片叉乘上一步得到的三维空间中圆的参数方程_第30张图片,叉乘结果必然垂直于三维空间中圆的参数方程_第31张图片三维空间中圆的参数方程_第32张图片,单位化叉乘结果,就得到三维空间中圆的参数方程_第33张图片

接下来,利用Matlab软件对三维空间中圆的参数方程进行测试。代码如下:

n=[1 1 1]; %法向量n
r=1; %圆的半径为1
c=[1 1 1]; %圆心的坐标
theta=(0:2*pi/100:2*pi)'; %theta角从0到2*pi
a=cross(n,[1 0 0]); %n与i叉乘,求取a向量
if ~any(a) %如果a为零向量,将n与j叉乘
    a=cross(n,[0 1 0]);
end
b=cross(n,a); %求取b向量
a=a/norm(a); %单位化a向量
b=b/norm(b); %单位化b向量

c1=c(1)*ones(size(theta,1),1);
c2=c(2)*ones(size(theta,1),1);
c3=c(3)*ones(size(theta,1),1);

x=c1+r*a(1)*cos(theta)+r*b(1)*sin(theta);%圆上各点的x坐标
y=c2+r*a(2)*cos(theta)+r*b(2)*sin(theta);%圆上各点的y坐标
z=c3+r*a(3)*cos(theta)+r*b(3)*sin(theta);%圆上各点的z坐标

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

Matlab运行结果如下图:

三维空间中圆的参数方程_第34张图片

你可能感兴趣的:(C++)