Effacer les filtres
Effacer les filtres

Command window output of still running task

1 vue (au cours des 30 derniers jours)
Pieter van den Berg
Pieter van den Berg le 2 Sep 2011
Commenté : Thomas Ibbotson le 28 Mai 2014
Hello,
does anyone whether there is a way to get the command window output of a task while it is still running?
If not, is there another built-in way of monitoring running tasks (besides the state?)?
Thanks,
Pieter

Réponse acceptée

Walter Roberson
Walter Roberson le 2 Sep 2011
Start the session from another process, using OS-level pipe() to communicate with it. Unfortunately MATLAB does not flush its buffer at any particular time.
If you need graphics, you might have to read the output using screen capture techniques.
There is no mechanism within MATLAB to do what you would like (unfortunately.)
  2 commentaires
Pieter van den Berg
Pieter van den Berg le 2 Sep 2011
That is unfortunate... thanks for the info.
Mustafa
Mustafa le 2 Sep 2011
I just posted a question and i thought this is somewhat relevant to my question. I will appreciate any help
"Is it possible to check the whole history of a program which has let say i=20000 iteration. I have tried to debug the code but everything works fine till i=200 but i can't go till 20000.
The thing is when the program finishes, i can only see last couple of hundred iterations.
Is there anyway,i can check the whole program iteration(other than debugging)"
Cheers.

Connectez-vous pour commenter.

Plus de réponses (2)

Thomas Ibbotson
Thomas Ibbotson le 12 Sep 2012
Hi Pieter,
Starting in R2012b it is now possible to get the diary output of a task while it is still running. See http://www.mathworks.com/help/distcomp/release-notes.html.
Cheers, Tom
  2 commentaires
Xinyi Shen
Xinyi Shen le 27 Mai 2014
nobody explains how to use it. Therefore, there's still no way of doing so.
Thomas Ibbotson
Thomas Ibbotson le 28 Mai 2014
Here are some examples of how you might do this:
If you are using a batch job to run your task, then you can use the diary() function passing in the job while it is still running e.g.
job = batch('myScript');
diary(job)
If you are using jobs and tasks, you must set the CaptureDiary flag on the task to true, and then query the Diary property of the task e.g.
myCluster = parcluster;
job = createJob(myCluster);
task = createTask(job, @myFunction, 0, {}, 'CaptureDiary', true);
submit(job);
task.Diary

Connectez-vous pour commenter.


Pieter van den Berg
Pieter van den Berg le 9 Sep 2011
A hack that worked very well for me is to overload the built-in disp function with something that writes the output of the built-in disp to a logfile.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by