目录
1.一维时间序列线性插值
线性插值的核心思想:在两个已知点之间,用直线拟合未知点的函数值。

如上图所示,令y=f(x),设一维坐标轴上有两个已知点:(xi-1,yi-1)和(xi,yi),待求点x位于区间xi-1,xi 内,其对应的函数值y可以表示为。
y=yi-1+(yi-yi-1)/(xi-xi-1)*(x-xi-1)
这个部分对应的matlab程序如下:
clear; clc; close all;
%% ==================== 1. 构造已知原始点(样本点) ====================
x_known = 1:100; % 已知点x坐标
y_known = sin(2*pi*x_known/100); % 已知点y值(可任意修改)
N_known = length(x_known); % 已知点数量
%% ==================== 2. 生成需要插值的目标点 ====================
% 生成密集x坐标,用于插值(比原始点更密)
x_min = min(x_known);
x_max = max(x_known);
x_interp = linspace(x_min, x_max, 9); % 插值目标点(100个点)
N_interp = length(x_interp);
% 初始化插值结果
y_interp = zeros(1, N_interp);
%% ==================== 3. 一维线性插值核心算法(纯公式实现) ====================
for k = 1:N_interp
x = x_interp(k); % 当前待插值点
% ========== 步骤1:找到x落在哪个已知区间 x_known(i), x_known(i+1) ==========
i = 1;
while i < N_known && x > x_known(i+1)
i = i + 1;
end
% 区间两个端点
x0 = x_known(i);
y0 = y_known(i);
x1 = x_known(i+1);
y1 = y_known(i+1);
% ========== 步骤2:计算归一化插值系数 α ==========
dx = x1 - x0;
if dx == 0
alpha = 0; % 避免除零
else
alpha = (x - x0) / dx;
end
% ========== 步骤3:线性插值公式(加权形式) ==========
y = (1 - alpha) * y0 + alpha * y1;
% 保存结果
y_interp(k) = y;
end
%% ==================== 4. 结果可视化 ====================
figure('Name','一维线性插值结果');
plot(x_known, y_known, 'r', 'LineWidth', 2, 'MarkerSize', 8); % 已知点
hold on;
plot(x_interp, y_interp, 'b-o', 'LineWidth', 1.5); % 插值曲线
legend('已知离散点','一维线性插值结果','Location','best');
xlabel('X 轴');
ylabel('Y 轴');
grid on; grid minor;
其对应的仿真结果如下图所示:

2.二维图像双线性插值
双线性插值本质:在二维平面上,分三步执行一维线性插值------ 先对行方向插值,再对列方向插值,最终得到未知点的灰度值。其原理如下图所示:

其中,(x0, y0)、(x0, y1)、(x1, y0)、(x1, y1) 均为原图像上的像素坐标点,灰度值分别对应为f(x0, y0)、f(x0, y1)、f(x1, y0)、f(x1, y1)。而灰度值未知的插值点(x, y),根据双线性插值法的约束,可以先由像素坐标点(x0, y0)和(x0, y1) 在y轴向作一维线性插值得到f(x0, y)、由像素坐标点(x1, y0)和(x1, y1)在y轴向作一维线性插值得到 f(x1, y),然后再由(x0, y)和(x1, y)在x轴向作一维线性插值得到插值点(x, y)的灰度值f(x, y)。
这个部分对应的matlab程序如下:
clear; clc; close all;
%读取图像
img = rgb2gray(imresize(imread('1.jpg'),256,256)); % 替换为你的图像路径
H, W, C = size(img); % H=高 W=宽 C=通道数
%设置目标尺寸(放大2倍)
scale = 2;
H_new = round(H * scale);
W_new = round(W * scale);
% 新建空白目标图
img_out = zeros(H_new, W_new, C, 'uint8');
%3. 双线性插值核心(逐像素计算)
for ch = 1:C
for x = 1:H_new
for y = 1:W_new
% ======================
% 反向映射:目标坐标 → 原图坐标
% ======================
u = (x - 1) * H / H_new + 1;
v = (y - 1) * W / W_new + 1;
% ======================
% 找到四个最近邻点
% ======================
i = floor(u);
j = floor(v);
i1 = i + 1;
j1 = j + 1;
% ======================
% 边界检查(防止越界)
% ======================
i = max(i, 1);
i1 = min(i1, H);
j = max(j, 1);
j1 = min(j1, W);
% ======================
% 取四个点的像素值
% ======================
f11 = double(img(i, j, ch));
f12 = double(img(i, j1, ch));
f21 = double(img(i1, j, ch));
f22 = double(img(i1, j1, ch));
% ======================
% 双线性插值公式
% ======================
a = u - i; % 垂直方向权重
b = v - j; % 水平方向权重
value = (1 - a) * (1 - b) * f11 + (1 - a) * b * f12 + a * (1 - b) * f21 + a * b * f22;
% 赋值
img_out(x, y, ch) = uint8(value);
end
end
end
imshow(img); title('原始图像');
figure;
imshow(img_out); title('双线性插值结果');
仿真结果如下图所示:

我们打开上述两个图像的变量名称,以图像中心区域为例,线性插值效果如下:

如上图所示,像素75,44之间,通过插值,多了一个60的像素值。