3.2 端点间二次样条的构建
在两个路点之间生成曲线,并且要求两个路点可以自由控制位置和朝向(切线方向)时,使用单一的一段二次曲线会遇到自由度不够的问题。这里构造了如下两条拼接的二次曲线来解决这个问题(见图3.1)。
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0053_0001.jpg?sign=1739336782-3kWfPn9nDPFHUIujAGDjxQszvMbP4CGQ-0-8e9196f413e3eb3634e36950868bcb4f)
图3.1 二次样条曲线示意图
给定起点P0、起点切线T0、终点P1和终点切线T1,有二次曲线f1(t)和f2(t),令其满足如下条件:
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0052_0001.jpg?sign=1739336782-Fl2AKwxFJ29Hp4NBRrXVlihFmSLbYVXm-0-695b6a746b57a957f845cae81f4a311a)
对于f1(1)和f2(0),假设有一动点Pm,在该点处曲线满足:
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0053_0002.jpg?sign=1739336782-hYx8gQvf5UdIKVSdUphQVDjNFCPYPzer-0-5f3a6b000ab3be2a89073d0ca36aff1f)
从而可以得到两条曲线的系数方程组:
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0053_0003.jpg?sign=1739336782-cVVFSYGtXyR47vbVw28p4ZAyBrBX9GgF-0-e8c4f4d624e2f2ad78770bb1c217669f)
该方程组的解为
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0053_0004.jpg?sign=1739336782-33HNpRTYM2cf2fC62cdXUIFyUlB2S3E8-0-5e50720c253b594112dfa2f7a71130e8)
则有
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0053_0005.jpg?sign=1739336782-5AbOy8KvR3dYF2o0zR9kjp0QD7RrNDTs-0-4eed6df2ab30698dc36eb4748b47a787)
可以看到,最终动点Pm不会出现在方程中,它为隐含的点,对外部是透明的。为了将分段曲线当作一段曲线使用,还需要将两段子曲线的参数t归一化到统一的[0,1]范围内。令为参数t归一化后的分段二次曲线,有
,
。这里使用每段子曲线占拼接曲线的比例来归一化曲线参数。设L1、L2分别为曲线
和
的长度,则有
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0054_0006.jpg?sign=1739336782-fh7K02B605IcbrjYL3V1ll8Zui27JpM8-0-3e73ee533edb1b7d7296bcddab6d33c8)
类似的,也可以得到曲线的长度方程,由子曲线长度方程
和
表示的归一化方程:
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0054_0010.jpg?sign=1739336782-1u1nTuPYi1OQQIYDvHnHHVOy7Cf28uz7-0-a23e8aba270807c6a2192c771b5c7cf8)
为此需要计算曲线f1(t)和f2(t)的曲线段和
的长度。对于二次曲线而言,曲线的线积分有解析解(分部积分):
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0054_0013.jpg?sign=1739336782-VZvfJQd6dElWY006zUOfd5FNCS7y40NP-0-2157c93312b8f1e03116126bc2c64aa9)
其中:
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0054_0014.jpg?sign=1739336782-uY6yqeDAf9JGP5YpajFYz1pKX7YWlUse-0-9bbf1b0e9274a2342981006d071c248e)
![](https://epubservercos.yuewen.com/EFD27D/14693592205506206/epubprivate/OEBPS/Images/figure_0055_0001.jpg?sign=1739336782-MpgkzTBWyd3Mix7nTtgXGztSVas3dXG4-0-fe392c4e396c183d79c319dfa424d1f2)
这些系数可以离线预计算好(静态路径),或者在运行时初始化曲线的时候计算(动态构建路径)。该公式较为复杂,但是多用于曲线归一化的预处理过程中。如果进一步完成了曲线的弧长参数化,将会使用更为简单的线性长度计算。