当前位置: 首页 > news >正文

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靠谱多了。

http://www.cnnetsun.cn/news/52222.html

相关文章:

  • 全面沦陷:所有 LLM 与 AI 绘画模型已被攻破——红队实战全景报告(2025)
  • systemd服务管理深入实践从入门到自定义服务
  • 基于微信小程序的网络安全知识科普平台系统【源码文末联系】
  • 基于VUE的实验室使用管理系统[VUE]-计算机毕业设计源码+LW文档
  • 【单片机毕业设计】【mcugc-mcu911】基于单片机的多功能安防系统
  • 【单片机毕业设计】【mcugc-mcu916】基于单片机的智能家居安防系统
  • 基于vue的家庭服务预约管理系统的设计与实现_f1709smp_springboot php python nodejs
  • Java---小球移动案例(附代码)
  • 分享一个夸克网盘不限速的下载方法-在线免费工具
  • 1、现代 C++ 挑战:从基础到实战
  • 当数据回归遇上暴击流:SVM Adaboost实战手札
  • 65、文件管理子系统与网络协议通信概述
  • DAY18 机器学习
  • jd.item_review获取京东商品评论 及tb.item_review获取taobao商品评论
  • Windows11系统文件verifier.dll丢失或损坏问题 下载修复
  • C++树形数据结构————树状数组、线段树中“逆序对”的问题
  • 2025年B站视频下载终极指南:bilili工具完整使用教程
  • 教程 32 - 几何体系统
  • Cursor高级技巧与最佳实践
  • Cursor + MCP:冲击的不仅是前端,而是整个软件开发范式!
  • 2025年十大旗舰对决:极致轻薄成高端手机新战场
  • 【Vue3】 中 ref 与 reactive:状态与模型的深入理解
  • 毕设 stm32 RFID员工打卡门禁系统(源码+硬件+论文)
  • 全球最大、最领先的吉利全球全域安全中心正式发布
  • Android中Compose系列之按钮Button
  • wangEditor导入excel数据到html富文本编辑
  • 光伏电池simulink仿真模型 光伏电池建模仿真 包括改变温度 改变辐照度的特性分析 模型可...
  • JSP中如何利用分块技术实现百万文件上传优化?
  • 60、Ubuntu 安装硬件规划全攻略
  • 2025年12月— CET四六级答案