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

目录

一、引言

二、代码实现 

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; % 初始化基函数的系数向量为1for i = 1 : m % 遍历所有节点用于计算if k ~= i %排除掉自身的情况V = conv(V, poly(X(i))) / (X(k) - X(i)); % 更新基函数的系数向量endendL1(k, :) = V; % 存储第k个基函数的系数l(k) = poly2sym(V) * Y(k); % 将基函数乘以对应的Y值,转换为符号表达式并存储
endC = 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 + 4C = 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:mz = x(i);       % 当前需要插值的x坐标s = 0.0;        % 插值和初始化为0for k = 1:np = 1.0;    % 插值多项式L_k(z)初始化为1q1 = 1.0;   % 误差估计中的分子初始化为1c1 = 1.0;   % 误差估计中的分母初始化为1for j = 1:nif 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;endy(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% 初始化结果 Ln = length(x);L = 0;% 计算拉格朗日多项式for i = 1:n% 初始化基多项式Li = 1;for j = 1:nif i ~= jLi = Li * (xi - x(j)) / (x(i) - x(j));endend% 累加到结果L = L + Li * y(i);end
end

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

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

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

相关文章

【编译原理】LL(1)预测分析法

一、实验目的 LL(1)的含义:第一个L表明自顶向下分析是从左向右扫描输入串,第2个L表明分析过程中将使用最左推导,1表明只需向右看一个符号便可决定如何推导,即选择哪个产生式进行推导。 LL(1) 预测分析方法是确定的自顶向下的语…

2024年【N1叉车司机】免费试题及N1叉车司机模拟试题

题库来源:安全生产模拟考试一点通公众号小程序 N1叉车司机免费试题考前必练!安全生产模拟考试一点通每个月更新N1叉车司机模拟试题题目及答案!多做几遍,其实通过N1叉车司机模拟考试题库很简单。 1、【多选题】《中华人民共和国特…

Java 反射效率

反射性能比正常new对象使用慢&#xff0c;今天我们来测试一下其中效率&#xff0c;以及探索优化。 测试方法main long start System.currentTimeMillis();for (int i0;i<10000000;i){// 调用如下不同case的测试方法分别创建一千万个对象&#xff0c;对比效率}long end Sys…

第三讲 栈、队列和数组 (1)

文章目录 第三讲 栈、队列和数组3.1 栈3.1.1 出栈元素的不同排列与卡特兰数3.1.2 栈的顺序表实现3.1.3共享栈3.1.4 栈的链表实现3.1.5 栈的两种实现的优缺点3.1.6 c中的栈( s t a c k stack stack)容器适配器3.1.7 栈的应用:star:3.1.7.1 **栈在括号匹配中的应用**3.1.7.2 **栈…

白话文docker-001

第一章&#xff1a;Docker简介 Docker的定义与历史 Docker 是一个开源的应用容器引擎&#xff0c;它允许开发者打包他们的应用以及应用的运行环境到一个可移植的容器中。Docker 首次发布于2013年&#xff0c;由 Solomon Hykes 和他领导的团队在 dotCloud 公司开发。Docker 的…

CSS布局和定位应用方案

目录 浮动布局绝对布局表格布局响应式布局弹性布局网格布局多栏布局浮动布局 CSS3浮动布局的核心在于使用float属性将元素移出文档流,通过左右浮动来排列元素,并结合clear属性或清除浮动技巧(如这里的伪元素法)来处理浮动带来的副作用。尽管浮动布局在某些简单布局中依然实…

m1系列芯片aarch64架构使用docker-compose安装rocketmq5.0以及运维控制台

之前看到 DockerHub 上有大佬制作了 m1 芯片, aarch64架构的 rocketmq 镜像, 所以就尝试的安装了下, 亲测可用: 一. docker-compose.yml 文件命令 volumes 挂载目录需要换成自己的目录 注意 depends_on 标签, broker 和 console 的 启动要晚于 namesrv, 因为 broker 需要注册…

MPLS LDP原理与配置

1.LDP基本概念 &#xff08;1&#xff09;LDP协议概述 &#xff08;2&#xff09;LDP会话、LDP邻接体、LDP对等体 &#xff08;3&#xff09;LSR ID 与LDP ID &#xff08;4&#xff09;LDP消息 ⦁ 按照消息的功能&#xff0c;LDP消息一共可以分为四大类型&#xff1a;发现…

JKI State Machine的特点与详细介绍

JKI State Machine是一种基于状态机的LabVIEW架构&#xff0c;由JKI公司开发。它广泛用于开发复杂的应用程序&#xff0c;提供了一种灵活且可扩展的结构&#xff0c;适用于多种任务的管理和执行。其设计目标是提高开发效率、代码可读性和可维护性。 2. 基本架构 JKI State Ma…

【算法题】520 钻石争霸赛 2024 全解析

都是自己写的代码&#xff0c;发现自己的问题是做题速度还是不够快 520-1 爱之恒久远 在 520 这个特殊的日子里&#xff0c;请你直接在屏幕上输出&#xff1a;Forever and always。 输入格式&#xff1a; 本题没有输入。 输出格式&#xff1a; 在一行中输出 Forever and always…

python给图片加上图片水印

python给图片加上图片水印 作用效果代码 作用 给图片加上图片水印图片水印的透明度&#xff0c;位置可自定义 效果 原始图片&#xff1a; 水印图片&#xff1a; 添加水印后的图片&#xff1a; 代码 from PIL import Image, ImageDraw, ImageFontdef add_watermark(in…

线性表——链式存储

单链表&#xff08;有头结点&#xff09; #include<stdio.h> #include<stdlib.h> //定义 typedef struct LNode{int data; //数据域 struct LNode *next; //指针域指向下一个结点&#xff0c;所以是 struct LNode类型 }LNode,*LinkList; //…

体检系统商业源码,C/S架构的医院体检系统源码,大型健康体检中心管理系统源码

体检系统商业源码&#xff0c;C/S架构的医院体检系统源码&#xff0c;大型健康体检中心管理系统源码 体检信息管理系统软件是对医院体检中心进行系统化和规范化的管理。系统从检前&#xff0c;检中&#xff0c;检后整个业务流程提供标准化以及精细化的解决方案。实现体检业务市…

C 语言实例 - 阶乘

一个正整数的阶乘&#xff08;英语&#xff1a;factorial&#xff09;是所有小于及等于该数的正整数的积&#xff0c;并且 0 的阶乘为 1。自然数 n 的阶乘写作 n!。 n!123…n。阶乘亦可以递归方式定义&#xff1a;0!1&#xff0c;1!1&#xff0c;n!(n-1)!n。 #include <st…

优化css样式的网站

一、按钮的css样式 https://neumorphism.io/#e0e0e0https://neumorphism.io/#e0e0e0 二、渐变样式 Fresh Background Gradients | WebGradients.com &#x1f48e;Come to WebGradients.com for 180 beautiful linear gradients in CSS3, Photoshop and Sketch. This collect…

【Linux+Docker】修改Docker容器中的hosts文件

1、进入容器bash docker exec -it <container_id> bash2、安装编辑器 2.1、安装vim apt-get updateapt-get install vim2.2、安装nano apt-get install nano3、编辑hosts文件 3.1、使用vim编辑 vi /etc/hosts3.2、使用nano编辑 nano /etc/hosts4、安装ping apt-get…

Git Core Lecture

1、Git 简介 官方介绍&#xff1a;Git is a fast distributed revision control system (Git 是一个快速的分布式版本控制系统) 2、Git Core Command 2.1 git init git 工程初始化&#xff0c;会在工作区 (working directory) 根目录中创建.git 目录 # 创建目录 $ mkdir git-i…

C# 深拷贝和浅拷贝

文章目录 1.深拷贝2.浅拷贝3.拷贝类4.浅拷贝的实现5.深拷贝实现5.1 浅拷贝对象&#xff0c;对引用类型重新一个个赋值5.2 反射实现5.3 利用XML序列化和反序列化实现 1.深拷贝 拷贝一个对象时&#xff0c;不仅仅把对象的引用进行复制&#xff0c;还把该对象引用的值也一起拷贝。…

MySQL数据库入门之视图、存储过程、触发器

一、视图&#xff1a; 1.1、视图是什么&#xff1f;怎么理解&#xff1f; 视图是从数据库的基本表&#xff08;或者视图&#xff09;导出的虚表&#xff08;数据库只放定义&#xff0c;它不实际存储数据&#xff0c;而是根据用户定义的SQL查询动态生成的结果集&#xff0c;具…

python期末作业:批量爬取站长之家的网站排行榜数据并保存,数据分析可视化

爬虫作业,含python爬取数据和保存文件,数据分析使用pyecharts做数据可视化 整体上分析网站的排名,直观看各个网站的热度。 数据分析之后大致的效果: 整个项目分为两个大的部分,第一部分就是抓取网站排名数据,然后保存为Excel、csv等格式,其次就是从文件中…