【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
相关推荐
FQNmxDG4S4 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
前端老石人5 小时前
HTML 字符引用完全指南
开发语言·前端·html
matlab_xiaowang5 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
虹科网络安全5 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje5 小时前
Java语法进阶
java·开发语言·jvm
老前端的功夫6 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287926 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
止语Lab6 小时前
从手动到框架:Go DI 演进的三个拐点
开发语言·后端·golang
yaoxin5211236 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
小短腿的代码世界6 小时前
Qt日志系统深度解析:从qDebug到企业级日志框架
开发语言·qt