The OPC Client can read multiple values from an OPC server if the server supports data arrays. A data array is a set of contiguous data of the same data type. By reading multiple values with a single item, you simplify the driver configuration and improve driver throughput.
Example 1
Suppose you want to read 200 values of contiguous addresses from your OPC server. Without data arrays, you have to create 200 items, one for each value. Each value is read independently, resulting in 200 messages to the OPC server. Using data arrays, you can create one item to read all 200 values. All values are read at once, resulting in one message to the OPC server.
Using data arrays is best when the OPC Client communicates with the server using synchronous I/O because the OPC Client reads the entire array. When data arrays are used with asynchronous I/O, the driver throughput may not improve because the OPC server sends the entire array to the OPC Client even if only one value in the array changes. Consequently, it may be better to create individual items for specific values that change frequently and use data arrays for all other values.
Example 2
Assume the values at addresses 100, 150, and 200 change frequently. All other values from addresses 1 to 200 do not change frequently. In this situation, instead of creating one data array for all 200 values, it would be better to create the following items:
- Item 1, address 100
- Item 2, address 150
- Item 3, address 200
- Item 4, data array reading addresses 1-99
- Item 5, data array reading addresses 101-149
- Item 6, data array reading address 151-199
Data Array Syntax
The item ID syntax for data arrays depends on your OPC server. However, you can use the following general syntax:
itemid
- Or -
itemid!subscript:length
(Schneider Automation only)
itemid[subscript],Llength (RS-Linx only)
Where:
- itemid is the OPC server’s name for the item you want to access.
- subscript is the starting address of the array.
- length is the number of elements in the array.
Examples
To configure an item in the Power Tool as a 100-element array for an RS-Linx OPC server, use syntax similar to the following:
Sign_Int_Array[0],L100
To configure an item in the Power Tool as a 100-element array for an S7 Siemens server, use syntax similar to the following:
S7:[S7_300|VFD1|CP5613_5614(PROFIBUS)]DB1,B0,100
To configure an item in the Power Tool as a 100-element array for a Schneider Automation OFS OPC server, use syntax similar to the following:
MBT:1.2.3.4!400001:100
Consult your OPC server documentation for the exact syntax required for your server.
Access Data Arrays with a Database Block
You must enter an I/O address in a database block to access data from a data array. The exact syntax you must use is similar to the item ID syntax:
servername;groupname;itemid;accesspath;[element]
Where:
- servername is the name of your OPC server.
- groupname is the name of the group containing the item you want to access.
- itemid is the OPC server’s name for the item you want to access. The item ID may also include a length. Item IDs for RS-Linx servers include brackets and should not be confused with the array element you want to access. For example, Sign_Int_Array[0] identifies an item starting at address 0.
- accesspath is the OPC server’s name for the access path you want to use. If no access path is specified you can leave it blank.
- element is the element in the array you want to access. This value must be between the starting address and the sum of the starting address plus the length minus 1 (start + length-1).
Examples
With an Item Start of 0 defined in the Power Tool, you can access the fifth element in a 100-element array located at address 2 on the RS-Linx OPC server RSLinxV22 using syntax similar to the following:
RSLINXV22;SignIntGroup1;Sign_Int_Array[2],L100;Clogix;[4]
To access the fifth element in a 100-element array on an S7 Siemens server, use syntax similar to the following:
Server1;Group1;S7:[S7_300|VFD1|CP5613_5614(PROFIBUS)]DB1,B0,100;No Access Path;[4]
To access the fifth element in a 100-element array at address 400001 on a Schneider Automation OPC server, use syntax similar to the following:
Server1;Group1;MBT:1.2.3.4!400001:100;No Access Path;[5]
Using Analog Register and Digital Register Blocks
After you complete the I/O Address field of an Analog Register or Digital Register block, you can use offset in picture data sources to access different values in the array.
Example
Suppose you create an Analog Register block, AR10, with the I/O address:
RSLINXV22;SignIntGroup1;Sign_Int_Array[5],L100;;[20]
Then the following data sources access the specified array elements:
The data source... |
Accesses the array element... |
AR10.F_0 |
Sign_Int_Array[5],L100;;[20] |
AR10.F_1 |
Sign_Int_Array[5],L100;;[21] |
AR10.F_2 |
Sign_Int_Array[5],L100;;[22] |
AR10.F_3 |
Sign_Int_Array[5],L100;;[23] |
Offsets with a Digital Register block work the same way.
NOTES:
- You cannot use the Auto Create option with items configured as data arrays.
- Data arrays support boolean and numeric (integer and float) data types. Arrays of strings are not supported.
- The OPC Client does not support exception-based processing for database blocks that reference items configured as data arrays.
The OPC Client does not automatically resize items configured as data arrays. If you need to change the size of the array, disable the item, change the array’s length, and re-enable the item. Make sure the length of the array in the OPC Client matches the length of the array defined in the OPC server. If the lengths do not match, the data quality is set to BAD.