ITData Management
ITData Management
formerly Wonderware
aveva.com
        © 2021 AVEVA Group plc and its subsidiaries. All rights reserved.
        No part of this documentation shall be reproduced, stored in a retrieval system, or transmitted by any means,
        electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of AVEVA.
        No liability is assumed with respect to the use of the information contained herein.
        Although precaution has been taken in the preparation of this documentation, AVEVA assumes no responsibility
        for errors or omissions. The information in this documentation is subject to change without notice and does not
        represent a commitment on the part of AVEVA. The software described in this documentation is furnished under
        a license agreement. This software may be used or copied only in accordance with the terms of such license
        agreement.
        ArchestrA, Aquis, Avantis, Citect, DYNSIM, eDNA, EYESIM, InBatch, InduSoft, InStep, IntelaTrac, InTouch, OASyS,
        PIPEPHASE, PRiSM, PRO/II, PROVISION, ROMeo, SIM4ME, SimCentral, SimSci, Skelta, SmartGlance, Spiral
        Software, Termis, WindowMaker, WindowViewer, and Wonderware are trademarks of AVEVA and/or its
        subsidiaries. An extensive listing of AVEVA trademarks can be found at: https://sw.aveva.com/legal. All other
        brands may be trademarks of their respective owners.
        Publication date: Monday, May 3, 2021
        Contact Information
        AVEVA Group plc
        High Cross
        Madingley Road
        Cambridge
        CB3 0HB. UK
        https://sw.aveva.com/
        For information on how to contact sales and customer training, see https://sw.aveva.com/contact.
        For information on how to contact technical support, see https://sw.aveva.com/support.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 2
Contents
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                              Page 3
          Creating Discrete Tags ................................................................................................................................ 28
          Creating Integer and Real Tags................................................................................................................... 29
          Creating Message Tags ............................................................................................................................... 30
          Creating I/O Tags ........................................................................................................................................ 30
        Modifying Tags ................................................................................................................................... 30
        Deleting Tags ...................................................................................................................................... 31
        Printing a Tag List and Usage Information ............................................................................................ 31
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                              Page 4
             Accessing the Server as a Standard User ................................................................................................ 59
          OPC ............................................................................................................................................................. 59
          OPC UA ....................................................................................................................................................... 60
          MQTT .......................................................................................................................................................... 60
        Setting Up Access Names .................................................................................................................... 61
          Deleting Access Names .............................................................................................................................. 62
        Accessing I/O Data with I/O Tags ......................................................................................................... 63
          Configuring I/O Tag Properties................................................................................................................... 63
             Specifying a Discrete I/O Tag .................................................................................................................. 63
             Specifying Integer and Real I/O Tags ...................................................................................................... 64
             Specifying a Message I/O Tag ................................................................................................................. 65
             Setting I/O Access Parameters ............................................................................................................... 66
          Retrieving Information About I/O Tags at Run Time .................................................................................. 67
             IOGetNode() Function ............................................................................................................................ 67
             IOGetApplication() Function ................................................................................................................... 67
             IOGetTopic() Function ............................................................................................................................ 68
          Dynamically Changing I/O Tag References at Run Time ............................................................................ 68
             .Reference Dotfield ................................................................................................................................. 68
             IOSetItem() Function .............................................................................................................................. 69
             IOSetAccessName() Function ................................................................................................................. 70
        Converting Tags to Remote References ................................................................................................ 71
        Accessing I/O Data by Remote References ........................................................................................... 74
          Redirecting Remote References During Run Time ..................................................................................... 75
             IOSetRemoteReferences() Function ....................................................................................................... 75
             Restoring References .............................................................................................................................. 77
        Accessing Application Server Data from InTouch .................................................................................. 78
          Using Application Server Object Attributes with InTouch Tags ................................................................. 78
          Browsing Application Server Object Attributes from InTouch ................................................................... 79
          Application Server Browser Restrictions .................................................................................................... 79
          Special Extensions in Application Server Objects....................................................................................... 80
          Mapping Application Server Data Types to InTouch Data Types ............................................................... 81
          Read/Write Behavior of Application Server Attributes .............................................................................. 83
          Configuring the InTouch HMI to Use a Galaxy as a Remote Tag Source .................................................... 85
        Viewing Timestamp and Quality Information for an I/O Tag ................................................................. 88
          Viewing Timestamp Information for an I/O Tag ........................................................................................ 88
             .TimeDate Dotfield.................................................................................................................................. 88
             .TimeDateString Dotfield ........................................................................................................................ 89
             .TimeDateTime Dotfield ......................................................................................................................... 89
             .TimeDay Dotfield ................................................................................................................................... 90
             .TimeHour Dotfield ................................................................................................................................. 90
             .TimeMinute Dotfield ............................................................................................................................. 91
             .TimeMonth Dotfield .............................................................................................................................. 91
             .TimeMsec Dotfield................................................................................................................................. 92
             .TimeSecond Dotfield ............................................................................................................................. 92
             .TimeTime Dotfield ................................................................................................................................. 93
             .TimeTimeString Dotfield ........................................................................................................................ 93
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                Page 5
             .TimeYear Dotfield .................................................................................................................................. 94
          Viewing Quality Information for an I/O Tag ............................................................................................... 94
             Quality Data Format ............................................................................................................................... 94
             About Data Quality Dotfields .................................................................................................................. 95
             .Quality Dotfield...................................................................................................................................... 95
             .QualityLimit Dotfield.............................................................................................................................. 96
             .QualityLimitString Dotfield .................................................................................................................... 97
             .QualityStatus Dotfield ........................................................................................................................... 97
             .QualityStatusString Dotfield .................................................................................................................. 98
             .QualitySubstatus Dotfield ...................................................................................................................... 98
             .QualitySubstatusString Dotfield ............................................................................................................ 99
        Initializing and Resetting I/O Connections at Run Time ........................................................................ 99
          Reinitializing I/O Connections with Commands ....................................................................................... 100
          Reinitialize I/O Connections with Scripts ................................................................................................. 102
             IOReinitAccessName() Function ........................................................................................................... 102
             IOReinitialize() Function ....................................................................................................................... 103
             IOStartUninitConversations() Function ................................................................................................ 103
        Using Failover Functionality with Access Names ................................................................................ 104
          Configuring Failover ................................................................................................................................. 104
             Editing the Access Name Parameters of a Failover Pair ....................................................................... 106
             Removing Failover for an Access Name................................................................................................ 106
          Forcing Failover to a Backup Access Name .............................................................................................. 106
             Failover Expression ............................................................................................................................... 107
             IOForceFailover() Function ................................................................................................................... 107
          Temporarily Disabling Failover Functionality ........................................................................................... 107
             Disable Failover Configuration Option ................................................................................................. 108
             IODisableFailover() Script Function ...................................................................................................... 108
          Retrieving Information About Failover Pairs Using Scripting ................................................................... 109
             IOGetAccessNameStatus() Function ..................................................................................................... 109
             IOGetActiveSourceName() Function .................................................................................................... 110
        Monitoring the Status of an I/O Connection ...................................................................................... 111
          Using IOStatus Topic Name ...................................................................................................................... 111
             Using IOStatus Topic Name in Excel ..................................................................................................... 113
             Monitoring I/O Server Communications Status ................................................................................... 113
        Accessing InTouch Tag Data from Other Applications ......................................................................... 114
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                         Page 6
        Defining a SuperTag Template ........................................................................................................... 120
          Editing SuperTag Templates and Member Tags....................................................................................... 122
        Creating Instances of SuperTags ........................................................................................................ 123
          Using the Tagname Dictionary to Create a SuperTag Instance ................................................................ 123
          Using the Tagname Dictionary to Replicate a SuperTag Instance............................................................ 124
          Using the Tagname Dictionary to Add a Tag to a SuperTag Instance ...................................................... 125
          Other Ways to Create SuperTags ............................................................................................................. 126
        Referencing SuperTag Members ........................................................................................................ 126
          Importing SuperTags with the Bulk Import Utility ................................................................................... 127
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                   Page 7
          Configuring the Time Span of a Historical Trend ..................................................................................... 155
          Configuring Historical Trend Display Options .......................................................................................... 156
          Changing the Trend Configuration at Run Time ....................................................................................... 157
          Controlling a Historical Trend Using Dotfields ......................................................................................... 159
            .DisplayMode Dotfield .......................................................................................................................... 159
            .MinRange Dotfield ............................................................................................................................... 160
            .MaxRange Dotfield .............................................................................................................................. 160
            .UpdateCount Dotfield ......................................................................................................................... 161
            .UpdateInProgress Dotfield .................................................................................................................. 162
            .UpdateTrend Dotfield .......................................................................................................................... 163
            .ChartLength Dotfield ........................................................................................................................... 163
            .ChartStart Dotfield............................................................................................................................... 164
            .Pen1-8 Dotfields .................................................................................................................................. 165
            .TagID Dotfield ...................................................................................................................................... 166
            .ScooterLockLeft Dotfield ..................................................................................................................... 167
            .ScooterLockRight Dotfield ................................................................................................................... 168
            .ScooterPosLeft Dotfield ....................................................................................................................... 168
            .ScooterPosRight Dotfield ..................................................................................................................... 169
        Using the Historical Trend Wizard ...................................................................................................... 170
          Creating a Trend With the Historical Trend Wizard ................................................................................. 171
          Configuring Which Tags to Display on the Trend Graph .......................................................................... 171
          Configuring the Historical Trend Time Span............................................................................................. 172
          Configuring Display Options ..................................................................................................................... 173
          Changing the Configuration at Run Time ................................................................................................. 174
        Controlling a Historical Trend Wizard Using Scripts ............................................................................ 174
          Updating the Trend to the Current Time ................................................................................................. 175
            HTUpdateToCurrentTime() Function .................................................................................................... 175
          Changing the Trend Configuration ........................................................................................................... 175
            HTSelectTag() Function ......................................................................................................................... 175
            HTSetPenName() Function ................................................................................................................... 176
          Retrieving Information About the Trendand Historical Data ................................................................... 177
            HTGetPenName() Function................................................................................................................... 177
            HTGetTimeAtScooter() Function .......................................................................................................... 178
            HTGetTimeStringAtScooter() Function ................................................................................................. 178
            HTGetValue() Function ......................................................................................................................... 179
            HTGetValueAtScooter() Function ......................................................................................................... 180
            HTGetValueAtZone() Function.............................................................................................................. 181
          Panning and Zooming the Trend .............................................................................................................. 182
            HTScrollLeft() Function ......................................................................................................................... 182
            HTScrollRight() Function ....................................................................................................................... 182
            HTZoomIn() Function ............................................................................................................................ 183
            HTZoomOut() Function ......................................................................................................................... 184
          Printing the Trend .................................................................................................................................... 184
            PrintHT() Function ................................................................................................................................ 185
          Troubleshooting the Trend ...................................................................................................................... 185
            HTGetLastError() Function .................................................................................................................... 185
          Displaying Real-Time Values in a Trend ................................................................................................... 186
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                        Page 8
        Using Real-Time Trend Objects .......................................................................................................... 186
          Creating a Real-Time Trend ...................................................................................................................... 186
          Configuring Which Tags to Display on a Real-time Trend ........................................................................ 187
          Configuring the Real-Time Trend Time Span and Update Rate ............................................................... 188
          Configuring Real-time Trend Display Options .......................................................................................... 188
        Printing a Trend at Run Time ............................................................................................................. 190
          Configuring Trend Printing Options ......................................................................................................... 190
        Displaying Historical Tag Values from Other InTouch Nodes or IndustrialSQL Server ........................... 192
          Using the InTouch HMI with the IndustrialSQL Server ............................................................................. 192
          Configuring Pens to Display Remote Trend Data ..................................................................................... 193
          Using the Tag Browser to Assign Pens to Remote History Providers ....................................................... 194
          Using a QuickScript to Assign a Pen to a Remote History Provider ......................................................... 194
        Chapter 11               Accessing Historical Tag Values from Other Applications ............. 196
        About Accessing Historical Tag Values from Other InTouch Applications............................................. 196
        Using DDE Items to Show Historical Data ........................................................................................... 197
        Accessing Log Data with DDE ............................................................................................................. 199
          Manually Extracting Log Data with HistData ............................................................................................ 199
            Create a HistData Access Name............................................................................................................ 199
            Create HistData Tags ............................................................................................................................ 200
            Create a HistData Window ................................................................................................................... 201
            Run HistData ......................................................................................................................................... 203
          Using the HistData Wizard to Extract Log Data ........................................................................................ 203
        Accessing Historical Data from Other Applications ............................................................................. 204
        Troubleshooting HistData Errors........................................................................................................ 205
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                        Page 9
Chapter 1
        A tag represents a data item in an InTouch HMI application. You use tags to make specific component properties
        accessible as data items from a manufacturing environment. In the figure above, the PumpState tag indicates
        whether the pump is on or off. You create tags for components in your manufacturing environment whose
        properties you want to monitor or control in your InTouch application.
        You can use different types of tags for the different types of data collected from a manufacturing component.
        For example, the PumpState tag returns a Boolean On/Off value to indicate if the pump is running or stopped.
        You assign the appropriate type of InTouch tag for the type of data that you want to be part of your application.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 10
                                                                                                                         AVEVA™ InTouch HMI Data Management Guide
                                                                                                                              Chapter 1 – Data Management Overview
                                                                                                 WindowViewer Run-Time
                     Tagname                                                                           Memory
                     Dictionary               Development Tag
                                                 Repository                   Run-Time Tag
                                                                               Repository
          InTouch
         Developer                   PumpInP          PumpRPM                   PumpInP                      PumpOutP
                                       Inlet                                      Inlet                        Outlet
                                                         RPM                    Pressure                      Pressure
                                     Pressure
                                    PumpOutP          PumpState                PumpState                     PumpRPM
                                      Outlet            On/Off                   On/Off
                                                                                                               RPM
                                     Pressure            State                    State
        You assign the name and type of tag with the Tagname Dictionary. For some types of tags, you have other
        options in the Tagname Dictionary to specify additional properties of tags. For example, I/O type tags include
        additional options to specify the connection to a remote data source.
        InTouch applications run in the WindowViewer environment. When WindowViewer starts an application, it
        reads the tags from the development repository and places them into run-time memory.
        The InTouch application communicates with the tags placed into run-time memory using animation links or
        scripts. The InTouch application tracks the current values and other status information from the component
        properties assigned to tags.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                          Page 11
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                    Chapter 1 – Data Management Overview
In the Tagname Dictionary, you use the Tag Types dialog box to assign the tag type to any tag you created.
After you assign a tag type, the Tagname Dictionary lists specific options for the type of tag you selected.
    Memory Tags
        Memory tags define internal system constants and variables within InTouch applications. For example, you can
        define an internal constant as a real number of 3.414. In process simulations, memory tags can control the
        actions of background QuickScripts by acting as a counter. Based upon the count associated with the tag, the
        QuickScript can trigger various animation effects. Memory tags can also act as calculated variables that are
        accessed by other programs.
        Select from the four types of memory tags, based upon the process data associated with the tag.
            Memory Discrete
             Memory discrete tags are associated with the state properties of a process component. The values assigned
             to memory discrete tags are two possible Boolean states such as:
             o   0 or 1
             o   False or true
             o   On or off
             o   High or low
            Memory Integer (Analog)
             You can assign memory integer tags 32-bit signed-integers between -2,147,483,648 and 2,147,483,647.
            Memory Real (Analog)
             You can assign memory real tags floating decimal point numbers between -3.4 x 1038 and 3.4 x 1038. All
             floating point calculations are performed with 64-bit resolution, but the results are stored as 32-bit decimal
             numbers. For more information about the maximum precision of real numbers, see IEEE Decimal Units on
             page 208.
            Memory Message
             You can assign memory message tags text strings up to 131 single-byte characters in length.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 12
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                   Chapter 1 – Data Management Overview
        Local Tags
        Local Tags allow the user to create per-session memory tags for use in the Web Client. For example, the user can
        configure a local memory tag to be used for navigation. In runtime when the user clicks the navigation symbol
        linked to that tag, each session will behave independently.
    I/O Tags
        I/O tags read or write InTouch application data to or from an external source. External data includes input and
        output from programmable controllers, process computers, and network nodes. I/O tag data values are
        remotely accessed through the following protocols:
            Microsoft Dynamic Data Exchange (DDE)
            SuiteLink™
        When the value of an I/O tag changes in run-time memory, the InTouch HMI updates the remote application.
        Conversely, I/O tag values in InTouch are updated whenever the values of corresponding data items change in a
        remote application.
        The InTouch HMI provides four types of I/O tags based upon the process data associated with the tag. These
        four types of I/O tags are similar to memory tag types.
            I/O Discrete
             I/O discrete tags are associated with component process properties whose values are represented by two
             possible states such as:
             o   0 or 1
             o   False or true
             o   On or off
             o   High or low
            I/O Integer (Analog)
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 13
                                                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                                                       Chapter 1 – Data Management Overview
                 I/O integer tags can be assigned 32-bit signed-integers between -2,147,483,648 and 2,147,483,647.
                I/O Real (Analog)
                 I/O real tags can be assigned floating decimal point numbers between -3.4 x 1038 and 3.4 x 1038. All I/O real
                 tag floating point calculations are performed with 64-bit resolution, but the results are stored as 32-bit
                 numbers. For more information about the maximum precision of I/O real numbers, see IEEE Decimal Units
                 on page 208.
                I/O Message
                 I/O message tags can be assigned text strings up to a maximum of 131 single-byte characters.
    Indirect Tags
        Indirect tags act as "pointers" to other tags. For example, you can create a single InTouch window and use
        indirect tags to show data from multiple different sets of tags.
        The following figure shows an example of an application window that is capable of displaying several pumps.
        Instead of creating separate windows for each pump, you can use indirect tags in one window to show the
        values of different source tags associated with individual pumps.
               Physical Plant Environment           WindowViewer Application Window
                Positive
             Displacement
                Pump 1
                                                       QuickScript Operator
                                                                    Action
                                            PumpRPM1
                    PLC 1                                                     Indirect Tag References to either
                                              RPM                                   Pump1 or Pump2 RPM
IndPumpRPM
RPM
               Positive
            Displacement
               Pump 2
        A QuickScript or operator action points the indirect tag to the source tags. For example, the following script
        statements assign the two PumpRPM tags to an indirect analog tag called IndPumpRPM based on the value of
        the PumpNo tag.
        IF PumpNo == 1 THEN
           IndPumpRPM.Name = "PumpRPM1";
           ELSE
           IndPumpRPM.Name = "PumpRPM2";
        ENDIF;
        When you equate an indirect tag to another source tag, the indirect tag acts as if it is the source tag. The values
        associated with the original source and indirect duplicate tags are synchronized together. If the value of the
        source tag changes, the indirect tag reflects the change. If the indirect tag's value changes, the source tag
        changes accordingly.
        You can use discrete, analog, and message types of indirect tags. These three types of indirect tags are
        comparable to similar memory and I/O types of tags.
        For more information about indirect tags, see Defining Indirect Tags on page 115.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                   Page 14
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                    Chapter 1 – Data Management Overview
    Miscellaneous Tags
        You can use other types of InTouch tags designed for specific, restricted purposes. You can use these tags to
        create dynamic alarm displays, create historical trends, and change the tags assigned to historical trend pens.
        Tag ID Tags
        Tag ID tags retrieve information from tags whose values are plotted in an InTouch historical trend graph.
        Typically, you use a Tag ID tag to show the name of the tag assigned to a specific trend pen or change the tag
        assigned to a trend pen.
        You can include a statement in a QuickScript to assign a new tag to a pen in any historical trend using a Tag ID
        type tag. For example, the following QuickScript statement changes the tag associated with a historical trend
        pen:
        HistTrend.Pen1=MyLoggedTag.TagID;
        When this QuickScript runs, Pen1 of the historical trend begins trending the historically logged data for the
        MyLoggedTag.
        For more information about defining and using Hist Trend tags, see Using the Historical Trend Wizard on page
        170.
        SuperTags
        A SuperTag is a template that contains a set of related tags. For example, you can create a SuperTag template
        containing a set of tags assigned to all the properties of a pump.
        Use SuperTags when you have identical equipment in your production process. Instead of creating a set of tags
        for each piece of equipment, assign an instance of the SuperTag template to each of the identical process items.
        For more information about SuperTags, see Defining Reusable Tag Structures on page 119.
        Obsolete Tags
        Using a Group Var tag, you can create dynamic alarm displays, dynamic logging on disk, and dynamic printing
        with the standard alarm system of InTouch. Group Var tags are included only for backward compatibility with
        applications developed with InTouch version 7.11 and earlier. Do not use Group Var tags in applications
        developed with InTouch versions later than 7.11.
Tag Properties
        Each InTouch tag type has a set of properties that describe the characteristics of data associated with the tag.
        The four principal data types associated with InTouch tags are:
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 15
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                      Chapter 1 – Data Management Overview
        All tag properties are assigned initial values when you create a tag with the Tagname Dictionary. The following
        figure shows the properties of an I/O Integer tag.
        After setting the initial values of tag properties from the Tagname Dictionary, you can dynamically change most
        tag properties using dotfields. A dotfield identifies a tag property that can be monitored or modified by a script
        when the InTouch application is running. You append the dotfield to the name of the tag in a script.
        For more information about using dotfields to dynamically change tag properties, see Using Tag Dotfields to
        View or Change Tag Properties on page 38.
        % Deviation                              •                        •
        % per                                    •                        •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 16
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                     Chapter 1 – Data Management Overview
        ACK Model                 •              •                       •
        Alarm Comment             •              •             •         •
        Alarm Group               •              •             •         •
        Alarm Inhibitor           •              •                       •
        Alarm State               •
        Alarm Value                              •                       •
        Comment                   •              •             •         •
        Deadband                                 •                       •
        Eng Units                                •                       •
        Deviation Deadband                       •                       •
        %
        High                                     •                       •
        HiHi                                     •                       •
        Initial Value             •              •             •         •
        Log Data                  •              •                       •
        Log Deadband                             •                       •
        Log Events                •              •             •         •
        Lo                                       •                       •
        LoLo                                     •                       •
        Maximum Length                                         •
        Major Deviation                          •                       •
        Max Value                                •                       •
        Min Value                                •                       •
        Minor Deviation                          •                       •
        Off Msg                   •
        On Msg                    •
        Priority                  •              •             •         •
        Rate of Change                           •                       •
        Read Only                 •              •             •         •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 17
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                      Chapter 1 – Data Management Overview
        Read Write                •              •             •          •
        Retentive                                •                        •
        Parameters
        Retentive Value           •              •             •          •
        Target                                   •                        •
        Value Deadband                           •                        •
        % Deviation                              •                        •
        % per                                    •                        •
        Access Name               •              •              •         •
        ACK Model                 •              •                        •
        Alarm Comment             •              •              •         •
        Alarm Group               •              •              •         •
        Alarm Inhibitor           •              •                        •
        Alarm State               •
        Alarm Value                              •                        •
        Comment                   •              •              •         •
        Conversion                               •                        •
        Deadband                                 •                        •
        Deviation Deadband                       •                        •
        %
        Eng Units                                •                        •
        High                                     •                        •
        HiHi                                     •                        •
        Initial Value             •              •              •         •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 18
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                      Chapter 1 – Data Management Overview
        Input Conversion          •
        Item                      •              •              •         •
        Log Data                  •              •                        •
        Log Deadband                             •                        •
        Log Events                •              •              •         •
        Lo                                       •                        •
        LoLo                                     •                        •
        Maximum Length                                          •
        Major Deviation                          •                        •
        Max EU                                   •                        •
        Max Raw                                  •                        •
        Max Value                                •                        •
        Min EU                                   •                        •
        Min Raw                                  •                        •
        Min Value                                •                        •
        Minor Deviation                          •                        •
        Off Msg                   •
        On Msg                    •
        Priority                  •              •              •         •
        Rate of Change                           •                        •
        Read Only                 •              •              •         •
        Read Write                •              •              •         •
        Retentive Parameters                     •                        •
        Retentive Value           •              •              •         •
        Square Root                              •                        •
        Conversion
        Target                                   •                        •
        Use Tagname as Item •                    •              •         •
        Name
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 19
                                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                                   Chapter 1 – Data Management Overview
Value Deadband • •
Access_Name:"PumpRPM"
                                                            PumpRPM
                                                              RPM
        You create an InTouch application to reference tags located on a remote node by two methods:
              Associate I/O tags with an Access Name that identifies a remote server as the tag source. For more
               information about defining an Access Name for an I/O tag, see Setting Up Access Names on page 61.
              Use a remote reference directly to the tag. For example, PLC1:PumpRPM.
        For more information, see Accessing I/O Data by Remote References on page 74.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                               Page 20
Chapter 2
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                               Page 21
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                       Chapter 2 – Managing Tags with the Tagname Dictionary
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 22
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                     Chapter 2 – Managing Tags with the Tagname Dictionary
             c. Optionally, type a comment about the new tag in the Comment box.
        4. Click Type. The Tag Types dialog box appears with a list of supported InTouch tag types.
        5. Select a type of tag from the list and click OK. The Tagname Dictionary reappears and shows the type of tag
           you selected.
        6. If needed, click Details to see the additional Tagname Dictionary options for the selected tag type.
        7. Specify further tag options in the Tagname Dictionary dialog box.
             For more information about specifying tag properties, see Configuring Tag Properties on page 23.
        8. Click Save. Click Close to close the Tagname Dictionary dialog box.
        Each type of InTouch tag has unique data properties. After you select a tag type, the Tagname Dictionary dialog
        box expands to show a set of options, based upon the selected tag type.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 23
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                             Chapter 2 – Managing Tags with the Tagname Dictionary
        All tags belong to an alarm group, which is another common tag property. By default, all tags belong to the
        $System alarm group. For more information about assigning tags to other alarm groups, see Configuring Alarms
        in the InTouch® HMI Alarms and Events Guide.
             If possible, avoid using special characters in tag names unless absolutely required by your application.
            Avoid using a dash (-) in a tag name.
             A dash is a valid character for an InTouch tag name. But, InTouch evaluates a dash as a negation or
             subtraction operator in logical or arithmetic expressions. For example, the expression A=B-C can be
             interpreted as A=B minus C or the tag named B-C is assigned to tag A.
             Hyphen or minus sign (-) will not be allowed when Tag Names start with a numeric character.
            Do not use blank spaces in tag names.
            Do not use a number in the tag name that can be interpreted as an exponential number.
             For example, you cannot name a tag 125E4 because it could be interpreted as a base number with an
             exponent raised to the fourth power.
            Do not use a number in the tag name that can be interpreted as a hexadecimal number.
             For example, you cannot name a tag 0x123B because it could be interpreted as a hexadecimal number.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                         Page 24
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                       Chapter 2 – Managing Tags with the Tagname Dictionary
        Tag Comments
        You can enter an optional comment up to 50 characters in the Tagname Dictionary Comment box when you
        create a tag.
        The first time you access the Tagname Dictionary, the default comment for the $AccessLevel system tag appears
        in the Comment box. Delete this comment to prevent it from being associated with any tags that you create.
        I/O tags have additional properties to establish network communication and transform raw data from network
        devices to normalized values used by the InTouch application. For more information about defining I/O tags, see
        Configuring I/O Tag Properties on page 63.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 25
                                                                                           AVEVA™ InTouch HMI Data Management Guide
                                                                                   Chapter 2 – Managing Tags with the Tagname Dictionary
        Tag Deadbands
        A deadband is a sensitivity setting for tag values. A deadband is usually associated with I/O tags whose values
        change constantly. A deadband filters out small momentary changes in a tag value to reduce the amount of
        InTouch data processing.
        The Tagname Dictionary includes two deadband properties for tags associated with integer and real data.
            Value Deadband: The value deadband property sets a threshold that must be exceeded before
             WindowViewer refreshes the tag’s value in run-time memory. The following figure shows the absolute
             deadband range around a current tag value.
                                   Value deadband
New value
                                                            Tag value
                   Current value
                                                            unchanged
                                         Deadband
New value
            Log Value Deadband: The log deadband sets a threshold that must be exceeded before the tag’s value is
             written to the log file. The following figure shows the deadband around the current value of a logged tag.
                                    Logged Value
                                     Deadband
                     New value                          Logged value changes
                                            Deadband
                       Current
                                                            Logged value
                    logged value
                                            Deadband
             Only new tag values outside of the deadband are written to the log file. Small value changes within the
             deadband range are ignored and not logged.
        To set a tag deadband
        1. Open the Tagname Dictionary dialog box.
        2. Click Select. The Select Tag dialog box appears. The tags currently defined for the application are listed.
        3. Select an integer or real tag type from the list.
        4. Click OK. The detail portion of the Tagname Dictionary dialog box shows additional options when you select
           a real or integer tag.
        5. Set the value deadband by entering an integer or real number in the Deadband box based upon the selected
           tag type.
             The value deadband sets an absolute threshold level in engineering units.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                               Page 26
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                        Chapter 2 – Managing Tags with the Tagname Dictionary
        6. Set the log deadband by entering an integer or real number in the Log Deadband box based upon the
           selected tag type.
             Like the value deadband, the log deadband sets an absolute threshold in engineering units.
        7. Click Save to save your deadband changes.
        8. Click Close to close the Tagname Dictionary dialog box.
        I/O Connection
        All types of I/O tags must identify the Access Name and Item Name of the external data source. For more
        information about specifying the Access Name and Item Name for I/O tags, see Setting I/O Access Parameters on
        page 66.
        Tag Logging
        During run time, WindowViewer can write an entry to the historical log file each time a tag’s value changes more
        than the specified log deadband. WindowViewer also writes entries to the log at a fixed interval regardless of
        current tag values. By default, this fixed interval is one hour.
        Note: For more controllable and versatile logging, consider using Historian to store InTouch historical data.
        The Tagname Dictionary dialog box includes separate options to log data and events to the log file. You can set
        value logging options. For information about setting event logging, see Configuring Alarms in the InTouch® HMI
        Alarms and Events Guide.
        For a tag's value to be written to the historical log file, historical logging must be enabled. For more information
        about setting general logging properties, see Configuring Historical Logging on page 142.
        For integer and real tags, you can set the Log Deadband in their respective details dialog boxes. The Log
        Deadband option specifies how many engineering units a tag's value must change to write a log entry.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 27
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                        Chapter 2 – Managing Tags with the Tagname Dictionary
        4. Select Log Events if you want to log value changes to the tag initiated by an operator, an I/O, QuickScript, or
           operating system. The Priority box appears after you select Log Events.
             The Priority value determines the event priority for the tag. Valid values are 1 to 999, where 1 is the highest
             priority and 999 is the lowest.
        5. Click Save and then close the Tagname Dictionary.
        3. Select On or Off as the initial value associated with the tag. The tag is set to this initial value when the
           application starts.
        4. Enter messages in the On Msg and Off Msg boxes that appear when the tag transitions in and out of an
           alarm state.
             These messages are available for use in any animation link or script, regardless of whether the tag has
             alarms configured or not.
             o   If you define a discrete alarm that is active when the tag value is equal to 1 (On, True), the message
                 entered in the On Msg box appears in the Value and Limit columns of your ActiveX alarm displays.
                 When the tag’s alarm state returns to normal, the message entered in the Off Msg box appears in the
                 Value column and the On message remains in the Limit column.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                         Page 28
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                        Chapter 2 – Managing Tags with the Tagname Dictionary
             o   If you define a discrete alarm that is active when the tag value is equal to 0 (Off, False), the message
                 entered in the Off Msg box appears in the Value and Limit columns of your ActiveX alarm displays.
                 When the tag’s alarm state returns to normal, the message entered in the On Msg box appears in the
                 Value column and the Off message remains in the Limit column.
        5. Save your changes to the tag.
        2. Set the properties for integer and real tags. Do the following:
             o   In the Initial Value box, type the integer or real number associated with the tag when the application
                 starts.
             o   In the Min Value box, type the minimum integer or real number for the tag.
                 The Min Value sets the minimum possible value for numbers associated with memory integer and real
                 tags.
             o   In the Max Value box, type the maximum integer or real number for the tag.
                 The Max Value sets the maximum possible value for numbers associated with memory integer and real
                 tags.
             o   In the Eng Units box, type the label you want to use for the tag's engineering units.
        3. Save your changes to the tag.
        For more information about setting the tag’s deadband and log deadband properties, see Tag Deadbands on
        page 26.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 29
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                        Chapter 2 – Managing Tags with the Tagname Dictionary
Modifying Tags
        Modifying a tag is similar to creating a tag. You select the tag to be modified from the Tagname Dictionary. Then,
        you change the tag’s properties following the same steps to create a tag.
        Important: It is not easy to modify a tag's type after it is used in an InTouch application. The tag type selection
        may be limited to similar data types. You should carefully select the correct data type when you define your
        tags.
        To modify a tag
        1. Open the Tagname Dictionary dialog box.
        2. Click Select. The Select Tag dialog box appears. A list of tags currently defined for the application is shown.
        3. Select the tag to be modified from the list.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 30
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                     Chapter 2 – Managing Tags with the Tagname Dictionary
        4. Click OK. The Tagname Dictionary dialog box shows the values specified for the selected tag.
        5. Make changes to the tag’s properties.
        6. Click Save to update the tag with your changes.
        7. Click Close to close the Tagname Dictionary.
Deleting Tags
        A count is maintained for all tags defined for an InTouch application. The tag count does not decrease
        automatically when a window containing animation links or scripts is deleted. The tags associated with the
        deleted window are still considered to be in use and cannot be deleted.
        To be able to delete a tag that is no longer used, you must close WindowViewer and update local and remote
        tag use counts. You can determine where a tag is being used with the InTouch Cross-Reference utility. For more
        information about using the Cross Reference Utility and updating tag counts, see Reducing Tag Usage on page
        128.
        Tags can be deleted after the use count is updated. For more information, see Deleting Unused Tags on page
        138.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 31
Chapter 3
System Tags
        $AccessLevel                        Read-only integer tag that specifies the     See Securing InTouch in
                                            access level associated with the currently   the InTouch® HMI
                                            logged-on operator.                          Application
                                                                                         Management and
                                            This information can be used in animation
                                                                                         Extension Guide.
                                            links or scripts to control the operator’s
                                            access to specific InTouch functions.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 32
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                                       Chapter 3 – System Tags
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 33
                                                                                    AVEVA™ InTouch HMI Data Management Guide
                                                                                                        Chapter 3 – System Tags
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                       Page 34
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                                       Chapter 3 – System Tags
        $Month                              Read-only integer tag that shows the           See Built-In Functions in
                                            number of the current month (1-12).            the InTouch® HMI
                                                                                           Scripting and Logic
                                                                                           Guide.
        $Msec                               Read-only integer tag that shows the           See Built-In Functions in
                                            current millisecond (0-999).                   the InTouch® HMI
                                                                                           Scripting and Logic
                                                                                           Guide.
        $NewAlarm                           Read/write discrete tag that indicates when See Controlling Alarm
                                            a new local alarm has occurred.             Properties of Tags and
                                                                                        Groups at Run Time in
                                                                                        the InTouch® HMI
                                                                                        Alarms and Events
                                                                                        Guide.
        $ObjHor                             Read-only integer tag that shows the           See Animating Objects
                                            horizontal pixel location of the center of a   in the InTouch® HMI
                                            selected object on the screen.                 Visualization Guide.
        $ObjVer                             Read-only integer tag that shows the           See Animating Objects
                                            vertical pixel location of the center of a     in the InTouch® HMI
                                            selected object on the screen.                 Visualization Guide.
        $Operator                           Read-only message tag that shows the name See Securing InTouch in
                                            of the operator logged on to an InTouch   the InTouch® HMI
                                            application.                              Application
                                                                                      Management and
                                                                                      Extension Guide.
        $OperatorDomain                     Read-only message tag that contains the        See Securing InTouch in
                                            domain or machine name specified at log on     the InTouch® HMI
                                            when the application is secured with           Application
                                            operating system-based security.               Management and
                                                                                           Extension Guide.
        $OperatorDomainEntered              Write-only message tag assigned the            See Securing InTouch in
                                            domain of the operator for a logon attempt     the InTouch® HMI
                                            to an InTouch application.                     Application
                                                                                           Management and
                                            The logon attempt does not start until you
                                                                                           Extension Guide.
                                            assign a value to the $PasswordEntered
                                            system tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 35
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                                       Chapter 3 – System Tags
        $OperatorEntered                    Read/write message tag assigned the user       See Securing InTouch in
                                            account name of an operator for a logon        the InTouch® HMI
                                            attempt to an InTouch application.             Application
                                                                                           Management and
                                            The logon attempt does not start until you
                                                                                           Extension Guide.
                                            assign a value to the $PasswordEntered
                                            system tag.
        $OperatorName                       Read-only message tag that shows the full      See Securing InTouch in
                                            name of the operator if operating              the InTouch® HMI
                                            system-based or ArchestrA® authentication      Application
                                            is used.                                       Management and
                                                                                           Extension Guide.
        $PasswordEntered                    Write-only message tag assigned the            See Securing InTouch in
                                            password of an operator for a logon            the InTouch® HMI
                                            attempt to an InTouch application.             Application
                                                                                           Management and
                                            When you write a value to this tag, a logon
                                                                                           Extension Guide.
                                            attempt is started using the values of the
                                            $OperatorDomainEntered,
                                            $OperatorEntered, and $PasswordEntered
                                            system tags.
        $Second                             Read-only integer tag that shows the           See Built-In Functions in
                                            current second (0-59).                         the InTouch® HMI
                                                                                           Scripting and Logic
                                                                                           Guide.
        $StartDdeConversations              Read/write discrete tag used to start          See Data Access with
                                            uninitiated conversations during run time.     I/O on page 56.
        $System                             Read-only tag that identifies the root alarm   See Overview of Alarms
                                            group.                                         and Events in the
                                                                                           InTouch® HMI Alarms
                                                                                           and Events Guide.
        $Time                               Read-only integer tag that shows the           See Built-In Functions in
                                            elapsed time in milliseconds since midnight    the InTouch® HMI
                                            of the current day.                            Scripting and Logic
                                                                                           Guide.
        $TimeString                         Read-only message tag that shows the           See Built-In Functions in
                                            current time in the same format specified      the InTouch® HMI
                                            from the Windows Regional and Language         Scripting and Logic
                                            Options dialog box.                            Guide.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 36
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                                       Chapter 3 – System Tags
        $VerifiedUserName                   Read-only message tag that contains either     See Securing InTouch in
                                            a verified user’s full name or null.           the InTouch® HMI
                                                                                           Application
                                                                                           Management and
                                                                                           Extension Guide.
        $Year                               Read-only integer tag that shows the           See Built-In Functions in
                                            current year as a four-digit number.           the InTouch® HMI
                                                                                           Scripting and Logic
                                                                                           Guide.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 37
Chapter 4
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 38
                                                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
                                                                                                                                                                                 Distributed Alarm
                                                                                                                                                                                 Object / Controls
                                                                                                                                                      Alarm Group
                                                                                                                                                                    Hist Trend
                                                                       Message
Message
                                                                                                                                            Message
                                           Discrete
Discrete
                                                                                                                        Discrete
                                                      Integer
Integer
Analog
                                                                                                                                                                                                     TagID
                                                                Real
                                                                                                       Real
        .Ack                                •          •         •                 •          •         •                •          •                    •
        .AckDev                                        •         •                            •         •                           •                    •
        .AckDsc                             •                                      •                                     •                               •
        .AckROC                             •          •         •                            •         •                           •                    •
        .AckValue                                      •         •                            •         •                           •                    •
        .Alarm                              •          •         •                 •          •         •                •          •                    •
        .AlarmAccess                                                                                                                                                              •
        .AlarmAckModel                      •          •         •                 •          •         •                •          •
        .AlarmClass                                                                                                                                                               •
        .AlarmComment                       •          •         •      •          •          •         •      •         •          •        •           •           •            •                  •
        .AlarmDate                                                                                                                                                                •
        .AlarmDev                                      •         •                            •         •                           •                    •
        .AlarmDevCount                                 •         •                            •         •                           •                    •
        .AlarmDevDeadband                              •         •                            •                                     •
        .AlarmDevUnAckCount                            •         •                            •         •                           •                    •
        .AlarmDisabled                      •          •         •                 •          •         •                •          •                    •
        .AlarmDsc                           •                                      •                                     •                               •
        .AlarmDscCount                      •                                      •                                     •                               •
        .AlarmDscDisabled                   •                                      •                                     •                               •
        .AlarmDscEnabled                    •                                      •                                     •                               •
        .AlarmDscInhibitor                  •                                      •                                     •                               •
        .AlarmDscUnAckCount                 •                                      •                                     •                               •
        .AlarmEnabled                       •          •         •                 •          •         •                •          •                    •
        .AlarmGroup                                                                                                                                                               •
        .AlarmGroupSel                                                                                                                                                            •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                                            Page 39
                                                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
Tag Types
                                                                                                                                                                                 Distributed Alarm
                                                                                                                                                                                 Object / Controls
                                                                                                                                                      Alarm Group
                                                                                                                                                                    Hist Trend
                                                                       Message
Message
                                                                                                                                            Message
                                           Discrete
Discrete
                                                                                                                        Discrete
        Dotfields
Integer
Integer
Analog
                                                                                                                                                                                                     TagID
                                                                Real
                                                                                                       Real
        .AlarmHiDisabled                               •         •                            •         •                           •
        .AlarmHiEnabled                                •         •                            •         •                           •
        .AlarmHiHiDisabled                             •         •                            •         •                           •
        .AlarmHiHiEnabled                              •         •                            •         •                           •
        .AlarmHiHiInhibitor                            •         •                            •         •                           •
        .AlarmHiInhibitor                              •         •                            •         •                           •
        .AlarmLimit                                                                                                                                                               •
        .AlarmLoDisabled                               •         •                            •         •                           •
        .AlarmLoEnabled                                •         •                            •         •                           •
        .AlarmLoInhibitor                              •         •                            •         •
        .AlarmLoLoDisabled                             •         •                            •         •                           •
        .AlarmLoLoEnabled                              •         •                            •         •                           •
        .AlarmLoLoInhibitor                            •         •                            •         •                           •
        .AlarmMajDevDisabled                           •         •                            •         •                           •
        .AlarmMajDevEnabled                            •         •                            •         •                           •
        .AlarmMajDevInhibitor                          •         •                            •         •                           •
        .AlarmMinDevDisabled                           •         •                            •         •                           •
        .AlarmMinDevEnabled                            •         •                            •         •                           •
        .AlarmMinDevInhibitor                          •         •                            •         •                           •
        .AlarmName                                                                                                                                                                •
        .AlarmOprName                                                                                                                                                             •
        .AlarmOprNode                                                                                                                                                             •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                                            Page 40
                                                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
Tag Types
                                                                                                                                                                                 Distributed Alarm
                                                                                                                                                                                 Object / Controls
                                                                                                                                                      Alarm Group
                                                                                                                                                                    Hist Trend
                                                                       Message
Message
                                                                                                                                            Message
                                           Discrete
Discrete
                                                                                                                        Discrete
        Dotfields
Integer
Integer
Analog
                                                                                                                                                                                                     TagID
                                                                Real
                                                                                                       Real
        .AlarmPri                                                                                                                                                                 •
        .AlarmProv                                                                                                                                                                •
        .AlarmROC                                      •         •                            •         •                           •
        .AlarmROCCount                                 •         •                            •         •                           •
        .AlarmROCDisabled                              •         •                            •         •                           •
        .AlarmROCEnabled                               •         •                            •         •                           •
        .AlarmROCInhibitor                             •         •                            •         •                           •
        .AlarmROCUnAckCount                            •         •                            •         •                           •
        .AlarmState                                                                                                                                                               •
        .AlarmTime                                                                                                                                                                •
        .AlarmTotalCount                    •          •         •                 •          •         •                •          •                    •
        .AlarmType                                                                                                                                                                •
        .AlarmUnAckCount                    •          •         •                 •          •         •                •          •                    •
        .AlarmUserDefNum1                   •          •         •                 •          •         •                •          •                    •
        .AlarmUserDefNum1Set                •          •         •                 •          •         •                •          •                    •
        .AlarmUserDefNum2                   •          •         •                 •                    •                •          •                    •
        .AlarmUserDefNum2Set                •          •         •                 •          •         •                •          •                    •
        .AlarmUserDefStr                    •          •         •                 •          •         •                •          •                    •
        .AlarmUserDefStrSet                 •          •         •                 •          •         •                •                               •
        .AlarmValDeadband                              •         •                            •         •                           •
        .AlarmValue                                              •                                      •                           •                    •                        •
        .AlarmValueCount                               •         •                            •         •                           •                    •
        .AlarmValueUnAckCount                          •         •                            •         •                           •                    •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                                            Page 41
                                                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
Tag Types
                                                                                                                                                                                 Distributed Alarm
                                                                                                                                                                                 Object / Controls
                                                                                                                                                      Alarm Group
                                                                                                                                                                    Hist Trend
                                                                       Message
Message
                                                                                                                                            Message
                                           Discrete
Discrete
                                                                                                                        Discrete
        Dotfields
Integer
Integer
Analog
                                                                                                                                                                                                     TagID
                                                                Real
                                                                                                       Real
        .Caption                                                                                                                                                                  •
        .ChartLength                                                                                                                                                 •
        .ChartStart                                                                                                                                                  •
        .Comment                            •          •         •      •          •          •         •      •         •          •        •           •           •                               •
        .DevTarget                                     •         •                            •         •                           •
        .DisplayMode                                                                                                                                                 •
        .Enabled                                                                                                                                                                  •
        .EngUnits                                      •         •                            •         •                           •
        .Freeze                                                                                                                                                                   •
        .HiHiLimit                                     •         •                            •         •                           •
        .HiHiSet                                       •         •                            •         •                           •
        .HiHiStatus                                    •         •                            •         •                           •
        .HiLimit                                       •         •                            •         •                           •
        .HiSet                                         •         •                            •         •                           •
        .HiStatus                                      •         •                            •         •                           •
        .ListChanged                                                                                                                                                              •
        .ListCount                                                                                                                                                                •
        .ListIndex                                                                                                                                                                •
        .LoLimit                                       •         •                            •         •                           •
        .LoLoLimit                                     •         •                            •         •                           •
        .LoLoSet                                       •         •                            •         •                           •
        .LoLoStatus                                    •         •                            •         •                           •
        .LoSet                                         •         •                            •         •                           •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                                            Page 42
                                                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
Tag Types
                                                                                                                                                                                 Distributed Alarm
                                                                                                                                                                                 Object / Controls
                                                                                                                                                      Alarm Group
                                                                                                                                                                    Hist Trend
                                                                       Message
Message
                                                                                                                                            Message
                                           Discrete
Discrete
                                                                                                                        Discrete
        Dotfields
Integer
Integer
Analog
                                                                                                                                                                                                     TagID
                                                                Real
                                                                                                       Real
        .LoStatus                                      •         •                            •         •                           •
        .MajorDevPct                                   •         •                            •         •                           •
        .MajorDevSet                                   •         •                            •         •                           •
        .MajorDevStatus                                •         •                            •         •                           •
        .MaxEU                                         •         •                            •         •                           •
        .MaxRange                                                                                                                                                    •
        .MaxRaw                                        •         •                            •         •
        .MinEU                                         •         •                            •         •                           •
        .MinorDevPct                                   •         •                            •         •                           •
        .MinorDevSet                                   •         •                            •         •                           •
        .MinorDevStatus                                •         •                            •         •                           •
        .MinRange                                                                                                                                                    •
        .MinRaw                                        •         •                            •         •                           •
        .Name                               •          •         •      •          •          •         •      •         •          •        •           •           •            •                  •
        .NewIndex                                                                                                                                                                 •
        .NextPage                                                                                                                                                                 •
        .Normal                             •          •         •                 •          •         •                •          •                    •
        .NumAlarms                                                                                                                                                                •
        .OffMsg                             •                                      •                                     •
        .OnMsg                              •                                      •                                     •
        .PageNum                                                                                                                                                                  •
        .Pen1 through .Pen8                                                                                                                                          •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                                            Page 43
                                                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
Tag Types
                                                                                                                                                                                 Distributed Alarm
                                                                                                                                                                                 Object / Controls
                                                                                                                                                      Alarm Group
                                                                                                                                                                    Hist Trend
                                                                       Message
Message
                                                                                                                                            Message
                                           Discrete
Discrete
                                                                                                                        Discrete
        Dotfields
Integer
Integer
Analog
                                                                                                                                                                                                     TagID
                                                                Real
                                                                                                       Real
        .PendingUpdates                                                                                                                                                           •
        .PrevPage                                                                                                                                                                 •
        .PriFrom                                                                                                                                                                  •
        .PriTo                                                                                                                                                                    •
        .Quality                            •          •         •      •          •          •         •      •         •          •        •
        .QualityLimit                       •          •         •      •          •          •         •      •         •          •        •
        .QualityLimitString                 •          •         •      •          •          •         •      •         •          •        •
        .QualityStatus                      •          •         •      •          •          •         •      •         •          •        •
        .QualityStatusString                •          •         •      •          •          •         •      •         •          •        •
        .QualitySubstatus                   •          •         •      •          •          •         •      •         •          •        •
        .QualitySubstatusString             •          •         •      •          •          •         •      •         •          •        •
        .QueryState                                                                                                                                                               •
        .QueryType                                                                                                                                                                •
        .RawValue                           •          •         •                 •          •         •                •          •                    •
        .ReadOnly                                                                                                                                                                 •
        .Reference                          •          •         •      •          •          •         •      •         •          •        •
        .ReferenceComplete                  •          •         •      •          •          •         •      •         •          •        •
        .ROCPct                                        •         •                            •         •                           •
        .ROCSet                                        •         •                            •         •
        .ROCStatus                                     •         •                            •         •                           •
        .ScooterLockLeft                                                                                                                                             •
        .ScooterLockRight                                                                                                                                            •
        .ScooterPosLeft                                                                                                                                              •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                                            Page 44
                                                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
Tag Types
                                                                                                                                                                                 Distributed Alarm
                                                                                                                                                                                 Object / Controls
                                                                                                                                                      Alarm Group
                                                                                                                                                                    Hist Trend
                                                                       Message
Message
                                                                                                                                            Message
                                           Discrete
Discrete
                                                                                                                        Discrete
        Dotfields
Integer
Integer
Analog
                                                                                                                                                                                                     TagID
                                                                Real
                                                                                                       Real
        .ScooterPosRight                                                                                                                                             •
        .Successful                                                                                                                                                               •
        .SuppressRetain                                                                                                                                                           •
        .TagID                              •          •         •                 •          •         •                •          •
        .TimeDate                           •          •         •      •          •          •         •      •         •          •        •
        .TimeDateString                     •          •         •      •          •          •         •      •         •          •        •
        .TimeDateTime                       •          •         •      •          •          •         •      •         •          •        •
        .TimeDay                            •          •         •      •          •          •         •      •         •          •        •
        .TimeHour                           •          •         •      •          •          •         •      •         •          •        •
        .TimeMinute                         •          •         •      •          •          •         •      •         •          •        •
        .TimeMonth                          •          •         •      •          •          •         •      •         •          •        •
        .TimeMsec                           •          •         •      •          •          •         •      •         •          •        •
        .TimeSecond                         •          •         •      •          •          •         •      •         •          •        •
        .TimeTime                           •          •         •      •          •          •         •      •         •          •        •
        .TimeTimeString                     •          •         •      •          •          •         •      •         •          •        •
        .TimeYear                           •          •         •      •          •          •         •      •         •          •        •
        .TopIndex                                                                                                                                                                 •
        .TotalPages                                                                                                                                                               •
        .UnAck                              •          •         •                 •          •         •                •          •                    •
        .UpdateCount                                                                                                                                                 •
        .UpdateinProgress                                                                                                                                            •
        .UpdateTrend                                                                                                                                                 •
        .Value(Tagname)                     •          •         •      •          •          •         •      •         •          •        •           •                                           •
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                                            Page 45
                                                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
Tag Types
                                                                                                                                                                                 Distributed Alarm
                                                                                                                                                                                 Object / Controls
                                                                                                                                                      Alarm Group
                                                                                                                                                                    Hist Trend
                                                                       Message
Message
                                                                                                                                            Message
                                           Discrete
Discrete
                                                                                                                        Discrete
        Dotfields
Integer
Integer
Analog
                                                                                                                                                                                                     TagID
                                                                Real
                                                                                                       Real
        .Value(Windows Control)                                                                                                                                                   •
        .Visible                                                                                                                                                                  •
        Dotfields can be categorized by their intended function. For more information about dotfield functional
        categories, see the following sections:
Category See
        Values and limits        Changing the Value Limits of a Tag on page 46.
        Alarm parameters         Controlling Alarm Properties of Tags and Groups at
                                 Run Time in the InTouch® HMI Alarms and Events
                                 Guide.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                                                                                            Page 46
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        .MinRaw Dotfield
        The .MinRaw dotfield shows the Min Raw low clamp setting assigned to a tag. The value for .MinRaw dotfield
        comes from the Min Raw value assigned to the I/O tag in the Tagname Dictionary. Any raw value less than this
        setting is clamped to this minimum value.
        Category
        Tags
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 47
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        Usage
        tag_name.MinRaw;
        Parameter
             Tag_name
             The name of any I/O integer, I/O real, and indirect analog tag.
        Remarks
        This read-only dotfield shows the value assigned to the Min Raw low clamp setting.
        Data Type
        Real or integer (read-only).
        Valid Values
        Any analog value.
        Example
        The following script shows an error window if the raw value associated with pump inlet pressure is outside of
        the lower and upper value boundaries set by the tag’s Min Raw and Max Raw properties.
        IF ((PumpInP.RawValue > PumpInP.MaxRaw) OR
           (PumpInP.RawValue < PumpInP.MinRaw)) THEN
           Show "Instrument Failure Window";
        ENDIF;
        See Also
        .EngUnits, .MinEU, .MaxEU, .MaxRaw, .RawValue
        .MaxRaw Dotfield
        The .MaxRaw dotfield shows the Max Raw high clamp setting assigned to an I/O tag from the Max Raw property
        in the Tagname Dictionary. Any raw data value that exceeds this setting is clamped to this maximum raw value.
        Category
        Tags
        Usage
        Tag_name.MaxRaw
        Parameter
             Tag_name
             The name of any I/O integer, I/O real, and indirect analog tag.
        Remarks
        This read-only dotfield shows the value assigned to the Max Raw high clamp setting.
        Data Type
        Real or integer (read-only).
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 48
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        Valid Values
        Any analog value.
        Example
        This script determines if a tag value is out of normal operating range and a window is shown if this is the case.
        IF ((Temp01.RawValue > Temp01.MaxRaw) OR (Temp01.RawValue <
           Temp01.MinRaw))THEN
           Show "Instrument Failure Window";
        ENDIF;
        See Also
        .EngUnits, .MinEU, .MaxEU, .MinRaw, .RawValue
        .RawValue Dotfield
        The .RawValue dotfield shows the actual value received from an I/O Server by WindowViewer. The .RawValue
        dotfield allows you to access the value of an I/O tag before InTouch applies scaling.
        Category
        Tags
        Usage
        Tag_name.RawValue
        Parameter
             Tag_name
             The name of any I/O integer, I/O real, I/O discrete, indirect discrete, and indirect analog tag.
        Remarks
        This read-only dotfield is used to show the actual discrete or analog I/O value before InTouch applies scaling.
        Data Type
        Any data appropriate for the type of tag associated with the .RawValue dotfield. For example, real numbers for
        real tags or discrete values for discrete tags (read-only).
        Example
        The following script issues a warning message when the raw pump inlet pressure is below or above the tag’s
        minimum and maximum clamping limits.
        IF ((PumpInP.RawValue > PumpInP.MaxRaw) OR (PumpInP.RawValue < PumpInP.MinRaw)) THEN
           AlarmMessage = "Pump sensor is out of calibration or requires replacement.";
        ENDIF;
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 49
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        See Also
        .EngUnits, .MinEU, .MaxEU, .MinRaw, .MaxRaw
        .MaxEU Dotfield
        The .MaxEU dotfield shows the maximum engineering unit value assigned to the specified tag from the
        Tagname Dictionary.
        Category
        Tags
        Usage
        Tag_name.MaxEU
        Parameter
             Tag_name
             Any integer, real, or indirect analog tag.
        Remarks
        The .MaxEU dotfield is used to scale raw data values to an engineering unit range defined for the tag. It defines
        the upper limit of engineering unit range.
        Data Type
        Real for real tags and integer for integer tags (read-only).
        Valid Values
        Depends on the type of tag specified.
        Example
        A level gauge is read by a Programmable Logic Controller in the field. The level transmitter sends a signal that
        ranges between 4 and 20mA. The PLC converts this signal to an integer value between 0 and 4095. This value is
        assigned to the TankTwoLevel tag.
        Displaying the raw value (between 0 and 4095) provides no useful data to the operator. It is necessary to scale
        this value to an appropriate engineering range.
        To accomplish this, the Minimum engineering unit and Maximum engineering unit fields must be set up
        correctly. In our example, if the raw value of 0 (4mA from the field) translated to "0 Gallons" and the value of
        4095 (20mA from the field) translated to "100 Gallons", the following set up would be required to show the
        correct value on the screen:
        TankTwoLevel.MinRaw = 0;
        TankTwoLevel.MaxRaw = 4095;
        TankTwoLevel.MinEU = 0;
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 50
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        TankTwoLevel.MaxEU = 100;
        With these settings, when the raw value in the field is 4095, the value shown to the operator is 100.
        See Also
        .EngUnits, .MinEU, .MinRaw, .MaxRaw, .RawValue
        .MinEU Dotfield
        The .MinEU dotfield shows the minimum engineering unit value assigned to the specified tag from the Tagname
        Dictionary.
        Category
        Tags
        Usage
        Tag_name.MinEU
        Parameter
             Tag_name
             Any integer, real, or indirect analog tag.
        Remarks
        The .MinEU dotfield is used to scale raw data values to an engineering unit range defined for the tag. It defines
        the lower limit of engineering unit range.
        Data Type
        Real for real tags and integer for integer tags (read-only).
        Valid Values
        Depends on the type of tag specified.
        Example
        This example assigns the engineering unit range defined for the Tag1 tag to the AbsoluteTagRange tag.
        AbsoluteTagRange = (Tag1.MaxEU - Tag1.MinEU);
        See Also
        .EngUnits, .MaxEU, .MinRaw, .MaxRaw, .RawValue
        .EngUnits Dotfield
        The .EngUnits dotfield shows the text value assigned to an analog tag with the Eng Units property. The
        .EngUnits dotfield shows the engineering unit as a text value.
        Note: Values written to this field are not retentive.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 51
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        Category
        Tags
        Usage
        Tag_name.EngUnits
        Parameter
             Tag_name
             Any integer, real, or indirect analog tag.
        Data Type
        Message (read/write).
        Remarks
        The .EngUnits dotfield does not affect the scale, conversion, or format of the actual data associated with the tag.
        Valid Values
        Any string containing 0 to 31 characters.
        Example
        The following script calls a Fahrenheit temperature conversion function if the tag’s engineering unit is Celsius.
        IF Temperature.EngUnits == "Celsius" THEN
           CALL TempFConvert(Temperature);
        ENDIF;
        See Also
        .MinEU, .MaxEU, .MinRaw, .MaxRaw, .RawValue
        .Value Dotfield
        The .Value dotfield shows the current value of the specified tag in engineering units. .Value is the default
        InTouch dotfield implicitly applied to all tags. If a tag does not have an assigned dotfield, the .Value dotfield is
        assumed.
        Category
        Tags
        Usage
        tag_name.Value
        Parameter
             tag_name
             Any type of tag except the Hist Trend tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 52
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        Remarks
        You rarely need to use the .Value dotfield. However, in some instances, it makes a calculation or parameter
        usage more clear.
        Data Type
        The same as the specified tag's type (read/write).
        Valid Values
        Depends on the type of tag specified.
        Example
        The following statement sets the value of the memory integer PumpRPM tag equal to 100:
        PumpRPM.Value=100;
        which is functionally equivalent to:
        PumpRPM=100;
        .OnMsg Dotfield
        The .OnMsg dotfield allows you to access the On message assigned to a discrete tag from the Tagname
        Dictionary.
        Category
        Tags
        Usage
        Tag_name.OnMsg
        Parameter
             Tag_name
             Any discrete tag.
        Data Type
        Message (read/write). Values written to this dotfield are not retentive.
        Valid Values
        Any string containing 0 to 15 characters.
        Example
        The following statement issues a message if the indirect IndPumpState tag On message is assigned a string value
        of "Pump1 running".
        IF IndPumpState.OnMsg == "Pump1 running" THEN
           TypeOfTag = "The IndPumpState tag is assigned to Pump1.";
        ENDIF;
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 53
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        See Also
        .OffMsg
        .OffMsg Dotfield
        The .OffMsg dotfield allows you to access the Off message assigned to a discrete tag from the Tagname
        Dictionary.
        Category
        Tags
        Usage
        Tag_name.OffMsg
        Parameter
             Tag_name
             Any discrete tag.
        Data Type
        Message (read/write). Values written to this dotfield are not retentive.
        Valid Values
        Any string containing 0 to 15 characters.
        Example
        The following statement assigns the appropriate string to the StateMessage tag according to the state of the
        MyDiscrete tag.
        StateMessage=Dtext (MyDiscrete, MyDiscrete.OnMsg, MyDiscrete.OffMsg);
        See Also
        .OnMsg
        .Comment Dotfield
        The .Comment dotfield shows the comment assigned to a tag from the Tagname Dictionary. A tag comment can
        be a string up to 50 characters.
        Category
        Tags
        Usage
        Tag_name.Comment
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 54
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                    Chapter 4 – Using Tag Dotfields to View or Change Tag Properties
        Parameter
             Tag_name
             Any tag name.
        Remarks
        The comment associated with a tag can be modified with the .Comment dotfield while an InTouch application is
        running. After the application is stopped, the original comment specified from the Tagname Dictionary remains
        assigned to the tag.
        Data Type
        Message
        Valid Values
        Any string from 1 to 50 characters.
        Example
        The following statement creates an operator message by combining a tag’s assigned comment to the name of
        the tag:
        OperatorMessage=PumpRPM.Name + " has a comment of: " + PumpRPM.Comment;
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 55
Chapter 5
                                  Access Name
                                    Node:
                                  Application:
                                    Topic:
        You can set up an InTouch application to identify an element of data stored on another node by using a
        three-part addressing convention. This convention includes the node, application, and topic names. To obtain
        data from a remote node, you need to configure an Access Name for your InTouch application that specifies
        these three items.
        For example, if you want to access data from a remote I/O Server running on another node, your Access Name
        consists of the following:
Node Name Node name of the computer running the I/O Server program.
        Application Name                     Name of the I/O Server program running on the node.
                                             For example, "UA_SampleServer" might be the name of an OPC UA
                                             server.
                                             For more information about the application names associated with
                                             Operations Integration (OI) servers, refer to the OI server
                                             documentation.
        Topic Name                           Label assigned to the I/O Server Device Group.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                               Page 56
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
If you use an Excel spreadsheet as your InTouch data source, you can define your Access Name as follows:
Node Name Node name of the computer running the Excel program.
        In addition to the node, application, topic, and item, you need to specify the type of data located on the remote
        node. This information determines the I/O type for the tag when it is defined in the Tagname Dictionary.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 57
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
            The Gateway can be activated as a COM Server (OPC Server) using standard COM activation mechanisms.
            The Gateway can be run only out-of-proc within OPC clients.
            The Gateway can communicate only with ArchestrA data source components delivered with Application
             Server v2.0 and later. Earlier versions of Application Server are not supported.
    SuiteLink
        SuiteLink is a TCP/IP-based protocol designed specifically for industrial applications. SuiteLink provides data
        integrity, high throughput, and simple diagnostic procedures. The SuiteLink protocol is supported by Microsoft
        Windows NT 4.0 and later.
        SuiteLink is not a replacement for DDE or NetDDE. Each connection between a client and a server depends on
        your network requirements.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 58
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 5 – Data Access with I/O
    OPC
        OPC is not itself a communication protocol, but functions as a driver—a non-proprietary set of standard
        interfaces, based on Microsoft’s OLE/COM technology. This standard makes possible interoperability between
        automation/control applications, field systems/devices, and business/office applications.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 59
                                                                                    AVEVA™ InTouch HMI Data Management Guide
                                                                                                Chapter 5 – Data Access with I/O
        Avoiding the traditional requirement of software application developers to write custom drivers to exchange
        data with field devices, OPC defines a common, high-performance interface that permits this work to be done
        once, and then easily reused by HMI, SCADA, control and custom applications.
        Over a network, OPC uses DCOM (Distributed COM) for remote communications.
    OPC UA
        OPC Unified Architecture (OPC UA) is an industrial machine-to-machine communication protocol for
        interoperability. It provides process control with enhanced security, advanced communication, security, and
        information models, and cross-platform connectivity.
        OPC UA is implemented as a client in OI Gateway.
        OPC UA differs significantly from OPC. The following provides the key differences between classic OPC and OPC
        UA.
    MQTT
        MQTT, formerly called Message Queuing Telemetry Transport, is a publish/subscribe messaging protocol for use
        over TCP/IP. MQTT is designed to ensure that devices can communicate with each other while minimizing power
        and bandwidth requirements. It is a simple messaging protocol that is well-suited for use with devices that rely
        on slow or unreliable networks.
        The MQTT protocol is an application layer specification, and has been published as standard ISO/IEC PRF 20922.
        MQTT uses a Publish-Subscribe mechanism which requires a mediating broker. The publishers send data to the
        broker, and subscribing clients receive data published to the broker. Only clients that have subscribed to a
        particular topic receive messages about that topic. The protocol supports bidirectional communication such that
        a device that is a publisher can also receive updates.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                       Page 60
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
        3. Set the properties of the Add Access Name dialog box. Do the following:
             o   In the Access box, type a name that identifies this Access Name.
             o   If the data resides on a network I/O Server, type the remote server’s node name in the Node Name box.
             o   In the Application Name box, type the actual program name of the I/O Server program from which data
                 will be acquired.
                 If the I/O data source is a DAServer, type the name of the DAServer program, do not include the .exe file
                 name extension of the program.
             o   In the Topic Name box, type the topic name you want to access.
                 The topic name is an application-specific sub-group of data elements. In the case of data coming from a
                 DAServer program, the topic name is the same name configured for the topic in the DAServer program.
                 When communicating with Microsoft Excel, the topic name must be the name assigned to the book and
                 spreadsheet when it was saved. For example, [Book1]Sheet1.
             o   Select the communication protocol to communicate with the I/O Server.
             o   Select the option to poll information stored on the server.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 61
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
Option Definition
        Advise all items     Polls for all data whether or not it is in visible windows, alarmed, logged,
                             trended, or used in a script. Selecting this option affects performance, so its
                             use is not recommended.
        Advise only          Polls for data shown in visible windows and data that is alarmed, logged,
        active items         trended, or used in any script.
                             A button action script is not polled unless it appears in a visible window.
4. Select Enable Secondary Source if you want to select a secondary back up server. Otherwise, go to step 5.
             o   If you select the Enable Secondary Source option, the Add Access Name dialog box expands to show the
                 configuration fields for the second source.
             o   Complete the options.
             o   Click OK after assigning all values to the secondary source back up server.
             o   When you are done specifying the Access Name, click OK. The Access Names dialog box reappears and
                 shows the new Access Name is added to the list.
        5.    Click Close.
        For more information about setting up your secondary server for failover switching, see Using Failover
        Functionality with Access Names on page 104.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 62
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
            WindowViewer is stopped.
        To delete an Access Name
        1. On the Special menu, click Access Names. The Access Names dialog box appears. The current Access Names
           are listed.
        2. To delete an Access Name, select it from the list and click Delete. A message appears requesting
           confirmation that the Access Name should be deleted.
        3. Click Yes.
        4. Click Close or repeat this procedure if you need to delete other defined Access Names.
        3. Do the following:
             o   Select On or Off as the initial value associated with the tag.
                 The InTouch HMI assigns this value to the tag when the application starts, but does not write this initial
                 value to the I/O device.
             o   Select Direct or Reverse as the input conversion applied to the value received from a remote I/O tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 63
                                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                                          Chapter 5 – Data Access with I/O
        4. Enter messages in the On Msg and Off Msg boxes that appear when the tag transitions in and out of an
           alarm state.
              These messages are available for use in any animation link or script, regardless of whether the tag has
              alarms configured or not.
              o      If you define a discrete alarm that is active when the tag value is equal to 1 (On, True), the message
                     entered in the On Msg box appears in the Value and Limit columns of your ActiveX alarm displays.
                     When the tag’s alarm state returns to normal, the message entered in the Off Msg box appears in the
                     Value column and the On message remains in the Limit column.
              o      If you define a discrete alarm that is active when the tag value is equal to 0 (Off, False), the message
                     entered in the Off Msg box appears in the Value and Limit columns of your ActiveX alarm displays.
                     When the tag’s alarm state returns to normal, the message entered in the On Msg box appears in the
                     Value column and the Off message remains in the Limit column.
        5. Save your changes to the tag.
                                                       Min Raw
                                     Low
                                    Value
        I/O integer and real tags include attributes that set minimum and maximum limits for raw input data sent by the
        PLC. The InTouch HMI clamps I/O values that are below or above the raw value range. Clamping reassigns values
        outside of the range to the minimum or maximum raw values.
        I/O integer and real tags include attributes that scale clamped raw values within a range of engineering units.
        Minimum and maximum engineering unit attributes set the upper and lower boundaries of the scaled values.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                                 Page 64
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 5 – Data Access with I/O
        When you define integer and real I/O tags, you specify the type of conversion to scale raw values when
        calculating engineering units. You can select Linear or Square Root.
        For linear scaling, the result is calculated using linear interpolation between the minimum and maximum end
        points. The algorithm for linear scaling of input is:
        EUValue = (RawValue - MinRaw) * ((MaxEU - MinEU) / (MaxRaw - MinRaw)) + MinEU
        The algorithm for linear scaling of output is:
        RawValue = (EUValue - MinEU) * ((MaxRaw - MinRaw) / (MaxEU - MinEU)) + MinRaw
        For square root scaling, the minimum and maximum raw values are used for interpolation. This is useful for
        scaling inputs from nonlinear devices like pressure transducers. The algorithm for square root scaling of input is:
        EUValue = sqrt(RawValue - MinRaw) * ((MaxEU - MinEU) / sqrt(MaxRaw - MinRaw)) + MinEU
        The algorithm for square root scaling of output is:
        RawValue = square((EUValue - MinEU) * (sqrt(MaxRaw – MinRaw) / (MaxEU -MinEU))) + MinRaw
        To define integer and real I/O tags
        1. Open the Tagname Dictionary and assign a name for a new tag.
        2. Assign I/O integer or I/O real as the type of tag from the Tag Types dialog box. The detail portion of the
           Tagname Dictionary dialog box appears.
        3. Do the following:
             o   In the Initial Value box, type the integer or real number associated with the tag when the application
                 starts.
                 The application does not write this initial value to the external process.
             o   In the Min EU box, type the minimum engineering unit for the tag.
             o   In the Max EU box, type the maximum engineering unit for the tag.
             o   In the Min Raw box, type the minimum value of the low clamp for raw I/O integer or real numbers.
             o   In the Max Raw box, type the maximum value of the high clamp for raw I/O integer or real numbers.
             o   In the Eng Units box, type the label to use for the tag's engineering units.
             o   Select Linear or Square Root as the type of conversion to scale raw values when calculating engineering
                 units.
        4. Save your changes to the tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 65
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 5 – Data Access with I/O
        2. Select I/O Message as the type of tag from the Tag Types dialog box. The detail portion of the Tagname
           Dictionary dialog box appears.
        3. In the Maximum Length box, type the maximum number of characters allowed in the tag's message.
             You can enter messages to a maximum of 131 characters.
        4. In the Initial Value box, type the text string that you want shown when WindowViewer starts the
           application.
        5. Save your changes to the tag.
        2. Click Access Name to define or select the Access Name assigned to the tag. The Access Names dialog box
           appears showing a list of current Access Names recognized by the InTouch HMI. (Galaxy is the default Access
           Name for an ArchestrA connection.)
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 66
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 5 – Data Access with I/O
                 To use the least significant bit of register 1 of an Allen-Bradley PLC as the Item Name, type R1:0 in the
                 Item box.
             o   To use the tag as the item, select Use Tagname as Item Name.
        IOGetNode() Function
        The IOGetNode() function returns the node address defined for a specific Access Name to a tag associated with
        the function in the script.
        Category
        Miscellaneous
        Syntax
        IOGetNode("AccessName");
        Argument
             AccessName
             The existing Access Name to return node information for.
        Remarks
        You can specify the Access Name as a literal string, or as a string value provided by other InTouch tags or
        functions.
        Example
        The following example returns the node information for the ModbusPLC1 Access Name to the NodeName tag.
        NodeName = IOGetNode("ModbusPLC1");
        IOGetApplication() Function
        The IOGetApplication() script function returns the application name defined for a specific Access Name to a tag
        assigned as an argument of the function.
        Category
        Miscellaneous
        Syntax
        IOGetApplication("AccessName");
        Argument
             AccessName
             The existing Access Name in which the application is defined.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 67
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
        Remarks
        You can specify the Access Name as a literal string, or as a string value provided by other InTouch tags or
        functions.
        Example
        The example returns the name of the application specified for the ModbusPLC1 Access Name to the AppName
        tag.
        AppName = IOGetApplication ("ModbusPLC1");
        IOGetTopic() Function
        The IOGetTopic() script function returns the topic name defined for a specific Access Name to a tag associated
        with the function in the script.
        Category
        Miscellaneous
        Syntax
        IOGetTopic("AccessName");
        Argument
             AccessName
             The Access Name whose topic name is returned.
        Remarks
        The Access Name can be specified as a literal string, or it can be a string value provided by other InTouch
        message tags or functions.
        Example
        This example returns topic information for the ModbusPLC1 Access Name to the TopicName tag.
        TopicName = IOGetTopic("ModbusPLC1");
        .Reference Dotfield
        You can implement Dynamic Reference Addressing by assigning a valid reference to the .Reference dotfield of
        an I/O tag. You can use the .Reference dotfield to dynamically change the data source by modifying the
        characteristics of the Access Name assigned to the I/O tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 68
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 5 – Data Access with I/O
        Each I/O type tag has a .ReferenceComplete dotfield. The value of this discrete dotfield indicates if the item
        requested in the .Reference dotfield is reflected in the .Value dotfield.
        The .ReferenceComplete field is set to false (0) when the application starts in WindowViewer. When it is
        confirmed that the .Value dotfield is being updated by the source specified in the .Reference dotfield, the
        .ReferenceComplete value is set to true (1). If the .Reference dotfield is changed, the .ReferenceComplete
        dotfield is automatically set to false (0), and then updated to true (1) when the new value is updated.
        IOSetItem() Function
        You can implement Dynamic Reference Addressing by using the IOSetItem() function within a script. IOSetItem()
        includes arguments to change the values assigned to the .Reference dotfield of an I/O tag during run time.
        Category
        Miscellaneous
        Syntax
        IoSetItem ("Tag", "AccessName", "Item");
        Arguments
             Tag
             Any InTouch I/O tag enclosed in quotation marks.
             AccessName
             The Access Name assigned to the I/O tag.
             Item
             The Item assigned to the I/O tag.
        The Tag, AccessName, and Item arguments can be specified as literal strings or they can be string values
        provided by other InTouch tags or functions.
        Examples
        In the following example, the .Reference dotfield of the PumpInP1 tag is changed to point to the excel Access
        Name and the R1C1 item.
        IOSetItem("PumpInP1", "excel", "R1C1");
        or
        Number = 1;
        TagNameString = "PumpInP" + Text(Number,"#");
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 69
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
        IOSetAccessName() Function
        You can implement Dynamic Reference Addressing by using the IOSetAccessName() function within a script.
        IOSetAccessName() modifies the application or topic name characteristics of an I/O tag’s Access Name during
        run time.
        Note: When the IOSetAccessName() function is processed, there is a time delay while the existing conversation
        is terminated and the new conversation is started. During this period, any attempted POKEs or writes to the new
        topic are lost.
        Category
        Miscellaneous
        Syntax
        IOSetAccessName("AccessName", "NodeName", "AppName", "TopicName");
        Arguments
             AccessName
             The existing Access Name to assign the new AppName and Topic Name values to. Actual string or message
             tag.
             NodeName
             The new Node Name to assign. Actual string or message tag.
             AppName
             The new Application Name to assign. Actual string or message tag.
             TopicName
             The new Topic Name to assign. Actual string or message tag.
        Remarks
        The values assigned to the AccessName, AppName, and TopicName arguments can be specified as literal strings
        or string values provided by other InTouch tags or functions.
        If you configured a secondary source for access name failover using the Add Access Name dialog box, you
        cannot change the secondary source configuration at run time using the IOSetAccessName() function.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 70
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
        Note: When creating Access Names in WindowMaker, if the Access Name is SuiteLink type, the InTouch HMI
        prevents Access Names from accessing the same, node, application, and topic. Do not allow the
        IOSetAccessName() function to redirect Access Names to duplicates during run time. Using the
        IOSetAccessName() function in run time allows SuiteLink type Access Names to be redirected to duplicate
        topics. The redirected Access Name will not work.
        Examples
        The MyAccess1 Access Name can be changed to point to the Excel application and the [Book1]Sheet1 topic,
        without affecting the current NodeName, by using the following script function:
        IOSetAccessName("MyAccess1", "", "EXCEL", "[Book1]Sheet1");
        If an empty string is specified for a Topic, the Access Name’s current Application value is updated and its Topic
        value is retained.
        For example, the following script changes the Application Name for the MyAccess2 Access Name to EXCEL
        without affecting its current Topic value:
        IOSetAccessName("MyAccess2", "", "EXCEL", "");
        If an empty string is specified only for an Application Name, the tag’s current Topic value is updated and its
        Application value is retained. For example, the following script changes the Topic for the MyAccess3 tag to
        [Book2]Sheet1 without affecting its current Application Name value:
        IOSetAccessName("MyAccess3", "", "", "[Book2]Sheet1");
        This example can be used when PLC redundancy is a requirement.
Access_Name:"PumpRPM"
                                                            PumpRPM
                                                              RPM
In this example, you can retrieve the value of the PumpRPM tag from Node 2 in two ways:
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 71
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
            Create an I/O type tag in Node1's Tagname Dictionary that uses Node2 as the node name in the Access
             Name associated with the I/O tag.
            Use a direct remote reference to the PumpRPM tag. For example, PLC1:"PumpRPM".
             In a window or QuickScript, you can reference a remote tag by appending the Access Name as the prefix to
             the remote tag name in the form:
             access_name:"tag_name"
        When importing a window or QuickScript, you can convert the placeholder tags to remote tag references. For
        example, you can convert the placeholder tags to point to the application from which you imported the window.
        The tags do not need to be defined in your local Tagname Dictionary.
        You can use several methods to convert local tags to remote tag references:
            Append the remote tag reference
            Convert the placeholder tags associated with an imported window
            Launch the Tag Browser and open the tag source's Tagname Dictionary to select the remote tag reference.
        To manually convert tags to remote tag references
        1. Open an application window in WindowMaker.
        2. Select the object associated with the local tag that you want to change to a remote tag reference.
        3. On the Special menu, click Substitute Tags. The Substitute Tagnames dialog box appears with a list of tags
           associated with the object.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 72
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 5 – Data Access with I/O
        2. On the Special menu, click Substitute Tags. The Substitute Tagnames dialog box appears.
        3. Click Convert. The Convert dialog box appears.
        4. Click Remote. The Access Names dialog box appears. All Access Names defined in your local InTouch
           application are shown.
        7. Click OK.
        To select a remote tag reference in the Tag Browser
        1. Select the objects associated with the local tag that you want to convert to a remote tag reference.
        2. On the Special menu, click Substitute Tags. The Substitute Tagnames dialog box appears showing the
           selected tags.
        3. Delete the tag name in the New Name box that you want to replace with a remote tag reference.
        4. Double-click the New Name box. The Select Tag dialog box appears with a list of tags associated with the
           application.
        5. Select a remote tag using the Tree view.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 73
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
a. Click the Tree icon to show a hierarchical list of all local and remote Access Names in the left pane.
             b. Select a remote Access Name folder to show its assigned tags in the right pane.
             c. Select a remote tag that you want to use as a remote reference.
             d. Click OK. The Substitute Tagnames dialog box appears with the selected remote tag name in the New
                Name box.
        6. Click OK to close the dialog box and associate the remote tag with the selected objects.
        7. Repeat these steps for each tag that you want to associate with a remote reference.
TempTag
        In this example, the InTouch application running on Node1 can retrieve the value of TempTag on Node2 by two
        methods:
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 74
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                         Chapter 5 – Data Access with I/O
            Create an I/O type tag in Node1's Tagname Dictionary that uses Node2 as the Node Name in the Access
             Name associated with the I/O tag.
            Use a remote reference directly to TempTag. For example, Node2:"TempTag".
        When you want to directly reference a remote tag in any other application, only AccessName:item is required.
        You do not have to define the remote tag in your local Tagname Dictionary. Remote references can also access
        data from any I/O data source such as a DAServer or Microsoft Excel.
        You can also make a remote reference to SuperTags. The valid syntax for a remote tag reference to a SuperTag
        is:
        Access_name:Parent_Instance\ChildMember\SubMember.
        For more information about remote references to SuperTags, see Referencing SuperTag Members on page 126.
        When importing a window or QuickScript, you can convert the placeholder tags to remote tag references. You
        do not have to define tags in your local Tagname Dictionary. The remote references are accessible from any
        application on the network.
                               Server Node
                                               Provides:
                                                  Alarming
                                                  Historical Logging
                                                  Tag Database
PLC
        IOSetRemoteReferences() Function
        You can use the IOSetRemoteReferences() script function to redirect ArchestrA object references or remote
        references to tags while an InTouch application is running. IOSetRemoteReferences() finds all remote references
        that match specified strings and changes those references according to specified argument values. You can
        create a script that triggers the function to redirect references based on conditions being met or by a user
        action.
        Category
        Misc
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 75
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
        Syntax
        IOSetRemoteReferences(BaseAccess, NewAccess, MatchString, SubstituteString, Mode)
        Arguments
             BaseAccess
             This string argument specifies the original configured Access Name to match in the references.
             NewAccess
             The new Access Name. The new Access Name is applied to all references in which the original Access Name
             matches the string provided with BaseAccess and for which the original Item Name matches the MatchString
             value if one is specified.
             MatchString
             The string to match in the original configured Item Name in the references. If the MatchString value is an
             empty string, it is regarded as a match for any Item Name.
             SubstituteString
             The string to substitute for the original Item Name. The string replaces the MatchString value to create the
             new active Item Name for the references. If SubstituteString is an empty string, no substitution is made.
             Mode
             Determines the method used to compare the original configured Item Name to the MatchString value.
             Matching is always from the beginning of the Item Name. A Mode value of 0 specifies the match must be for
             the entire Item Name or up to a period (.) within the name. A Mode value of 1 specifies that a partial match
             is allowed, even if the next character is not a period.
        Remarks
        IOSetRemoteReferences() does not check the validity of the new tag or Access Name before changing the object
        references.
            IOSetRemoteReferences() only changes remote references. The function redirects those references in which
             the original, configured Access Name matches the specified value of the BaseAccess argument, and the
             original Item Name matches the MatchString value.
            A single call to IOSetRemoteReferences() affects all remote references in active windows that are in
             memory in which the original, configured name strings match the values assigned to the BaseAccess and
             MatchString arguments.
            If you do not assign a value to the BaseAccess argument, IOSetRemoteReferences() does not redirect any
             remote references.
            If the MatchString argument is empty, IOSetRemoteReferences() redirects all remote references in which
             the original Access Name matches the value assigned to the BaseAccess argument.
            When the Mode argument is set to 0, replacement in the Item Name is only done for full object names (or
             tags), or full property names (or dotfields). The value of the MatchString argument must match the entire
             original Item Name or up to a character followed by a period.
            When the Mode argument is set to 1, partial replacement of the item string is allowed when the item string
             starts with the match item string. That is, MatchString must match some portion of the original item string,
             but that sub-portion must start at the beginning of the item string. The last character in the matching string
             does not need to be followed by a period.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 76
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
            The original, configured names for a remote reference remain unchanged. Subsequent calls to
             IOSetRemoteReferences() do not need to recognize the current active name. Calls to
             IOSetRemoteReferences() can be made in any order.
            If you want two or more windows to refer to one remote reference, that remote reference acts like an I/O
             tag. When you redirect it, all windows see the same thing. Do not use a single name to refer to two separate
             targets at the same time.
        Note: Changing many references simultaneously, for example in a Window OnShow script, can take some time
        before all references are resolved.
        Examples
        The following example redirects all remote references to the pump001 item name of the Galaxy Access Name if
        the original item name exactly matches pumpX.
        IOSetRemoteReferences("Galaxy","","pumpX", "pump001",0);
        The following example matches changes the Galaxy Access Name to TagServer1 if the item name exactly
        matches pumpX. Also, the item name is changed to p2.
        IOSetRemoteReferences("Galaxy","TagServer1", "pumpX","p2",0);
        The following example changes the TagServer1 Access Name to TagServer2 when the item name is pumpX. Also,
        the item name is changed to backpump3.
        IOSetRemoteReferences("TagServer1","TagServer2", "pumpX","backpump3",0)
        The following example changes the Tank item name of the TagServer1 Access Name to Plant.
        IOSetRemoteReferences("TagServer1","","Tank", "Plant",1)
        The following example does not redirect any remote references because no value is assigned to the BaseAccess
        argument.
        IOSetRemoteReferences("","Galaxy","pumpX", "pump001",0);
        Restoring References
        If the NewAccess argument is empty without an assigned value, IOSetRemoteReferences() restores the active
        Access Name to the original base Access Name.
        If the MatchString argument is empty without an assigned value, IOSetRemoteReferences() restores the active
        Item Name to the original Item Name.
        Note: Even if SubstituteString is not empty, if MatchString is empty, the Item Name is restored to the original
        Item name. Inserting text at the beginning of the name is not allowed. For example, running the script
        IOSetRemoteReferences("Access1", "", "","Valve",0); does not append the string Valve at the beginning or end
        of the all original Item Names.
        If SubstituteString is empty without an assigned value, IOSetRemoteReferences() restores the active Item Name
        to the original Item Name. Using a non-empty MatchString with an empty SubstituteString enables you to select
        a subset of remote references on the indicated original base access and restore them to their original Item
        names.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 77
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
        Typically, the InTouch HMI works with Application Server to provide the visual interface for the application that
        operators interact with to manage a plant process.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 78
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
To return from the Galaxy Browser dialog box to the regular InTouch Select Tag dialog box, click Back.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 79
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
            Automation object array elements can be displayed or retrieved in the InTouch HMI by using
             "TagName.AttributeName[index]" as a reference. Use an index of -1 to show or retrieve all array element
             values.
            You can select a property of an object attribute with the Tag Browser. By default, the Value property is
             selected when the attribute is selected.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 80
                                                                                       AVEVA™ InTouch HMI Data Management Guide
                                                                                                   Chapter 5 – Data Access with I/O
        For .#VString, if the status is good but the quality is bad, this item returns the quality description string, available
        from Message Exchange, instead of the value.
        The value is returned as a string only when quality and status for UserGetAttribute are both good or when the
        quality is good and the status is uncertain. This may require coercion if the data type returned by Message
        Exchange is not a string. When quality or status is uncertain, the value shows a "?" as a suffix. For example,
        "3.27?" or "True?".
        Attribute
        Property Data Type                 InTouch Data Type Notes
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 81
                                                                                       AVEVA™ InTouch HMI Data Management Guide
                                                                                                   Chapter 5 – Data Access with I/O
        Attribute
        Property Data Type                 InTouch Data Type Notes
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 82
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                                                 Chapter 5 – Data Access with I/O
        Attribute
        Property Data Type                 InTouch Data Type Notes
        Array of Strings                   Message - MBCS           Put each element of the array into a
                                           (Read-only)              comma-separated string such as:
                                                                    "String1,String2,String3"
                                                                    up to the maximum limit of an InTouch
                                                                    string value. If this is truncated, the
                                                                    associated quality sent to the InTouch
                                                                    HMI is uncertain. You cannot write to an
                                                                    entire array of strings, but you can write
                                                                    to individual elements of an array.
        All arrays                         Integer, Real,           Only supports a subscription to a single
                                           Message, or              element of an array. In this case, the
                                           Discrete                 conversions described above are
                                                                    applicable. Otherwise, the return is an
                                                                    empty string with Bad quality.
        MxInternationalizedText            Message                  This is accessed as a string type at run
                                                                    time.
        .#EnumOrdinal          Integer             Contains the currently read ordinal value for attributes
                               (read/write)        of the Qualified Enum type. This is a way to return an
                                                   integer for enumerations rather than returning a string.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                        Page 83
                                                                                    AVEVA™ InTouch HMI Data Management Guide
                                                                                                Chapter 5 – Data Access with I/O
        Attribute
        Extension              Data Type           Purpose
        .#WriteSts             String              Contains the last write status of the item to which this
                               (Read-Only)         string is concatenated, for example
                                                   Pump1.Cmd.#WriteSts. This is provided by Message
                                                   Exchange as a string. If the string is blank, the last write
                                                   to the item is successful. Otherwise, #WriteSts can be
                                                   one of the following values:
                                                   "?Config"- configuration error
                                                   "?Comms" - communication error
                                                   "?Oper" - operational error
                                                   "?Pending" - pending
                                                   "?Warning" - warning
                                                   "?Security" - security error
                                                   "?Software" - software error
                                                   "?Other" - other error
                                                   Note: If the associated item (for example, TIC101.PV) is
                                                   not subscribed to, the returned string is blank.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                       Page 84
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
        3. In the Value Display area, click Analog. A dialog box appears to insert an expression.
        4. Delete any expression located within the Expression box.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 85
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                         Chapter 5 – Data Access with I/O
5. Double-click in the Expression box. The Select Tag dialog box appears.
6. Click the button to the right of the Tag Source box. The Define Tag Sources dialog box appears.
        8. Enter values for the boxes of the Define Tag Source dialog box. Do the following:
             a. In the Tag Source Name box, type the name of your remote Galaxy tag source.
             b. In the Access Name box, select Galaxy from the list.
             c. In the Tag Source Type box, select Galaxy from the list.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 86
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
             d. In the Location area, type the Galaxy Repository Node name and select the Galaxy from the list.
             e. Click OK. The Define Tag Sources dialog box shows the remote tag source you defined in its list.
        9. Click Close to close the Define Tag Sources dialog box. The Select Tag dialog box shows the new tag source
           from the list of the Tag Source box.
        10. Select the new tag source you created from the Tag Source box. The Galaxy Browser dialog box opens with
            a list of tags in the left pane.
        11. Select a tag from the left pane of the Galaxy Browser dialog box. The right pane of the Galaxy Browser
            dialog box refreshes with the attributes of the selected tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 87
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
        12. Click the attribute you want to use and click OK. The Output -> Analog Expression dialog box appears with
            an expression in the Expression box.
        .TimeDate Dotfield
        The .TimeDate dotfield shows the whole number of days that have passed between January 1, 1970 and the last
        update of a tag value from an I/O Server.
        Category
        Tag
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 88
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
        Usage
        Tag_name.TimeDate
        Parameter
              Tag_name
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
        See Also
        .TimeDateString, .TimeDay, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMsec, .TimeMonth, .TimeSecond,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeDateString Dotfield
        The .TimeDateString dotfield shows the date and time when a tag value is updated from an I/O Server.
        Category
        Tag
        Usage
        Tag.TimeDateString
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Message (read-only).
        See Also
        .TimeDate, .TimeDay, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMsec, .TimeMonth, .TimeSecond,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeDateTime Dotfield
        The .TimeDateTime dotfield shows the fractional number of days that have passed between January 1, 1970 and
        the last update of a tag value from an I/O Server.
        Category
        Tag
        Usage
        Tag.TimeDateTime
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 89
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
        Data Type
        Real (read-only).
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeHour, .TimeMinute, .TimeMsec, .TimeMonth, .TimeSecond,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeDay Dotfield
        The .TimeDay dotfield shows the number of days within the month that have passed since the last update of a
        tag value from an I/O Server.
        Category
        Tag
        Usage
        Tag.TimeDay
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
        Valid Values
        Values can range from 1-31.
        See Also
        .TimeDate, .TimeDateString, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMsec, .TimeMonth, .TimeSecond,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeHour Dotfield
        The .TimeHour dotfield shows the number of hours within a day that have passed since the last update of a tag
        value from an I/O Server.
        Category
        Tag
        Usage
        Tag.TimeHour
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 90
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
        Valid Values
        Values can range from 0-23.
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeDateTime, .TimeMinute, .TimeMsec, .TimeMonth, .TimeSecond,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeMinute Dotfield
        The .TimeMinute dotfield shows the minute portion of the time when the tag value was last updated from an
        I/O Server.
        Category
        Tag
        Usage
        Tag.TimeMinute
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
        Valid Values
        Values can range from 0-59.
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeDateTime, .TimeHour, .TimeMsec, .TimeMonth, .TimeSecond,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeMonth Dotfield
        The .TimeMonth dotfield shows the month number (1-12) of the date when a tag value is updated from an I/O
        Server.
        Category
        Tag
        Usage
        Tag.TimeMonth
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 91
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
        Valid Values
        Values can range from 1-12.
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMsec, .TimeSecond,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeMsec Dotfield
        The .TimeMsec dotfield shows the millisecond portion of the time when the tag value was last updated from an
        I/O Server.
        Category
        Tag
        Usage
        Tag.TimeMsec
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
        Valid Values
        Values can range from 0 - 999.
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMonth, .TimeSecond,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeSecond Dotfield
        The .TimeSecond dotfield shows the second portion of the time when the tag value was last updated from an
        I/O Server.
        Category
        Tag
        Usage
        Tag.TimeSecond
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 92
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
        Valid Values
        Values can range from 0 - 59.
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMsec, .TimeMonth,
        .TimeTime, .TimeTimeString, .TimeYear
        .TimeTime Dotfield
        The .TimeTime dotfield shows the timestamp when a tag value is updated from an I/O Server expressed as the
        number of milliseconds that have elapsed since midnight.
        Category
        Tag
        Usage
        Tag.TimeTime
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
        Valid Values
        Values can range from 0 - 86399999.
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMsec, .TimeMonth,
        .TimeSecond, .TimeTimeString, .TimeYear
        .TimeTimeString Dotfield
        The .TimeTimeString dotfield shows the time when a tag value is updated from an I/O Server.
        Category
        Tag
        Usage
        Tag.TimeTimeString
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Message (read-only).
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 93
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 5 – Data Access with I/O
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMsec, .TimeMonth,
        .TimeSecond, .TimeTime, .TimeYear
        .TimeYear Dotfield
        The .TimeYear dotfield shows the four-digit year when a tag value is updated from an I/O Server.
        Category
        Tag
        Usage
        Tag.TimeYear
        Parameter
              Tag
              Any discrete, integer, real, message, indirect analog, indirect discrete, or indirect message tag.
        Data Type
        Integer (read-only).
        Valid Values
        Any year expressed as a four-digit number.
        See Also
        .TimeDate, .TimeDateString, .TimeDay, .TimeDateTime, .TimeHour, .TimeMinute, .TimeMsec, .TimeMonth,
        .TimeSecond, .TimeTime, .TimeTimeString.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 94
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 5 – Data Access with I/O
        .Quality Dotfield
        The .Quality dotfield shows a numerical assessment of the quality of data provided by an I/O Server.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 95
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                               Chapter 5 – Data Access with I/O
        Category
        Tag
        Usage
        Tag.Quality
        Parameter
              Tag
              Any discrete, integer, real, indirect analog, or message tag type.
        Data Type
        Integer (read-only).
        Valid Values
        Values can range from 0-255.
        See Also
        .QualityLimit, .QualityStatus, .QualitySubstatus
        Example
        IF I0Tag.Quality <> 192 THEN
           LogMessage("This data is not Good, assuming high-byte of 2-byte quality is zero");
           LogMessage("Better to check .QualityStatus to avoid this assumption");
        ENDIF;
        .QualityLimit Dotfield
        The .QualityLimit dotfield shows the quality limit of a data value provided by a connected I/O Server.
        Category
        Tag
        Usage
        Tag.QualityLimit
        Parameter
              Tag
              Any discrete, integer, real, indirect analog, or message tag type.
        Data Type
        Integer (read-only).
        Valid Values
        0 = Not Limited
        1 = Low Limited
        2 = High Limited
        3 = Constant
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 96
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                               Chapter 5 – Data Access with I/O
        See Also
        .Quality
        .QualityLimitString Dotfield
        The .QualityLimitString dotfield shows the quality limit string of a data value provided by a connected I/O
        Server.
        Category
        Tag
        Usage
        Tag.QualityLimitString
        Parameter
              Tag
              Any discrete, integer, real, indirect analog, or message tag type.
        Data Type
        Message (read-only).
        See Also
        .Quality, .QualityLimit
        .QualityStatus Dotfield
        The .QualityStatus dotfield shows an integer quality status of a data value provided by an I/O Server.
        Category
        Tag
        Usage
        Tag.QualityStatus
        Parameter
              Tag
              Any discrete, integer, real, indirect analog, or message tag type.
        Data Type
        Integer (read-only).
        Valid Values (SSSS)
        0 = Bad
        1 = Uncertain
        3 = Good
        Example
        IF I0Tag.QualityStatus <> 3 THEN
           LogMessage("This data is not Good!");
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 97
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                               Chapter 5 – Data Access with I/O
ENDIF;
        See Also
        .Quality, .QualitySubStatus
        .QualityStatusString Dotfield
        The .QualityStatusString dotfield shows the quality status string of a data value provided by an I/O Server.
        Category
        Tag
        Usage
        Tag.QualityStatusString
        Parameter
              Tag
              Any discrete, integer, real, indirect analog, or message tag type.
        Data Type
        Message (read-only).
        See Also
        .QualityStatus, .QualitySubStatus, .Quality
        .QualitySubstatus Dotfield
        The .QualitySubstatus dotfield shows the quality sub-status of a data value provided by an I/O Server.
        Category
        Tag
        Usage
        Tag.QualitySubstatus
        Parameter
              Tag
              Any discrete, integer, real, indirect analog, or message tag type.
        Data Type
        Integer (read-only).
        Valid Values (SSSS) and (QQ)
        Substatus (SSSS) for BAD quality (QQ=0).
              0 = Non-specific
              1 = Configuration error
              2 = Not connected
              3 = Device failure
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 98
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                               Chapter 5 – Data Access with I/O
              4 = Sensor failure
              5 = Last known value
              6 = Communication failure
              7 =Out of service
        Substatus (SSSS) for UNCERTAIN quality (QQ=1).
              0 = Non-specific
              1 = Last usable value
              4 = Sensor not accurate
              5 = Engineering Units exceeded
              6 = Sub-Normal
        Substatus (SSSS) for GOOD quality (QQ=3).
              0 = Non-specific
              6 = Local override
        See Also
        .QualityStatus, .QualitySubStatus, .Quality
        .QualitySubstatusString Dotfield
        The .QualitySubstatusString dotfield shows the quality sub-status string of a data value provided by an I/O
        Server.
        Category
        Tag
        Usage
        Tag.QualitySubstatusString
        Parameter
              Tag
              Any discrete, integer, real, indirect analog, or message tag type.
        Data Type
        Message (read-only).
        See Also
        .QualityStatus, .QualitySubstatus, .Quality
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 99
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 5 – Data Access with I/O
        You can also specify that I/O connections should be reinitialized based on their default values. If you select this
        option, the default settings are used and the current settings are ignored when Access Names are reinitialized.
        To reinitialize I/O conversations by Access Name, you must have an InTouch application with Access Names
        already defined.
        2. Click one or more Access Names to reinitialize, then click Reinitialize. The selected Access Names are
           reinitialized.
        To reinitialize Access Names using default settings
        1. Open an application within WindowMaker.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 100
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                         Chapter 5 – Data Access with I/O
        2. On the Special menu, click Configure, then click WindowViewer. The WindowViewer Properties dialog box
           appears with a list of options.
        3. On the General tab, select the Reinitialize Default check box in the I/O area.
        4. Click OK.
        5. Open the application in WindowViewer.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                               Page 101
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 5 – Data Access with I/O
6. On the Special menu, click Reinitialize I/O, then click Select. The Reinitialize I/O dialog box appears.
        7. Select one or more Access Names to reinitialize, then click Reinitialize. The current settings are ignored for
           node name, application name, and topic. The Access Names are reinitialized with the original Access Name
           settings.
        IOReinitAccessName() Function
        The IOReinitAccessName() function reinitializes the I/O connection to a specified Access Name.
        Category
        I/O communication
        Syntax
        IOReinitAccessName("AccessName", Default);
        Arguments
             AccessName
             Access Name to be reinitialized.
             Default
             Default = 1. The I/O reinitialization uses the original default Access Name values assigned from
             WindowMaker.
             Default = 0. The I/O reinitialization uses the current node, application, and topic values assigned to the
             Access Name.
        Remarks
        The default settings are determined by the settings in the Access Name configuration panel and also in the
        WindowViewer configuration (Retry Initiates, Start Local Servers, Reinitialize Default).
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 102
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
        Examples
        This example reinitializes the I/O connection to AccessName1 using the default values assigned to the node,
        application, and topic.
        IOReinitAccessName("AccessName1", 1);
        This example reinitializes the I/O connection to AccessName2 using the current values assigned to the node,
        application, and topic.
        IOReinitAccessName("AccessName2", 0);
        IOReinitialize() Function
        The IOReinitialize() function first closes and then restarts all active I/O connections defined for an InTouch
        application.
        Category
        Miscellaneous
        Syntax
        IOReinitialize();
        Arguments
        None.
        Remarks
        The IOReinitialize() function performs the same operation as the Reinitialize I/O command on the
        WindowViewer Special menu.
        If WindowViewer is running as a service, the IOReinitialize() function and Reinitialize ALL command on the
        WindowViewer Special menu do not reinitialize all Access Names. If you select the Access Names listed in the
        Reinitialize I/O dialog box and click Reintialize, the selected Access Names are reinitialized.
        For more information about navigating to the Reinitialize I/O dialog box, see Reinitializing I/O Connections with
        Commands on page 100.
        Example
        This example closes any active I/O connections and restarts all I/O connections defined for the InTouch
        application.
        IOReinitialize();
        IOStartUninitConversations() Function
        When WindowViewer begins running an InTouch application, it automatically processes an initiate request to
        start all I/O conversations. If an I/O Server program does not respond to WindowViewer's initiate request, you
        can use the IOStartUninitConversations() script function to force WindowViewer to attempt to start the I/O
        conversation again.
        Category
        Miscellaneous
        Syntax
        IOStartUninitConversations();
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 103
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
        Arguments
        None.
        Remarks
        The IOStartUninitConversations() function performs the same operation as the Start Uninitiated Conversations
        command on the WindowViewer Special menu.
        Example
        This example forces WindowViewer to submit another initiate request to start all I/O connections defined for
        the InTouch application.
        IOStartUninitConversations();
    Configuring Failover
        You can specify that your InTouch application switches to a failover secondary I/O Server when it can no longer
        communicate with the primary I/O Server.
        When you set the failover, you specify the failover deadband. The failover deadband is the delay in seconds
        before switching from the primary Access Name to the secondary Access Name. The InTouch HMI triggers the
        failover when the expression or an I/O communication failure is true for the length of the deadband period.
        When the failover deadband is set to 0 or blank, the failover is triggered as soon as an I/O communication failure
        is detected.
        To configure failover for an Access Name
        1. If needed, stop WindowViewer.
        2. On the Special menu, click Access Names. The Access Names dialog box appears with a list of all defined
           Access Names.
        3. Select the Access Name from the list to add a failover server.
        4. Click Modify. The Modify Access Names dialog box appears.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 104
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
5. Click Enable Secondary Source. The Modify Access Name dialog box expands.
        6.    Do the following:
             o   In the Node Name box, type the node name of the secondary I/O Server.
             o   In the Application Name box, type the program name of the secondary I/O Server program from which
                 data will be acquired.
             o   In the Topic Name box, type the topic name you want to access from the secondary I/O source.
             o   In the Which protocol to use area, select either DDE or SuiteLink as the secondary I/O Server
                 communication protocol.
             o   In the When to advise server area, select Advise all items or Advise only active items for the secondary
                 I/O source.
        7. Click Failover. The Failover Configuration dialog box appears.
        8. Enter an optional failover expression or double-click in the Failover expression box to select a tag. For more
           information about failover expressions, see Forcing Failover to a Backup Access Name on page 106.
        9. In the Failover Deadband box, type the length of the failover deadband in seconds.
        10. Select Switch back to primary when Failover conditions clear if you want to enable switching from the
            secondary Access Name back to the primary Access Name after the failover condition clears.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 105
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
             The default is to not switch back to the primary Access Name. If you select Switch back to primary when
             failover conditions clear, then the Fail-back Deadband option becomes selectable from the Failover
             Configuration dialog box.
        11. From Failback Deadband, type the length of the failback deadband in seconds.
             The InTouch HMI triggers a failback to the primary Access Name after the expression and any associated I/O
             communication failure clear for the deadband period. When the expression is left blank or 0, the fail-back
             occurs as soon as the I/O communication failure condition clears.
        12. Click OK to close the Failover Configuration dialog box.
        13. Click OK to close the Modify Access Name dialog box.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 106
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
        Failover Expression
        The Failover Configuration dialog box shows the Failover Expression option to include a tag or expression that
        triggers a failover. The figure below shows the dialog box with the failover memory discrete tag entered as the
        value of Failover Expression.
        Setting the failover expression to true, for example by setting the failover tag to true, switches the Access Name
        from the primary (false) to secondary (true) I/O data sources.
        IOForceFailover() Function
        The IOForceFailover() script function switches between the primary and secondary data sources of the Access
        Name. The active I/O node toggles between the primary and secondary nodes with each invocation of the script
        function.
        Typically, the IOForceFailover() function is part of a script associated with button or another window object.
        Operators select the object from an application window to force a failover. After operators click the object
        again, the IOForceFailover function forces the I/O connection back to the formerly active I/O node.
        Category
        I/O Communication
        Syntax
        IOForceFailover("AccessName");
        Argument
             AccessName
             Access name for which failover has been configured.
        Example
        The Acc1 Access Name has Primary and Secondary data sources and Primary is active. Acc1 fails over to the
        Secondary data source when the script runs.
        IOForceFailOver("Acc1");
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 107
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
        You must edit the Access Name definition to set the Disable Failover option to active. As long as the option is
        active for the Access Name, failover is disabled.
        Arguments
             AccessName
             Access name for which failover has been configured.
             Option
             1 = Disables failover
             0 = Enables failover
        Remarks
        The Access Name can be specified as a literal string or it can be a string value provided by other InTouch tags or
        functions.
        Examples
        In this example, failover is disabled for the ModbusPLC1 Access Name.
        IODisableFailover ("ModbusPLC1",1)
        In this example, failover is enabled for the ModbusPLC1 Access Name.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 108
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
IODisableFailover ("ModbusPLC1",0)
        IOGetAccessNameStatus() Function
        The IOGetAccessNameStatus() script function returns an integer indicating the connection status of the primary,
        secondary, or active I/O source of an Access Name.
        Typically, the IOGetAccessNameStatus() return value is associated with an integer tag. The value of the tag can
        drive a discrete value display animation link that shows the status of the Access Names’s active, primary, and
        secondary I/O sources to an operator.
        Category
        Miscellaneous
        Syntax
        Result=IOGetAccessNameStatus("AccessName", Mode);
        Arguments
             AccessName
             The existing Access Name for which to return the status.
             Mode
             The value assigned to this argument determines what Access Name of the failover pair is queried about its
             current status.
             0 - Status of the active Access Name I/O source
             1 - Status of the Access Name primary I/O source
             2 - Status of the Access Name secondary I/O source
        Results
        Returned
        Value            Description
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 109
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 5 – Data Access with I/O
        Remarks
        The IOGetAccessNameStatus() function is typically used in a script that determines the status of the secondary
        IO Source that is currently inactive. The operator runs the script to verify the status of the secondary connection
        before forcing a fail-over.
        Example
        This example returns the status of the secondary I/O source of the ModbusPLC1 Access Name. The returned
        value is associated with the ANStatus tag.
        ANStatus = IOGetAccessNameStatus ("ModbusPLC1",2)
        IOGetActiveSourceName() Function
        The IOGetActiveSourceName() script function returns whether an access name currently uses its primary or
        secondary data source.
        Typically, the IOGetActiveSourceName() function is included in a script associated with button or another
        window object. Operators then select the object from an application window to request the status of the
        application’s I/O Servers.
        Category
        Miscellaneous
        Syntax
        Result=IOGetActiveSourceName("AccessName");
        Argument
             AccessName
             The existing Access Name for which to return the source name.
        Remarks
        IOGetActiveSourceName() returns a string that indicates whether the primary or secondary nodes of an Access
        Name are being actively polled. Possible return values of the IOGetActiveSourceName() function are:
        Example
        In this example, the ActiveServer message tag is assigned the returned value (Primary, Secondary, or Null) that
        identifies the current active node of the ModbusPLC1 Access Name.
        ActiveServer = IOGetActiveSourceName ("ModbusPLC1");
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 110
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
4. Click Access Name to assign the tag to an Access Name definition that defines IOStatus as its topic name.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 111
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                         Chapter 5 – Data Access with I/O
             Finding the Access Name containing the right topic name in this example is easy because the tag and Topic
             Name are the same.
        6. Click Cancel to close the dialog box and return to the initial Access Name dialog box.
        7. Click Add. The Add Access Name dialog box appears.
        8.    Do the following:
             a. In the Access box, type IOStatus.
             b. In the Application Name box, type View because you are going to monitor the status from
                WindowViewer.
             c. In the Topic Name box, type IOStatus as the InTouch internal topic.
             d. Select Advise only active items.
        9. Click OK to close the dialog box. The initial Access Name dialog box reappears showing your new Access
           Name, IOStatus, in the list:
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                               Page 112
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                         Chapter 5 – Data Access with I/O
        10. Click Close to close the dialog box and associate the new Access Name with your I/O Discrete tag.
             In the Item box, type the Access Name for the actual topic name that you want to monitor.
        11. Because your tag is the same as the Topic Name, you can select Use Tagname as Item Name and
            automatically enter it as the Item.
        Note: When using the built-in topic IOStatus (DDEStatus before InTouch Version 7.0) to monitor an I/O
        conversation, the name you type in the Access Name box is always also used for the Item.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                               Page 113
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 5 – Data Access with I/O
To monitor the status of all communication to the topic PLC1, create the following tag definition:
        In Excel, you can read the status of the PLC communications by entering the following formula in a cell:
        =SIMULATE|PLC1!'STATUS'
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 114
Chapter 6
              Positive
           Displacement
              Pump 1
                                                     QuickScript Operator
                                                                  Action
                                          PumpRPM1
                  PLC 1                                                     Indirect Tag References to either
                                            RPM                                   Pump1 or Pump2 RPM
IndPumpRPM
RPM
             Positive
          Displacement
             Pump 2
        Indirect tags minimize your development time. You create fewer application windows because a single window
        object can represent multiple processes running in the production environment.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 115
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 6 – Defining Indirect Tags
        When you equate an indirect tag to another source tag, the indirect tag behaves as if it is the source tag. If the
        value of the source tag changes, the indirect tag reflects the change. If the indirect tag's value changes, the
        source tag changes accordingly.
        Because the .Name dotfield of an indirect tag is a simple string, you can dynamically assign the indirect tag
        target at run time. For example, if you create a Data Change QuickScript that runs each time the value of the
        Number tag changes, the source tag assigned to the indirect IndPumpRPM tag changes accordingly:
        IndPumpRPM.Name = "PumpRPM" + Text(Number, "#" );
        When this script runs, the value of the analog tag Number is converted to text and appended to the string
        PumpRPM. If Number equals 1, this sets the name of the indirect IndPumpRPM tag to PumpRPM1.
        Indirect analog-type tags are used for both integer and real tags. Indirect tags can be mapped to any other tag as
        long they are the same tag type.
        You can also assign retentive attributes to indirect tags. With retention, the indirect tag retains its most recent
        tag assignment when the application starts again.
        To redirect the faceplate to the appropriate tag, include a statement within a QuickScript.
        Indirect_tag_name.Name = "tag_name";
        In this script example, tag_name is the name of an actual tag defined in the local Tagname Dictionary. When the
        script runs, all dotfield values associated with this local tag become accessible to the application object through
        the indirect tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 116
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 6 – Defining Indirect Tags
        where
            AccessName is any valid InTouch Access Name.
            Item is any valid Item Name that is supported by the I/O Server specified in the Access Name definition.
        When you use remote references, the server returns a value to the client, not a tag structure. The value includes
        a time stamp and a quality stamp. Thus, an indirect tag assigned to a remote reference cannot access any tag
        dotfields other than those related to value, time, and quality. For example, an indirect tag cannot access tag
        attributes through a remote reference to specify alarm limits.
        One possible solution is to create a faceplate with a set of indirect tags. The following figure shows a faceplate to
        modify the alarm limits for a pump.
        In this example, the faceplate uses 10 indirect tags that are associated with an implied .Value dotfield. The alarm
        faceplate is being redirected to the remote reference tag, IndPumpRPM, on a remote InTouch node named
        TagServer1. An InTouch Access Name is configured as follows:
        To redirect the faceplate to the remote reference tag PumpRPM, run the following QuickScript:
        IndPumpRPMName.Name = "TagSource1:PumpRPM.Name";
        IndPumpRPMValue.Name = "TagSource1:PumpRPM";
        IndPumpRPMHiHiLimit.Name = "TagSource1:PumpRPM.HiHiLimit";
        IndPumpRPMHiLimit.Name = "TagSource1:PumpRPM.HiLimit";
        IndPumpRPMLoLimit.Name = "TagSource1:PumpRPM.LoLimit";
        IndPumpRPMLoLoLimit.Name = "TagSource1:PumpRPM.LoLoLimit";
        IndPumpRPMHiHiStatus.Name = "TagSource1:PumpRPM.HiHiStatus";
        IndPumpRPMHiStatus.Name = "TagSource1:PumpRPM.HiStatus";
        IndPumpRPMLoStatus.Name = "TagSource1:PumpRPM.LoStatus";
        IndPumpRPMLoLoStatus.Name = "TagSource1:PumpRPM.LoLoStatus";
        The script must run each time the faceplate is redirected. Another solution is to create an InTouch
        QuickFunction that enables you to write a single script and pass it the name of the remote reference. You can
        reduce the amount of script coding by using multiple faceplates that call the same QuickFunction.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 117
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                        Chapter 6 – Defining Indirect Tags
        For example, using a similar set of script commands, you can define a QuickFunction called
        RedirectAlarmFacePlate:
        You can call the RedirectAlarmFacePlate function to handle the entire redirection. To do this, the function must
        be called by another InTouch QuickScript. For example:
        CALL RedirectAlarmFacePlate ("TagSource1:PumpRPM");
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 118
Chapter 7
        All tags that belong to an instance of a SuperTag behave exactly like normal tags. The member tags can be
        assigned as InTouch discrete, integer, real, and message data types. The tags support trending, alarming, and all
        tag dotfields.
        A SuperTag template can organize its member tags in two nesting levels. A SuperTag template can contain up to
        64 embedded child tags. Each child tag can contain up to 64 sub-member tags. This gives you a total of 4095 tags
        in a SuperTag template.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                            Page 119
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                               Chapter 7 – Defining Reusable Tag Structures
        The following figure shows how tags are organized within a SuperTag template.
                                          SuperTag Template
         Sub-member
                        Tag1_1          Tag1_64       Tag64_1     Tag64_64
            Level
        When one SuperTag template parent is embedded into another SuperTag template, the embedded tag becomes
        a child member.
        After you create a SuperTag parent template, the Tagname Dictionary lists it as a tag type in the Tag Types
        dialog box. The template can be selected immediately as a tag type when you create a new tag. You do not need
        to restart WindowMaker to define tags that use a newly created SuperTag type.
        All SuperTag templates are saved in the supertag.dat file in the C:\Documents and Settings\All Users\Application
        Data\Wonderware\InTouch folder.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 120
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                 Chapter 7 – Defining Reusable Tag Structures
        5. Click OK. The TemplateMaker dialog box appears again with the new template listed in the window. The
           Add Member and Delete buttons are active after a template is added.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 121
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                               Chapter 7 – Defining Reusable Tag Structures
        5. Click OK. The name of the new member tag appears beneath the SuperTag parent template in the
           TemplateMaker dialog box.
        6. The tag name includes the selected tag type assigned to the tag as a colon-delimited prefix.
             Example:
             Discrete:PumpState
        7. Repeat these steps to add all tags to the SuperTag template. The TemplateMaker dialog box lists all tags
           that you added beneath the SuperTag template name.
             After creating a SuperTag template, the Tag Types dialog box shows both the SuperTag template and its
             indirect form as selectable tag types.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 122
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                Chapter 7 – Defining Reusable Tag Structures
        2. Double-click the SuperTag template name or member tag that you want to edit. The Edit Template or Edit
           Member Tag dialog box appears. The dialog box shows either the SuperTag template's or member tag's
           current definition.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 123
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                 Chapter 7 – Defining Reusable Tag Structures
             A SuperTag instance name can be up to 10 characters. An instance name follows the same naming rules as
             regular InTouch tags.
        4. Click Type to show the Tagname Types dialog box.
        5. Select a SuperTag template name from the list.
6. Click OK. The Tagname Dictionary dialog box expands to show additional options.
             The new tag that you entered in the Tagname box becomes the parent for all member tags that belong to
             the selected SuperTag template.
        7. Set the properties of the tag. Do the following:
             a. In the Member List box, select a tag from the SuperTag template list.
             b. From Data Access, select Memory or I/O to show the respective Memory or I/O details dialog box.
             c. Enter the details as you do for a standard InTouch tag.
             d. Select the remaining member tags from the list and configure them.
        8. Click Close after you specify all details for the member tags that belong to the SuperTag instance.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 124
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                 Chapter 7 – Defining Reusable Tag Structures
        6. Click Yes. The Enter Name dialog box appears and you are prompted for the name of the new SuperTag.
        7. Enter a name up to 10 characters using standard tag naming conventions.
        8. Click OK. The new SuperTag instance appears in the Tagname Dictionary.
        9. If needed, edit the member tags as you do for a normal InTouch tag.
        10. Click Close.
        Note: If you plan to use the ArchestrA Bulk Import Utility to migrate the tags from your InTouch application to
        Application Server, see Importing SuperTags with the Bulk Import Utility on page 127 for more information
        about substituting the standard backslash delimiter.
        To add a tag to a SuperTag instance
        1. Open the Tagname Dictionary.
        2. To add a tag to a SuperTag instance, do the following:
             a. Click New.
             b. In the Tagname box, type the exact name of your SuperTag instance followed by the backslash (\)
                delimiter and the name of the new member tag.
             c. Click Type.
             d. Select the tag type for the new member tag you are adding to the instance.
             e. Click OK. The details dialog box for the member tag's type appears.
             f.   Enter the required details as you do for a normal InTouch tag.
        3. Click Save.
        4. Click Select.
        5. Select the SuperTag instance that you added a member tag.
        6. Click OK.
             In the Member List box, all member tags that belong to the SuperTag template are listed.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 125
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                   Chapter 7 – Defining Reusable Tag Structures
        Note: If the SuperTag instance and member tag you specify in an animation expression or QuickScript are not
        currently defined, you are prompted to define the tag. Click OK. The Tagname Dictionary appears and shows the
        SuperTag instance and member tag that you created.
        The following syntax examples are valid:
        ParentInstance\ChildMember ParentInstance\ChildMember\Submember
        The following syntax examples are not valid:
        ParentInstance\
        ParentInstance\ChildMember\
        If an invalid format is used, an error message box indicates the SuperTag syntax contains an error.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 126
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                               Chapter 7 – Defining Reusable Tag Structures
        Each member in a SuperTag template is accessible in the standard format currently used to access the dotfields
        of standard InTouch tag types. The SuperTag reference syntax is supported throughout InTouch where standard
        tags can be used. For example, a valid SuperTag dotfield reference is:
        TankFarm\Tank1\Pump1RPM.RawValue
        Remote tag references also support SuperTags. For example, a valid SuperTag remote reference is:
        PLC1:"TankFarm\Tank1\Pump1RPM.RawValue"
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 127
Chapter 8
        You should maintain the minimum number of tags required to run your InTouch application. One way to
        minimize your tag count is to delete unused tags. You must update the tag count before deleting unused tags.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 128
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 8 – Reducing Tag Usage
        The InTouch HMI can store historical tag data to remote historical repositories. In this case, you must share the
        InTouch HMI application directory and configure Historian to access the InTouch application. If you use the
        Historian to store InTouch HMI historical data, you must use the Distributed Name Manager from WindowMaker
        to specify a connection to the database.The InTouch HMI can show historical data stored in a Historian database
        in a Trend Wizard. You need to install SQL Server client components and browse the Historian computer to
        access historical tag data.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 129
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 8 – Reducing Tag Usage
The dialog box also includes a total tag count and maximum tag usage based upon the InTouch license.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 130
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 8 – Reducing Tag Usage
For example:
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 131
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 8 – Reducing Tag Usage
        Icons appear in the InTouch Cross Reference Utility report to show status and usage.
        Icon      Description
                  The tag or SuperTag is defined in the application's Tagname Dictionary, but is not assigned
                  to an object.
                  The tag or SuperTag is used in an animation link, InTouch QuickScript or Industrial graphic.
                  Shown for all selected scripts. Double-click on the script name to view the script in read
                  only mode.
                  The tag or SuperTag is used in a Window script.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 132
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 8 – Reducing Tag Usage
Icon Description
                  When cross-referencing by Window, this icon precedes the window name in which the
                  displayed tag or SuperTag is used. Double-click on the icon to view all tags used in the
                  window.
                  Displayed tag or SuperTag is used in a SQL application.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                       Page 133
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 8 – Reducing Tag Usage
        The Cross Reference Utility will also search Industrial graphics for attribute references, which are part of the
        Object Attribute. The exceptions to the tag usage report are:
        1. Object Attribute references:
             o   Object Attribute using relative reference (such as me.I1) will not be supported and will not be displayed
                 in the cross reference utility tag usage report.
             o   Reference using <InTouchViewApp instance name>.<Tagname> syntax will not be considered as InTouch
                 Tag reference. This reference will be considered as Object Attribute.
                 Example: InTouchViewApp1.Tag1
             o   Any reference that is not in "InTouch:<Tag>" syntax will be considered as Object Attribute reference.
        2. Client script references that are used as the script function parameters will not be considered as InTouch tag
           or object attribute reference.
        1. Use the Filter icon ( ) to select from a list of options like Contains, Does not contain, Starts with, Ends
           with, Equals, Not equal to, Is null, Is not null and Custom.
        2. Enter the search term against the selected filter option.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 134
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 8 – Reducing Tag Usage
The grid will display all records that match the filter option and the search term.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 135
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 8 – Reducing Tag Usage
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 136
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 8 – Reducing Tag Usage
        The cross reference tag listing file lists all tags by name, how they are used in the application, and the name of
        the window where they are located. You can open the cross reference tag listing file with Excel or any other
        program that supports .csv files.
        You can also print the contents of the Tagname Dictionary. Printing the contents of the Tagname Dictionary
        shows you database entries used in the application. You can specify the level of detail you want to see.
        You can send this report to the printer or save it to a file.
        To save a cross-reference file
        1. In the InTouch Cross Reference Utility dialog box, click Save As. The Save As dialog box appears.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 137
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 8 – Reducing Tag Usage
        3. Select Database Entries if you want to print tag information from the Tagname Dictionary.
             If you select Database Entries, the following options become active:
             o   Select Details to include the details of the tags in your report.
             o   Select Alarm Information to include the tag alarm information in your report.
             o   Select With Window Cross-Reference to print all Tagname Dictionary entries with window
                 cross-references. If you select this option, specify the level of detail to print.
                 Link Details prints the location and animation link details where the tag is used.
                 Window Names Only prints only the name of the cross-referenced windows.
        4. Click Next. The Select Output Destination dialog box appears.
        5. Select the option to print the contents of the Tagname Dictionary or send the output to a text or .html file.
        6. Click Print.
        You can save your cross reference tag listing to a file and view it with any application that supports the .csv file
        format.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 138
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                               Chapter 8 – Reducing Tag Usage
        The tag count must be updated to remove unused tags from the total before you can delete unused tags. For
        more information about updating tag counts, see Determining Tag Counts on page 129.
        Caution:Tags that are only alarmed have no use count and can be accidentally deleted. To ensure that alarmed
        only tags are included in the use count, you need to use them in a window or QuickScript.
        To delete multiple unused tags
        1. Close WindowViewer if it is running.
        2. Open an InTouch application in WindowMaker.
        3. On the Special menu, click Delete Unused Tags.
             The Delete Unused Tags dialog box appears with a list of unused tags.
             The status bar at the bottom of the dialog box lists the Number of records, Number of Local tags, Number of
             selected tags, Total number of tags and the Tag license count.
        4. Use the filter (      ) option to refine the list of unused tags. Select the filter option and enter a search term.
             The tags matching the criteria are displayed.
        5. Click the column headings to sort the columns.
6. Select the tags you want to delete. To select all tags for the current filter criteria, click Select All.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 139
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 8 – Reducing Tag Usage
             Note: The status bar displays the number of tags that have been selected (for example: No. of records: 1
             of 14). The tag selection is maintained even if the column criteria is changed. The “Selected Tags” value will
             reflect the total number of tags that user has selected, independent of filter criteria. To view the entire list
             of selected tags, clear all the filter criteria.
        7. Click Clear, to clear the tag selection for the current filter.
        8. Click the Include all graphics from Graphic Toolbox checkbox to only see tags that are not used in any
           graphics or windows. These tags are safe to delete as they are not referenced in graphics or windows that
           contains graphics.
             For example: 10 tags are configured in the tag dictionary, 4 are referenced in graphics in the graphic toolbox
             (but not embedded on any windows), 4 tags are referenced on graphics placed on windows. By default, 6
             tags (2 unused tags + 4 tags from the graphics in the graphic toolbox not embedded on any window) will be
             displayed. If the checkbox is selected, then only the 2 unused tags are displayed.
        9. Click Delete, to delete all tag selections independent of the filter criteria.
             A confirmation message appears. The message will specify the number of tags that will be deleted.
        10. Click OK to confirm.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 140
Chapter 9
        When storing data to historical log files, the InTouch HMI creates two log files. One file contains logged data
        stored in a proprietary format. The other file is an index to the data.
        Names are assigned to the two log files with the following format:
        YYMMDD00.LGH and YYMMDD00.IDX
        where:
YY Last two digits of the year the log files are created
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 141
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 9 – Recording Tag Values
        A daily logging cycle begins and ends at midnight. The Historical Logger writes the last entries to the active log
        files at midnight and archives them. Two new files are created for the next day and data is logged to them.
        Log files are saved for a specified number of days. Log files that are older than the retention period are deleted.
        For more information about setting the number of days to retain log files, see Configuring General Logging
        Properties - Historical Log File on page 143.
Note: You can configure logging to LGH files and/or the Historian server.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 142
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 9 – Recording Tag Values
             The Tagname Dictionary dialog box includes other tag attributes closely associated with logging:
             o   Log Deadband sets a engineering units threshold that must be exceeded before a tag’s value is written
                 to the log file. Only new values outside of the deadband are written to the log file. Small value changes
                 within the deadband range are ignored.
             o   The Min EU and Max EU properties scale clamped raw values within a range of engineering units.
                 Minimum and maximum EU properties set the upper and lower boundaries of the scaled values.
                 The Min/Max engineering units determine the range boundary for log values shown in a trend. By
                 default, an InTouch historical trend shows log data from 0-100 percent of the EU range.
        6. Click Save.
        7. Repeat these steps to enable logging for each tag whose data you want to log.
        8. Click Close to close the Tagname Dictionary when you are done.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 143
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 9 – Recording Tag Values
        3. On the Tools view, expand Configure and select Historical Logging. The Historical Logging Properties dialog
           box appears.
             For more information about setting up trend printing, see Printing a Trend at Run Time on page 190.
        4. Select the Enable Historical Logging check box.
        5. In the Keep Log Files for box, type the number of days prior to the current day to retain log files.
             Log files are kept for the current day and the number of days within the specified retention period. Log files
             that are older than the retention period are deleted. Setting the value to 0 retains all log files indefinitely.
             Example:
             Set the retention period to five days and began logging on the first day of the month. On the seventh day of
             the month, the log files are retained from the five previous days and the current day (02-07). The log files
             created on the first day of the month are deleted.
             Consider disk space usage when you set the number of days to save logging data. Historical logging stops if
             your hard disk runs out of free space. You must free disk space to resume logging.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 144
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 9 – Recording Tag Values
             Note: The folder path and the name of the file to store log data can be a maximum of 55 characters.
             Select Store Log Files in Application Directory to save the log files in the same folder as the InTouch
             application creating the logged data.
             Select Store Log Files in specific Directory to specify another folder to store log files. You can specify the
             folder to store log files as:
             o   Windows folder path such as C:\History Log Files
             o   Universal Naming Convention (UNC) path such as \\node\share\directory.
             If you are saving log files to a distributed node, you must specify the directory as a UNC path.
             If configured to write historical data to the master application node's Application Directory, all NAD nodes
             try to write historical data to the master application. To avoid this, configure historical data on each NAD
             node to write to a local directory, not the master application node.
        7. In the Name of Logging Node box, type the node name of the computer running the InTouch application
           creating log data.
        8. Click OK to save your settings.
             The logging configuration changes become effective immediately. Logging begins the next time you run the
             application.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 145
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 9 – Recording Tag Values
        3. On the Tools view, expand Configure and select Historical Logging. The Historical Logging Properties dialog
           box appears.
             For more information about setting up trend printing, see Printing a Trend at Run Time on page 190.
        4. Select the Enable Storage to Historian check box.
        5. In the Historian node name box, type the node name of the computer running the Historian server. You can
           also specify the IP address and if the server is installed on the same machine you can use ‘localhost’. Only
           the following special characters are allowed; full stop (.), underscore (_) and hyphen (-).
        6. In the History store forward directory box, type the path to the local folder location where the files related
           to store forward are stored. The files will allow the historical data to stored temporarily if the connection to
           the Historian server is lost. After the connection is established, the Historian server will sync with the files
           from this store forward directory and preserve all information.
        7. Click Advanced Settings… to specify settings related to the Historian connection.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 146
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 9 – Recording Tag Values
             a. Under the Connection section, you can specify the TCP Port. The TCP port on the Historian Server node
                to which history data will be sent. The TCP port is configured when the Historian Server is installed. The
                default port is 32568.
             b. Under the Bandwidth Optimization section, you can select the Enable compression checkbox. Once
                selected you can specify:
                 –    Throttling network bandwidth: Specifies limit of bandwidth usage, in kbps, for network
                      communication used by HCAL when communicating with the Historian. A value of 0 disables this
                      feature (default). For more information on estimating your bandwidth needs, see the performance
                      and sizing recommendations for the Historian Server in the System Platform Installation Guide. The
                      allowed values are 0 kbps to 65535 kbps.
                 –    Wait to send incomplete packets: Specifies the maximum time, in milliseconds, for keeping a
                      partially-filled Historian Client Access Layer (HCAL) buffer before sending it to the Historian Server. If
                      the buffer is full, then it is sent immediately, regardless of any value configured in this field. If you
                      have fast-changing data, this setting is irrelevant. If you have slow-changing data and limited
                      network bandwidth, you might want to increase this value so that you have less "chatter" on the
                      network. The allowed values are 1000 milliseconds to 30000 milliseconds.
             c. Under the Data Management section, you can specify:
                 –    Pre-processing buffer size: The total size, in MB, of all buffers used by Historian Client Access Layer
                      (HCAL). The default and minimum value is 8. If you have very high data bursts, then you should
                      increase this value. If this is too low, data loss occurs and error messages related to buffer overflows
                      appear in the ArchestrA Logger. Increase this value in increments of 10 MB. The allowed values are 8
                      MB to 65535 MB
                 –    Store forward threshold: The size, in MB, of free space to reserve on the HCAL store-and-forward
                      disk. The space designated will not be used during store-and-forward. This value cannot be a
                      negative number. The allowed values are 0 MB to 65535 MB
                 –    Store forward minimum duration: The minimum duration, in seconds, for HCAL to function in
                      store-and-forward mode. HCAL will function in store-and-forward mode for this length of time even
                      if the condition that caused HCAL to function in store-and-forward mode no longer exists. The
                      allowed values are 30 seconds to 3600 seconds.
                 –    Select the Reconnect as soon as possible and do not mark disconnects checkbox: Specifies how
                      trends appear during communication disconnects between Application Server and Historian. It does
                      not affect how trends of history data appear after communications have been restored. If TRUE, no
                      gap will appear in client-side trends for the disconnect interval. While disconnected, the interval is
                      filled in with the last-received value before the disconnect. If FALSE, a gap will appear in client-side
                      trends for the disconnect interval. NULL values are injected on disconnect to create the gap. In both
                      cases, after reconnect, the interval will be filled in with store-and-forward data.
             d. Click OK.
        8. Select Log Alarms and Events to enable logging alarms and events. Specify the alarm query in the Alarm
           Query text box.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 147
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 9 – Recording Tag Values
             Note: If different InTouch applications store tag data to the same Historian server and use the same tag
             name, the InTouch applications will not detect such a scenario and may cause the Historian data to overlap.
             Use a unique prefix or suffix to differentiate between applications. For more information, see Configuring
             the Affix String on page 148.
        9. Click OK to save your settings.
             The logging configuration changes become effective immediately. Logging begins the next time you run the
             application.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 148
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 9 – Recording Tag Values
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 149
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 9 – Recording Tag Values
            The Stop Historical Logging command stops logging for the duration of the current application session.
             Logging remains stopped for the current session until it is manually started again.
            The Restart Historical Logging command restarts logging after it is manually stopped with the Stop
             Historical Logging option.
        You can also add a button to your application and write a QuickScript that includes the $HistoricalLogging
        system tag to start and stop historical logging. Logging starts when $HistoricalLogging is assigned a value of 1.
        Logging stops when $HistoricalLogging is assigned a value of 0. For more information about the
        $HistoricalLogging system tag, see System Tags on page 32.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 150
Chapter 10
        You can also use a set of trend controls. Using these controls, you can select the data shown in a trend and how
        data appears in the trend.
        You can configure real-time and historical trends. Both trend types include configuration options to set a trend’s
        data collection interval and visual appearance.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 151
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
            The Average/Bar historical trend shows the average value of a data point during the time intervals in bar
             form.
            The Min/Max historical trend shows the changes in the percentage of engineering units scale as a vertical
             line over the time span. The emphasis is on time flow and rate-of-change, rather than amount of change.
            The Average/Scatter historical trend shows the average value of the data points over each trend time
             interval.
        You can create graphical sliders called scooters to access the details of trend data based on the scooter's current
        position within a trend. For example, when the operator positions the scooter over an area on the trend that has
        visible data, the time and values at that location for all database values being trended are shown.
        You can also create buttons or sliders to zoom in and out between the scooters or to data, such as the maximum
        to minimum value. Average and standard deviation can be shown for the complete chart or for the area
        between the scooters.
        Historical trends can also be scrolled by any amount of time. You can create custom scales and link them to the
        .MinEU and .MaxEU dotfields to create a trend that shows the full range of data set by its engineering unit.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 152
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 153
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
4. If needed, adjust the height and width of the trend with its object handles.
        Note: WindowViewer must be closed. Otherwise, the Pen boxes cannot be selected.
        You can select tags from remote history providers, if the providers are configured. For information about setting
        up a remote history provider, see Distributing Applications in the InTouch® HMI Application Management and
        Extension Guide.
        Note: You can also configure a IndustrialSQL Server history provider to visualize historical trend data. For more
        versatility and other charting options, use the ActiveFactory trend tools to create trends with InTouch historical
        data saved to a IndustrialSQL Server database.
        To configure which tags to display from a historical trend
        1. Double-click the trend object in the window. The Historical Trend Configuration dialog box appears.
        2. In the Historical Tag box, type the tag that you want to use for the trend.
             The tag must be defined as a Hist Trend type. You must assign a different Hist Trend tag to each historical
             trend in an InTouch application.
             If the tag you enter is not currently defined in the Tagname Dictionary, a dialog box appears and asks if you
             want to create a tag. If you select OK to define a tag, the Tagname Dictionary dialog box appears.
        3. In the Tagname area, specify the name of an existing local or remote tag in one or more Pen boxes.
        4. To assign an existing local or remote tag directly, click in a Pen box and type the name of the tag.
        5. To browse to the tag to assign:
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 154
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
             b.    Select the tag provider you want to use for the pen.
             c. Click OK to show a dialog box listing the tags for the selected provider.
             d. Double-click on a tag from the list to select it.
        6. Double-click the color box next to each pen assigned a tag to show the color palette. Click the color for the
           pen.
        7. In the Width box, type the line width in pixels for each pen shown in the trend.
        8. Repeat steps 3 to 7 for each tag that you want to assign to a historical trend pen.
        9. If needed, select the Allow runtime changes check box to allow an operator to configure a historical trend
           while the application is running.
             For more information about updating a historical trend during run time, see Changing the Trend
             Configuration at Run Time on page 157.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 155
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                               Chapter 10 – Trending Tag Data
             Average                     Each pixel within a trend time segment shows the average value of
                                         a tag over the period of time within the segment.
        5. Go to Configuring Historical Trend Display Options on page 156 to configure the visual appearance of a
           historical trend.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 156
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
                 The major time divisions appear on the horizontal time axis of the trend. The maximum time between
                 major time divisions is 65536 seconds, or 18 hours, 12 minutes, 16 seconds.
             o   Select the color for the major division lines.
             o   From Minor Div/Major Div, type the number of minor time divisions within each major time division.
                 The number of minor time divisions should be evenly divisible within a major division. For example, if
                 the major division is set to 60 seconds, entering a value of 2 in Minor Div/Major Div sets the minor time
                 division to 30 seconds.
             o   Select the color for the minor division lines.
             o   Select Top Labels or Bottom Labels to specify the placement of time labels on the trend.
             o   If you are using time labels, type the number of major time division lines per time label in the Major
                 Div/Time Label box.
             o   Select the color of the time division labels.
             o   Select the time units shown as the label of the major time division.
        4. In the Value Divisions area, configure the appearance of the vertical axis of the trend.
             Value Divisions options are configured the same way as the Time Divisions options. The vertical axis
             specifies the range of data values that appear in the trend based upon engineering units for all tags.
        5. Click OK to save your configuration changes and close the Historical Trend Configuration dialog box.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 157
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        2. In the Chart Start area, type the starting date and time of the historical trend data collection interval.
        3. In the Display Mode area, select the type of historical trend chart.
             The trend display mode affects performance. The primary factor that determines trend performance is the
             length of the lines shown in a trend. The longer the lines, the longer it takes to generate the trend.
             Line width also affects performance. Wide lines take significantly longer to draw. Min/Max or
             Average/Scatter trends can be created more quickly than an Average/Bar Chart.
        4. In the Chart Length area, type the duration to be displayed on the trend and then select the unit of
           measure.
             For example, if you enter 2 and select Hrs, the trend duration is 2 hours.
        5. In the Chart Range area, type the percentage of engineering unit range shown on the vertical axis of the
           historical trend.
             The scale of the trend is a segment of the trended tag’s engineering unit range defined by a percentage
             range. The values range from 0 to 100. For example, if you want to trend the variance of the selected tags
             from 40 to 60 percent of their engineering unit range, type 40 and 60 in the Min and Max range boxes,
             respectively.
        6. In the Tags area, click a pen number to assign a tag.
             The Select Tags dialog box appears with a list of tags that can be assigned to the historical trend pen.
        7. Use the following statement in a QuickScript or button to allow the operator to update the chart:
             Hist_TrendTag.UpdateTrend = 1;
        8. Use any of the following functions in a QuickScript or on a button:
             HTUpdateToCurrentTime(Hist_Tag);
             HTScrollLeft(Hist_Tag,Percent);
             HTScrollRight(Hist_Tag,Percent);
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 158
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
             HTZoomIn(Hist_Tag,LockString);
             HTZoomOut(Hist_Tag,LockString);
             HTSetPenName(Hist_Tag,PenNum,Tagname);
             For more information about using scripts containing trend functions, see Controlling a Historical Trend
             Wizard Using Scripts on page 174.
        9. Change any of the following trend tag dotfields:
             .ChartStart
             .ChartLength
             .MaxRange
             .MinRange
             .Pen1-.Pen8
             For more information about using dotfields with historical trends, see Controlling a Historical Trend Using
             Dotfields on page 159.
        .DisplayMode Dotfield
        The .DisplayMode dotfield specifies the trend format used to display a tag’s values.
        Category
        Historical
        Usage
        tag_name.DisplayMode
        Parameter
             tag_name
             Any Hist Trend tag.
        Data Type
        Analog (read/write).
        Valid Values
        1 = Shows the min/max value that occurred in each sample period (default).
        2 = Shows the average value of each sample period in a scatter historical trend.
        3 = Shows the average of each sample period in a bar chart historical trend.
        Example
        This statement specifies that the values in the historical trend represented by the "HistTrend_Tag" are
        formatted as a bar chart historical trend.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 159
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
HistTrend_Tag.DisplayMode=3;
        See Also
        .ChartLength, .ChartStart
        .MinRange Dotfield
        The .MinRange dotfield specifies the minimum percentage of the tag's engineering unit range to show for each
        tag in a Historical trend.
        Category
        Historical.
        Usage
        tag_name.MinRange
        Parameter
             tag_name
             Any Hist Trend tag.
        Remarks
        A historical trend can show several types of tags at the same time. Specifying the minimum and maximum
        boundaries of the value range in engineering units is difficult because different types of tags can have different
        engineering ranges. Therefore, the minimum and maximum range values are expressed as a percentage of the
        engineering range of each tag. This way, regardless of the tag's true engineering range, the historical trend
        shows the indicated percentage of that tag's particular engineering range.
        Data Type
        Real (read/write).
        Valid Values
        The limits for the .MaxRange and .MinRange dotfields are from 0 to 100. .MinRange is always less than
        .MaxRange. If you assign a value less than 0 or greater than 100 to either of these dotfields, the value is clamped
        at 0 or 100. If .MinRange is greater than or equal to .MaxRange, the trend does not show any data.
        Example
        This example dotfield statement sets the minimum percentage range of the historical trend to 25 percent of the
        possible engineering unit range of a Hist Trend tag.
        HistTrend.MinRange=25
        See Also
        .ChartStart, .ChartLength, .DisplayMode, .EngUnits, .MinEU, .MaxEU, .MaxRange, .MinRaw, .MaxRaw, .RawValue
        .MaxRange Dotfield
        The .MaxRange dotfield specifies the maximum percentage of the tag's engineering unit range to show for each
        tag in a Historical trend.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 160
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        Category
        Historical.
        Usage
        tag_name.MaxRange
        Parameter
             tag_name
             Any Hist Trend tag.
        Remarks
        A historical trend can show many types of tags simultaneously. Specifying the minimum and maximum
        boundaries of the range in engineering units can be difficult because tags can have different engineering ranges.
        Therefore, the minimum and maximum range values are expressed as a percentage of the engineering range of
        each tag. This way, regardless of the tag's true engineering range, the historical trend shows the indicated
        percentage of that tag's engineering range.
        Data Type
        Real (read/write).
        Valid Values
        The limits for .MaxRange and .MinRange dotfields are from 0 to 100. .MinRange is always less than .MaxRange.
        If you assign a value less than 0 or greater than 100 to either of these dotfields, the value is clamped at 0 or 100.
        If .MinRange is greater than or equal to .MaxRange, the trend does not show any data.
        Example
        This example dotfield statement sets the maximum percentage range of the historical trend to 75 percent of the
        possible engineering unit range of a Hist Trend tag.
        HistTrend.MaxRange=75
        See Also
        .ChartStart, .ChartLength, .DisplayMode, .EngUnits, .MinEU, .MaxEU, .MinRange, .MinRaw, .MaxRaw, .RawValue
        .UpdateCount Dotfield
        The .UpdateCount dotfield increments a count each time a historical trend is updated. The .UpdateCount
        dotfield can be used as a trigger for further functions.
        Category
        Historical.
        Usage
        HistTrendTag.UpdateCount
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 161
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 10 – Trending Tag Data
        Data Type
        Integer (read-only).
        Valid Values
        Any positive integer.
        Example
        This example uses the HTGetValueAtScooter() function to retrieve the value of Pen1 at the right scooter's
        current position. A change to any function argument causes the function to be re-evaluated. When the update
        completes and the value of .UpdateCount is incremented, this statement is re-evaluated.
        MyRealTag=HTGetValueAtScooter( MyHistTrendTag,MyHistTrendTag.UpdateCount, 2,
        MyHistTrendTag.ScooterPosRight, 1, "PenValue");
        See Also
        .UpdateInProgress, .UpdateTrend
        .UpdateInProgress Dotfield
        The .UpdateInProgress dotfield indicates the current status of a historical trend update operation. The value of
        the dotfield is set to 1 if a historical retrieval is in progress; otherwise the dotfield is set to 0.
        Category
        Historical.
        Usage
        HistTrendTag.UpdateInProgress
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
        Remarks
        Whenever new data is requested from the historical trend, this dotfield's value is set to 1. After the process
        completes, .UpdateInProgress is reset to 0. .UpdateInProgress can be used in functions related to historical
        trends.
        If the operator scrolls the trend to a period outside the currently shown period, it can take some time to retrieve
        the historical data. The .UpdateInProgress dotfield provides a way to alert the operator that the requested data
        is being retrieved. Without feedback, the operator may not be aware that the trend is being updated.
        Data Type
        Discrete (read-only).
        Value Values
        0 = No update in progress
        1 = Update in progress
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 162
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        Example
        The .UpdateInProgress dotfield is typically used as the expression in a visibility link on a text object near or on
        the scroll buttons of a Historical Trend. You can use the .UpdateInProgress dotfield to show "Busy" on the
        window when the data is being retrieved with the following message value display animation link:
        DText(HistTrend1.UpdateInProgress,"Busy","Ready")
        See Also
        .UpdateCount, .UpdateTrend
        .UpdateTrend Dotfield
        The .UpdateTrend dotfield triggers an update to a historical trend. Using the .UpdateTrend dotfield in a button
        action script, the operator can manually update the trend during run time.
        Category
        Historical.
        Usage
        HistTrendTag.UpdateTrend
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
        Remarks
        Historical trends do not automatically update. A change must be made to either the .ChartStart or the
        .ChartLength dotfields to update the chart and show the current values for the specified tags. By using this
        dotfield in a button action script, the operator can update the chart during run time. You can also use this
        dotfield in a QuickScript if other dotfields associated with the historical trend are going to be changed.
        You should only set the .UpdateTrend dotfield to a value of 1.
        Data Type
        Discrete (write only).
        Valid Values
        1
        Example
        This example triggers the historical trend associated with the MyHistTrendTag tag to update with the current
        values of all parameters.
        MyHistTrendTag.UpdateTrend=1;
        .ChartLength Dotfield
        The .ChartLength dotfield specifies the length of time shown in a Historical trend.
        Category
        Historical.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 163
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        Usage
        HistTrendTag.ChartLength
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
        Remarks
        The value assigned to .ChartLength specifies the length of the chart in seconds. The length is defined as the
        amount of time currently shown on the Historical Trend Chart. More specifically, the calculation retrieved as the
        Chart Length from a Historical Trend Chart is:
        ChartLength=(Date/Time Stamp on Right-Hand Side of Chart) - (Date/Time Stamp on Left-Hand Side
        of Chart);
        Because Date/Time Stamps are expressed in seconds from midnight on January 1, 1970, the calculation results
        in seconds of time displayed between the left and right sides of the chart.
        Whenever adding or subtracting from .ChartLength, time is expressed in seconds. Therefore, to subtract two
        hours from the current .ChartLength, convert hours to seconds before performing the calculation. For example:
        (2 hours) * (60 minutes/hour) * (60 seconds/minute) = 7200 seconds.
        Data Type
        Integer (read/write).
        Valid Values
        Any positive integer.
        Examples
        This example forces the length of the historical trend to one hour.
        HtTag.ChartLength=3600 {60 minutes * 60 seconds/minute};
        This example scrolls the trend left by 50 percent.
        HtTag.ChartStart=HtTag.ChartStart - HtTag.ChartLength / 2;
        This example scrolls the chart left by 10 percent.
        HtTag.ChartStart=HtTag.ChartStart - (.10 * HtTag.ChartLength);
        See Also
        .ChartStart
        .ChartStart Dotfield
        The .ChartStart dotfield can be used to set or verify the value of the starting (left side) date/time stamp of a
        historical trend.
        Category
        Historical.
        Usage
        HistTrendTag.ChartStart
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 164
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
        Remarks
        This read/write dotfield is used to set or verify the value of the starting date/time stamp of a historical trend.
        The .ChartStart dotfield is expressed as the number of elapsed seconds after midnight January 1, 1970. The
        starting point is defined as the first date/time stamp on a historical trend.
        Data Type
        Integer (read/write).
        Valid Values
        Any positive integer.
        Example
        The following statement scrolls the chart to the right by one minute.
        HtTagname.ChartStart=HtTagname.ChartStart + 60;
        See Also
        .ChartLength
        .Pen1-8 Dotfields
        The .Pen1-8 dotfields assign a logged tag to a historical trend pen.
        Category
        Historical
        Usage
        HistTrendTag{.Pen1 | .Pen2 | .Pen3 | .Pen4 | .Pen5 | .Pen6 | .Pen7 | .Pen8};
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
        Remarks
        You assign tags to trend pens using the .Pen1-8 dotfields with the following format:
        HistTrend.PenX = Tag_Name.TagID
        Where X is an integer 1 to 8.
        It is recommended that you use the HTSetPenName() and HTGetPenName() functions if possible.
        Note: Only local tags can be assigned to a .PenX dotfield. The provider.tag notation cannot be used. The
        provider.tag can be used only with the HTSetPenName() function.
        A good reference to use when learning how these dotfields work is a historical trend wizard placed on the
        screen and broken apart.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 165
                                                                                   AVEVA™ InTouch HMI Data Management Guide
                                                                                                Chapter 10 – Trending Tag Data
        Data Type
        TagID (read/write).
        Valid Values
        This dotfield data type is type TagID. This means only the handle of a tag can be assigned to the .Pen1-8
        dotfields. You cannot directly assign the name of a tag to the .Pen1-8 dotfields. You must associate the
        associated .TagID dotfield of a tag to a .Pen1-8 dotfield using the following syntax:
        HistTrendTag.Pen1=LoggedTag.TagID;
        In general, a TagID type tag can be equated only to another TagID tag. It cannot be used with any other tag type
        unless the .TagID dotfield extension is added to the other tag.
        Although the .Pen1-8 dotfields are considered read/write, their values cannot be directly shown on the screen.
        Examples
        The following example assigns a new tag to the .Pen5 dotfield of the historical trend associated with the Hist
        Trend tag. You must append the .TagID dotfield to the name of the logged tag in order to assign it to .Pen5
        dotfield.
        HistTrendTag.Pen5=PumpPress.TagID;
        Working from the previous example, you can show the name of the tag assigned to HistTrendTag.Pen5. Creating
        a legend that shows the tag assigned to each trend pen is useful information for an operator.
        You cannot show the tag assigned to HistTrendTag.Pen5 in a Message Display link. The actual value of the .Pen5
        dotfield is an integer that represents a memory location within WindowViewer, which is not useful for display
        purposes. You need to create a new TagID type tag called Pen05. Place the following statement underneath the
        statement from the previous example:
        Pen05=HistTrendTag.Pen5;
        In the first example, the PumpPress tag is assigned to pen 5 of HistTrendTag. In this example, Pen05 is assigned
        the value of Pen5 of the HistTrendTag, which is the TagID of the PumpPress tag.
        The .Pen1-8 dotfields are pointers to the tags that are associated with pens selected to appear in a trend. The
        .Pen1-8 dotfields are of a special data type, namely .TagID. After you make the assignment, you can use the
        .Name dotfield of the TagID tag to show the name of the tag.
        .TagID Dotfield
        The .TagID dotfield can be used in conjunction with the .Pen1 - .Pen8 dotfields to assign a tag to a historical
        trend pen.
        Category
        Historical tag.
        Usage
        tag_name.TagID
        Parameter
             tag_name
             Any discrete, integer, real, indirect discrete, or indirect analog tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 166
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        Remarks
        The .TagID dotfield provides the handle of a tag and is used mainly to assign tags to pens in a historical trend.
        Data Type
        TagID (read-only).
        Example
        This example uses the .TagID dotfield to assign the PumpRPM tag to pen 6 of the historical trend.
        HistTrendTag.Pen6=PumpRPM.TagID;
        See Also
        .Pen1-.Pen8
        .ScooterLockLeft Dotfield
        The .ScooterLockLeft dotfield specifies whether an operator can move the right scooter further left than the left
        scooter's current position on the historical trend.
        Category
        Historical.
        Usage
        HistTrendTag.ScooterLockLeft
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
        Remarks
        In general, you should prevent an operator from moving the right scooter further left than the left scooter's
        current position. When the left scooter is locked, it forces the right scooter position to be equal to the left
        scooter position whenever the right scooter overtakes the left scooter.
        Data Type
        Discrete (read/write).
        Valid Values
        0 = False. Right scooter can move further left than the left scooter’s current position on the historical trend
        1 = True. Right scooter cannot move further left than the left scooter’s current position on the historical trend.
        Example
        The following example prevents the right scooter from moving further left than the left scooter's current
        position on the historical trend.
        HistTrendTag.ScooterLockLeft=1;
        See Also
        .ScooterPosRight, .ScooterPosLeft, .ScooterLockRight
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 167
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        .ScooterLockRight Dotfield
        The .ScooterLockRight dotfield specifies whether an operator can move the left scooter further right than the
        right scooter's current position on the historical trend.
        Category
        Historical.
        Usage
        HistTrendTag.ScooterLockRight
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
        Remarks
        In general, you should prevent the operator from moving the left scooter further right than the right scooter's
        current position. When the right scooter is locked, if forces the left scooter position to be equal to the right
        scooter position whenever the left scooter overtakes the right scooter.
        Data Type
        Discrete (read/write).
        Valid Values
        0 = False. Left scooter can move further right than the right scooter’s current position on the historical trend.
        1 = True. Left scooter cannot move further right than the right scooter’s current position on the historical trend.
        Example
        The following example prevents the left scooter from moving further right than the right scooter's current
        position on the historical trend.
        HistTrendTag.ScooterLockRight=1;
        See Also
        .ScooterPosRight, .ScooterPosLeft, .ScooterLockLeft
        .ScooterPosLeft Dotfield
        The .ScooterPosLeft dotfield dynamically controls the position of the left scooter on a historical trend.
        Category
        Historical
        Usage
        HistTrendTag.ScooterPosLeft
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 168
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 10 – Trending Tag Data
        Remarks
        This read/write dotfield dynamically controls the position of the left scooter. You can use this dotfield in a
        QuickScript function to retrieve the current position of the left scooter, or you can assign a value to this dotfield
        to adjust the position of the left scooter to another location on the trend.
        This dotfield is most often used in conjunction with the set of HTGetValue() functions. These functions must
        specify which historical trend is being queried, as well as the current position of the trend's scooters.
        Data Type
        Real (read/write).
        Valid Values
        0.0 to 1.0; where 0.0 is the extreme left of the historical trend chart, and 1.0 is the extreme right of the historical
        trend chart.
        Examples
        The following example repositions the left scooter. The left scooter moves to a location 34 percent of the chart's
        total length from the left side of the historical trend chart currently associated with the MyHistTrendTag tag.
        MyHistTrendTag.ScooterPosLeft=.34;
        In the following statement, the QuickScript HTGetValueAtScooter() function retrieves the value of pen 1 at the
        left scooter's current position. A change to any value within a function's argument list causes the function to be
        re-evaluated. Each time the position of the left scooter changes, this statement is re-evaluated.
        MyRealTag=HTGetValueAtScooter (MyHistTrendTag,MyHistTrendTag.UpdateCount, 1,
        MyHistTrendTag.ScooterPosLeft, 1, "PenValue");
        See Also
        .ScooterPosRight, .ScooterLockLeft, .ScooterLockRight
        .ScooterPosRight Dotfield
        The read/write .ScooterPosRight dotfield dynamically controls the position of the right scooter.
        Category
        Historical.
        Usage
        HistTrendTag.ScooterPosRight
        Parameter
             HistTrendTag
             HistTrend tag assigned the name of the trend.
        Remarks
        This read/write dotfield dynamically controls the position of the right scooter. You can use this dotfield in a
        QuickScript function to retrieve the current position of the right scooter. You can also assign a value to this
        dotfield to move the right scooter to another location on the trend.
        This dotfield is most often used in conjunction with the HTGetValue() functions. These functions must specify
        which historical trend is being queried, as well as the current position of the trend's scooters.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 169
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 10 – Trending Tag Data
        Data Type
        Real (read/write)
        Valid Values
        0.0 to 1.0; where 0.0 is the extreme left of the historical trend chart, and 1.0 is at the extreme right the historical
        trend chart.
        Examples
        The following statement specifies a new location for the right scooter. The right scooter moves to a location 34
        percent of the chart's total length from the left side of the Historical Trend chart associated with the
        MyHistTrendTag tag.
        MyHistTrendTag.ScooterPosRight=.34;
        The following statement uses the HTGetValueAtScooter() QuickScript function to retrieve the value of pen 1 at
        the right scooter's new position. A change to any variable within a function's parameter list causes the function
        to be re-evaluated. Each time the position of the right scooter changes, this statement is re-evaluated.
        MyRealTag=HTGetValueAtScooter(MyHistTrendTag, MyHistTrendTag.UpdateCount, 2,
        MyHistTrendTag.ScooterPosRight, 1, "PenValue");
        See Also
        .ScooterPosLeft,. ScooterLockLeft, .ScooterLockRight
        To add zoom and movement functions or pen controls to a historical trend, use the trend Zoom/Pan Panel and
        Trend Pen Legend wizards.
        You can create and configure a historical trend. You can:
            Create a historical trend with wizards
            Select the tags for a trend
            Configure the historical trend time span
            Controlling a trend with QuickScripts
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 170
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
6. Double-click the trend. The Historical Trend Chart Wizard dialog box appears.
        7. Click Suggest. The Historical Trend Chart Wizard automatically assigns default configuration values to the
           trend.
             The only remaining configuration task is to assign tags to the trend pens.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 171
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
3. Enter the name of an existing local tag in the Pen box. You can enter a maximum of 49 characters.
             Note: WindowViewer must be closed. Otherwise, the Pen boxes cannot be selected.
             If you double-click within the Pen box, the Select Tag dialog box appears with a list of tags assigned the Log
             Data option for the application. You can assign a tag to the pen by selecting it from the Select Tag dialog
             box.
        4. Click the color box next to each pen and select another color if you want to change the default pen color.
           Otherwise, skip this step and accept the default color.
        5. Click OK to close the Trend Pens dialog box.
        6. Click OK to close the Historical Trend Chart Wizard dialog box.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 172
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
             a. In the Major Divisions box, type the number of major time divisions shown on the horizontal time axis
                of the trend.
             b. In the Minor Div/Major box, type the number of minor time divisions within each major division.
             c. In the Initial Time Span box, type the length of the time period shown on the horizontal axis of the
                trend. Trends created with the Historical Trend Wizard can be updated while the application is running
                in WindowViewer. Operators can change the length of the trend time period. But a historical trend
                always starts with the time period set from the Time Format dialog box.
             d. Select the unit of measure for the trend time period in seconds, minutes, hours, and days.
             e. Optionally, include milliseconds in the scooter time display. The following example shows a scooter
                slider with milliseconds appended to the current time.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 173
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 10 – Trending Tag Data
                                                           .
        2. In the Chart Start area, type the starting date and time of the chart.
        3. In the Display Mode area, select the type of historical trend.
        4. In the Chart Length area, type the length of time to show on the trend, and then select the time increment
           for the length.
        5. In the Chart Range area, type the percentage of engineering unit scale shown as the vertical range of the
           trend.
        6. In the Tags area, click each Pen# to assign a tag to the trend pen. The Select Tag dialog box appears and
           shows those tags for which logging is enabled.
        7. Double-click on the name of a tag to assign it to the trend pen.
        8. Click OK to save your run-time changes to the trend.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 174
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
        HTUpdateToCurrentTime() Function
        The HTUpdateToCurrentTime() function retrieves and shows the data with an end time equal to the current
        time. The start time is equal to end time minus the width of the chart.
        Category
        Historical
        Syntax
        HTUpdateToCurrentTime(Hist_Tag);
        Argument
             Hist_Tag
             HistTrend tag assigned the name of the historical trend.
        Example
        The following statement retrieves and shows data for the Trend1 historical tag at the current time:
        HTUpdateToCurrentTime("Trend1");
        If the current time is 3:04 PM and the width of the trend is 60 seconds, the new end time is 3:04 PM. The new
        trend start time is 3:03 PM.
        HTSelectTag() Function
        The HTSelectTag() function opens the Select Tag dialog box for the operator to assign a different tag to a trend
        pen.
        Note: The Select Tag dialog box only lists the tags that are defined for historical logging with the Log Data option
        selected in the Tagname Dictionary.
        Category
        Historical
        Syntax
        HTSelectTag();
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 175
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        Remarks
        The HTSelectTag() function only shows tags in which the Log Data option has been selected from the Tagname
        Dictionary. However, it is possible to use the Tag Browser's filter to display a smaller set of tags. For example all
        tags that begin with "A". The function returns the selected tag and can be used as function parameter to assign a
        tag to a pen.
        Example
        The following QuickScript causes the Select Tag dialog box to appear in WindowViewer. The user can then select
        a tag from the list. This tag is assigned to pen 1 by the Historical Object named HistTrend.
        HTSetPenName("HistTrend",1,HTSelectTag());
        See Also
        HTSetPenName()
        HTSetPenName() Function
        The HTSetPenName() function assigns a different tag to a trend's pen.
        Category
        Historical
        Syntax
        HTSetPenName(Hist_Tag,PenNum,Tagname);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             PenNum
             Integer tag or value representing the pen number (1-8) of the trend.
             Tagname
             Name of the new tag to assign to the pen.
        Remarks
        This QuickScript function is the only method to add tags from a distributed history provider during run time.
        You can enter a maximum of 49 characters for a reference in a pen name.
        You may see the following error message when you attempt to unassign a trend pen:
        VIEW /UpdateData: Invalid DBS.TAGNAME handle – 0
        This error occurs if you're trying to unassign a pen that was previously assigned to a remote tag in the form
        histprovider.tag_name. To resolve this error, create a local tag with the Log Data option selected. Then, use the
        following script to unassign the pen:
        HTSetPenName( "HistTrend", 1, "localtag" );
        {assigns the pen to a locally logged tag---localtag}
        HistTrend.Pen1=None;
        {unassigns the pen}
        Where None is a TagID type tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 176
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
        Examples
        The following statement assigns the OutletPressure tag to pen 3 of Trend1.
        HTSetPenName("Trend1",3,"OutletPressure");
        The following statement assigns the HistPrv1.Tag1 tag to TrendPen4 of Trend1.
        HTSetPenName("Trend1",TrendPen4,"HistPrv1.Tag1");
        See Also
        HTSelectTag()
        HTGetPenName() Function
        The HTGetPenName() function returns the name of the tag currently assigned to the specified pen number of
        the historical trend.
        Category
        Historical
        Syntax
        MessageResult=HTGetPenName(Hist_Tag,UpdateCount, PenNum);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             UpdateCount
             Integer representing the trend's .UpdateCount dotfield. The argument value acts as a data change trigger to
             re-evaluate the function
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 177
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 10 – Trending Tag Data
             PenNum
             Integer tag or value representing the pen number (1-8) of the trend.
        Example
        The following statement retrieves the name of the tag assigned to Pen 2 of the Trend1 trend and places the
        name in the TrendPen message tag:
        TrendPen=HTGetPenName("Trend1", Trend1.UpdateCount,2);
        HTGetTimeAtScooter() Function
        The HTGetTimeAtScooter() returns the time in seconds after 00:00:00 hours GMT, January 1, 1970 for the
        sample at the scooter location specified by the ScootNum and ScootLoc arguments.
        Category
        Historical
        Syntax
        IntegerResult=HTGetTimeAtScooter(Hist_Tag, UpdateCount,ScootNum,ScootLoc);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             UpdateCount
             Integer representing the trend's .UpdateCount dotfield.
             ScootNum
             Integer representing the left or right scooter:
             1=Left Scooter
             2=Right Scooter
             ScootLoc
             Real number representing the value at the .ScooterPosRight or .ScooterPosLeft positions on the trend.
        Remarks
        Any changes to the values assigned to the UpdateCount, ScootNum, and ScootLoc arguments cause the
        expression to be evaluated. This ensures the expression is evaluated after new data retrievals or after a scooter
        is moved.
        Example
        The following statement retrieves the time in seconds for the value at the current left scooter location of the
        Trend1 trend:
        HTGetTimeAtScooter("Trend1",Trend1.UpdateCount,1, Trend1.ScooterPosLeft);
        HTGetTimeStringAtScooter() Function
        The HTGetTimeStringAtScooter() function returns the string containing the time/date for the sample at the
        specified scooter location.
        Category
        Historical
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 178
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 10 – Trending Tag Data
        Syntax
        MessageResult=HTGetTimeStringAtScooter(Hist_Tag, UpdateCount, ScootNum, ScootLoc,
        Format_Text);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             UpdateCount
             Integer representing the trend's .UpdateCount dotfield.
             ScootNum
             Integer representing the left or right scooter:
             1=Left Scooter
             2=Right Scooter
             ScootLoc
             Real number representing the value at the .ScooterPosRight or .ScooterPosLeft positions on the trend.
             Format_Text
             String specifying the time/date format to use. The following Format_Text strings are acceptable:
             "Date", "Time", "DateTime", "DOWShort" (Wed, for example), and "DOWLong" (Wednesday, for example).
        Remarks
        Any changes to the values assigned to the UpdateCount, ScootNum, and ScootLoc arguments cause the
        expression to be evaluated. This ensures the expression is evaluated after new data retrievals or after a scooter
        is moved. The format of the string determines the contents of the return value.
        Example
        The following statement retrieves the date and time for the value at the current scooter location for the right
        scooter of the Trend1 trend. The value is stored in the NewRightTimeString message tag and is in "Time" format:
        NewRightTimeString=HTGetTimeStringAtScooter ("Trend1",Trend1.UpdateCount,2,
        Trend1.ScooterPosRight,"Time");
        HTGetValue() Function
        The HTGetValue() function returns a value of the requested type for the trend's specified pen.
        Category
        Historical
        Syntax
        RealResult=HTGetValue(Hist_Tag,UpdateCount, PenNum,ValType_Text);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             UpdateCount
             Integer representing the trend's .UpdateCount dotfield.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 179
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 10 – Trending Tag Data
             PenNum
             Integer tag or value representing the pen number (1-8) of the trend.
             ValType_Text
             String indicating the type of value to return:
             PenAverageValue = Average for the entire trend.
             PenMaxValue = Maximum pen value for the entire trend.
             PenMinValue = Minimum pen value for the entire trend.
             PenMaxEU = Maximum engineering units value for the entire trend.
             PenMinEU = Minimum engineering units value for the entire trend.
             PenStdDev = Standard deviation for the entire trend.
        Remarks
        The function returns the requested value as a real value.
        Example
        The following statement obtains the standard deviation for the pen 2 data retrieved from the PumpPress trend.
        The value is stored in the LeftHemisphereSD memory real tag:
        LeftHemisphereSD=HTGetValue("PumpPress", PumpPress.UpdateCount,2,"PenStdDev");
        HTGetValueAtScooter() Function
        The HTGetValueAtScooter() function returns a value of the requested type for the sample at the specified
        scooter position, trend, and pen number. The UpdateCount argument causes the expression to be evaluated
        after function processing is finished.
        Category
        Historical
        Syntax
        RealResult=HTGetValueAtScooter(Hist_Tag, UpdateCount,ScootNum,ScootLoc,PenNum,
        ValType_Text);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             UpdateCount
             Integer representing the trend's .UpdateCount dotfield.
             ScootNum
             Integer representing the left or right scooter:
             1 = Left Scooter
             2 = Right Scooter
             ScootLoc
             Real number representing the trend's .ScooterPosRight or .ScooterPosLeft dotfields.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                               Page 180
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 10 – Trending Tag Data
             PenNum
             Integer tag or value representing the pen number (1-8).
             ValType_Text
             String indicating the type of value to return:
             PenValue = Value at scooter position.
             PenValid = 0 if value is invalid, 1 if valid.
        When the ValType_Text argument is used with the HTGetValueAtScooter() function, use one of the valid types
        listed.
        Example
        The following function returns a 1 if the value is an actual sample or a 0 if the value is invalid for pen 3 of the
        Trend1 trend for the right scooter's current position:
        HTGetValueAtScooter("Trend1",Trend1.UpdateCount, 2,Trend1.ScooterPosRight,3, "PenValid");
        HTGetValueAtZone() Function
        The HTGetValueAtZone() function returns a value of the requested type for the data located between the right
        and left scooter positions for a trend's specified pen.
        Category
        Historical
        Syntax
        RealResult=HTGetValueAtZone(Hist_Tag,UpdateCount,
        Scoot1Loc,Scoot2Loc,PenNum,ValType_Text);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             UpdateCount
             Integer representing the trend's .UpdateCount dotfield. It is used only as a trigger to evaluate the function.
             Scoot1Loc
             Real representing the trend's .ScooterPosLeft dotfield. It is used only as a trigger to evaluate the function.
             Scoot2Loc
             Real representing the trend's .ScooterPosRight dotfield. It is used only as a trigger to evaluate the function.
             PenNum
             Integer tag or value representing the pen number (1-8) of the trend.
             ValType_Text
             String indicating the type of value to return.
             PenAverageValue = Average for zone between the scooters.
             PenMaxValue = Maximum value for the zone between the scooters.
             PenMinValue = Minimum value for the zone between the scooters.
             PenMaxEU = Maximum engineering unit value for the zone between scooters.
             PenMinEU = Minimum engineering unit value for the zone between the scooters.
             PenStdDev = Standard Deviation for the zone between the scooters.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 181
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
        Remarks
        A real value is returned representing the calculated value of the given type. Specifying constant values for the
        Scoot1Loc and Scoot2Loc arguments has no effect and are only used to trigger the evaluation of the function.
        The function uses the trend tag's .ScooterPosLeft and .ScooterPosRight dotfield values directly, regardless of the
        values you specify for the Scoot1Loc and Scoot2Loc arguments.
        Example
        The following statement calculates the average value for data between the right and left scooters of the Trend1
        trend for pen 1. The value is stored in the AvgValue memory real tag:
        AvgValue=HTGetValueAtZone("Trend1", Trend1.UpdateCount,Trend1.ScooterPosLeft,
        Trend1.ScooterPosRight,1,"PenAverageValue");
        HTScrollLeft() Function
        The HTScrollLeft() function sets the start time of the trend to an earlier time than the current start time by a
        percentage of the trend's total time span. The effect is to scroll the chart to the left to an earlier time by a
        specified percentage of the trend’s total time span.
        Category
        Historical
        Syntax
        HTScrollLeft(Hist_Tag,Percent);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             Percent
             Real number representing the percentage of the chart’s time span to scroll (0.0 to 100.0) left.
        Example
        The following statement scrolls the time/date left by 10 percent of the PumpPress trend’s total width:
        HTScrollLeft("PumpPress",10.0);
        If the current display starts at 12:00:00 PM and the display width is 60 seconds, then the new trend starts at
        11:59:54 AM after the function is processed.
        HTScrollRight() Function
        The HTScrollRight() function sets the start time of the trend to a time later than the current start time by a
        percentage of the trend's width. The effect is to scroll the date/time of chart to the right by a specified
        percentage of the trend’s width.
        Category
        Historical
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 182
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
        Syntax
        HTScrollRight(Hist_Tag,Percent);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             Percent
             Real number representing the percentage of the chart to scroll (0.0 to 100.0) right.
        Example
        The following statement scrolls the PumpPress trend to the right by 20 percent.
        HTScrollRight("PumpPress",20.0);
        If the current display starts at 12:00:00 PM and the display width is 60 seconds, then the new trend starts at
        12:00:12 PM after the function is processed.
        HTZoomIn() Function
        The HTZoomIn() function calculates a new chart width and start time. If the trend's scooters are at the left and
        right sides of the trend, then the new chart width equals the old chart width divided by two. The new start time
        is calculated based on the value of the LockString argument.
        If the scooters are not at the left and right sides of the trend, the HTZoomIn() function zooms the trend to the
        zone defined by the scooters and ignores the LockString argument.
        Category
        Historical
        Syntax
        HTZoomIn(Hist_Tag,LockString);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             LockString
             String representing the type of zoom:
        Remarks
        If the scooter positions are not at the left and right sides of the trend, the new chart width is the time between
        .ScooterPosLeft and .ScooterPosRight positions. In this case, the value of LockString is not used. The minimum
        chart width is one second. The scooter positions are set to .ScooterPosLeft=0.0 and .ScooterPosRight=1.0 after
        the zoom.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 183
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                           Chapter 10 – Trending Tag Data
        Example
        The following statement zooms the display by a factor of two and maintains the same start time for the Trend1
        trend. Trend1.ScooterPosRight is equal to 1.0 and Trend1.ScooterPosLeft is equal to 0.0. If the start time before
        zooming was 1:25:00 PM and the chart width was 30 seconds, the new start time remains at 1:25:00. The new
        chart width is 15 seconds.
        HTZoomIn("Trend1","StartTime");
        HTZoomOut() Function
        The HTZoomOut() function calculates a new chart width and start time. The new chart width is the old chart
        width multiplied by two. The new start time is calculated based on the value of the LockString argument .
        Category
        Historical
        Syntax
        HTZoomOut(Hist_Tag,LockString);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             LockString
             String representing the type of zoom:
             StartTime = Keep start time equal to before zoom
             Center = Keep center time equal to before zoom
             EndTime = Keep end time equal to before zoom
        Remarks
        The current scooter positions have no effect on HTZoomOut(). After the function zoom finishes, the new scooter
        positions are set to .ScooterPosLeft=0.0 and .ScooterPosRight=1.0.
        Example
        The following statement zooms out the trend time by a factor of two and maintains the same center time for
        the Volume trend. If the start time before zooming was 2:15:00 PM and the chart width was 30 seconds, the
        start time after zooming is now 2:14:45. The chart width is 60 seconds and the center of the trend remains at
        2:15:15.
        HTZoomOut("Volume","Center");
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 184
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                               Chapter 10 – Trending Tag Data
        PrintHT() Function
        The PrintHT() function prints the historical trend currently visible on the screen. Usually, the PrintHT() function
        is associated with a screen button included on the historical trend window. Operators click the button to print
        the visible historical trend with its current values.
        Category.
        Historical
        Syntax
        PrintHT(Trend_Tag);
        Argument
             Trend_Tag
             HistTrend tag.
        Example
        This example prints the PumpPress historical trend currently visible on the screen.
        PrintHT(PumpPress);
        HTGetLastError() Function
        The HTGetLastError() function can be used in a script to determine if an error occurred during the last data
        retrieval for a specified historical trend pen.
        Category
        Historical
        Syntax
        [Result=]HTGetLastError(Hist_Tag,UpdateCount, PenNum);
        Arguments
             Hist_Tag
             HistTrend tag assigned the name of the trend.
             UpdateCount
             Integer representing the trend's .UpdateCount dotfield.
             PenNum
             Integer tag or value representing the pen number (1-8) of the trend.
             Result
             Integer assigned to a tag that represents the status of the last script function call for the specified pen.
             0 = No error
             1 = General server error
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 185
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
             2 = Old request
             3 = File error
             4 = Server not loaded
             5 = Trend/Pen passed in function does not exist
             6 = Trend tag does not exist in database
             7 = Pen number passed to function is invalid (not in range of 1 to 8).
             8 = No tag or a non-logged tag assigned to the pen number
        Examples
        The following statement retrieves the status of the last data retrieval for pen 3 of the Trend1 trend and assigns
        the result to the ResultCode integer tag.
        [ResultCode=]HTGetLastError("Trend1", Trend1.UpdateCount,3);
        In an animation Analog Value Display QuickScript the following statement would be used:
        HTGetLastError("Trend1",Trend1.UpdateCount,3);
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 186
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
        2. Move the mouse over the window area where you want to place the real-time trend. Drag the mouse
           diagonally to create a rectangle the desired size of the trend. The Real-time Trend object appears in the
           window.
3. If needed, adjust the height and width of the trend with its object handles.
        2. In the Expression area, type the name of a local tag or expression that contains one or more local tags.
             If you double-click in the Pen box, the Select Tag dialog box appears showing a list of tags defined for the
             application. You can assign a tag to the pen by selecting it from the Select Tag dialog box.
        3. Click the color box next to each pen assigned a tag to show a color palette.
        4. Click the color that you want to assign to the pen.
        5. In the Width box, type the line width in pixels for each pen shown in the trend.
             Selecting a line width greater than 1 increases the time required to update or print a trend.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 187
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
        6. Select the Only update when in memory check box if you want the trend to update only when shown in the
           active window.
             If you do not select this option, the trend updates continuously even if the window is closed. Continuous
             trend updating slows system performance.
        7. Keep the Real Time Trend Configuration dialog box open and go to the next procedure described in
           Configuring the Real-Time Trend Time Span and Update Rate on page 188.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 188
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
                 White is the default background color. Any other background color significantly increases the time
                 needed to print a trend.
             o   Click on the Border Color box to open the color palette. Select the border color of the trend.
        3. In the Time Divisions area, configure the time divisions. Do the following:
             o   In the Number of Major Div box, type the number of major trend time divisions The major time
                 divisions appear on the horizontal time axis of the trend.
                 The number of major time divisions must be an even multiple of the Major Div/Time Label value. For
                 example, a division number of 20 is an even multiple of the Major Div/Time Label value of 4.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 189
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
4. In the Value Divisions area, configure the appearance of the vertical axis of the trend.
             Value Divisions options are configured like Time Divisions options. The major and minor divisions on the
             y-axis show the magnitude of data values rather than time. The vertical axis specifies the range of data
             values that appear in the trend based upon engineering units for all tags.
             To show decimal points for the minor and major value divisions, type real numbers for the Min Value and
             Max options. For example, 0.00 to 100.00.
        5. Click Select Display Font. The Font dialog box appears with options to set the font, style, and size of text that
           appears in the trend.
        6. Click OK.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 190
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Chapter 10 – Trending Tag Data
        2. In the Printing Control area, specify the percentage of the page to print the trend in the Default % of page
           to print on box.
             If you enter 50, the trend is printed on half of the page vertically and horizontally. A trend printed at 50
             percent takes much less time to print than a full-page trend.
             As a printing alternative, you can use the PrintWindow() QuickScript function.
        3. In the Max consecutive time to spend printing box, type the process time slice in milliseconds.
             A time slice represents the period allocated to the computer processor to run the print module process in
             the foreground and print the trend. A longer time slice enables the trend to be printed more quickly at the
             expense of other processes running on the computer.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 191
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Chapter 10 – Trending Tag Data
        4. In the Time to wait between printing box, type the time in milliseconds the print module waits between
           processor time slices.
             A shorter waiting period between processor time slices enables the trend to be printed more quickly.
        5. Click Select Printer Font. The Font dialog box appears. Select the characteristics of the text appearing in a
           trend.
        6. Click OK to save your printing configuration and close the Historical Logging Properties dialog box.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 192
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 10 – Trending Tag Data
        6. Click Configure InSQL Provider. The InSQL History Provider Properties dialog box appears.
             a. In the Data Source box, type the node name of the server where the IndustrialSQL Server is installed.
             b. Enter a name for a IndustrialSQL Server database user account.
             c. Enter the password for the user account in both the Password and Re-enter password boxes.
             d. Click Test to verify the connection to the IndustrialSQL Server database. A message appears indicating
                whether the connection to the database is successful or not.
        7. Click OK to close the dialog box.
        8. Click OK to close the InSQL History Providers dialog box. The IndustrialSQL Server node appears in the
           History Providers list.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 193
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Chapter 10 – Trending Tag Data
             Example:
             TankFarm1.Pump1RPM
             Each pen of a historical trend can refer to a different remote history provider.
        3. Click OK to save your configuration changes.
Note: The .TagID dotfield cannot be used in remote history provider tag references.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 194
                                                                             AVEVA™ InTouch HMI Data Management Guide
                                                                                          Chapter 10 – Trending Tag Data
        In this example, the number 1 specifies the number of the pen in the historical trend that plots the remote
        Boiler1 tag values from the HistPrv1 remote history provider.
        The run-time Historical Trend Setup dialog box and Pen dotfields are not supported for remote history
        providers.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                               Page 195
Chapter 11
Tagname Dictionary
DDE
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 196
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
        DBDIR                     Message      Path of the folder containing the contents of the InTouch
                                               Tagname Dictionary.
        STARTDATE                 Message      Start date to extract data from the log file. The format of
                                               the start date is MM/DD/YY.
        STARTTIME                 Message      Start time to extract data from log files. The format of the
                                               start time is HH:MM:SS using a 24-hour clock.
        DURATION                  Message      Length of the data collection interval from log files.
                                               DURATION can be expressed as:
                                                   Weeks (w)
                                                   Days (d)
                                                   Hours (h)
                                                   Minutes (m)
                                                   Seconds (s)
                                               Fractional DURATION periods can be specified. For
                                               example, DURATION=0.5m is equivalent to 30 seconds. To
                                               request a single sample, set DURATION to 0.
        INTERVAL                  Message      Length of time between data collection intervals.
                                               INTERVAL can be expressed in weeks, days, hours,
                                               minutes, and seconds. The units of time of an INTERVAL
                                               period are the same as a DURATION period.
                                               Fractional intervals can be specified. For example,
                                               INTERVAL=0.25d represents 6 hours.
                                               The maximum period for DURATION or INTERVAL is six
                                               weeks. The maximum six week period applies to any time
                                               value assigned to DURATION or INTERVAL. For example,
                                               42 is the maximum number of days of an DURATION or
                                               INTERVAL period.
        FILENAME                  Message      Name and folder location of the file containing data
                                               extracted from the historical log file.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 197
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
        WRITEFILE                 Integer      Flag that indicates the status of HistData write operation
                                               to the output file. When set to 1, HistData writes the
                                               requested data to the file specified by the FILENAME Item
                                               Name. When the file update is complete, WRITEFILE
                                               automatically resets to 0.
        ERROR                     Message      String containing a description of the last error that
                                               occurred while extracting data from log files. When
                                               STATUS is set to 1, the ERROR string is set to None. When
                                               STATUS is set to 0, the ERROR string contains an error
                                               message.
        TAGS1, TAGS2,...          Message      String containing the name of one or more tags whose
                                               data is extracted from the log files.
                                               The TAGS string can be 131 characters in WindowViewer
                                               and 255 characters in Excel.
                                               The string can be appended for longer requests by adding
                                               tag items named Tagsn, where n represents an
                                               incrementing integer.
                                               If a tag needs additional tag text, place a plus (+) at the
                                               end of the string.
                                               For example:
                                                    TAGS="$Date,ProdLevel,ProdTemp,+"
                                                    TAGS1="ReactLevel,Temp,GasLevel,+"
                                                    TAGS2="MotorStatus"
                                               Duplicate tags are not allowed and the maximum length
                                               of each tag’s string is 512 bytes.
        PRINTTAGNAMES             Discrete     Flag that indicates whether the names of tags are placed
                                               above the associated column of values. When set to 1, tag
                                               names are printed. When set to 0, tag names are not
                                               printed.
        DATA                      Message      This item holds the requested data in the HistData
                                               program in comma separated values format. It is used by
                                               other applications to ADVISE or REQUEST data by DDE.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 198
                                                                                    AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
        SENDDATA                  Integer      Flag that indicates the status of the HistData update
                                               operation. When set to 1, HistData updates the DATA
                                               item with the requested data. When the update is
                                               complete, SENDDATA automatically resets to 0.
                                               If you receive an error message indicating too much data
                                               was requested using SENDDATA, shorten the DURATION
                                               period or reduce the number of requested tags. Duplicate
                                               tags are not allowed and the maximum length of each
                                               tag’s string is 512 bytes.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 199
                                                                                       AVEVA™ InTouch HMI Data Management Guide
                                                                  Chapter 11 – Accessing Historical Tag Values from Other Applications
        3. In the Access Name box, type a name up to 32 alphanumeric characters. The values assigned to Access
           Name and Topic Name should be the same.
        4. In the Node Name box, type the name of the node where the log files are currently located.
        5. In the Application Name box, type HistData without the .exe file name extension.
        6. In the Topic Name box, type the name you specified from the Access Name box. Access Name and Topic
           Name should be the same.
        7. Select DDE as the communication protocol.
        8. In the When to advise server area, select Advise all items whenever HistData is used.
        9. Click OK.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                            Page 200
                                                                                      AVEVA™ InTouch HMI Data Management Guide
                                                                 Chapter 11 – Accessing Historical Tag Values from Other Applications
        Note: The HistData Wizard creates these tags automatically except for the PRINTTAGNAMES tag.
        Create two additional tags if you want to send log data to the Data item so that it can be accessed from other
        applications. Also, the HistData Wizard does not automatically create the HDWSendData and HDWData tags.
        The # symbols are linked to a user input link. For example, the # symbol has a User Inputs/String link to the
        HDWDataDir tag. The user input link allows you to change the value of the tags during run time.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                           Page 201
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
The Status button is linked to a fill color—discrete expression, based on the HDWStatus tag.
The Write File button is linked to a fill color—discrete expression, based on the HDWWriteFile tag.
        When the Initialize Data button is clicked, the HistData items are initialized with the desired values. If needed,
        these values can also be changed during run time by using the User Inputs Links.
        The Write File button is linked to a Touch Pushbutton Action script:
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 202
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
        Run HistData
        After creating the HistData window, complete the following steps to run it under WindowViewer.
        To run the HistData window
        1. Start HistData and minimize it.
        2. Start WindowViewer and open the HistData window.
        3. Click the Initialize button and make changes to the HistData items if needed.
        4. Click the WriteFile button.
             If the operation is successful, the value of Status is ON and the color associated with the ON status appears.
             If the operation is not successful, the value of Status is OFF and Error Message shows the cause of the
             failure.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 203
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
        8. Double-click the HistData Wizard object placed in the trend window. The HistData Panel Wizard dialog box
           appears.
        9. In the Hist Trend box, type a name for the HistTrend tag.
        10. In the Number of Records to Write per CSV File box, type the number of records to write to an output file.
        11. Click OK. The HistData Wizard creates a set of tags that are identified with a HDW prefix.
             The HistData Wizard creates the tags listed in Create HistData Tags on page 200. The HistData Wizard
             assigns the tags to the HisDataViewSt Access Name.
        12. Run the historical trend window with WindowViewer.
        13. Click Save to File that is part of the HistData window object. HistData creates the output file in the folder
            location shown in the window object.
        Note: HistData does not populate the .csv file properly if the tag values do not change within an hour of starting
        InTouch with the newly-created *.idx and *.lgh files.
        The HistData data does not have the same resolution as for historical trend scooters. The HistData resolution is
        based on the number of values requested within the time span. It is not an exact reflection of the values that are
        in the *.idx and *.lgh files.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 204
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
In the example above, the data to be poked is in Sheet1. The following example shows the data to be poked:
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 205
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
        Error Message:                    This error occurs when too much data is requested
        Too much data requested – shorten by the SendData item.
        the duration or reduce the number If the only purpose is to create an output file
        of tagnames.                      containing data from the log files, do not use the
                                          SendData item.
        Error Message:                               The folder path does not exist or the spelling of the
        Could not open file                          folder path is incorrect.
        C:\FILES1\HISTDATA.CSV
        Error Message:                               No output file is defined.
        Could not open file C:\FILES\
        Error Message:                               The requested tag does not exist in the application’s
        Could not find tagname TAG• in               Tagname Dictionary. Verify the name of the tag is
        database                                     spelled correctly.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 206
                                                                                     AVEVA™ InTouch HMI Data Management Guide
                                                                Chapter 11 – Accessing Historical Tag Values from Other Applications
        The output .csv file contains date and There are no entries in the Historical log for the tags
        time stamps but does not contain any during the requested time period. Display a
        logged data for the requested tags.    historical trend to verify if the log file contains data
                                               during the requested period.
        The WWLogger contains the following The error message is written to the WWLogger each
        message:                            time the creation of the .csv file fails because of
        Error for DDE                       errors assigning values to the HistData items. This
        HistData|Viewstream1!               error can also occur if you try to set the WriteFile
        WriteFile: Poke was rejected by item to 0, or if you try to write to the error item.
        the server.
        The .csv file contains only a single         The Interval item may be assigned an incorrect
        record when there should be many             value, which creates a very small collection interval.
        records from the log file.
                                                     Also, the Duration item may have an invalid format
                                                     such as HDWDuration=1- (no increment specified).
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                          Page 207
Appendix A
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                Page 208
                                                                                AVEVA™ InTouch HMI Data Management Guide
                                                                                             Appendix A – IEEE Decimal Units
        ABCDEF
        ###.####
        Any floating-point numbers with more than eight digits are subject to rounding errors.
        If you do not include a decimal in the format of the text, then the number is displayed with decimals, per the
        real format decimal precision configured in WindowViewer’s Advanced Format properties.
        Note: If you add "#" to the left of a decimal, or if there is no decimal, do not limit the number of digits displayed.
        Example 1
        A Historian application should show the real number 2.3. But, the number 2.3 is not an even power of two and
        cannot be precisely represented by the IEEE 32-bit floating point format beyond 8 decimal digits.
        To ensure the value 2.3 is shown from the application as the ASCII characters 2.3, the number must not exceed
        eight digits. If the number exceeds the eight digit maximum, the resulting number may be shown as 2.29999999
        or 2.30000001 instead.
        Example 2
        When two real tags values are compared, the difference of two real tag values should be greater than
        FLT_EPSILON (value 1.19209290E-07F, in decimal 0.0000001192092896). However is the number exceeds 8
        digits the resulting value may be incorrect. To correct for this multiply the value by 1000 or a larger multiple of
        10. By doing this the value is be greater than 1e-7. Perform the necessary comparison operations and then
        divide by 1000, or the number you multiplied by.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                    Page 209
Appendix B
InTouch Licensing
            The invalid tag handle bit is reserved to indicate if an invalid handle value occurs within the WindowViewer
             run-time database.
            InTouch version 10 includes 34 system tags, which cannot be replaced by user-defined tags. If you migrate a
             version 7.11 or earlier application to the current version of InTouch, the system tag count is 37.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 210
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Appendix B – InTouch Licensing
            At configuration time, 4096 database handles are reserved to store placeholder tags. When you import
             windows, scripts, or symbols during configuration time, placeholder tags are assigned to this memory
             segment. During run time, all 4096 placeholder handles are available to be assigned to remote reference
             tags.
        InTouch license options are based upon the maximum number of local and remote reference tags that can be
        used in an application.
        If an InTouch tag license is for less than 60K tags, then a sticky tag licensing scheme is enforced. A sticky tag is a
        remote tag reference that is bound at run-time when WindowViewer receives a data change notification for the
        remote reference. WindowViewer updates remote tag references during run-time up to the maximum limit of
        the InTouch license. WindowViewer does not update any additional remote tag references beyond the license
        limit. WindowViewer does not decrement the remote reference tag count when a window is closed. Each
        remote reference tag count sticks while the application is running.
        A single message appears when you exceed the maximum remote reference tag count of your InTouch license.
        After the license maximum is reached, the values associated with invalid remote reference tags are never
        updated in the application. You must stop and restart the application before you can open other windows that
        include one or more remote tag references that are not already associated with those counted against the
        license limit.
        A license that permits 60K tags means that sticky tags are not enforced and there is no enforced limit to the
        number of tags or the combinations of local and remote tags that can be used within an InTouch application.
        The total maximum number of tags is not limited to 60,000. Instead, the maximum possible number of remote
        reference and local tags is based upon the implementation limit of the InTouch run-time database, which is
        slightly larger than 60K.
        Using a 60K licence, the implementation limits for local and remote reference tags are:
            Total possible local tags
             61404 = 65535 – (4096 + 1 + 34)
            Total possible remote reference tags
             Maximum = 65535 – (1 + 34 + # Local Tags)
        So, running an application with a 60K license, you are effectively trading a potential remote reference for every
        user-defined tag in the local tag database. You can never have less than 4096 possible remote reference tags
        available in a run-time configuration.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 211
                                                                              AVEVA™ InTouch HMI Data Management Guide
                                                                                           Appendix B – InTouch Licensing
        The following figure shows an example of an InTouch application running under a 60K license without sticky
        remote reference tags. The count for the static remote reference tag sticks while the application is running. But,
        the count for the dynamic remote reference tag is only for the active tag source. The previous connections to
        remote tag sources do not stick and are not counted in the remote reference or total tag count.
              Application Window
                                           Hard Coded        Tag Source A
          Static Remote Reference Tag
                                          Reference to
                                        Remote Tag Source
Tag Source C
        The InTouch 60K license does not use sticky tag counts that impose limits on the number of dynamic remote tag
        references. This allows an application to dynamically access more than 60K tags during the period the
        application is running. The tag use count for dynamic remote references fluctuates up and down as windows
        with remote references are opened and closed. But, the application can never have more simultaneously active
        tags than the implementation limit of the run-time tag database.
        Dynamic reference tag counts only fluctuate up and down when WindowViewer uses disk storage to save the
        contents of a running application. If WindowViewer is configured to cache InTouch windows or Industrial
        graphics, the remote reference tag counts may not decrease unless a window is removed from the cache.
        When a window is not visible does not mean the remote tag references are not still bound to their sources.
        However, if window caching is completely disabled, and no high priority windows have been specified, then
        WindowViewer operates much like the legacy "Always load from disk" scenario. In this case, all windows are
        removed from memory when they are closed and the dynamic remote tag references are reclaimed in a 60K
        license environment.
        A remote reference from an I/O tag is not included in the sticky remote reference count of the InTouch license.
        An I/O tag’s remote reference can change an unlimited number of times without counting against the sticky
        remote reference limit.
        When fail-over to the secondary tag source occurs, the application can access the same items from the
        secondary source without increasing the licensed tag count. After failover, accessing new items from the
        secondary tag source increases the tag count. These items are accessible after fail-back to the primary tag
        source.
        After the tag count reaches the licensed maximum, no further items can be activated regardless of whether they
        are accessed from the primary or secondary tag source.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                 Page 212
                                                                                 AVEVA™ InTouch HMI Data Management Guide
                                                                                              Appendix B – InTouch Licensing
    IORRGetSystemInfo() Function
        The IORRGetSystemInfo() function returns a tag count for a running InTouch application. Based upon an
        argument value, the IORRGetSystemInfo() function returns a numerical value, which can be:
            Maximum number of remote tag addresses specified by the InTouch license
            Number of remote tag addresses counted against the license over the period that an InTouch application
             has been running
            Number of remote tags currently activated in an InTouch application
            Number of available remote tags in a running InTouch application
            Number of remote reference tags, which are currently disabled
            Number of local tags in a running InTouch application
            -1 if an error occurs during the function call or the Option argument is assigned an invalid value.
        Category
        Miscellaneous
        Syntax
        IORRGetSystemInfo(Option);
        Argument
             Option
             An integer tag or integer constant that specifies the type of remote reference tag count to return. Possible
             values are:
        1      Returns the maximum number of permitted remote tag addresses based upon the
               InTouch license. Local I/O tags are not counted in the remote tag count.
               This number is constant while the InTouch application is running.
        2      Returns the number of unique remote tag addresses counted against the licensed
               limits that are activated while an InTouch application is running. Local I/O tags are
               not counted in the remote tag count.
               If the license permits more than 60000 remote reference tags, this number may be 0,
               regardless of how many remote tag addresses are activated. While running under an
               unlimited license, WindowViewer does not count the activated remote tag
               addresses.
               While running an application under a license that has a remote tag limit, this count
               increments up to the limit of the remote tag license count. After the remote tag limit
               is reached, no further remote tag addresses can be activated. Only addresses
               currently activated can be reactivated. Use IORRWriteState with the Option
               argument set to 3 to obtain a list of remote reference tags that count against the
               license limit.
        3      Returns the number of remote reference tags currently activated within an InTouch
               application.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 213
                                                                                    AVEVA™ InTouch HMI Data Management Guide
                                                                                                 Appendix B – InTouch Licensing
        4      Returns the number of remote reference tags that can be activated in an InTouch
               application without running out of remote tag handles. This count typically changes
               while an application is running. Stopping and starting scripts and opening and closing
               windows containing remote reference tags affect the remote reference tag count.
               This number can be less than the number still remaining on the license, especially if
               the license is unlimited. This occurs because there is an internal limit to how many
               remote reference tags can be active simultaneously.
        5      Returns the number of remote tags currently in the disabled state within an InTouch
               application.
        6      Returns the number of local tags currently in the InTouch application.
        Example
        The following example returns the number of remote reference tags counted against the license limit while an
        InTouch application is running. The returned remote reference tag count is assigned as the value of the
        RRTagCount integer tag.
        RRTagCount = IORRGetSystemInfo(2);
    IORRWriteState() Function
        The IORRWriteState() function saves information about the current state of an application’s remote tags to a
        text file. The function creates the file if it does not exist. Each time the script containing the function runs, new
        information is concatenated to the file.
        You can specify what remote tag information is saved to the file. Also, the function’s return value indicates
        whether information is added successfully to the file.
        Category
        Miscellaneous
        Syntax
        IORRWriteState(FilePath, Option, " ");
        Arguments
             FilePath
             Full folder path to the text file containing information about an application’s remote tags. The FilePath
             argument can be a string constant or a message tag.
             Option
             An integer tag or integer constant that specifies the remote tag count information written to the file.
             Possible values are:
        1      List of current remote tag addresses. The information also includes each remote tag’s
               state, activation time, and deactivation time.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                     Page 214
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                               Appendix B – InTouch Licensing
        3      List of all remote reference tag addresses that have been activated and counted
               against the license limit.
               New items are added to the list as new remote tag addresses are activated. When the
               license limit is reached, no further items are added to the list.
               However, no addresses are added to this list if the remote tag license limit is unlimited.
        4      List of current addresses not activated because the remote reference tag count
               exceeds the license limit or because the internal tag handle limit was reached.
               Does not return addresses related to licensing if the remote tag license limit is
               unlimited.
               If the licensing is unlimited, the list contains any items that are not currently active
               because of implementation limitations. If any item in this list becomes active, it is
               removed from the list. When an item is deactivated because of licensing limitations, it
               is removed from the list. This list updates while the InTouch application is running.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                      Page 215
                                                                               AVEVA™ InTouch HMI Data Management Guide
                                                                                            Appendix B – InTouch Licensing
        The following line from the output file shows an example of a fully activated remote tag whose assigned values
        update the InTouch application:
        65429 <TestProt:di106> (A) {C:5/23/2007 9:58:35 AM} {A:5/23/2007 9:58:35 AM}
        The first number is the remote tag handle, followed by the address, then the flags, A, for allowed or D for
        disallowed. The creation, most recently activated, and most recently deactivated times follow the flags in the
        output line. The deactivation time does not appear if the remote tag has never been deactivated while the
        application is running.
        The following line from the output file shows an example of an active remote tag that exceeds the license limits:
        65342 <TestProt:di193> (D) {C:5/23/2007 9:58:35 AM} {A:5/23/2007 9:58:35 AM}
        Licensed Addresses
        The following line from the list shows the address assigned to the remote reference tag and when it was added
        to the list.
        <testprot:di000> {C:5/23/2007 9:58:36 AM}
        Denied Addresses
        Denied addresses appear in the list because of implementation limitations, or because the tag count exceeds
        license maximum.
        This example shows a remote tag address, which exceeds the license limit:
        testprot:di125 [1] (L) {F:5/23/2007 9:58:39 AM} {R:5/23/2007 9:58:39 AM}
        The address is listed along with the count to indicate how many times an attempt was made to reference the
        item. The flag indicates if the address is in the list because of an exceeded license, L, or because of an internal
        implementation limit, I. The two times represent the first time it was added to the list and its most recent access
        time.
        Example
        This example writes the current activated remote tag addresses to a file located in the c:\intouch\data folder.
        The ReturnValue tag is assigned an integer, which indicates whether the function call successfully wrote remote
        tag information to the file.
        ReturnValue = IORRWriteState("c:\intouch\data", 2, "");
    IORRGetItemActiveState() Function
        The IORRGetItemActiveState() function returns the status of a specified remote tag address.
        Category
        Miscellaneous
        Syntax
        IORRGetItemActiveState(ItemPath, Option);
        Arguments
             ItemPath
             ItemPath is a string that represents the address of interest. ItemPath can be a string constant or a message
             tag.
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                  Page 216
                                                                                  AVEVA™ InTouch HMI Data Management Guide
                                                                                               Appendix B – InTouch Licensing
             Option
             An integer tag or integer constant that specifies the type of remote reference tag count to return. Possible
             values are:
        Examples
        This example determines if the TestProt:di000 remote tag address is currently active:
        ReturnValue = IORRGetItemActiveState("TestProt:di000", 1);
        This example determines if the TestProt:di121 remote tag address is currently disabled:
        ReturnValue = IORRGetItemActiveState("TestProt:di121", 4);
        This example determines if the TestProt:di001 remote tag address is currently counted against the license limit.
        ReturnValue = IORRGetItemActiveState("TestProt:di001", 5);
© 2021 AVEVA Group plc and its subsidiaries. All rights reserved.                                                   Page 217
Index
    $
    $AccessLevel system tag • 22, 32
    $ApplicationChanged system tag • 32
    $ApplicationVersion system tag • 32
    $Date system tag • 32
    $DateTime system tag • 32
    $Day system tag • 32
    $HistoricalLogging system tag • 32
    $Hour system tag • 32
    $InactivityWarning system tag • 32
    $Language system tag • 32
    $LogicRunning system tag • 32
    $Minute system tag • 32
    $Month system tag • 32
    $Msec system tag • 32
    $NewAlarm system tag • 32
    $ObjHor system tag • 32
    $ObjVer system tag • 32
    $Operator system tag • 32
    $OperatorDomain system tag • 32
    $OperatorDomainEntered system tag • 32
    $OperatorName system tag • 32
    $PasswordEntered system tag • 32
    $Second system tag • 32
    $StartDdeConversations system tag • 32
    $System system tag • 32
    $Time system tag • 32
    $VerifiedUserName system tag • 32
    $Year system tag • 32
    .
    .ChartLength dotfield • 163
    .ChartStart dotfield • 164
    .DisplayMode dotfield • 159
    .EngUnits dotfield • 51
    .MaxEU dotfield • 50, 152
.MaxRange dotfield • 160
.MaxRaw dotfield • 47
.MinEU dotfield • 50, 152
.MinRange dotfield • 159
.MinRaw dotfield • 47
.Name dotfield • 115
.OnMsg dotfield • 53
.Pen1-8 dotfields • 165
.Quality dotfield • 95
.QualityLimit dotfield • 96
.QualityLimitString dotfield • 97
.QualityStatus dotfield • 97
.QualitySubstatus dotfield • 98
.QualitySubstatusString dotfield • 99
.RawValue dotfield • 49
.Reference dotfield • 68
.ReferenceComplete dotfield • 68
.ScooterLockLeft dotfield • 167
.ScooterLockRight dotfield • 168
.ScooterPosLeft dotfield • 168
.ScooterPosRight dotfield • 169
.TagID dotfield • 166
.TimeDate dotfield • 88
.TimeDateString dotfield • 88
.TimeDateTime dotfield • 89
.TimeDay dotfield • 90
.TimeHour dotfield • 90
.TimeMinute dotfield • 91
.TimeMonth dotfield • 91
.TimeMsec dotfield • 92
.TimeSecond dotfield • 92
.TimeTime dotfield • 93
.TimeYear dotfield • 94
.UpdateCount dotfield • 161
.UpdateInProgress dotfield • 162
.UpdateInProgress dotfields • 162
.UpdateTrend dotfield • 163
.Value dotfield • 52
A
Access Names
    application nameIXAccessNamesapplicationname • 61
    assigning to tags • 66
    communication protocolIXAccessNamescommunicationprotocol • 61
    creatingIXAccessNamescreating • 61
    description • 56
    indirect tag remote referencesIXAccessNamesindirecttagremotereferences • 116
    licensing considerations • 211
    polling information • 61
    reinitializing from WindowViewer • 100
    secondary backup serverIXAccessNamessecondarybackupserver • 61
   topic nameIXAccessNamestopicname • 61
ArchestrA Bulk Import Utility
   migrating SuperTags • 127
Average/Bar historical trend • 152
Average/Scatter historical trend • 152
C
communication protocols
    DDE • 58
    FastDDE • 58
    NetDDE • 58
   SuiteLink • 58
Cross Reference Utility
    description • 128
    search for all occurrences • 131
    search for specific occurrences • 131
D
DDESee Dynamic Data Exchange • 58
DDEStatus topic name • 111
dotfields
    .DisplayMode dotfield • 159
    .MaxEU dotfield • 50, 152
    .MaxRaw dotfield • 47
    .MinEU dotfield • 152
    .MinRange dotfield • 159
    .Name dotfieldIXdotfieldsNamedotfield • 115
    .OffMsg dotfield • 53
    .Reference dotfield • 68
    .TimeDateString • 88
    description • 38
    listingIXdotfieldslisting • 38
    syntax • 38
   using with local indirect tagsIXdotfieldsusingwithlocalindirecttags • 116
Dynamic Data Exchange
    communication protocol • 58
    HistData itemsIXDynamicDataExchangeHistDataitems • 197
F
floating-point numbers • 208
ForceLogCurrentValue parameter • 149
functions
    HTGetPenName() function • 177
    HTSelectTag() function • 175
    HTZoomOut() function • 184
    IOGetActiveSourceName() function • 110
    IOSetAccessName() function • 70
    IOSetItem() function • 68
    PrintHT() function • 185
H
HistData
    DDE itemsIXHistDataDDEitems • 197
    description • 196
historical logging
    data collection cycle • 141
    description • 141
    file naming convention • 141
    file retention • 141
historical trends
   descriptionIXhistoricaltrendsdescription • 152
HTGetLastError() function • 185
HTGetPenName() function • 177
HTGetTimeAtScooter() function • 178
HTGetTimeStringAtScooter() function • 178
HTGetValue() function • 179
HTGetValueAtScooter() function • 180
HTGetValueAtZone() function • 181
HTScrollLeft() function • 182
HTScrollRight() function • 182
HTSetPenName() function • 176
HTUpdateToCurrentTime() function • 175
HTZoomIn() function • 183
HTZoomOut() function • 184
I
IEEESee Institute of Electrical and Electronics Engineers • 208
indexed tag names • 24
indirect tags
    concatenating namesIXindirecttagsconcatenatingnames • 115
    descriptionIXindirecttagsdescription • 115
    equating to source tagsIXindirecttagsequatingtosourcetags • 115
    using with local tagsIXindirecttagsusingwithlocaltags • 116
    using with remote referencesIXindirecttagsusingwithremotereferences • 116
Institute of Electrical and Electronics Engineers • 208
InTouchView • 61
invalid tag handle • 210
IOGetApplication() function • 67
IOGetNode() function • 67
IOGetTopic() function • 68
IOReinitAccessName() function • 102
IOReinitialize() function • 103
IOStartUninitConversations() function • 103
L
license
    invalid tag handle • 210
    placeholder tag count • 210
    remote refernce tag count • 211
    system tag count • 210
    tag handles • 210
linear scaling • 64
M
Message Exchange • 78
Min/Max historical trend • 152
MinEU dotfield • 51
N
naming conventions for tagsIXnamingconventionsfortags • 24
R
remote references
    specifying indirect tagsIXremotereferencesspecifyingindirecttags • 116
   using with indirect tagsIXremotereferencesusingwithindirecttags • 116
remote tag countIXremotetagcount • 129
S
SuiteLink
    description • 58
    diagnosing communication problems • 59
   features • 58
SuperTags
   creating a templateIXSuperTagscreatingatemplate • 120
   defining instances • 123
   deleting a template • 122
   description • 119
   instances • 119
   migrating with ArchestrA Bulk Import Utility • 127
   template structure • 119
    templates • 119
system tags
   $Date system tag • 32
   $datestring system tag • 32
   $DateTime system tag • 32
   $Day system tag • 32
   $HistoricalLogging • 149
   $HistoricalLogging system tag • 32
   $Hour system tag • 32
   $InactivityWarning system tag • 32
   $Language system tag • 32
   $LogicRunning system tag • 32
   $Minute system tag • 32
   $Month system tag • 32
   $Msec system tag • 32
   $NewAlarm system tag • 32
   $ObjHor system tag • 32
   $ObjVer system tag • 32
   $Operator system tag • 32
   $OperatorDomain system tag • 32
   $OperatorDomainEntered system tag • 32
   $OperatorName system tag • 32
   $PasswordEntered system tag • 32
   $Second system tag • 32
   $StartDdeConversations system tag • 32
   $System system tag • 32
   $Time system tag • 32
   $TimeString system tag • 32
   $VerifiedUserName system tag • 32
   $Year system tag • 32
   license count • 210
T
Tagname Dictionary
    creating a new tag • 22
    creating tags overview • 11
    listing SuperTags • 119
    selecting the type of tagIXTagnameDictionaryselectingthetypeoftag • 11
    setting a logging deadband • 26
    setting common tag propertiesIXTagnameDictionarysettingcommontagproperties • 23
   updating tag countsIXTagnameDictionaryupdatingtagcounts • 129
Tagname dotfields
    .Comment • 54
    .MaxEU dotfield • 50, 51
    .MinRaw dotfield • 47
    .OnMsg dotfield • 53
    .RawValue dotfield • 49
    .Value dotfield • 52
tags
    adding to a SuperTag instance • 125
    common propertiesIXtagscommonproperties • 23
    configuring for historical loggingIXtagsconfiguringforhistoricallogging • 142
    description • 10
    determining usage • 129
    dynamic remote reference • 211
    handles • 210
    Hist Trend typeIXtagsHistTrendtype • 15
    indirectIXtagsindirect • 115
    initial value • 25
    life cycle • 11
    linear scaling • 64
    maximum EU units • 64
    measurement units • 25
    minimum raw value • 64
    miscellaneous typesIXtagsmiscellaneoustypes • 15
    naming conventionsIXtagsnamingconventions • 24
    placeholder count in license • 210
    planning usage • 21
    retentive parameters • 27
    square root scaling • 64
    static remote reference • 211
    Tag ID type • 15
    theoretical license maximum • 130
    typesIXtagstypes • 11
    updating local count • 129
    updating local tag countIXtagsupdatinglocaltagcount • 129
    updating remote count • 129
Tree view • 71
trends
    Average/BarIXtrendsAverageBar • 152
    Average/Scatter • 152
    description • 151
    Min/Max historical trend • 152
    typesIXtrendstypes • 151
V
value deadband
    description • 26
    setting • 26
Value Time Quality
   description • 58
VTQSee Value Time Quality • 58
W
windows
   printing • 31
WindowViewer
    description • 11