Hello Mat

 找回密码
 立即注册
查看: 3704|回复: 0

双线性滤波插值图像

[复制链接]

1323

主题

1551

帖子

0

金钱

管理员

Rank: 9Rank: 9Rank: 9

积分
22647
发表于 2017-3-8 23:25:07 | 显示全部楼层 |阅读模式
  1. function A_interp_pic = Bilinear_Filter_interp(A, filter_coef)
  2. % 双线性插值滤波
  3. % Input:    A: 输入图像
  4. %           filter_coef: 滤波器系数
  5. % Output:   
  6. %           A_interp_pic:  双线性插值滤波图像

  7. if (length(size(A)) == 3)
  8. % 如果输入图像为3D数组,则重复插值滤波3次
  9.     for i=1:3
  10.         A_interp_pic(:,:,i) = Bilinear_Filter_interp(A(:,:,i),filter_coef);
  11.     end
  12.    
  13. else
  14.     [m,n] = size(A);       % 求行列
  15.     % 初始化
  16.     A1 = [];           % 初始化
  17.     A_interp_pic = []; % 初始化
  18.     % 列插值
  19.     A_col= filter2(filter_coef,A);       % 滤波
  20.     for i=1:n
  21.         A1 = [A1, A(:,i), A_col(:,i)];
  22.     end
  23.     A1(:,end) = [];    % 去边缘
  24.     % 行插值
  25.     A_rows = filter2(filter_coef,A1')';  % 滤波
  26.     for i=1:m
  27.         A_interp_pic = [A_interp_pic; A1(i,:); A_rows(i,:)];
  28.     end
  29.     A_interp_pic(end,:) = []; % 去边缘
  30.    
  31. end
复制代码
主程序:filter_coef = [1 1]/2 ;  % (Bilinear Filter)
im_inter = Bilinear_Filter_interp(im, filter_coef);








算法QQ  3283892722
群智能算法链接http://halcom.cn/forum.php?mod=forumdisplay&fid=73
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Python|Opencv|MATLAB|Halcom.cn ( 蜀ICP备16027072号 )

GMT+8, 2024-11-22 23:20 , Processed in 0.191229 second(s), 22 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表