XFC_TimeToModuloPosition
XFC_TimeToModuloPosition berechnet die Zeitdauer, innerhalb derer eine Achse eine Position erreichen wird bzw. die Zeitdauer, die vergangen ist, seit die Achse diese Position passiert hat. Die Position ist in diesem Fall die in Fahrtrichtung nächstliegende Modulo-Position.
Die Funktion extrapoliert den Zeitpunkt bezogen auf die aktuelle Position und Dynamik. Eine genaue Extrapolation ist nur über einen kurzen Zeitraum möglich, da sich die Dynamik der Achse ändern kann.
Der Funktionsbaustein benötigt genau einen Aufruf, um das Ergebnis bereitzustellen. Er kann also ähnlich wie eine Funktion verwendet werden, gibt aber neben der Zeit eventuell auch einen Fehler zurück. Dieser Fehler muss ausgewertet werden, um sicherzustellen, dass die berechnete Zeitdauer gültig ist.
Eingänge
VAR_INPUT
Position : LREAL;
ModuloFactor : LREAL;
Options : ST_NcTimeConversionOptions;
END_VAR
Position | Absolute Achsposition | |
ModuloFactor | Modulo-Teiler, der für die Berechnung verwendet werden soll. ModuloFactor kann mit dem Modulo-Faktor der Achse identisch sein, z. B. 360. Es kann aber auch ein davon abweichender Faktor verwendet werden. | |
Options | Datenstruktur mit Optionen für die Extrapolation der Position. | |
Options. | SubIndex | Für Achsen mit mehr als einem Encoder kann in SubIndex der Index (0..9) des Encoders angegeben werden auf den sich die Position bezieht. |
Options. | InterpolationOptions | 0: Die Extrapolation der Position wird mit der aktuellen Geschwindigkeit durchgeführt, ohne die aktuelle Beschleunigung zu berücksichtigen. |
Options. | CompensationTime | zusätzliche Kompensationszeit |
Ausgänge
VAR_OUTPUT
Duration : DINT;
AbsolutePosition : LREAL;
TimeOfPosition : T_DCTIME32;
Error : BOOL;
ErrorID : UDINT;
END_VAR
Duration | Zeitdauer in Nanosekunden, nach der die Position erreicht sein wird. |
AbsolutePosition | Absolute Position (nicht modulo), die mit der Modulo-Position und der ermittelten Zeit korrespondiert. |
TimeOfPosition | Distributed Clock System Time, zu der die Position erreicht sein wird bzw. zu der sie erreicht wurde. |
Error | Wird im Fehlerfall TRUE. |
ErrorID | Liefert bei einem gesetzten Error-Ausgang die Fehlernummer |
Ein/Ausgänge
VAR_IN_OUT
Axis : AXIS_REF;
END_VAR
Axis | Achsdatenstruktur |
Die Achsdatenstruktur vom Typ AXIS_REF adressiert eine Achse eindeutig im System. Sie enthält unter anderem den aktuellen Status der Achse, wie Position, Geschwindigkeit oder Fehlerzustand.