算法笔记:样条插值

1 什么是样条

  • 样条来源于早期工程制图,为了将一些固定点连成一条光滑的曲线,采用具有弹性的木条固定在这些点上
  • 通过样条画出来的曲线不仅经过各固定点,而且连续光滑

2 样条函数

  • 数学上定义成一个分段多项式函数
    • 每两个点之间用一个多项式来表示,这些多项式的阶数相同,但是系数是不一样的
    • 样条插值的目的就是求这些多项式系数,已知系数,那些中间点的值就能唯一确定了

|---------------|--------------------------------------------------------------------------------------------------------------|
| #### 线性样条 | 在每两点间画一条直线 |
| #### 二次样条 | |
| #### 三次样条 | |

3 样条插值原理

  • 连续
  • 光滑
  • 边界条件

下面以三次样条插值为例,假设是已知的n+1个数据点,整个函数有这4n个未知数组成

若想求得这4n个未知系数,需要构建4n个方程

3.1 连续

  • 根据连续性原则,每个分段函数都经过其两侧端点
  • 因此,可得到2n个方程:

3.2 光滑性原则

  • 根据光滑性原则,相邻的两个分段函数连接处低阶导数相等
    • 对于三次样条来说,就是一阶导数和二阶导数

3.3 边界条件

  • 目前一共4n-2个方程,不足以得到4n个系数的解
  • 在公式(3)和(4)中,第1个点和第n+1个点在边界,只被使用了一次,导致整个方程组还差2个方程才能求解。
  • 此时,可以假设不同的边界条件来构成4n个方程。
  • 需要注意的是,不同的边界条件导致插值结果也有所不同。

|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| #### Natural Spline | 假设第1个和最后一个端点的二阶导为0 |
| #### Not-a-Knot Spline | 假设第一段和第二段函数的三阶导在端点处相等;第n-1段和第n段函数的三阶导在端点处也相等 |
| #### Periodic Spline | 最后一个分段函数的一阶段和二阶导于第一个分段的一阶导和二阶导相等 这种假设特别适合用在周期函数中,尤其是第一点与最后一点相等时 |
| #### Quadratic Spline | 强制第一个与最后一个分段函数的第一个系数为0 |

参考内容:样条插值(Spline Interpolation)-云社区-华为云 (huaweicloud.com)

相关推荐
Larry_Yanan14 分钟前
QML学习笔记(四十四)QML与C++交互:对QML对象设置objectName
开发语言·c++·笔记·qt·学习·ui·交互
摇滚侠1 小时前
Spring Boot 3零基础教程,WEB 开发 默认页签图标 Favicon 笔记29
java·spring boot·笔记
酌量4 小时前
基于3D激光点云的障碍物检测与跟踪---(1)体素下采样、ROI 区域裁剪与地面点云分割
笔记·机器人·ransac·障碍物检测·激光点云·roi·体素下采样
大邳草民4 小时前
Django 的动态特性:从 Python 动态机制到框架设计思想
笔记·python·django
Larry_Yanan4 小时前
QML学习笔记(四十五)QML与C++交互:信号槽的双向实现
c++·笔记·qt·学习·ui·交互
~无忧花开~6 小时前
CSS学习笔记(二):CSS动画核心属性全解析
开发语言·前端·css·笔记·学习·css3·动画
浓墨染彩霞7 小时前
Java----set
java·经验分享·笔记
爱滑雪的码农8 小时前
微信小程序页面配置,基本语法,页面切换,tabbar全局配置
笔记
学工科的皮皮志^_^8 小时前
网口学习理解
经验分享·笔记·嵌入式硬件·学习·fpga开发·以太网
张人玉9 小时前
C#WPF如何跳转页面
笔记·ui·c#·wpf