Overview
The PLC library Tc2_Utilities contains function blocks and functions for calling TwinCAT system functions and operating system functions as well as various conversion functions.
- Operating system functions
- PLC functions
- Checksum/CRC functions
- System functions
- Scope View functions
- Scope Server functions
- ADS Monitor functions
- Converting functions
- STRING functions
- Extended STRING functions
- 64 bit functions (unsigned)
- 64 bit functions (signed)
- 16 bit fixed point number functions (signed)
- Byte order converting functions
- FLOAT functions
- LCOMPLEX functions
- P[TYPE]_TO_[TYPE] converting functions
- T_Arg help functions
- CSV format functions
- Licensing functions
- Other functions
Operating system functions
Name | Description |
---|---|
Shutting down the operating system (shutdown). | |
Interrupting the shutdown process. | |
Carrying out a restart of the operating system. | |
Reading the current local Windows system time. | |
Setting the current local Windows system time. | |
Starts a Windows application from the PLC. | |
Synchronizing the local Windows system time with the real-time clock of the PC. | |
Reading out values from the registry. | |
Writing values to the Registry. | |
Searches in a directory for a file or a subdirectory whose name is similar to the specified name. Any entries found can be read individually. | |
Searches in a directory for a file or a subdirectory whose name is similar to the specified name. The found entries can be read out in groups. | |
Reads network adapter information. | |
Reads the host name of the local PC. | |
Converts the host name into the (IPv4) Internet protocol network address. | |
Reads the time zone configuration of the operating system. | |
Sets the time zone configuration of the operating system. | |
Returns the local Windows system time and summer time/winter time info. |
PLC functions
Name | Description |
---|---|
Resets the PLC. | |
Starts the PLC. | |
Stops the PLC. | |
Reading the symbol information of the PLC. | |
Reading the symbol information of a PLC variable with the help of the symbol name. | |
Reading the symbol information of a PLC variable with the help of the symbol name. The comment will be truncated if the available buffer size is insufficient. | |
Determining the execution time of the PLC code. | |
Saving the persistent data to the data storage device from the PLC program. | |
Saving the persistent data to the data storage device from the PLC program (extended version). |
Checksum/CRC functions
Name | Description |
---|---|
Calculates the 16 bit checksum. | |
Calculates CRC16-CCITT (cyclical redundancy check) of any data type. | |
Calculates CRC16-CCITT (cyclical redundancy check) of an individual data byte. |
System functions
Name | Description |
---|---|
Restart the TwinCAT system. | |
Stop the TwinCAT system. | |
Switching TwinCAT system to CONFIG mode. | |
Determining CPU usage of the TwinCAT system. | |
Determining the current and maximum latency time of a TwinCAT system. | |
Reading router information via the configured remote PCs. | |
Reading the AmsNetId of the local TwinCAT PC. | |
Reading TwinCAT router status information. | |
Reading router connection information. | |
Adding a new router connection. | |
Deleting an existing router connection. | |
Converts the AMS message router transport layer ID into a string. | |
Reads the device ID. | |
Reads the device ID. (Allows longer strings with hardware model and serial number.) | |
Reads the valid and invalid TwinCAT licenses. | |
Reads the SystemID as GUID. | |
Reads the SystemID and the Volume System ID. |
Scope View functions
TwinCAT Scope View functions are not supported by TwinCAT 3.
Scope Server functions
Name | Description |
---|---|
Controls (start/save..) the Scope Server for data logging. |
Converting functions
Name | Description |
---|---|
Converting DATE_AND_TIME to Windows system time structure. | |
Converting DATE_AND_TIME to Windows file time. | |
Converting Windows system time structure to DATE_AND_TIME. | |
Converting Windows system time structure to file time. | |
Converting Windows system time structure to string. | |
Converting string to Windows system time structure. | |
Converting Windows file time to DATE_AND_TIME. | |
Converting Windows file time to system time structure. | |
Converting decimal numbers to BCD numbers. | |
Converting BCD numbers to decimal numbers. | |
Converting degree-angle to radian. | |
Converting radian to degree-angle. | |
Converting TIME variable to a structure with resolved milliseconds, seconds, minutes etc. | |
Converting a structure with resolved milliseconds, seconds, minutes etc. to TIME variable. | |
Replaces by the Hi and Lo Word of a REAL variable. | |
Allows an explicit conversion of the type BYTE to a positive floating point number of the type LREAL. | |
Allows an explicit conversion of the type DWORD to a positive floating point number of the type LREAL. | |
Allows an explicit conversion of the type UDINT to a positive floating point number of the type LREAL. | |
Allows an explicit conversion of the type UINT to a positive floating point number of the type LREAL. | |
Converts a 64 bit number of the type ULINT into a 64 bit number of the type T_ULARGE_INTEGER. | |
Allows an explicit conversion of the type USINT to a positive floating point number of the type LREAL. | |
Converts byte array into a string. | |
Converts string into a byte array. | |
Converts UTC time into local time and vice versa (by bias). | |
Converts continuous local time (file time format) into UTC time. | |
Converts continuous local time (structured system time format) into UTC time. | |
Converts UTC time (file time format) into local time. | |
Converts UTC time (structured system time format) into local time. | |
Converts the ASCII code of a hexadecimal half-byte character into a decimal value. | |
Converts a hexadecimal half-byte character into its decimal value. | |
Compares two GUID values |
STRING functions
Name | Description |
---|---|
Converts a flowing point number into a string with the desired number of decimal places. | |
Converts a decimal number into a decimal string. | |
Converts a decimal number into a hexadecimal string. | |
Converts a decimal number into an octal string. | |
Converts a decimal number into a binary string. | |
Converts a decimal number into a decimal string. | |
Converts a decimal number into a hexadecimal string. | |
Converts a decimal number into an octal string. | |
Converts a decimal number into a binary string. | |
Converts an address (pointer) into a decimal string. | |
Converts an address (pointer) into a hexadecimal string. | |
Converts an address (pointer) into an octal string. | |
Converts an address (pointer) into a binary string. | |
Converts an address (pointer) into a string. | |
Converts a string into an address (pointer). | |
Converts a signed decimal number (64 bit) into a decimal string. | |
Converts a signed decimal number (32 bit) into a decimal string. | |
Converts and formats a decimal number or a flowing point number into a string. | |
Converts a decimal number of the type byte into a binary string. | |
Converts a decimal number into a decimal string. | |
Converts a decimal number into a hexadecimal string. | |
Converts a decimal number into an octal string. | |
Converts a decimal number of the type word into a binary string. | |
Converts a decimal number of the type word into a decimal string. | |
Converts a decimal number of the type word into a hexadecimal string. | |
Converts a decimal number of the type word into an octal string. | |
Converts and formats up to 10 arguments (decimal or flowing point numbers). | |
Searches a string for numbers. | |
Converts lowercase letters into uppercase letters in a string. | |
Converts uppercase letters into lowercase letters in a string. | |
Removes spaces at the beginning of a string. | |
Removes spaces at the end of a string. | |
Converts binary data into hexadecimal string. | |
Converts hexadecimal string to binary data. | |
Converts a structured GUID variable into a GUID string variable. | |
Converts a structured GUID variable into a registry GUID string variable | |
Converts a registry GUID string variable into a structured GUID variable. |
Extended STRING functions
Name | Description |
---|---|
Converts a character of the data type STRING into a character of the data type WSTRING (with null termination). | |
Concatenates two strings of the data type STRING. | |
Removes nLen characters from a string, starting at position nPos. | |
Checks whether a string contains only ASCII characters (0x000 to 0x7F) and returns the number of ASCII characters. | |
Finds a string, which may occur more than once, in another string. | |
Finds a string, which may occur more than once, in another string and removes it. | |
Finds a character, which may occur more than once, in a string and removes it. | |
Finds a string, which may occur more than once, in another string and replaces it with another string. | |
Finds a character, which may occur more than once, in a string and replaces it with another character. | |
Inserts a string into another string after position nPos. | |
Returns the number of characters in a string. | |
Replaces nLen characters of a string with another string, starting at position nPos. | |
Converts any character string of the data type STRING into a character string in UTF-8 format. | |
Converts any string of a variable of the data type STRING to a string in UTF-8 format. | |
Converts a variable of the data type STRING into a variable of the data type WSTRING. | |
Copies the character string of a variable of the data type STRING and checks whether the character string was completely copied | |
Converts a string in UTF-8 format into a string of the data type STRING. | |
Converts a string in UTF-8 format into a string of the data type WSTRING. | |
Returns the number of characters in a UTF-8 string. | |
Converts a variable of the data type WSTRING into a variable of the data type STRING (with null termination) | |
Concatenates two strings of the data type WSTRING of any length. | |
Returns the number of characters in a Unicode string of the data type WSTRING. | |
Converts any character string of the data type WSTRING into a character string in UTF-8 format. | |
Converts a variable of the data type WSTRING into a variable of the data type STRING. | |
Converts a string of a variable of the data type WSTRING into a string in UTF-8 format. | |
Copies a character string of a variable of the data type WSTRING and checks whether the character string was completely copied. |
64 bit functions (unsigned)
Name |
Description |
---|---|
Initializes/sets a 64 bit number. | |
Adds two 64 bit numbers. | |
Adds two 64 bit numbers (with Overflow check). | |
Subtracts two 64 bit numbers. | |
Compares two 64 bit numbers. | |
Multiplies two 32 bit numbers. The result is a 64 bit number. | |
Multiplies two 64 bit numbers. The result is a 64 bit number. | |
Multiplies two 64 bit numbers. The result is a 64 bit number (with overflow check). | |
Division of two 64 bit numbers. | |
Division of two 64 bit numbers (with remainder). | |
Division of one 64 bit number by a 16 bit number. The result is a 64 bit number. | |
Modulo division of two 64 bit numbers. | |
Bit by bit AND of two 64 bit numbers. | |
Bit by bit OR of two 64 bit numbers. | |
Bit by bit NOT of one 64 bit number. | |
Bit by bit XOR of two 64 bit numbers. | |
Bit by bit left rotation of one 64 bit number. | |
Bit by bit right rotation of one 64 bit number. | |
Bit by bit left shift of one 64 bit number. | |
Bit by bit right shift of one 64 bit number. | |
Minimum function | |
Maximum function | |
Limitation | |
Checks whether the value of the 64 bit number is zero. | |
Converts 64 bit number into a string. | |
Converts 64 bit number into a LREAL. | |
Converts a STRING into a 64 bit number. | |
Converts LREAL into a 64 bit number. | |
Converts a 64 bit number of the type LWORD into a 64 bit number of the type T_ULARGE_INTEGER. | |
Converts a 64 bit number of the type T_ULARGE_INTEGER into a 64 bit number of the type LWORD. | |
Converts a 64 bit number of the type T_ULARGE_INTEGER into a 64 bit number ULINT. |
64 bit functions (signed)
Name |
Description |
---|---|
Initializes/sets a 64 bit number. | |
Adds two 64 bit numbers. | |
Adds two 64 bit numbers (with Overflow check). | |
Subtracts two 64 bit numbers. | |
Compares two 64 bit numbers. | |
Division of two 64 bit numbers (with remainder). | |
Bit by bit NOT of one 64 bit number. | |
Checks whether the value of the 64 bit number is zero. | |
Negates a 64 bit number. | |
Converts 64 bit number into a LREAL. | |
Converts LREAL into a 64 bit number. | |
Converts a signed 64 bit number into an unsigned 64 bit number. | |
Converts an unsigned 64 bit number into a signed 64 bit number. | |
Converts a signed 64 bit number of the type LINT into a signed 64 bit number of the type T_LARGE_INTEGER. | |
Converts a signed 64 bit number of the type T_LARGE_INTEGER into a signed 64 bit number of the type LINT. |
16 bit fixed point number functions (signed)
Name | Description |
---|---|
Adds two fixed-point numbers. | |
Changes the resolution of a fixed-point number. | |
Subtracts two fixed-point numbers. | |
Divides two fixed-point numbers. | |
Multiplies two fixed-point numbers. | |
Converts LREAL into a fixed-point number. | |
Converts WORD into a fixed-point number. | |
Converts a fixed-point number into LREAL. | |
Converts a fixed-point number into WORD. |
Byte order converting functions
Name |
Description |
---|---|
Host-to-network converting (16 bit number) | |
Host-to-network converting (32 bit number) | |
Host-to-network converting (64 bit number, „legacy“-type: T_ULARGE_INTEGER) | |
Host-to-network converting (64 bit number, „native“-type: LWORD) | |
Host-to-network converting (128 bit number, „legacy“-type: T_UHUGE_INTEGER) | |
Host-to-network converting (16 bit number) | |
Network-to-host converting (32 number) | |
Network-to-host converting (64 bit number, „legacy“-type: T_ULARGE_INTEGER) | |
Network-to-host converting (64 bit number, „native“-type: LWORD) | |
Network-to-host converting (128 bit number, „legacy“-type: T_UHUGE_INTEGER) |
FLOAT functions
Name | Description |
---|---|
Converts a variable of the type BOOL to a variable of the type LREAL. | |
Converts a variable of the type DINT to a variable of the type FLOAT. | |
Converts a variable of the type FLOAT to a variable of the type BOOL. | |
Converts a variable of the type FLOAT to a variable of the type DINT. | |
Converts a variable of the type FLOAT to a variable of the type INT. | |
Converts a variable of the type FLOAT to a variable of the type SINT. | |
Converts a variable of the type FLOAT to a variable of the type STRING. | |
Converts a variable of the type FLOAT to a variable of the type TIME. | |
Converts a variable of the type FLOAT to a variable of the type UDINT. | |
Converts a variable of the type FLOAT to a variable of the type UINT. | |
Converts a variable of the type INT to a variable of the type FLOAT. | |
Converts a variable of the type SINT to a variable of the type FLOAT. | |
Converts a variable of the type TIME to a variable of the type FLOAT. | |
Converts a variable of the type UDINT to a variable of the type FLOAT. | |
Converts a variable of the type UINT to a variable of the type FLOAT. | |
Returns TRUE, when the argument of the type LREAL has a finite value. | |
Returns TRUE, when the argument of the type LREAL has an undefined value (NaN). | |
Returns TRUE, when the argument of the type REAL has a finite value. | |
Returns TRUE, when the argument of the type REAL has an undefined value (NaN). |
![]() | Obsolete function This function is obsolete. Please use the functions "..._TO_LREAL" or "LREAL_TO_..." instead, which give the same result. |
LCOMPLEX functions
Name | Description |
---|---|
Returns TRUE, when the argument of the type LCOMPLEX has an undefined value (NaN). | |
Returns the absolute value of the complex number transferred. |
P[TYPE]_TO_[TYPE] converting functions
Name | Description |
---|---|
Returns the content of a BOOL pointer variable. | |
Returns the content of a BYTE pointer variable. | |
Returns the content of a DATE pointer variable. | |
Returns the content of a DINT pointer variable. | |
Returns the content of a DT pointer variable. | |
Returns the content of a DWORD pointer variable. | |
Returns the content of a T_HUGE_INTEGER pointer variable. | |
Returns the content of an INT pointer variable. | |
Returns the content of a T_LARGE_INTEGER pointer variable. | |
Returns the content of a LINT pointer variable. | |
Returns the content of a LREAL pointer variable. | |
Returns the content of a LWORD pointer variable. | |
Returns the content of a T_MaxString pointer variable. | |
Returns the content of a REAL pointer variable. | |
Returns the content of a SINT pointer variable. | |
Returns the content of a STRING pointer variable. | |
Returns the content of a TIME pointer variable. | |
Returns the content of a TOD pointer variable. | |
Returns the content of an UDINT pointer variable. | |
Returns the content of a T_UHUGE_INTEGER pointer variable. | |
Returns the content of an UINT pointer variable. | |
Returns the content of a T_ULARGE_INTEGER pointer variable. | |
Returns the content of an ULINT pointer variable. | |
Returns the content of an USINT pointer variable. | |
Returns the content of a WORD pointer variable. | |
Returns the content of a T_ULARGE_INTEGER pointer variable. |
T_Arg help functions
Name | Description |
---|---|
Compares two variables of the type T_Arg | |
Copies the value of a variable of the type T_Arg to another variable and returns the number of successfully copied data bytes. | |
Returns TRUE if one of the T_Arg member variables has the value zero or was not initialised. | |
Returns information on a struct or array variable in a structure of the type T_Arg. | |
Returns information on a BOOL variable in a structure of the type T_Arg. | |
Returns information on a BYTE variable in a structure of the type T_Arg. | |
Returns information on a DINT variable in a structure of the type T_Arg. | |
Returns information on a DWORD variable in a structure of the type T_Arg. | |
Returns information on a T_HUGE_INTEGER variable in a structure of the type T_Arg. | |
Returns information on an INT variable in a structure of the type T_Arg. | |
Returns information on a T_LARGE_INTEGER variable in a structure of the type T_Arg. | |
Returns information on a LINT variable in a structure of the type T_Arg. | |
Returns information on a LREAL variable in a structure of the type T_Arg. | |
Returns information on a LWORD variable in a structure of the type T_Arg. | |
Returns information on a REAL variable in a structure of the type T_Arg. | |
Returns information on a SINT variable in a structure of the type T_Arg. | |
Returns information on a T_MaxString variable in a structure of the type T_Arg. | |
Returns information on an UDINT variable in a structure of the type T_Arg. | |
Returns information on a T_UHUGE_INTEGER variable in a structure of the type T_Arg. | |
Returns information on an UINT variable in a structure of the type T_Arg. | |
Returns information on a T_ULARGE_INTEGER variable in a structure of the type T_Arg. | |
Returns information on an ULINT variable in a structure of the type T_Arg. | |
Returns information on an USINT variable in a structure of the type T_Arg. | |
Returns information on a WORD variable in a structure of the type T_Arg. | |
Returns information on a PVOID variable in a structure of the type T_Arg. |
CSV format functions
Name | Description |
---|---|
Converts the value of a string with a data field in CSV format into an PLC string variable. | |
Converts the value of a PLC string variable into a string with a data field in CSV format. | |
Converts a byte buffer with a data field in CSV format into a value of a random PLC variable. | |
Converts the value of a random PLC variable into a byte buffer with a data field in CSV format. | |
Splits data sets in CSV format which are in a byte buffer into individual data fields. | |
Generates individual or several data sets in a byte buffer from individual data fields |
Licensing functions
Name | Description |
---|---|
Reads the StorageInfo of the license dongle and the file directory. | |
Creates a file on the license dongle. | |
Deletes a file from the license dongle. | |
Reads a file from the license dongle to a buffer. | |
Copies a file from the hard disk to the license dongle. | |
Copies a file from the license dongle to the hard disk. | |
Determines the TwinCAT 3 license status for a given license ID. | |
Reads the system ID and the volume ID of the TwinCAT 3 license dongle as GUID. | |
Determines the number of connected license dongles and returns address and status. | |
Reads the valid and invalid TwinCAT licenses. | |
Determines the status of all TwinCAT 3 licenses and OEM licenses. |
Other functions
Name |
Description |
---|---|
Simple PID controller | |
Reading version information of the library. | |
Verifies the formatting of a floating point number in accordance with the IEEE. | |
Determines whether a year is a leap year. | |
Determines the maximum number of days in a month. | |
Determines the number of the day in the year. | |
Determines the month based on the day number in the year. | |
Determines the number of the weekday. | |
Determines the calendar week. | |
Determines the date of the first, second etc. weekday in a specified month and year. | |
Returns the number of the calendar week for a predefined date. | |
"Software"-RTC (Real Time Clock) | |
"Software"-RTC (Real Time Clock) | |
"Software"-RTC (Real Time Clock) | |
Writes/reads data sets to or from the file (FIFO). | |
Writes/reads data sets to or from a buffer variable (FIFO). | |
Writes/reads data sets to or from a buffer variable (FIFO). | |
Writes/reads strings to or from a buffer variable (FIFO). | |
Writes/reads data sets to or from a buffer variable (LIFO). | |
Merges individual small data segments to one larger data segment. | |
Splits a memory area (data buffer) into several smaller segments. | |
Simple hash table. | |
Simple linked list (double linked). | |
A simple DCF77 decoder. | |
DCF77 decoder with plausibility check of two consecutive telegrams and time zone information. |