Why pause(eps) takes much time?
    조회 수: 12 (최근 30일)
  
       이전 댓글 표시
    
Hello !
My program is utilizing Matlab and Simulink for real-time music signal processing.
The structure of Matlab code is as follows :
while (k<= maximum_iteration)
    set_param('simulink', 'simulationcommand', 'pause');
    pause(eps);  % for update variable from simulink to matlab worksapce
    set_param('simulink', 'simulationcommand', 'continue');
    if( conditions on variable from simulink workspace )
     signal processing;
     end
     tic;
     pause(eps);    % (A)
     toc;
     k = k+1;
end
The purpose of my program is for processing signal of length 0.1s in real-time.
I put 'pause command' in part (A) since if that part is missing, the while-loop is excuted infinitely.
And execution time for part (A) is really variable like follows :
Elapsed time is 0.125663 seconds. Elapsed time is 0.137812 seconds. Elapsed time is 0.019411 seconds. Elapsed time is 0.210091 seconds. Elapsed time is 0.125145 seconds. Elapsed time is 0.004557 seconds. Elapsed time is 0.126217 seconds. Elapsed time is 0.003950 seconds. Elapsed time is 0.125991 seconds.
As I know, pause(eps) should take only eps time. But it takes much more time than eps. Can you guess how I can reduce that time? Because it makes program much slower.
If you give me any comments related to this, I really appreciate your help.
Thank you.
댓글 수: 0
답변 (3개)
  Azzi Abdelmalek
      
      
 2012년 8월 12일
        
      편집: Azzi Abdelmalek
      
      
 2012년 8월 12일
  
      if the speed of your Laptop is 177,730 MIPS at 3.33 GHz  hhttp://en.wikipedia.org/wiki/Instructions_per_second, that means the instruction "pause" takes at least 1/(177,730*1000000) sec to be executed. eps=2.2204e-16 which is very small. then your code can't be paused during eps. the minimum time of pause will be 1/(177,730*1000000) sec. the sampling frequency of your application can't be superior to the frequency of your processor
댓글 수: 0
  Tom
      
 2012년 8월 12일
        
      편집: Tom
      
 2012년 8월 12일
  
      It's just a limitation of the function- see the pause documentation: http://www.mathworks.com/help/techdoc/ref/pause.html?nocookie=true
"pause(n) pauses execution for n seconds before continuing, where n can be any nonnegative real number. The resolution of the clock is platform specific. A fractional pause of 0.01 seconds should be supported on most platforms."
댓글 수: 0
  Walter Roberson
      
      
 2012년 8월 12일
        The underlying implementation of pause() uses timers that are much coarser than eps() . The time for pause() should never be expected to be exact: at the best of times the time will be the requested time "plus or minus one tick".
I do not recall at the moment which of the internal timing facilities that pause() uses, but I believe it is at most 1000 ticks per second (1 Khz)
댓글 수: 0
참고 항목
카테고리
				Help Center 및 File Exchange에서 Sources에 대해 자세히 알아보기
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!



