Imshow on Parallel Computing Toolbox
3 views (last 30 days)
Show older comments
Dimitris Vayenas
on 8 Apr 2013
Commented: Walter Roberson
on 13 Feb 2020
I am converting my code to utilise the Parallel Computing Toolbox and I am getting a peculiar error in an imshow instruction:
Error using imshow (line 209) IMSHOW unable to display image.
Error in GPUDemo (line 9) parfor (HSize = 1:n);
Caused by: Error using imshow (line 209) IMSHOW unable to display image.
line 209 of Imshow is the error message:
if ~images.internal.isFigureAvailable() error(message('images:imshow:needJavaFigure')); end
The error appears only when I use the matlabpool.
Obviously I am using many pools in order to have each pool applying a different value for a parameter (eg. HSize or Sigma in an imfilter) to the image
So I cant quite get the Aprils fool joke here: http://blogs.mathworks.com/steve/?s_cid=global_nav :(
Thank you.
0 Comments
Accepted Answer
Walter Roberson
on 8 Apr 2013
It is not possible to display graphics from inside a worker. The joke was in saying that it was possible.
Note the reference to the non-existent R2011c, and to running on TRS-80's.
5 Comments
Walter Roberson
on 9 Apr 2013
As far as I have determined, the protocol used between the parent and the workers is a message-passing protocol that (for whatever reasons) has not been designed to handle graphics messages. It appears that except for spmd, the protocols might possibly have been designed to send in the data and only listen for the result message -- though perhaps that approach would be too simplistic to account for distributed arrays.
Each worker is a separate process that does not have access to the graphics (which is in the memory space of the parent process... which might not even be on the same computer.)
I do agree that it would seem plausible to be able to handle graphics through a message passing protocol (e.g., X Windows is designed that way.) I do not know why that was not used.
rgb2gray() is, at heart, a fairly simply matrix multiplication; it should not be difficult to write a replacement for it that would execute on GPU, except possibly over the issue of single precision vs double precision.
More Answers (3)
Daniel Golden
on 29 Apr 2014
I'm running R2014a and the image and imagesc functions do work within parfor loops, although the imshow function does not. If you substitute image for imshow, follow it with this command to get similar results:
axis image off
However, the pixels shown on the screen won't be 1:1 like they are by default with the imshow command.
0 Comments
kinjal shah
on 6 Mar 2015
what is about the imshow error? what is solution?
2 Comments
shital shinde
on 13 Feb 2020
Edited: shital shinde
on 13 Feb 2020
anybody please tell me how to convert matlab code into many core and multi core. I attached the file for image watermarking. but i want to perform parallelization on it. please help me for code.
See Also
Categories
Find more on Asynchronous Parallel Programming in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!