码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Lagrange插值法实验:求拉格朗日插值多项式和对应x的近似值matlab实现(内附代码)


    一、实验要求

    已知函数表:
    在这里插入图片描述
    求出Lagrange 插值多项式,并计算x=1.2处的y的近似值。

    二、MATLAB代码

    求解多项式:

    X = input('请输入横坐标向量X:\nX=');  % 获取用户输入的横坐标向量
    Y = input('请输入纵坐标向量Y:\nY=');  % 获取用户输入的纵坐标向量
    m = length(X);  % 获取节点个数
    L = ones(m, m);  % 初始化基函数系数矩阵
    for k = 1 : m  % 循环计算每个基函数的系数
        V = 1;  % 初始化基函数的临时变量
        for i = 1 : m
            if k ~= i  % 排除当前节点时的计算
                V = conv(V, poly(X(i))) / (X(k) - X(i));  % 在当前节点处计算基函数的系数
            end
        end
        L(k, :) = V;  % 将基函数的系数存储到矩阵中
    end
    l = sym(zeros(m, 1));  % 初始化基函数数组
    for k = 1 : m  % 遍历基函数系数矩阵
        l(k) = poly2sym(L(k, :));  % 将基函数系数转化为符号表达式
    end
    fprintf('基函数为:\n');
    for k = 1 : m  % 输出每个基函数的表达式
        fprintf('q%d(x)=%s\n', k, char(l(k)));
    end
    P = sym(0);  % 初始化拉格朗日多项式
    for k = 1 : m  % 计算拉格朗日多项式的表达式
        P = P + Y(k) * l(k);
    end
    fprintf('拉格朗日多项式为:\nP(x)=%s\n', char(P));  % 输出拉格朗日多项式的表达式
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    求解近似值:

    % 定义拉格朗日插值多项式的系数
    coeff = [1/12, -29/6, 1/12, 62/3];
    
    % 计算 x=1.2 处的 y 的近似值
    x = 1.2;
    y_approx = polyval(coeff, x);
    
    % 显示结果
    disp(['当 x = ' num2str(x) ' 时,y 的近似值为 ' num2str(y_approx)]);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    三、实验结果

    请输入横坐标向量X:
    X=[1, 2, 4, 5]
    请输入纵坐标向量Y:
    Y=[16,12,8,9]
    基函数为:
    q1(x)=(11x^2)/12 - (19x)/6 - x^3/12 + 10/3
    q2(x)=(29x)/6 - (5x^2)/3 + x^3/6 - 10/3
    q3(x)=(4x^2)/3 - (17x)/6 - x^3/6 + 5/3
    q4(x)=(7x)/6 - (7x^2)/12 + x^3/12 - 2/3
    拉格朗日多项式为:
    P(x)=x^2/12 - (29*x)/6 + x^3/12 + 62/3
    在这里插入图片描述
    当 x = 1.2 时,y 的近似值为 13.9507

    参考:lagrange插值法:求拉格朗日插值多项式matlab实现(内附代码及例题)

  • 相关阅读:
    阿里云ECS和轻量服务器有什么区别?
    day01_matplotlib_demo
    np中的normalize/histogram/cumsum/interp函数
    都知道0.1+0.2 = 0.30000000000000004,那要怎么让它等于0.3
    牛视系统源码定制开发,抖音矩阵系统定制开发。
    让mybatis-plus支持NOT逻辑运算
    方法引用知识点
    虚函数可不可以重载为内联 —— 在开启最大优化时gcc、clang和msvc的表现
    Windows学习总结(24)—— 升级到 Windows 11 版本的九个理由
    2023版 STM32实战11 SPI总线读写W25Q
  • 原文地址:https://blog.csdn.net/m0_63007797/article/details/133531585
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号