x = image;
[J1,S1,C1,D1] = SWT2(x);
L = 1;
for i = 1:15
[J(1+i),S(1+i),C(1+i),D(1+i)] = SWT2(J(i))
e_J(i) = Entropy(J(i))
e_J(1+i) = Entropy(J(1+i))
L = L+1
if e_J(1+i) > e_J(i)
break
end
end
程序思路:输入一幅图像x,通过SWT2函数使x可以产生4幅图像(J1,S1,C1,D1)。对J1再调用SWT2函数产生4幅图像(J2,S2,C2,D2)。对J2再调用SWT2函数产生4幅图像(J3,S3,C3,D3),如此循环15次。
SWT2函数的功能:将输入的图像分解成近似图像,水平细节图像,垂直细节图像和对角细节图像
Entropy函数的功能:计算输入图像的熵值
上述代码肯定执行不了,那么在循环中如何利用i将J(1+i)定义成变量名?例如:当i=3时,J(1+i)表示为变量名为“J4”的一个变量。