【matlab】代码库-双线性插值

interp_2D函数:实现双线性插值

摘要:该MATLAB函数interp_2D实现了二维双线性插值算法。函数接受两个点的坐标及其对应的查找表点,通过fund_updowm辅助函数确定相邻点位置后,先在x方向进行线性插值生成中间值,再在y方向进行插值计算最终结果。算法能正确处理边界情况(当点位于查找表节点时直接取值),适用于二维网格数据的插值计算。

matlab 复制代码
function out = interp_2D(point1,lut_ponit1,point2,lut_ponit2,lut)
%双线性插值计算公式
%    point1  |  注:ripple
%    point2  _  注:Gray


[x_down,x_up]=fund_updowm(point1,lut_ponit1);
[y_down,y_up]=fund_updowm(point2,lut_ponit2);

[V,H]=size(lut_ponit1);
num_point1=max(H,V);
[v,h]=size(lut_ponit2);
num_point2=max(h,v);

new_lut=zeros(num_point2,1,'double');
if x_down~=x_up
    for i=1:num_point1
        new_lut(i,1)=lut(i,x_down)+(point1-x_down)*(lut(i,x_up)-lut(i,x_down))/(x_up-x_down);
    end
else
    new_lut(:,1)=lut(:,x_down);
end

if y_down~=y_up
   
    out=double(new_lut(y_down)+(point2-lut_ponit2(y_down))*(new_lut(y_up)-new_lut(y_down))/(lut_ponit2(y_up)-lut_ponit2(y_down)));
   
else
    out=double(new_lut(y_down));
end



end
相关推荐
lzhdim11 小时前
SharpCompress:跨平台的 C# 压缩与解压库
开发语言·c#
嘿嘿嘿x311 小时前
Linux记录过程
linux·开发语言
默 语11 小时前
Records、Sealed Classes这些新特性:Java真的变简单了吗?
java·开发语言·python
止观止11 小时前
拥抱 ESNext:从 TC39 提案到生产环境中的现代 JS
开发语言·javascript·ecmascript·esnext
卷心菜狗11 小时前
Python进阶-深浅拷贝辨析
开发语言·python
时寒的笔记11 小时前
js逆向7_案例惠nong网
android·开发语言·javascript
Evand J11 小时前
【MATLAB例程】基于低精度IMU、GNSS的UAV初始航向(三维角度)校准的仿真,包含卡尔曼滤波、惯导解算与校正
开发语言·matlab·gnss·imu·卡尔曼滤波
feng_you_ying_li12 小时前
c++之哈希表的介绍与实现
开发语言·c++·散列表
网域小星球12 小时前
C 语言从 0 入门(十四)|文件操作:读写文本、保存数据持久化
c语言·开发语言·文件操作·fopen·fprintf
网域小星球12 小时前
C 语言从 0 入门(七)|字符数组与字符串完整精讲|VS2022 高质量实战
c语言·开发语言·字符串·vs2022·字符数组