diff options
Diffstat (limited to 'SD-VBS/common/toolbox/MultiNcut/doog1.m')
-rwxr-xr-x | SD-VBS/common/toolbox/MultiNcut/doog1.m | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/SD-VBS/common/toolbox/MultiNcut/doog1.m b/SD-VBS/common/toolbox/MultiNcut/doog1.m new file mode 100755 index 0000000..dd8e87b --- /dev/null +++ b/SD-VBS/common/toolbox/MultiNcut/doog1.m | |||
@@ -0,0 +1,32 @@ | |||
1 | function H=doog1(sig,r,th,N); | ||
2 | % H=doog1(sig,r,th,N); | ||
3 | |||
4 | |||
5 | % by Serge Belongie | ||
6 | |||
7 | no_pts=N; % no. of points in x,y grid | ||
8 | |||
9 | [x,y]=meshgrid(-(N/2)+1/2:(N/2)-1/2,-(N/2)+1/2:(N/2)-1/2); | ||
10 | |||
11 | phi=pi*th/180; | ||
12 | sigy=sig; | ||
13 | sigx=r*sig; | ||
14 | R=[cos(phi) -sin(phi); sin(phi) cos(phi)]; | ||
15 | C=R*diag([sigx,sigy])*R'; | ||
16 | |||
17 | X=[x(:) y(:)]; | ||
18 | |||
19 | Gb=gaussian(X,[0 0]',C); | ||
20 | Gb=reshape(Gb,N,N); | ||
21 | |||
22 | m=R*[0 sig]'; | ||
23 | |||
24 | a=1; | ||
25 | b=-1; | ||
26 | |||
27 | % make odd-symmetric filter | ||
28 | Ga=gaussian(X,m/2,C); | ||
29 | Ga=reshape(Ga,N,N); | ||
30 | Gb=rot90(Ga,2); | ||
31 | H=a*Ga+b*Gb; | ||
32 | |||