用Python作一条已知曲线的等距曲线
创始人
2024-04-24 05:08:16
0

参考资料:

该如何作一条已知曲线的等距曲线? - 知乎

等距线_百度百科


目录

1.等距线

2.数学推导 

3.示例

4.代码与结果


 1.等距线

等距线(equidistant line)亦称平行曲线,一种平面曲线,即由一已知曲线所产生的另一曲线。平行曲线如下图。

2.数学推导

2.1 核心思想: 

从原曲线法线方向偏移所需的距离,就可以得到这些平行曲线

2.2数学推导

对于参数曲线r(t),其切线速度就是其第一导数:

v(t)=r'(t)

归一化后得单位切线矢量:

T(t)=(T_{x}(t),T_{y}(t))=\frac{v(t)}{\left | v(t) \right |}

在二维中,垂直于切线的单位法矢量只需旋转切线90度,可以得到垂直于切线的单位法矢量为

N(t)=(-T_{y}(t),T_{x}(t))

那么,设偏移距离为a,r(t)的两条平行曲线为

s(t)=r(t)\pm aN(t)

3.示例

本文以y=4x^{3}+3x^{2}+2x+1为例,将该方程转为参数方程,得s(t)为,

s(t)=\left\{\begin{matrix}t \\ 4t^{3}+3t^{2}+2t+1 \end{matrix}\right.

对s(t)求导得v(t),

v(t)=\left\{\begin{matrix}1 \\ 12t^{2}+6t+2 \end{matrix}\right.

归一化后得单位切线矢量T(t),

T(t)=\left\{\begin{matrix}\frac{1}{\sqrt{1+(12t^{2}+6t+2)^{2}}} \\ \frac{12t^{2}+6t+2}{\sqrt{1+(12t^{2}+6t+2)^{2}}} \end{matrix}\right.

将T(t)旋转90度得到N(t),

N(t)=\left\{\begin{matrix}-1*\frac{12t^{2}+6t+2}{\sqrt{1+(12t^{2}+6t+2)^{2}}} \\ \frac{1}{\sqrt{1+(12t^{2}+6t+2)^{2}}} \end{matrix}\right.

于是平移距离为a的曲线为,

S(t)=r(t)\pm aN(t)

4.代码与结果

 PS:注意横、纵坐标尺度不一致,想看更明显的效果可以试验一下y=x^2

import numpy as np
import matplotlib.pyplot as pltt = np.linspace(-5,5,40)
x1 = t
y1 = 4*t**3 + 3*t**2 + 2*t + 1x2 = t + 3*-1*(12*t**2+6*t+2)/np.sqrt(1+(12*t**2+6*t+2)**2)
y2 = 4*t**3 + 3*t**2 + 2*t + 1 + 3*1/np.sqrt(1+(12*t**2+6*t+2)**2)x3 = t - 3*-1*(12*t**2+6*t+2)/np.sqrt(1+(12*t**2+6*t+2)**2)
y3 = 4*t**3 + 3*t**2 + 2*t + 1 - 3*1/np.sqrt(1+(12*t**2+6*t+2)**2)plt.plot(x1,y1)
plt.plot(x2,y2)
plt.plot(x3,y3)

 

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
客厅放八骏马摆件可以吗(家里摆... 今天给各位分享客厅放八骏马摆件可以吗的知识,其中也会对家里摆八骏马摆件好吗进行解释,如果能碰巧解决你...
苏州离哪个飞机场近(苏州离哪个... 本篇文章极速百科小编给大家谈谈苏州离哪个飞机场近,以及苏州离哪个飞机场近点对应的知识点,希望对各位有...