Difference between revisions of "PLS Timing Issues"

From SoftMC-Wiki
Jump to: navigation, search
(Delete section)
(Debug variables)
Line 53: Line 53:
 
Two read-only properties returning in microseconds the time of the IO toggle. If not initiated -1 will be returned.
 
Two read-only properties returning in microseconds the time of the IO toggle. If not initiated -1 will be returned.
  
 +
[[Axystems:MC-Basic:pls.HWIOtime |PLS.HWIOtime ]]
  
=== <nowiki><pls>.PLSdelaytime[<index>]</nowiki> ===
+
[[Axystems:MC-Basic:pls.PLSdelaytime | PLS.PLSdelaytime]]
 
 
 
 
See: [[Axystems:MC-Basic:pls.PLSdelaytime | PLSdelaytime]]
 
  
 
== General illustration of PLS-timing ==
 
== General illustration of PLS-timing ==

Revision as of 11:14, 15 May 2014

Introduction

This document describes timing issues of PLS triggering.

The following variables influence PLS timing.

Axis.PositionErrorDelay

PLS.HWAssistance

PLS.PLSPropagationDelay


At samples in motion profile where acceleration profile change its basic formula (jerk discontinuity) there will be an increased error in computing the inter-sample delay (Δt). This is due to the in-availability of exact profile change parameter inside of one sample. Also the higher-order (quadratic, cube, sine, ….) acceleration profiles are not modeled in the inter-sample delay (Δt) calculations, therefore an error of JT3/6 is to be expected.

In all cases of non-linear acceleration change:

  • sine acceleration
  • one-sample duration movements
  • velocity-trapeze corners
  • acceleration-trapeze corners
  • extreme acceleration (so acc phase duration is 1 sample) or very short movement

there will be an increased error in computing of the inter-sample delay (Δt)! It is very difficult to estimate the position error introduced but it is typically around JT3/6.



NOTE-Info.svgNOTE
Note that in cases of extremely short motions (velocity or acceleration too high or path length too short) even if user commanded sine-acceleration profile the system will automatically change it to velocity-trapeze.
NOTE-Info.svgNOTE
If PLS is triggered by a “feedback” source like PFB or PEXT we will always have PLS triggered too late. But in this case no additional delay should be added!

Buffering

As noted in previous paragraphs the delay of the motion-bus forces the system to postpone the switching of the PLS output. Therefore the detected PLS output switch events are stored in the buffer and executed after the estimated delay.

There are two different buffers (per each PLS) dedicated for the PLS delayed outputs:


  • Motion-Bus PLS delay Buffer, used for storing PLS-delays through multiple sampling periods. The size of this buffer is: 2 (FW ver: 4.5.29) - 4*10(FW ver: 4.5.31 and later)
  • Digital Output microsecond delay buffer. Used for storing microsecond delays of only one motion-bus sample. The size of this buffer is 4 and it is hardware defined.


NOTE-Info.svgNOTE
Note that in the systems with relatively big motion-bus delay (PositionErrorDelay >> 3) number of the stored PLS switches can be bigger then the Motion-Bus Delay Buffer size. In this case the error returned will be 3298: "The PLS positions are too close to each other and/or the velocity is too high for output to toggle". In case there is more then 4 PLS in one sample the IO error will be returned 21011: "Too many PLS toggling requested ".


Debug variables

Two read-only properties returning in microseconds the time of the IO toggle. If not initiated -1 will be returned.

PLS.HWIOtime

PLS.PLSdelaytime

General illustration of PLS-timing

Axystems;Plstiming-scheme.png

--Mirko 10:23, 15 November 2010 (CET)