数据插值之朗格朗日插值(一)

news2025/5/25 11:43:47

目录

一、引言

二、代码实现 

2.1 Lagrange插值求插值多项式:

代码解析:

1.vpa解释

 2.ploy(x)解释:

3.conv()解释

4.poly2sym()解释

2.2 Lagrange插值求新样本值和误差估计:

代码解析:

1.errorbar(x, y, R, '.g')

2.plot(X, Y, 'or')

三、Lagrange在Matlab中的使用模板


一、引言

数据插值是指通过有限个原始数据点构造出一个解析表达式,从而可以计算数据点之间的函数值。在Matlab中数据插值的方法主要有拉格朗日插值、牛顿差值、三次样条插值、埃尔米特插值、一维数据插值、二维数据插值等等。笔者旨在写一个使用Matlab进行数值插值的专题,通过介绍插值原理,代码实现,形成模板,方便日后使用时直接代入参数直接调用。

本节介绍拉格朗日插值(Lagrange interpolation)。Lagrange插值是一种用于逼近通过给定数据点的函数的方法。它涉及构造一个度数为 ( n-1 ) 或更低的多项式,该多项式通过 ( n ) 个给定点。该多项式是使用Lagrange基多项式构造的,这是一组多项式,当在给定点之一进行评估时,会得到1,并且当在任何其他给定点进行评估时会得到0。

Lagrange插值多项式可表示为:

L(x) = \sum_{i=0}^{n} y_i l_i(x)

Lagrange插值基函数可以表示为:

l_i(x) = \frac{(x-x_0)(x-x_1)\cdots(x-x_{i-1})(x-x_{i+1})\cdots(x-x_n)}{(x_i - x_0)(x_i - x_1)\cdots(x_i - x_{i-1})(x_i - x_{i+1})\cdots(x_i - x_n)}

二、代码实现 

2.1 Lagrange插值求插值多项式:

function[C, L, L1, l] = lagranl(X, Y)
% 定义拉格朗日插值多项式和基函数
%
% 输入:
%   X - 插值节点的横坐标向量
%   Y - 插值节点的纵坐标向量
%
% 输出:
%   C - 拉格朗日插值多项式的系数向量
%   L - 拉格朗日插值多项式的符号表达式
%   L1- 拉格朗日基函数对应的系数矩阵
%   l - 拉格朗日基函数对应的符号表达式

m = length(X); % 获取插值节点的个数

L1 = zeros(m, m); % 初始化存储拉格朗日基函数系数的矩阵
l = sym(zeros(1, m)); % 初始化单行符号值存储基函数表示式

for k = 1:m % 遍历每一个插值节点
    V = 1; % 初始化基函数的系数向量为1
    for i = 1 : m % 遍历所有节点用于计算
        if k ~= i %排除掉自身的情况
            V = conv(V, poly(X(i))) / (X(k) - X(i)); % 更新基函数的系数向量
        end
    end
    L1(k, :) = V; % 存储第k个基函数的系数
    l(k) = poly2sym(V) * Y(k); % 将基函数乘以对应的Y值,转换为符号表达式并存储
end

C = sum(Y .* L1, 1); % 计算拉格朗日插值多项式的系数向量
L = sum(l); % 计算拉格朗日插值多项式的符号表达式

 下面进行测试:

X = [-2.2, -1.0, 0.01, 1.0, 2.0, 3.3, 2.2];
Y = [17.1, 7.3, 1.1, 2.0, 17.1, 23.1, 19.3];
[C, L, L1, l] = lagranl(X, Y);
L = vpa(L, 3)

代码解析:

1.vpa解释

vpa 是 MATLAB 中的一个函数,表示 “Variable Precision Arithmetic”(可变精度计算)。在这个特定的调用中,vpa(L, 3) 将 L 的符号表达式以3位小数的精度表示。具体解释:

  • L: 是从 lagranl 函数中返回的拉格朗日插值多项式的符号表达式。
  • vpa(L, 3): 会将这个符号表达式的系数和结果值保留到小数点后3位。

假如:

L = sym('0.123456789*x^2 + 0.987654321*x + 3.141592653');

使用 vpa 后:

L = vpa(L, 3)
% 将变为
L = sym('0.123*x^2 + 0.988*x + 3.14');
 2.ploy(x)解释:

在MATLAB中,ploy(x)函数并不是直接用来创建多项式的,容易与用于多项式插值的ployfit()或构造多项式系数的polyval()函数混淆。实际上,ploy(x)函数是用来从根求多项式的系数的。也就是说,如果你有一系列的复数或实数根,poly() 可以帮助你找到一个多项式,其在这些点上的值为零。

 基本用法:

p = poly(r)
  • r 是一个向量,包含了多项式的根。
  • p 是返回的结果,是一个向量,表示对应于根 r 的多项式的系数,按降幂排列。

举个例子:

r = [1, 2];
p = poly(r);
disp(p);  % 输出多项式系数

 这段代码会输出 [1 -3 2],对应于多项式x^2-3x+2,验证了1和2确实是这个多项式的根。

3.conv()解释

conv是MATLAB 中用来执行多项式卷积(Convolution)的函数。在多项式运算中,conv 可以用来计算两个多项式的乘积。

 基本用法

C = conv(A, B)

其中 A 和 B 是两个多项式的系数向量,返回向量 C 表示这两个多项式的乘积的系数。

示例:

假设我们有两个多项式:

P(x) = 1 + 2x + 3x^2

Q(x) = 4 + 5x

用系数向量表示:

P = [3, 2, 1]; % 对应:1 + 2x + 3x^2
Q = [5, 4]; % 对应: 5x + 4

我们使用conv来计算两者的乘积:

P = [3, 2, 1];  % 3x^2 + 2x + 1
Q = [5, 4];     % 5x + 4

C = conv(P, Q)

% 输出 C
% C = [15 22 13 4] 对应最终方程式:15x^3 + 22x^2 + 13x + 4

4.poly2sym()解释

poly2sym()是把多项式系数转换为符号多项式。

V = [1, 2, 3]\rightarrow x^2+3x+2

2.2 Lagrange插值求新样本值和误差估计:

%% 拉格朗日插值及误差估计
% 此函数使用拉格朗日插值公式来计算插值值,并估计误差
% 输入参数:
% X - 已知数据点的x坐标 (向量)
% Y - 已知数据点的y坐标 (向量)
% x - 需要插值的x坐标 (向量)
% M - 最大连续(n+1)阶导数的上界 (标量)
% 输出参数:
% y - 插值后的y值 (向量)
% R - 误差估计 (向量)

function [y, R] = lagranzi(X, Y, x, M)
    n = length(X);      % 已知数据点的数量
    m = length(x);      % 需要插值的数据点数量

    for i = 1:m
        z = x(i);       % 当前需要插值的x坐标
        s = 0.0;        % 插值和初始化为0

        for k = 1:n
            p = 1.0;    % 插值多项式L_k(z)初始化为1
            q1 = 1.0;   % 误差估计中的分子初始化为1
            c1 = 1.0;   % 误差估计中的分母初始化为1

            for j = 1:n
                if j ~= k
                    % 计算拉格朗日基函数L_k(z)
                    p = p * (z - X(j)) / (X(k) - X(j));
                end
                % 计算误差估计的分子部分
                q1 = abs(q1 * (z - X(j)));
                % 计算误差估计的分母部分
                c1 = c1 * j;
            end
            
            % 加权求和得到插值值
            s = p * Y(k) + s;
        end
        
        y(i) = s;         % 存储插值结果
        R(i) = M * q1 / c1;  % 计算并存储误差估计
    end
end

下面进行测试:

clc
clear
X = [-2.2, -1.0, 0.01, 1.0, 2.0, 3.3, 2.2];
Y = [17.1, 7.3, 1.1, 2.0, 17.1, 23.1, 19.3];
x = linspace(-3, 4, 50);
M = 1;
[y, R] = lagranzi(X, Y, x, M);
errorbar(x, y, R, '.g')
hold on
plot(X, Y, 'or')
x = 2.8;
[y, R] = lagranzi(X, Y, x, M);
x = -3:0.01:4;
L = 0.21*x.^6 - 0.87*x.^5 - 1.21*x.^4 + 5.9*x.^3 + 4.48*x.^2 - 7.68*x + 1.18;
plot(x, L)
legend('误差', '样本点', '拉格朗日多项式函数曲线')
print(gcf, '-r600', '-djpeg', '图2-1.jpg')

代码解析:

1.errorbar(x, y, R, '.g')

在MATLAB中,errorbar() 函数用于绘制带有误差条的图形,它能够直观地展示数据点的不确定度或误差范围。函数调用格式中的各个参数含义如下:

errorbar(x, y, R, '.g')

这里各参数的含义是:

  • x:数据点,在x轴上的值。
  • y:数据点,与x对应,在y轴上的值。
  • R:这可以是一个向量或一个矩阵,定义了误差条的长度。如果是向量,那么这个向量提供了每个数据点y方向上的误差估计;如果是矩阵(通常是2列),第一列是负方向的误差,第二列是正方向的误差,用于分别表示y值的下限和上限。
  • '.':这是一个标记符号参数,指定了数据点的样式,在这个例子中使用的是点。
  • 'g':颜色代码,指定了数据点和误差条的颜色,在这里是绿色。
2.plot(X, Y, 'or')
  • 'o' 表示数据点将以圆圈形式标记。如果只用 'o',MATLAB 会在每个 (X, Y) 数据对的位置绘制一个空心的圆圈。
  • 'r' 表示红色(red)。结合前面的 'o',这意味着每个数据点将以红色填充的圆圈来表示。

三、Lagrange插值使用模板

如果目前你拥有X,Y样本点,仅想求出一个新的x所对应的y值,可以直接在下述代码中进行修改“示意用法”中的值,程序放入Matlab中可以直接执行:

clc
clear
% 示例用法
x = [1, 2, 3, 4];
y = [1, 4, 9, 16];
xi = 2.5;
L_value = lagrange_interpolation(x, y, xi);
disp(['在 xi = ' num2str(xi) ' 处的插值值是 ' num2str(L_value)]);

function L = lagrange_interpolation(x, y, xi)
    % 拉格朗日插值函数
    % x 和 y 是已知的数据点
    % xi 是希望插值的点
    % 返回的 L 是在 xi 处的插值结果
    
    % 确保 x 和 y 长度一致
    if length(x) ~= length(y)
        error('x 和 y 必须具有相同的长度');
    end
    
    % 初始化结果 L
    n = length(x);
    L = 0;
    
    % 计算拉格朗日多项式
    for i = 1:n
        % 初始化基多项式
        Li = 1;
        for j = 1:n
            if i ~= j
                Li = Li * (xi - x(j)) / (x(i) - x(j));
            end
        end
        % 累加到结果
        L = L + Li * y(i);
    end
end

参考资料:《Matlab编程与汽车仿真应用》 ——崔胜民

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1695362.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

鲁教版七年级数学上册-笔记

文章目录 第一章 三角形1 认识三角形2 图形的全等3 探索三角形全等的条件4 三角形的尺规作图5 利用三角形全等测距离 第二章 轴对称1 轴对称现象2 探索轴对称的性质4 利用轴对称进行设计 第三章 勾股定理1 探索勾股定理2 一定是直角三角形吗3 勾股定理的应用举例 第四章 实数1 …

C++技能进阶指南——多态语法剖析

前言:多态是面向对象的三大特性之一。顾名思义, 多态就是多种状态。 那么是什么的多种状态呢? 这里的可能有很多。比如我们去买火车票, 有普通票, 学生票; 又比如我们去旅游, 有儿童票&#xff…

心链2---前端开发(整合路由,搜索页面,用户信息页开发)

心链——伙伴匹配系统 接口调试 说书人📖:上回书说到用了两种方法查询标签1.SQL查询,2.内存查询;两种查询效率是部分上下,打的是难解难分,是时大地皴裂,天色聚变,老祖斟酌再三最后决…

数据库-SQL性能分析

SQL执行频率 慢查询日志 慢查询日志记录了所有执行时间超过指定参数(long_query_time,单位:秒,默认10秒)的所有 SQL语句的日志。 MySQL的慢查询日志默认没有开启,我们可以查看一下系统变量 slow_query_l…

leetcode328. 奇偶链表,附详细解析和代码注释

leetcode328. 奇偶链表 给定单链表的头节点 head ,将所有索引为奇数的节点和索引为偶数的节点分别组合在一起,然后返回重新排序的列表。 第一个节点的索引被认为是 奇数 , 第二个节点的索引为 偶数 ,以此类推。 请注意&#xff0…

初出茅庐的小李博客之用MQTT.fx软件进行消息发布与订阅【 基于EMQX Cloud】

MQTT.fx软件使用简单介绍 MQTT.fx 的软件界面如下图所示,最上方为 MQTT Broker 连接地址栏,及其连接配置。其下方功能 Tabs 含有 Publish 发布栏、Subscribe 订阅栏、Scripts 脚本栏、Broker Status 状态消息栏、Log 日志信息控制栏。 连接之前要明确几…

Distributed Transactions Mit 6.824

Topic1:distributed transactions concurrency control atomic commit 传统计划:事务 程序员标记代码序列的开始/结束作为事务。 事务示例 x 和 y 是银行余额——数据库表中的记录。x 和 y 位于不同的服务器上(可能在不同的银行&#x…

NDIS小端口驱动(九)

PCIe设备难免会遇到一些重置设备的请求,例如重置总线的时候,但是由于NIC网卡的多样性,重置设备确实也有许多要注意的地方,另外还有一些包含WDM的NDIS驱动 微型端口驱动程序硬件重置 微型端口驱动程序必须向 NdisMRegisterMinipo…

10款免费黑科技软件,强烈推荐!

1.AI视频生成——巨日禄 网页版https://aitools.jurilu.com/ "巨日禄 "是一款功能强大的文本视频生成器,可以快速将文本内容转换成极具吸引力的视频。操作简单,用户只需输入文字,选择喜欢的样式和模板, “巨日禄”就会…

qemu+gdb调试linux内核

打开CONFIG_DEBUG_INFO,编译内核 通过图形菜单配置该宏,执行make menuconfig。 kernel hacking —> compile-time checks and compiler options —> compile the kernel with debug info 验证是否打开成功,grep -nr “CONFIG_DEBUG_INFO” .config。 打开成功,然后…

初识Spring Boot

初识Spring Boot SpringBoot是建立在Spring框架之上的一个项目,它的目标是简化Spring应用程序的初始搭建以及开发过程。 对比Spring Spring Boot作为Spring框架的一个模块,旨在简化Spring应用程序的初始搭建和开发过程,以下是Spring Boot相对于传统Spri…

【通义千问—Qwen-Agent系列2】案例分析(图像理解图文生成Agent||多模态助手|| 基于ReAct范式的数据分析Agent)

目录 前言一、快速开始1-1、介绍1-2、安装1-3、开发你自己的Agent 二、基于Qwen-Agent的案例分析2-0、环境安装2-1、图像理解&文本生成Agent2-2、 基于ReAct范式的数据分析Agent2-3、 多模态助手 附录1、agent源码2、router源码 总结 前言 Qwen-Agent是一个开发框架。开发…

iZotope RX 11 for Mac:音频修复的终极利器

在音频处理的世界里,纯净与清晰是每一个创作者追求的目标。iZotope RX 11 for Mac,这款专为Mac用户打造的音频修复软件,凭借其卓越的音频修复能力和丰富的功能,已经成为众多音频工程师和音乐制作人的首选工具。 iZotope RX 11 for…

线程生命周期

创建线程的两种方法 1.继承Thread类 2.实现Runnable接口 线程从创建到消亡分为新建、就绪、运行、阻塞、死亡5种状态。 新建状态 创建一个线程就处于新建状态。此时线程对象已经被分配了内存空间,并且私有数据也被初始化,但是该线程还不能运行。 就…

nodeJs学习(第一周)

文章目录 学习总结nodejs基础知识核心模块(内置模块)fs(file-system)文件系统fs增删查改urlQuery String httprequest根据不同的请求路径发送不同的响应结果requireip地址和端口号Content-Type 第三方模块 express登录接口逻辑分析…

【LeetCode:2769. 找出最大的可达成数字 + 模拟】

🚀 算法题 🚀 🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀 🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨ 🌲 作者简介:硕风和炜,…

MySQL--执行计划

一、执行计划 1.介绍 执行计划是sql在执行时,优化器优化后,选择的cost最低的方案 通过desc、explain可以查看sql的执行计划 2.如何查看执行计划 table语句操作的表,在多表时才有意义type查找类型possible_keys可能会用到的索引key最终选择的…

基于python数据挖掘在淘宝评价方面的应用与分析,技术包括kmeans聚类及情感分析、LDA主题分析

随着电子商务的蓬勃发展,淘宝作为中国最大的在线购物平台之一,吸引了大量的消费者进行购物并留下了大量的客户评价。这些客户评价中包含了丰富的消费者意见和情感信息,对于商家改进产品、提升服务质量以及消费者决策都具有重要的参考价值。 …

JVM学习-垃圾回收(一)

什么是垃圾 垃圾是指在运行程序中没有任何指针指向的对象,这个对象就是需要被回收的垃圾如果不及时对内存的垃圾进行清理,垃圾对象所占用的内存空间会一直保留到应用程序结束,被保留的空间无法被其它对象所用,甚至可能导致内存溢…