【Matlab】线性插值

例:

有一组函数,x=0:10:100,y=f(x),想线性插值的方式求函数值,例如:

x=2.5,根据x=0、f(0)、x=10、f(10)插值求x=2.5时的值

x=-10,根据x=0、f(0)、x=10、f(10)插值求x=-10时的值

x=55,根据x=50、f(50)、x=60、f(60)插值求x=55时的值

x=101,根据x=90、f(90)、x=100、f(100)插值求x=101时的值

注:此情况下,内插精度较高

代码:

主代码:

matlab 复制代码
%线性插值只有内插时精度是最好的
clc
clear
close all
%%
x=0:1:100;
y=sin(x);
x0=9.05;
y0=ChaZhi(x,y,x0)
%%
figure(1)
plot(x,y,'b-')
hold on
plot(x0,y0,'r*')

插值函数:

matlab 复制代码
function y0=ChaZhi(x,y,x0)%x是行矩阵
%%
xx=sort([x,x0]);
label=find(xx==x0);%找到x0的标签
label=label(1);
%% 找最近的两个数,超范围了就取最小/大的两个值
if label==1
    x1=xx(2);y1=y(1);
    x2=xx(3);y2=y(2);
elseif label==length(xx)
    x1=xx(length(xx)-1);y1=y(length(y));
    x2=xx(length(xx)-2);y2=y(length(y)-1);
else
    x1=xx(label-1);y1=y(label-1);
    x2=xx(label+1);y2=y(label);
end
%% 线性插值
y0=y2-(y2-y1)/(x2-x1)*(x2-x0);
相关推荐
可编程芯片开发7 小时前
基于时空相关性的风电功率预测模型matlab建模与仿真
matlab·时空相关性·风电功率预测模型
weixin_4284984914 小时前
使用MATIO库读取Matlab结构体(struct)数据的示例程序
matlab
阿昆的科研日常17 小时前
Matlab进阶绘图第74期-带填充纹理的单组柱状图
开发语言·matlab·可视化·论文插图
tianyukun022320 小时前
MATLAB学习笔记(二) 控制工程会用到的
笔记·学习·matlab
IT猿手1 天前
基于CNN-BiLSTM的深度Q网络(Deep Q-Network,DQN)求解移动机器人路径规划,MATLAB代码
网络·matlab·cnn
机器学习之心1 天前
多输入多输出 | Matlab实现BO-GRU贝叶斯优化门控循环单元多输入多输出预测
matlab·bo-gru·贝叶斯优化门控循环单元·多输入多输出预测
硬件大脑1 天前
MATLAB如何打印一个桃心形状
matlab
十七算法实验室2 天前
Matlab实现鼠群优化算法优化随机森林算法模型 (ROS-RF)(附源码)
开发语言·算法·决策树·随机森林·机器学习·支持向量机·matlab
软件算法开发3 天前
基于SIMP算法的材料结构拓扑优化matlab仿真
matlab·simp算法·材料结构·拓扑优化
机器学习之心3 天前
TCN-LSTM时间卷积长短期记忆神经网络多变量时间序列预测(Matlab完整源码和数据)
神经网络·matlab·lstm·多变量时间序列预测·tcn-lstm·时间卷积长短期记忆神经网络