用Python作一条已知曲线的等距曲线
创始人
2024-04-24 05:45:03
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)

 

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...