How can i write this equation in matlab ??????
1 次查看(过去 30 天)
显示 更早的评论
(v(i,j))^(k+1)= (1-ω)(v(i,j))^(k)-ω[(W1(i,j)(v(i+1,j))^(k)+ W2(i,j)(v(i-1,j))^(k+1)+ W3(i,j)(v(i,j+1)^(k)+ W4(i,j)(v(i,j-1))^(k+1)(/(W i,j)]
v matrix k iteration W may by matrix (have i &j) w constant
0 个评论
回答(2 个)
John Petersen
2013-9-18
The trick is to update v(i-1,j) and v(i,j-1) without updating v(i+1,j) and v(i,j+1) before going on the v(i,j). After that do:
v(i,j)= (1-ω)*v(i,j) - ω*[(W1(i,j)*v(i+1,j) + W2(i,j)*v(i-1,j) + W3(i,j)*v(i,j+1) + W4(i,j)*v(i,j-1))/W(i,j)]
3 个评论
Image Analyst
2013-9-18
convolution, conv2(), and imfilter() do this "trick" inherently and efficiently. With your code, as you move over to the next j, your v(i,j) will now be the new v(i, j-1) and will be affected. So it will have some kind of recursive/hysteresis effect or trailing blur or something that's not right. imfilter() and conv2() do not suffer from this. If she insists on using two nested for loops (a much less efficient approach especially for larger windows) then she'll have to at least assign the result (right hand side of the equation) to a new output variable, like vout(i,j), not the original input variable.
conv2() and imfilter are more efficient because they only need to read in and discard a few of the pixels on the edge, not the whole array. For example with a 7x7 window, you have 49 elements/pixels in the window but as you slide over one pixel you only need to read in 7 new pixels, not all 49.
Image Analyst
2013-9-18
编辑:Image Analyst
2013-9-18
Looks like unsharp masking, so you can do this
kernel = [0, W1, 0; W3, 0, W4; 0, W2, 0];
filtered = conv2(vk, kernel, 'same');
vk = (1-omega)*vk + filtered./W;
8 个评论
Image Analyst
2013-9-20
Just tell me what it's supposed to do. It looks like you might be able to use convolution but if W1, etc. are not constants, then maybe not. I really need to know what the intent of that code is. For example if it's to do unsharp masking then you should use a different output variable if you're going to do it in a loop so that you avoid hysteresis. I suspect that you transcribed the equation incorrectly but I can't say exactly how to fix it unless I know what you want to accomplish. John's code will probably work in that it will do what you tried to do, but I'm not sure that is really what you want to do because I don't feel that you described in words properly what you want to do.
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!