Page Tree
Software Knowledgebases
What are Tags and Templates?
Tags
In FactoryStudio and throughout this guide, the term "tag" refers to any real-time variable or its associated historical data. Tags usually map to devices, such as PLC registers or other physical equipment in the production process. A tag can also be connected to entries in SQL databases, external data sources, or an internally calculated value.
All tags have a specific type, such as integer, text, or date and time. FactoryStudio provides over a dozen predefined types, and allows users to define new types as well. In addition, some tags may be defined as arrays, and tags may have optional parameters.
Tags are the process variables for your application. Use tags and their properties to set up the data model for your process.
Templates
Although FactoryStudio provides many predefined types, sometimes you may need to define your own type. This is done using a template. Templates may be defined with properties similar to those of a predefined type. each template represents a user-defined type that you can use in the same manner as predefined types.
Using templates, you can extend the types of tags available and create new types to fit your application needs, such as machine data, equipment status, vessels, or the representation of any asset attributes in your plant.
On this page: |
---|
FactoryStudio provides 13 built-in tag types, most of which are based directly on .NET datatypes. These are summarized in the following table.
Tag Type | .Net Type | Value Range |
Digital | System.Int32 | 0 through 1 |
Integer | System.Int32 | -2,147,483,648 through 2,147,483,647 |
Long | System.Int64 | -2,147,483,648 through 2,147,483,647 |
Double | System.Double | -1.79769313486231570E+308 through -4.94065645841246544E-324 for negative values; 4.94065645841246544E-324 through 1.79769313486231570E+308 for positive values |
Decimal | System.Decimal | 0 through +/-79,228,162,514,264,337,593,543,950,335 with no decimal point; 0 through +/-7.9228162514264337593543950335 with 28 places to the right of the decimal; smallest nonzero number is +/-0.000 |
Text | System.String | 0 to approximately 2 billion Unicode characters |
Timer | System.Int32 | Same range as Integer, but with built-in parameters to produce a repetitive wave pattern (see notes below) |
DateTime | System.DateTimeOffset | from 12:00:00 midnight, January 1, 0001 to 11:59:59 P.M., December 31, 9999 |
TimeSpan | TimeSpan | Data Interval, in Days, Hours, Minutes, Seconds and Milliseconds, where each of those properties can hold a Double value |
Guid | Guid | Standard Microsoft Globally Unique Identifier (GUID) |
DataTable | System.Data.DataTable | Holds an in-memory DataTable |
Image | System.Byte[] | Can hold an Image file or any binary content. Maximum size of the content is the long value. |
Decimal
The Decimal type allows calculation with higher precision than Double. However, math operations using Decimal can be 40 times slower than using Double. So the Decimal type should only be used when Double precision is not enough.
Timer
Timer is a built-in integer type that can be used to generate precise timing signals. Timers have the following varieties:
For the SquareWave, Pulse and Comparer, If you set the tag StartValue, the tag toggles between 0 and StartValue (instead of 0 and 1) .
Reference
Reference Tags allows dynamic addressing of the variables.
The concept is closer to the concept of References in .NET programming, more than the old C++ pointers. This is because Reference Tags, like .NET references, are typed; that means that when creating a Reference Tag, you need to define the type of the object the reference will be pointing to. Like .NET References and unlike C++ pointers, a Reference Tag cannot be defined to point to invalid memory areas that would cause errors in the application.
The target Type for Reference types is defined in the Parameters columns.
The use of typed references brings advantages both in Engineering and Runtime. In Engineering it allows Intellisense to directly browse the members of the template, when the reference is pointing to a template; In the runtime it allows string data validation.
All Reference Tags have an additional runtime attribute, the link, which specifies the tag that the reference will be linked to during execution.
Essentially the Link property is a string property that should receive the target tag name before using the reference tag. You can assign a string directly or by using a string expression, but the best way to set the Link property is to use the Method GetName(), which will create the string based on the current tag name. This way, you can rename the tag without having to search the strings. This also shows the tag names linked on the cross-reference utility.
An example project (ReferenceTags) ships with FactoryStudio.
Examples:
@Tag.Reference1.Link = @Tag.TagName.GetName() (VB)
@Tag.Reference1.Link = @Tag.TagName.GetName(); (C#)
@Tag.Reference1.Link = "Tag.TagName"; (C#)
@Tag.Reference1.Link = "Tag.TagNa" + "me"; (C#)
The reason for using the GetName() method instead of using strings directly, is that with GetName() you retain the benefits of Cross-Reference and Refactoring.
Creating and Editing Tags
To create and edit tags:
Column | Description |
Name | Enter a name for the tag. The system lets you know if the name is not valid.
|
Type | Select the tag type, which may be a built-in type or a user-defined template. |
Parameters | Configure the parameters, if any. The parameters vary based on the tag type. Once the type is entered, you can double click on the parameters field to see a dropdown menu with the applicable parameters. |
Array | When this field is blank, the Tag is not an Array. When the field contains an integer value N, an Array is created from position 0 to N. For example, if the field contains the value 5, the Array is created from Tag[0] to Tag[5]. This means that 6 elements are created. Two programming styles are accommodated by this method; one that counts elements from 0 to less than five, and one that counts from 1 to 5. |
The columns above are visible by default. To add or remove a column, right-click the column heading area and check or uncheck the columns that will be visible.
Column | Description |
Units | Enter the engineering units of measure that you want to use as a label for this tag. |
StartValue | Enter a starting value for this tag. This is the value the tag will be initialized with when FactoryStudio starts. |
Format | Enter a default format for displaying the data. For example:
|
Retentive | Select an option to save the value of the tag and its internal properties to the database every time the value changes. This retains the value when the application shuts down and makes the value available when the application next starts.
|
Min | Enter the minimum value that is valid for the object. |
Max | Enter the maximum value that is valid for the object. |
Visibility | Select the value visibility on the OPC server for remote projects:
|
Domain | Tag value for the entire project or value specific to each client display.
|
Comment | Enter any comments about this tag. |
ReadSecurity | Select which groups have the right to read the Tag. Tag Security protection can be configured in Display > Client Settings |
ScaleMin | Enter the scale min value for communication. |
ScaleMax | Enter the scale max value for communication. |
DevicePoint | Read-only. Show which communication point is related to the tag (if related) |
WriteSecurity | Select which groups have the right to write in the Tag. Tag Security protection can be configured in Display > Client Settings |
[Other columns] | For definitions of other columns that are available in this table, see "Common Column Definitions". |
Continue adding as many tags as you need.
Notes
You can also create a tag from anywhere in FactoryStudio by clicking New Tag in the toolbar.
Like any other configuration table, you can also import CSV files or copy/paste contents directly from an Excel spreadsheet or other applications.
With FactoryStudio you can replace names at any time, so an easy way to create a tag is to click with the mouse on the Name column of the insertion row, then press space and enter. Each time, the system will create a Tag of the same type as the last one created. You can use the mouse on the insertion row to select the Type, then click with the mouse in the header or any other part of that grid. That will also create a tag with a default name. Also, you can configure more than one row at the same time, just select the rows with Shift button then right-click and select "Edit Combined Rows". A new popup will open with the rows' information. All settings changed in this window will change all rows selected. If a column has , it shows that this column has more than one configuration.
Tag Formats
The format property defines the display format for tag values. These formats follow the specifications provided in Microsoft .NET. For valid numeric formats, refer to Standard Numeric Format Strings (http://msdn.microsoft.com/en-us/library/dwhawy9k%28v=VS.90%29.aspx). For example: N1 (number with 1 decimal place).
For valid date and time formats, refer to Standard Date and Time Format Strings (http://msdn.microsoft.com/en-us/library/az4se3k1%28v=VS.90%29.aspx). For example: d (short date).
For a more in-depth discussion of format strings, refer to Formatting Types (http://msdn.microsoft.com/en-us/library/fbxft59x%28v=VS.90%29.aspx).
Numeric format examples |
|
Specifier | Description |
N0 | Number with no decimal places |
N3 | Number with 3 decimal places |
X | Hexadecimal (supported only for integral types) |
C | Currency |
Date/time format examples |
|
Specifier | Description |
T (only) | Long time pattern (equivalent to HH:mm:ss). |
d (only) | Short date pattern (equivalent to M/d/yyyy (month/day/year) for en-us). |
dd | Show the day of the month as a number from 01 through 31. |
ddd | Show the abbreviated name of the day of the week. |
dddd | Show the full name of the day of the week. |
MM | Show the month as a number from 01 through 12. |
MMM | Show the abbreviated name of the month. |
yy | Show the year as a two-digit number. |
yyyy | Show the year as a four-digit number. |
hh | Show the hour as a number from 01 through 12. |
HH | Show the hour as a number from 00 through 23. |
mm | Show the minute as a number from 00 through 59. |
ss | Show the seconds as a number from 00 through 59. |
fff | Show the milliseconds as a number from 000 through 999. |
tt | Show the A.M./P.M. designator. |
Templates let you create new tag types based on existing built-in types.
To create a tag template:
Enter or select information, as needed, all the properties are the same as in Tags (see Creating and Editing Tags).
Assets
If you have the Enterprise version of FactoryStudio, assets let you configure additional metadata for your project. For example, you can organize objects in your project, such as tags, devices, and alarms, into a hierarchy. This lets you group tags that are related to each other. The hierarchy may reflect such things as areas of your manufacturing floor or the location of your machinery.
To create assets:
Categories
If you have the Enterprise version of FactoryStudio, you can create user-defined categories of data that you can use as metadata for tags. Categories are useful for filtering, both when creating the project and during runtime.
To create categories:
All project tags are available to the runtime modules as .NET objects at the Tag Namespace.
All Built-in Tag Types share a common set of properties and methods defined in the base class TagObj. The Tags created from user defined templates are implemented by the base class UserType.
Class Type | Description. |
TagObj | Base classes to all Tag objects. |
Digital | Runtime properties for tags of Type Digital. |
Analog | Runtime properties for all Analog Tag Types. |
AnalogInt | Runtime properties for tags of Type Integer. |
AnalogLong | Runtime properties for tags of Type Long. |
AnalogDecimal | Runtime properties for tags of Type Decimal. |
AnalogDouble | Runtime properties for tags of Type Double. |
Text | Runtime properties for tags of Type Text. |
TDateTime | Runtime properties for tags of Type DateTime. |
Timer | Runtime properties for tags of Type Timer. |
TTimeSpan | Runtime properties for tags of Type TimeSpan. |
Reference | Runtime properties for tags of Type Reference. |
TDataTable | Runtime properties for tags of Type DataTable. |
UserType | Runtime Properties for tags from Templates. |
See "Namespaces" for the complete programming reference on runtime objects.