if, for loop, median
显示 更早的评论
hi, I am new to matlab programming. I wish to write a program involving image processing, which serves the following purpose: consider a 3x3 window in a normalised 512x512 image. Compare each value of the pixel with 0.3. If the value of image pixel is less than 0.3, sort the vector, and find the median of all the pixels with value less than 0.3. And if value is more than 0.3, neglect that pixel value, and find median of all remaining pixels which have values less than 0.3. All of this should result in a new image. Thanks and Regards Manpreet Kapoor
采纳的回答
Is this 3 x 3 window to be slid overlapping over the whole image, or is the image to be broken up in to 3 x 3 blocks? If it is to be broken up in to 3 x 3 blocks, there is a problem because 512 is not divisible by 3.
You can use sorting to find the median if you want, but there is a median() function. For example, if P are the pixels in the window, then
median(P(P<0.3))
10 个评论
walter,
please dont concentrate on the size of the image, wat I want is the program to implement the logic given. I just want to see the way the functions are designed....
The logic for overlapping blocks is different than for non-overlapping blocks.
If you are using non-overlapping blocks, see
http://www.mathworks.com/matlabcentral/answers/5163-image-block-block-dividing
walter,
it is overlapping window, coz the median needs to be found for every pixel window, thus forming a new image. I know the function to be used is nlfilter, wat i want to know is the sequence of commands to perform the above said function. I basically need to learn the usage of functions in a program.
I'm not familiar with nlfilter, but it does appear suitable
B = nlfilter(A,[3,3],@(x) median(x(x<0.3)));
The rest of the problem statement is noise, two equivalent conditions.
hi
this command does not work, even wen I defined both A and B.... Wat to do?
Please be more specific about what you mean by "does not work". Do you have the image processing toolbox?
You might want to try the example given in the documentation,
http://www.mathworks.com/help/toolbox/images/ref/nlfilter.html
walter,
I have already gone through the above document earlier, wat I am facing trouble is in the the designing of 'fun' which performs the median of the pixel values less than 0.3.
I already mentioned I am new to matlab and programming watsoever, so cant understand the implementation of 'fun'. Please help.....
Okay, so let's go back to you being more specific about the command not working. What exactly do you mean by that? If the cameraman example from the documentation worked for you, then my very small variation on it should work. The cameraman example had median(x(:)) and I have median(x(x<0.3)) . For an array, x(x<0.3) will return a vector suitable for input to median, and that vector will consist only of the pixels with value less than 0.3 .
Sorry for the misunderstanding earlier, the logic u gave is absolutely correct, but the problem I have now is that nlfilter takes almost an hour to code one image, hence another command I found faster is colfilt.
can u offer any help in this....???
any help will be highly appreciated.
Thanks and Regards
Sorry, I am not familiar with colfilt .
I would think it likely that blkproc() or blockproc() would be much faster than nlfilter.
更多回答(0 个)
类别
在 帮助中心 和 File Exchange 中查找有关 Neighborhood and Block Processing 的更多信息
标签
另请参阅
2011-4-11
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!选择网站
选择网站以获取翻译的可用内容,以及查看当地活动和优惠。根据您的位置,我们建议您选择:。
您也可以从以下列表中选择网站:
如何获得最佳网站性能
选择中国网站(中文或英文)以获得最佳网站性能。其他 MathWorks 国家/地区网站并未针对您所在位置的访问进行优化。
美洲
- América Latina (Español)
- Canada (English)
- United States (English)
欧洲
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
