news 2026/5/1 9:39:43

9种缺失值插值算法Matlab代码 含三次样条插值、线性插值、Hermite插值等 使用该程序可以

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
9种缺失值插值算法Matlab代码 含三次样条插值、线性插值、Hermite插值等 使用该程序可以

9种缺失值插值算法Matlab代码 含三次样条插值、线性插值、Hermite插值等 使用该程序可以:(1)实现缺失数据插值;(2)对定义域外的样本点进行插值;(3)区分内插和外插,均可以选择不同的算法 内插策略包括: 1:线性插值 2:最近邻点插值 3:下一个邻点插值 4:上一个邻点插值 5:保形分段三次插值 6:三次卷积插值 7:修正Akima三次Hermite插值 8:三次样条插值 9:插入固定值 外插策略包括: 1:使用与内插所用相同的方法来计算落在定义域范围外的点 2:为落在定义域范围外的点返回一个特定常量值 程序纯手写,可修改。

日常做数据分析总免不了遇到缺失值,就像炒菜突然发现盐罐子空了。今天咱们来盘一盘手写实现的九宫格插值工具箱,覆盖从基础线性到三次样条的各种骚操作,顺便解决外插这个让人头秃的问题。

先看核心函数怎么玩转内外插:

function yi = myinterp1(x,y,xi,method,extrap_method,extrap_val) % 输入检查略过...直接上干货 valid_indices = ~isnan(y); xv = x(valid_indices); yv = y(valid_indices); % 内插核心 switch method case 1 % 线性 yi = interp1_linear(xv,yv,xi); case 8 % 三次样条 pp = spline(xv,yv); yi = ppval(pp,xi); % 其他case处理... end % 外拓处理 out_of_range = xi < min(xv) | xi > max(xv); if any(out_of_range) switch extrap_method case 1 % 同内插 yi(out_of_range) = interp1_extend(xv,yv,xi(out_of_range),method); case 2 % 固定值 yi(out_of_range) = extrap_val; end end end

这个函数骨架妙在把内外插策略解耦,比如可以内插用三次样条保持曲线顺滑,外插直接给固定值防止飞上天。重点看几个特色实现:

保形分段三次插值(PCHIP)的微分计算很有意思:

function slopes = pchip_slopes(x,y) h = diff(x); delta = diff(y)./h; slopes = zeros(size(y)); % 端点处理 slopes(1) = delta(1); slopes(end) = delta(end); % 中间点斜率调和 for k = 2:length(x)-1 w1 = 2*h(k)+h(k-1); w2 = h(k)+2*h(k-1); slopes(k) = (w1+w2)/(w1/delta(k-1) + w2/delta(k)); end end

这种加权调和算法既避免三次样条的过度震荡,又比单纯的平均值更符合数据趋势。实际测试时发现,对股价这类需要保持单调性的数据效果拔群。

外插的智能延伸策略有点讲究,比如线性外插不是简单延直线:

function ye = linear_extend(x,y,xe) dx = x(end)-x(end-1); dy = y(end)-y(end-1); k = dy/dx; if isinf(k) % 处理垂直情况 ye = y(end)*ones(size(xe)); else ye = y(end) + k*(xe - x(end)); end end

这里特意处理了斜率无穷大的极端情况,防止出现NaN污染数据。曾经在电梯运行数据中遇到过这种垂直跳变,这种防御性编程能救命。

实战演示:处理带缺口的心电信号

t = 0:0.1:10; ecg = 2*sin(t) + 0.5*cos(3*t); ecg(35:45) = NaN; % 模拟信号丢失 % 三次样条内插+固定外推 filled1 = myinterp1(t,ecg,t,8,2,0); % Akima外插延续趋势 filled2 = myinterp1(t,ecg,t,7,1,0); subplot(2,1,1); plot(t, filled1); % 缺口处平滑过渡 subplot(2,1,2); plot(t, filled2); % 外沿保持波形走势

对比发现三次样条在缺口内部更平滑,但Akima在外插时延续波形更自然。这工具箱妙在能像乐高一样组合不同策略,比如用保形插值处理陡峭边缘,卷积插值处理周期性信号。

最后给个忠告:别迷信三次样条!曾有个项目用样条插值温度数据,结果外插时预测出-50℃的极端值,实际传感器最高才测到40℃。这种时候设置extrap_method=2加个合理阈值,比算法自high靠谱多了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 7:14:26

SQLALchemy与fastapi结合的基本流程与注意事项整理

文章目录一、模块导入二、初始化FastAPI对象三、数据库配置1、定义 SQLite 数据库的连接路径2、创建数据库连接3、创建会话四、创建数据库模型1、创建一个基础类2、定义数据库模型五、创建数据库表六、创建用户模型七、设置接口实例一、模块导入 from fastapi import FastAPI,…

作者头像 李华
网站建设 2026/5/1 7:19:43

通达信抄底王 源码

{}VAR2:MA(CLOSE, 5); VAR3:MA(CLOSE, 10); VAR4:MA(CLOSE, 20); VAR5:MA(CLOSE, 30); VAR6:(VAR2VAR3VAR4VAR5)/4; VAR7:(VAR6-REF(VAR6, 15))/REF(VAR6, 15)*100; VAR8:(VAR6-REF(VAR6, 15))/REF(VAR6, 15)*100; VAR9:EMA(VAR7, 8);{} 反转:STICKLINE(VAR9>1*REF(VAR9, 1)…

作者头像 李华
网站建设 2026/5/1 9:19:31

2、数学问题编程解决方案

数学问题编程解决方案 1. 问题概述 本文将介绍一系列数学问题及其对应的编程解决方案,涵盖了从基础的数学运算到复杂的数论问题。以下是这些问题的列表: 1. 计算小于给定上限的能被 3 或 5 整除的自然数之和。 2. 计算两个正整数的最大公约数。 3. 计算两个或多个正整数…

作者头像 李华
网站建设 2026/5/1 0:27:23

4、C++ 编程:语言特性与字符串处理技巧

C++ 编程:语言特性与字符串处理技巧 1. 高效资源管理与温度标量处理 1.1 资源管理优化 在处理资源时,合理的管理方式至关重要。例如,在文件操作中,若异常发生或开发者遗忘释放资源,可能导致句柄未正确关闭。以下是一个优化后的示例代码: void good_handle_example()…

作者头像 李华