matlab编写分段Hermite插值多项式

文章目录

原理

使用分段Hermite插值多项式原因

对牛顿插值多项式和拉格朗日插值多项式分析的时候,我们发现当我们用高次插值多项式逼近 f ( x ) f(x) f(x)时候,会发生龙格现象,为克服这种现象,我们引入分段线性,分段二次拉格朗日插值多项式,可以看出这两种插值函数,具有良好的一致收敛性。

但是他有个致命的缺点,呢就是它不是光滑的。即它在节点处的左右导数不相同。在插值条件中引入导数的条件,即分段Hermite插值多项式。

公式

第一类的两个插值积函数
第二类的两个插值积函数


如果要求插值函数具有连续性时候,我们既可以用分段拉格朗日也可以用分段Hermite,但是如果我们要求插值函数必须具有一阶连续导数,来近似 f ( x ) f(x) f(x)时候,我们只能采用三次Hermite插值,而不能用三次拉格朗日插值,

例题

法一
法二

代码

在 MATLAB 中编写 分段 Hermite 插值多项式,可以利用给定的节点以及每个节点的函数值和导数值来构造插值多项式。分段 Hermite 插值多项式不仅通过数据点(( x_i, y_i ))进行插值,而且还通过节点的导数信息进行插值,能够提供更平滑的插值曲线。

分段 Hermite 插值的思路:

假设给定的插值数据为:
[ x 0 , x 1 , ... , x n ] [x_0, x_1, \dots, x_n] [x0,x1,...,xn]

对应的函数值是:
[ y 0 , y 1 , ... , y n ] [ y_0, y_1, \dots, y_n ] [y0,y1,...,yn]

对应的导数值是:
[ y 0 ′ , y 1 ′ , ... , y n ′ ] [ y'_0, y'_1, \dots, y'_n ] [y0′,y1′,...,yn′]

Hermite 插值多项式可以通过每对相邻的节点 ( ( x i , x i + 1 ) ) (( x_i, x_{i+1} )) ((xi,xi+1))构建一个二次多项式 ( H i ( x ) ) ( H_i(x) ) (Hi(x)),而最终的插值多项式 ( P(x) ) 是这些二次多项式的分段拼接。

分段 Hermite 插值多项式的构造:

对于两个相邻的节点 ( ( x i , y i ) ) ( (x_i, y_i) ) ((xi,yi))和 ( x i + 1 , y i + 1 ) (x_{i+1}, y_{i+1}) (xi+1,yi+1),其对应的 Hermite 插值多项式为:


即:
H i ( x ) = ( 2 ( x − x i ) 3 − 3 ( x − x i ) 2 + 1 ) y i + ( ( x − x i ) 3 − 2 ( x − x i ) 2 + ( x − x i ) ) h i + ( − 2 ( x − x i + 1 ) 3 + 3 ( x − x i + 1 ) 2 ) y i + 1 + ( ( x − x i + 1 ) 3 − ( x − x i + 1 ) 2 ) h i + 1 H_i(x) = (2(x - x_i)^3 - 3(x - x_i)^2 + 1) y_i + ((x - x_i)^3 - 2(x - x_i)^2 + (x - x_i)) h_i\\+ (-2(x - x_{i+1})^3 + 3(x - x_{i+1})^2) y_{i+1} + ((x - x_{i+1})^3 - (x - x_{i+1})^2) h_{i+1} Hi(x)=(2(x−xi)3−3(x−xi)2+1)yi+((x−xi)3−2(x−xi)2+(x−xi))hi+(−2(x−xi+1)3+3(x−xi+1)2)yi+1+((x−xi+1)3−(x−xi+1)2)hi+1

其中,$( h_i ) $和 $( h_{i+1} ) $分别是导数值 ( y i ′ ) ( y'i ) (yi′) 和 ( y i + 1 ′ ) ( y'{i+1} ) (yi+1′) 的权重。

满足:

MATLAB 实现代码:

matlab 复制代码
x = [0, 1, 2];   % x 坐标
y = [1, 2, 0];   % y 坐标
dy = [1, -1, 2]; % 导数值
X = linspace(0, 2, 100);  % 生成 100 个插值点


n = length(x);  % 数据点的个数
    m = length(X);  % 插值点的个数
    H = zeros(1, m); % 用于存储结果
    
    for k = 1:m
        xi = X(k);  % 当前插值点
        % 计算每个分段的插值
        sum_val = 0;
        for i = 1:n-1
            % 构造 Hermite 插值的每一段
            if xi >= x(i) && xi <= x(i+1)
                % 计算 Hermite 插值多项式
                t = (xi - x(i)) / (x(i+1) - x(i)); % 归一化变量
                
                % Hermite插值的基函数
                h00 = 2*t^3 - 3*t^2 + 1;
                h10 = t^3 - 2*t^2 + t;
                h01 = -2*t^3 + 3*t^2;
                h11 = t^3 - t^2;
                
                % 计算当前段的插值
                sum_val = y(i)*h00 + dy(i)*(x(i+1)-x(i))*h10 + y(i+1)*h01 + dy(i+1)*(x(i+1)-x(i))*h11;
            end
        end
        H(k) = sum_val;
    end

x = [0, 1, 2]; % x 坐标

y = [1, 2, 0]; % y 坐标

结果如图:


H ( x ) H(x) H(x)有一阶导数

进行归一化不影响函数值:

matlab 复制代码
t = (xi - x(i)) / (x(i+1) - x(i));

在分段 Hermite 插值多项式 中的作用是将插值点 ( x_i ) 和 ( x_{i+1} ) 之间的区间线性化,使得插值的计算变得更加简单和规范。这一过程的主要目的是 将原始区间 ( [x_i, x_{i+1}] ) 映射到标准化的单位区间 ( [0, 1] ),便于后续的插值运算。

归一化变量的作用:

归一化变量 ( t = x i − x ( i ) x ( i + 1 ) − x ( i ) ) ( t = \frac{xi - x(i)}{x(i+1) - x(i)} ) (t=x(i+1)−x(i)xi−x(i)) 的目的是将原始区间 ( [ x i , x i + 1 ] ) ( [x_i, x_{i+1}] ) ([xi,xi+1]) 转换到标准化的区间 ( [0, 1] )。这样做的好处是:

  • 使得插值多项式的计算不依赖于原始数据的尺度或位置。
  • 使得插值公式在不同区间之间的一致性得以保持,便于构建和计算 Hermite 插值多项式。
相关推荐
MilesMatheson8 分钟前
ubuntu 编译android源码报错:loadlocale.c:129: _nl_intern_locale_data:
c语言·开发语言·算法
sysu6317 分钟前
73.矩阵置零 python
开发语言·数据结构·python·线性代数·leetcode·面试·矩阵
写代码的熊萌新1 小时前
JAVA2-类与对象编程(1)
java·开发语言
F-2H2 小时前
C语言:构造类型(共用体/联合体,枚举)
java·linux·c语言·开发语言·数据结构·c++·算法
Xiao5xiao1222 小时前
java后端对接飞书登陆
java·开发语言·飞书
疯狂小小小码农2 小时前
C++语言的文件操作
开发语言·后端·golang
莲动渔舟2 小时前
Python自学 - 类进阶(可调用对象)
开发语言·python
梵谷的忧伤2 小时前
两个栈实现队列(D)
java·开发语言·前端·算法
XiaoH2333 小时前
培训机构Day27
java·开发语言·javascript
chhanz3 小时前
MATLAB常用建模方法——常用非参数检验
数学建模·matlab