拉格朗日插值法的matlab实现

一、基本原理

比如有如下这些点

x1 x2 x3 x4
y1 y2 y3 y4

那么在拉个朗日原理中可以把过这些点的曲线表示为:

其g(x)y叫做一个插值基函数 (开关),当x=x1时,g1(x)=1,而当x=x2,x3,x4时,g1(x)都为0,其他的也是如此,这样当x=x1时,f(x)中就只保留了g1(x)y1项,其他项都为0,就保证了过点(x1,y1);其他点以此类推;

原理讲解得很简单,具体可以参考其他文献资料。

二、Matlab代码

matlab 复制代码
clear
clc

x = [466 741 950 1422 1634];
y = [7.04 4.28 3.40 2.54 2.13];

x1 = min(x):0.5:max(x);
y1 = lagrange(x,y,x1);
plot(x,y,'ko',x1,y1,'r-')

function fx = lagrange(x0,y0,x)
    m = length(x);
    n = length(x0);
    for i = 1:m
        z = x(i);
        s = 0;
        for k = 1:n
            p = 1;
            for j = 1:n
                if j~=k
                    p = p * (z-x0(j))/(x0(k)-x0(j));
                end
            end
            s = p*y0(k)+s;
        end
        fx(i) = s;
    end
end
相关推荐
阿常112 小时前
解决Maven项目中报错“java不支持版本6即更高的版本 7”
java·开发语言·maven
Stay Passion3 小时前
Java 实用工具类:Apache Commons IO 的 IOUtils
java·开发语言·apache
买了一束花5 小时前
二、机器学习中Python变量基础
开发语言·python·机器学习·conda
heyCHEEMS5 小时前
最大子段和 Java
java·开发语言·算法
bj32816 小时前
树的同构问题--Python
开发语言·python·算法
八股文领域大手子6 小时前
单机 vs 分布式:Java 后端限流的选择题
java·开发语言·数据结构·算法·spring
钢铁男儿7 小时前
C# 类成员的访问:内部与外部
服务器·开发语言·c#
小文数模8 小时前
2025五一数学建模竞赛B题完整分析论文(共42页)(含模型、可运行代码、数据)
python·数学建模·matlab
薛慕昭8 小时前
《ESP32无线网络编程全攻略:从STA/AP模式到NTP时间同步》
开发语言·单片机·嵌入式硬件
小杨升级打怪中9 小时前
前端面经-VUE3篇(二)--vue3组件知识(二)依赖注入、异步组件、生命周期、组合式函数、插件
开发语言·前端·javascript