【Matlab学习手记】拉格朗日插值

  •  源码
function [y0, coef] = Interpolation_Lagrange(x, y, x0)
%{
函数功能:拉格朗日插值法;
输入:
  x:已知点横坐标;
  y:已知点纵坐标;
  x0:未知点横坐标;
输出:
  y0:未知点纵坐标;
  coef:插值系数;
示例:
clear; clc;
x = 0 : 0.2 : 2;
y = sin(x);
x0 = 0.5;
[y0, coef] = Interpolation_Lagrange(x, y, x0);
plot(x, y, 'o-', x0, y0, '*');
%} 
% = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = 
if nargin < 3
   error('输入参数不足!');
end
m = length(x);
coef = zeros(m, 1);
y0 = 0;
for i = 1 : m
    coef(i) = 1;
    for j = 1 : m
        if j ~= i
            coef(i) = coef(i)*(x0 - x(j)) / (x(i) - x(j));
        end
    end
    y0 = y0 + y(i)*coef(i);
end

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值