【语言转换】matlab imdilate,strel参数为square的方法idl实现

matlab中用来求扩张的方法,在参数第一项中有很多选项,详情~~帮助文档里有,本文实现的是参数为‘square’的方法。

SEs=strel('square',b); 
a=imdilate(a,SEs);

在matlab中应是如上的语句。应是规定一个b*b的矩形模板,对a进行掩膜,每个值取邻域b*b里最大的值。

idl中通过实现方法是这样调用的:

a=imdilate_square(a,b)

具体方法实现如下,测试用例也在前面有:

FUNCTION imdilate_square,dataimage,valueimage
;PRO imdilate_square

;dataimage=[[1,2,3,4,5,6,7,8,9,10],[10,2,3,4,5,6,7,8,9,1],[1,2,3,4,5,6,7,8,9,10],[3,4,5,6,7,8,9,10,1,2]]
result=dataimage
;valueimage=3
errorvalue=min(dataimage)

cols=n_elements(dataimage[*,0])
rows=n_elements(dataimage[0,*])
;合法性检查
if valueimage le 0 then begin
  return,-1
endif
if valueimage gt cols && cols le rows then begin
  valueimage=cols
endif
if valueimage gt rows && rows le cols then begin
  valueimage=rows
endif

for i=0, rows-1 do begin
  for j=0, cols-1 do begin
    tmpmatirx= dblarr(valueimage*valueimage)
    tmp=0
    for h=-valueimage+2,valueimage-2 do begin
      for k=-valueimage+2,valueimage-2 do begin
        if j+h lt 0|| i+k lt 0 then begin
          tmpmatirx[tmp]=errorvalue
        endif else if j+h gt cols-1|| i+k gt rows-1 then begin
            tmpmatirx[tmp]=errorvalue
        endif else begin
          tmpmatirx[tmp]=dataimage[j+h,i+k]
        endelse
        tmp++
      endfor
    endfor
    result[j,i]=max(tmpmatirx)
  endfor
endfor

;print,result
return,result
END


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值