数学星空
发表于 2024-3-23 16:10:24
找到一个标准的计算方法,@mathe可以看看,对比一下楼上8#网友Huxley的方案(楼上没有简化过程,不确定是否正确?)
数学星空
发表于 2024-3-23 16:18:22
第二页
Jack315
发表于 2024-3-23 17:32:46
本帖最后由 Jack315 于 2024-3-23 17:36 编辑
对于可展曲面,展开的目标应该是找到三维曲面到二维平面的一个一一对应的映射关系。
假设锥面:\(f(x,y,z)=0\)为可展曲面,其顶点坐标为:\(V(0, 0, h)\) 。
考虑锥面上的一个点 \(P(x,y,z)\),将其映射到顶点位于坐标原点的极坐标 \((\rho,\theta)\) 中,则有:
\(\rho=\sqrt{x^2+y^2+(h-z)^2}\) —— 母线上线段长度不变。
\(\theta=\frac{\sqrt{x^2+y^2}}{\rho}\phi\) —— 母线上的点\((P)\)对应的圆弧弧长不变。
其中:\(\phi\) 为过 \(P\) 点和 \(z\) 轴的平面与 \(XOZ\) 平面之间的夹角。
算是先说个思路吧。不知道这个思路有没有问题,回头再画几个图看看。
用这个思路应该可以得到可展曲面的极坐标方程,但不知道有没有什么方法可以进行验证。
用机械制图软件?或者打印在纸上卷起来看看?
Jack315
发表于 2024-3-24 15:06:13
数学星空 发表于 2024-3-22 11:14
网友Huxley 给出了一般的理论分析见下截图
但没有看明白,请大神@mathe,@hujunhua帮忙看看,第(5)的公式是 ...
参考:
请问椭圆锥侧面展开图有没有人研究过?
https://www.zhihu.com/question/444087120
补充网友 Huxley 在上图中角度微分公式推导过程中省略的部分:
由于这部分推导过程不很明确,理解的时候有点难度了。
公式推导看起来没问题。回头再来验证这个公式……
Jack315
发表于 2024-3-24 17:47:46
本帖最后由 Jack315 于 2024-3-24 18:22 编辑
一般情况下,在极坐标中曲面展开后极径有比较简单的表达式,
而极角是一积分,很难求出表达式,估计只能上数值积分。
下面给出椭圆锥体的例子。Mathematica 代码计算作图。
曲面参数方程:\(r(t)=\{\lambda a\cos t,\lambda b\sin t, \lambda c\}\)
其中:\(0\le\lambda\le1,0\le t\le 2\pi\) 。
画椭圆锥体:
param = {a -> 3, b -> 2, c -> 5}
ParametricPlot3D[{k a Cos, k b Sin, k c} /. param, {k, 0, 1}, {t, 0, 2 \}, AxesLabel -> {x, y, z}]
公式:
\(r'=\dif r/\dif t=\{-\lambda a\sin t,\lambda b\sin t,0\}\)
\(r\*r=\lambda^2(a^2\cos^2t+b^2\sin^2t+c^2)\)
\(r\*r'=\lambda^2(b^2-a^2)\sin t\cos t\)
\(r'\*r'=\lambda^2(a^2\sin^2t+b^2\cos^2t)\)
极径:
\(\rho=\sqrt{r\*r}=\lambda\sqrt{a^2\cos^2t+b^2\sin^2t+c^2}\)
极角:
\(\theta=\int_0^t{\sqrt{\frac{r'\*r'}{r\*r}-(\frac{r\*r'}{r\*r})^2}}\dif t\)
\(=\int_0^t{\sqrt{\frac{a^2\cos^2t+b^2\sin^2t}{a^2\cos^2t+b^2\sin^2t+c^2}-[\frac{(b^2-a^2)\sin t\cos t}{a^2\cos^2t+b^2\sin^2t+c^2}]^2}}\dif t\)
定义被积函数:
f := Sqrt[((a^2 Cos^2 + b^2 Sin^2)/(a^2 Cos^2 + b^2 Sin^2 + c^2) -
(((b^2 - a^2) Sin Cos)/(a^2 Cos^2 + b^2 Sin^2 + c^2))^2)] /. param
为了使得展开曲线(关于 y 轴)对称,极角加上一起始角度 \(\alpha\) 。
\ = (\ - NIntegrate, {t, 0, 2 \}])/2
生成参数 \(t\):
t = Table[(2 \)/36 i, {i, 0, 36}]
计算极角 \(\theta\):
\ = Table, {x, 0, t[]}], {i, Length}] + \
计算极径 \(\rho\):
\ = Sqrt^2 + b^2 Sin^2 + c^2] /. param // N
画锥底椭圆展开曲线:
ListPolarPlot[], \[]}, {i, Length}], Joined -> True]
Jack315
发表于 2024-3-24 18:07:08
工程应用计算可以有很多种方法来解决,如:
1) 先用数学软件计算出若干个数据点,然后进行插值。
2) 如果插值计算都有困难的话,把展开曲线分成段用直线代替。
……
猜一下:工程计算应该没有实时性要求吧。
Jack315
发表于 2024-3-24 19:46:21
参考 15#
椭圆锥体参数:\(a=3,b=2,c=5\)
锥底椭圆按角度均匀分成 12 段,即:
\(t=\{0,\frac{\pi}{6},\frac{\pi}{3},\frac{\pi}{2},\frac{2\pi}{3},\frac{5\pi}{6},\pi,\frac{7\pi}{6},\frac{4\pi}{3},\frac{3\pi}{2},\frac{5\pi}{3},\frac{11\pi}{6},2\pi\}\)
得到 13 个点,直角坐标为:
{{5.74443, 1.00076}, {5.18727, 2.41707}, {4.31089, 3.41559}, {3.46574, 4.12172},
{2.62504, 4.83313}, {1.49092, 5.52514}, {3.57043*10^-16, 5.83095}, {-1.49092, 5.52514},
{-2.62504, 4.83313}, {-3.46574, 4.12172}, {-4.31089, 3.41559}, {-5.18727, 2.41707},
{-5.74443, 1.00076}}
以两点直线距离估计相应的弧长,则椭圆周长的近似值为 15.8074 。
理论周长为 \(2\pi b+4(a-b)=\)16.5664 。
绝对误差为 16.5664 - 15.8074 = 0.759004
相对误差为:1 - 15.8074 / 16.5664 = 4.5816%
Jack315
发表于 2024-3-24 19:59:17
有实时性要求意味着用于计算的时间有限制。
如果有可能就换个单片机,现在的单片机计算速度应该能胜任。
不排除可以把数值积分代码也设计进去。
当然这与分配用于计算的时间有关。
取点的位置应该根据展开曲线的曲率半径来定。
曲率半径大的弧段,点按排得稀一点;曲率半径小的弧段,点按排得密一点。
这样可以对提高计算精度有一定的帮助。
Jack315
发表于 2024-3-24 23:06:26
再说一个方法:
首先用数学软件计算出“精确”的展开曲线数据。然后用初等函数进行拟合。
涉及到的初等函数很有可能是线性函数和三角函数(级数)。
Jack315
发表于 2024-3-25 08:44:16
本帖最后由 Jack315 于 2024-3-25 09:44 编辑
继续 15# 的例子……
对 \(t\in\) 每隔 \(\frac{2\pi}{360}\) 计算一对 \((\rho,\theta)\) 。
用 \((t,\rho)\) 数据进行拟合得:
\(\rho=k_1+a_1\sin(b_1 t+c_1)+a_2\sin(b_2 t+c_2)+k_2\)
k1 = 5.610884606303115
a1 = 0.223
b1 = 1.999
c1 = 1.574
a2 = 0.002278
b2 = 4.038
c2 = -1.689
k2 = -0.000478906482411968
注:最后再加一个(负的)常数 \(k_2\) 是对拟合误差的调整。
用 \((t,\theta)\) 数据进行拟合得:
\(\theta=\beta_1 t+\beta_0+a_1\sin(b_1 t+c_1)+a_2\sin(b_2 t+c_2)\)
beta1 = 0.439746114054247
beta0 = 0.0168104449372901
a1 = 0.03573
b1 = 2.005
c1 = -0.0155
a2 = 0.02903
b2 = 0.191
c2 = 5.683
拟合误差在 \(1E-4\) 级别。
拟合函数用 Matlab 获得,附件是拟合结果的 Excel 文档:
展开曲线的计算,曲线拟合等,我所知道的编程软件有:
[*]Mathematica
[*]Matlab
[*]Python
如果需要更高的拟合精度,可以考虑在拟合函数中增加更多的三角函数 \(\sin\) 的谐波分量。
反之则可以减少三角函数 \(\sin\) 的谐波分量。
谐波分量越多,拟合精度越高,而计算时间则越长。
两者可以根据具体应用进行平衡。
其它的椭圆台展开曲线的 \((t,\rho)\) 和 \((t, \theta)\) 估计有类似的拟合函数形式。
正弦函数的计算有快速和足够精度的 Cordic 算法,
该算法甚至可以用整型数(定点小数)来计算。
如果最终需要的是直角坐标数据,涉及的依然是三角函数 \(\sin\) 的计算。