XFC_PositionAtTime

XFC_PositionAtTime 1:

XFC_PositionAtTime berechnet eine Achsposition, welche zu einer gegebenen Zeit gültig sein wird bzw. gültig gewesen ist.

Die Funktion extrapoliert die Position 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 Position eventuell auch einen Fehler zurück. Dieser Fehler muss ausgewertet werden, um sicherzustellen, dass die berechnete Position gültig ist.

Eingänge

VAR_INPUT
    DcTime  : T_DCTIME32; 
    Options : ST_NcTimeConversionOptions;
END_VAR

DcTime

Distributed Clock System Time.
DcTime enthält die unteren 32 Bit der vollständigen DcTime und deckt damit einen Zeitbereich von +/- 2 Sekunden um den aktuellen Zeitpunkt ab. Um einen möglichst genauen Positionswert zu berechnen, sollte die Zeit sehr nahe an der aktuellen Zeit liegen, also möglichst nur wenige SPS- bzw. NC-Zyklen in der Zukunft oder in der Vergangenheit.

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.
1: Die Beschleunigung der Achse wird in die Extrapolation der Position einbezogen.

Options.

CompensationTime

zusätzliche Kompensationszeit.

Ausgänge

VAR_OUTPUT
    Position : LREAL;
    Error    : BOOL;
    ErrorID  : UDINT;
END_VAR

Position

Extrapolierte Position, die zum vorgegebenen Zeitpunkt DcTime erreicht sein wird bzw. 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.