Azzera filtri
Azzera filtri

Command window output of still running task

1 visualizzazione (ultimi 30 giorni)
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

Risposta accettata

Walter Roberson
Walter Roberson il 2 Set 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 Commenti
Pieter van den Berg
Pieter van den Berg il 2 Set 2011
That is unfortunate... thanks for the info.
Mustafa
Mustafa il 2 Set 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.

Accedi per commentare.

Più risposte (2)

Thomas Ibbotson
Thomas Ibbotson il 12 Set 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 Commenti
Xinyi Shen
Xinyi Shen il 27 Mag 2014
nobody explains how to use it. Therefore, there's still no way of doing so.
Thomas Ibbotson
Thomas Ibbotson il 28 Mag 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

Accedi per commentare.


Pieter van den Berg
Pieter van den Berg il 9 Set 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