-
Contents
-
Table of Contents
-
Bookmarks
Quick Links
Logix5000 Controllers I/O and Tag Data
Catalog Numbers 1756 ControlLogix, 1756 GuardLogix,
1768 Compact GuardLogix, 1769 CompactLogix, 1789 SoftLogix,
PowerFlex with DriveLogix
Programming Manual
Related Manuals for Allen-Bradley Logix5000
Summary of Contents for Allen-Bradley Logix5000
-
Page 1
Logix5000 Controllers I/O and Tag Data Catalog Numbers 1756 ControlLogix, 1756 GuardLogix, 1768 Compact GuardLogix, 1769 CompactLogix, 1789 SoftLogix, PowerFlex with DriveLogix Programming Manual… -
Page 2
Labels may be on or inside the equipment, for example, a drive or motor, to alert people that surfaces may reach dangerous temperatures. Allen-Bradley, Rockwell Automation, RSLogix 5000, Logix5000, RSLinx Classic, RSLinx Enterprise, PanelView, PLC-2, PLC-5, SLC, CompactLogix, ControlLogix, GuardLogix, FlexLogix, DriveLogix, SoftLogix, Rockwell Software, FactoryTalk Security, and TechConnect are trademarks of Rockwell Automation, Inc. -
Page 3
Summary of Changes Introduction The release of this document contains new information. New Information New information is marked by change bars in the side column, as shown to the right. Section Changes Chapter 1 New information and examples for electronic keying. Chapter 4 Procedures and descriptions for the external access and constant tag attributes that control access to… -
Page 4
Summary of Changes Notes: Publication 1756-PM004C-EN-P — October 2009… -
Page 5: Table Of Contents
Table of Contents Preface Purpose of This Manual……..7 Chapter 1 Communicate with I/O Modules Introduction .
-
Page 6
Table of Contents Force an Input Value ……..60 Force an Output Value . -
Page 7: Purpose Of This Manual
Preface Purpose of This Manual This manual shows how to access I/O and tag data in Logix5000 controllers. This manual is one of a set of related manuals that show common procedures for programming and operating Logix5000 controllers. For a complete list of common procedures manuals, refer to the Logix 5000 Controllers Common Procedures Programming Manual, publication 1756-PM001.
-
Page 8
Preface Notes: Publication 1756-PM004C-EN-P — October 2009… -
Page 9: Introduction
Chapter Communicate with I/O Modules Introduction To communicate with an I/O module in your system, you add the module to the I/O Configuration folder of the controller. Add I/O modules here. When you add the module, you also define a specific configuration for the module.
-
Page 10: Requested Packet Interval
ControlNet network. The timing of this slot may not coincide with the exact value of the RPI, but the control system guarantees that the data transfers at least as often as the RPI. In Logix5000 controllers, I/O values update at a period that you configure via the I/O configuration folder of the project. The values update asynchronous to the execution of logic.
-
Page 11: Communication Format
• Direct or Rack-Optimized Connection. • Ownership. Direct or Rack-Optimized Connection The Logix5000 controller uses connections to transmit I/O data. These connections can be direct connections or rack-optimized connections. Term Definition Direct connection A direct connection is a real-time, data transfer link between the controller and an I/O module.
-
Page 12: Ownership
Communicate with I/O Modules Ownership In a Logix5000 system, modules multicast data. This means that multiple devices can receive the same data at the same time from a single device. When you choose a communication format, you have to choose whether to establish an owner or listen-only relationship with the module.
-
Page 13
Communicate with I/O Modules Chapter 1 Use the following table to choose the type of ownership for a module. Choose the Type of Ownership If module is And another controller And you want to Then use this type of connection Input module Does not own the module Owner (not listen-only) -
Page 14: Electronic Keying
For some specific module types, fewer options are available. Electronic keying is based on a set of attributes unique to each product revision. When a Logix5000 controller begins communicating with a module, this set of keying attributes is considered. Keying Attributes…
-
Page 15
Exact Match keying is also necessary to enable Automatic Firmware Update for the module via the Firmware Supervisor feature from a Logix5000 controller. In the following scenario, Exact Match keying prevents I/O EXAMPLE… -
Page 16
Chapter 1 Communicate with I/O Modules Changing electronic keying selections online may cause the I/O IMPORTANT Communication connection to the module to be disrupted and may result in a loss of data. Compatible Keying Compatible Keying indicates that the module determines whether to accept or reject communication. -
Page 17
3.2. In this case, communication is prevented because the minor revision of the module is lower than expected and ith 3.3. may not be compatible w Module Configuration Vendor = Allen-Bradley Product Type = Digital Input Module Catalog Number = 1756-IB16D Major Revision = 3… -
Page 18
Module Configuration Vendor = Allen-Bradley Product Type = Digital Input Module Catalog Number = 1756-IB16D Major Revision = 2… -
Page 19
1756-IF16 analog input module. In this case, communication is prevented because the analog module rejects the data formats that the digital module configuration requests Module Configuration Vendor = Allen-Bradley Product Type = Digital Input Module Catalog Number = 1756-IA16 Major Revision = 3… -
Page 20
1756-IB16 digital input module. In this case, communication is allowed because the two digital modules share common data formats Module Configuration Vendor = Allen-Bradley Product Type = Digital Input Module Catalog Number = 1756-IA16 Major Revision = 2… -
Page 21: Address I/O Data
Communicate with I/O Modules Chapter 1 Address I/O Data I/O information is presented as a set of tags. • Each tag uses a structure of data. The structure depends on the specific features of the I/O module. • The name of the tag is based on the location of the I/O module in the system.
-
Page 22: Buffer I/O
Chapter 1 Communicate with I/O Modules Buffer I/O Buffering is a technique that logic does not directly reference or manipulate the tags of real I/O devices. Instead, the logic uses a copy of the I/O data. Buffer I/O in the following situations: •…
-
Page 23
Communicate with I/O Modules Chapter 1 This example copies inputs and outputs to the tags of a structure for a drill machine. Buffer I/O EXAMPLE The main routine of the program executes the following subroutines in this sequence. Jump to Subroutine Jump to Subroutine Jump to Subroutine Routine name map_inputs… -
Page 24
Chapter 1 Communicate with I/O Modules This example uses the CPS instruction to copy an array of data that represent the input devices of a DeviceNet network. Buffer I/O EXAMPLE Local:0:I.Data stores the input data for the DeviceNet network that is connected to the 1756-DNB module in slot 0. To synchronize the inputs with the application, the CPS instruction copies the input data to input_buffer. -
Page 25: Introduction
Chapter Organize Tags Introduction With a Logix5000 controller, you use a tag (alphanumeric name) to address data (variables). Term Definition A text-based name for an area of the controller’s memory where data is stored. • Tags are the basic mechanism for allocating memory, referencing data from logic, and monitoring data.
-
Page 26: Tag Type
Receive data from another controller Consumed If you plan to use produced or consumed tags, you must follow additional guidelines as you organize your tags. See the Logix5000 Controllers Produced and Consumed Tags Programming Manual, publication 1756-PM011. Publication 1756-PM004C-EN-P — October 2009…
-
Page 27: Data Type
• Within a structure, each individual data type is called a member. • Like tags, members have a name and data type. • A Logix5000 controller contains a set of predefined structures (data types) for use with specific instructions such as timers, counters, Function Blocks, and so forth.
-
Page 28
– sign. Members of Data Type Members running_seconds 42365 To copy data to a structure, use the COP instruction. Refer to the Logix5000 Controllers General Instructions Reference Manual, publication 1756-RM003. Publication 1756-PM004C-EN-P — October 2009… -
Page 29: Scope
Other routines Main routine A Logix5000 controller lets you divide your application into multiple programs, each with its own data. There is no need to manage conflicting tag names between programs. This makes it easier to reuse both code and tag names in multiple programs.
-
Page 30: Guidelines For Tags
In any of the seven AXIS data types To communicate with a PanelView terminal None of the above Program scope (program tags) Guidelines for Tags Use the following guidelines to create tags for a Logix5000 project. Tag Guidelines Guideline Details Create user-defined data types User-defined data types (structures) let you organize data to match your machine or process.
-
Page 31
To increase the efficiency of your logic, minimize the use of SINT or INT data types. Whenever possible, use the DINT data type for integers. • A Logix5000 controller typically compares or manipulates values as 32-bit values (DINTs or REALs). -
Page 32
Chapter 2 Organize Tags Tag Guidelines Guideline Details Limit a tag name to 40 characters Here are the rules for a tag name: • Only alphabetic characters (A-Z or a-z), numeric characters (0…9), and underscores (_) • Must start with an alphabetic character or an underscore •… -
Page 33: Create A Tag
Organize Tags Chapter 2 Create a Tag The Tag Editor window lets you create and edit tags by using a spreadsheet-style view of the tags. RSLogix 5000 programming software also automatically creates IMPORTANT tags when you: • add an element to a sequential function chart (SFC). •…
-
Page 34: Create An Array
Chapter 2 Organize Tags Create an Array Logix5000 controllers also let you use arrays to organize data. Term Definition Array A tag that contains a block of multiple pieces of data. • An array is similar to a file. • Within an array, each individual piece of data is called an element.
-
Page 35
Organize Tags Chapter 2 The following example compares a structure to an array. This is a tag that uses the Timer structure (data type). This is a tag that uses an array of the Timer data type. Tag Name Data Type Tag Name Data Type −… -
Page 36
Chapter 2 Organize Tags Two-dimension array EXAMPLE A drill machine can drill one…five holes in a book. The machine requires a value for the position of each hole from the leading edge of the book. To organize the values into configurations, a two-dimension array is used. -
Page 37: Configure An Array
Organize Tags Chapter 2 Configure an Array To create an array, you create a tag and assign dimensions to the data type. 1. On the Controller Organizer, right-click Controller Tags and choose Edit Tags. The Tag Editor window appears. 42350 2.
-
Page 38: Create A User-Defined Data Type
Chapter 2 Organize Tags Create a User-defined Data User-defined data types (structures) let you organize your data to match your machine or process. Type User-defined data type that stores a recipe. EXAMPLE In a system of several tanks, each tank can run a variety of recipes. Because the recipe requires a mix of data types (REAL, DINT, BOOL, so forth), a user-defined data type is used.
-
Page 39
Organize Tags Chapter 2 User-defined data type that stores the data that is required to run a machine. EXAMPLE Because several drill stations require the following mix of data, use a user-defined data type. Name (of data type): DRILL_STATION Member Name Data Type Part_advance BOOL… -
Page 40: Guidelines For User-Defined Data Types
Chapter 2 Organize Tags Guidelines for User-defined Data Types When you create a user-defined data type, use these guidelines: • If you include members that represent I/O devices, you must use logic to copy the data between the members in the structure and the corresponding I/O tags.
-
Page 41
Organize Tags Chapter 2 3. Type a name and description for the user-defined data type. A description is optional. 4. For each member of the user-defined data type, type a name, data type, style, and description. 5. Click the External Access column, and choose an attribute. 42196 Limit any arrays to a single dimension. -
Page 42: Describe A User-Defined Data Type
Chapter 2 Organize Tags Describe a User-defined RSLogix 5000 programming software lets you automatically build descriptions out of the descriptions in your user-defined data types. This greatly reduces the Data Type amount of time you have to spend documenting your project. RSLogix 5000 software 13.0 or later As you organize your user-defined data types, keep in mind the following…
-
Page 43: Activate Pass-Through And Append Descriptions
Organize Tags Chapter 2 RSLogix 5000 software uses different colors for descriptions. Color Descriptions If Color Description Is This Is Gray Pass-through description Black Manually entered description Activate Pass-Through and Append Descriptions Follow these steps to use pass-through descriptions and append to base tag descriptions.
-
Page 44: Paste A Pass-Through Description
Chapter 2 Organize Tags Paste a Pass-Through Description Follow these steps to use a pass-through description as the starting point for a more specific description. 1. On the Controller Tags screen, right-click the pass-through description, and choose Paste Pass-Through. 2. Edit the description and press CTRL + Enter. Publication 1756-PM004C-EN-P — October 2009…
-
Page 45: Address Tag Data
Organize Tags Chapter 2 Address Tag Data A tag name follows this format. Name [Element] .Member [Element] .Bit .[Index] = Optional Where Name Name that identifies this specific tag. Element Subscript or subscripts that point to a specific element within an array. •…
-
Page 46: Alias Tags
Chapter 2 Organize Tags Alias Tags An alias tag lets you create one tag that represents another tag. • Both tags share the same value. • When the value of one of the tags changes, the other tag reflects the change as well.
-
Page 47: Display Alias Information
Organize Tags Chapter 2 The following logic was initially programmed by using descriptive tag names, such as stop and conveyor_on. Later, the tags were converted to aliases for the corresponding I/O devices. stop start stop is an alias for Local:2:I.Data.1 <Local:2:I.Data.1>…
-
Page 48: Assign An Alias
Chapter 2 Organize Tags Assign an Alias Follow these steps to assign a tag as an alias tag for another tag. 1. On the Controller Organizer, right-click Controller Tags and choose Edit Tags. The Tag Editor window appears. 42360 2. Select the scope of the tag. 3.
-
Page 49: Assign An Indirect Address
Organize Tags Chapter 2 Assign an Indirect Address If you want an instruction to access different elements in an array, use a tag in the subscript of the array (an indirect address). By changing the value of the tag, you change the element of the array that your logic references. When index equals 1, array[index] points here.
-
Page 50
Chapter 2 Organize Tags The following example loads a series of preset values into a timer, one value (array element) at a time. Step through an array. EXAMPLE The timer_presets array stores a series of preset values for the timer in the next rung. The north_tank.step tag points to which element of the array to use. -
Page 51: Expressions
Organize Tags Chapter 2 Expressions You can also use an expression to specify the subscript of an array. • An expression uses operators, such as + or -, to calculate a value. • The controller computes the result of the expression and uses it as the array subscript.
-
Page 52: Array Subscript Out Of Range
The controller checks the array subscript in these instructions even if the rung is false. EXAMPLE For more information on handling major faults, refer to the Logix5000 Controllers Major and Minor Faults Programming Manual, publication 1756-PM014. Publication 1756-PM004C-EN-P — October 2009…
-
Page 53: Tag Documentation
Organize Tags Chapter 2 Tag Documentation The table outlines the four types of tags that can be created and the descriptions that you can document for each one. RSLogix 5000 programming software automatically assigns IMPORTANT what are called pass-through descriptions of the tags you have created, descriptions you may or may not want to use.
-
Page 54
Chapter 2 Organize Tags Enter the localized descriptions in your RSLogix 5000 project, either when programming in that language or by using the import/export utility to translate the documentation off-line and then import it back into the project. Once you enable language switching in RSLogix 5000 software, you can dynamically switch between languages as you use the software. -
Page 55: Chapter 3 Introduction
Chapter Force I/O Introduction Use a force to override data that your logic either uses or produces. For example, use forces to: • test and debug your logic. • check wiring to an output device. • temporarily keep your process functioning when an input device has failed.
-
Page 56: Enable Forces
Chapter 3 Force I/O Enable Forces For a force to take effect, you enable forces. You can only enable and disable forces at the controller level. • You can enable I/O forces and SFC forces separately or at the same time.
-
Page 57: Check Force Status
Force I/O Chapter 3 Check Force Status Before you use a force, determine the status of forces for the controller. You can check force status. To determine status Use any of the following • Online toolbar I/O forces • FORCE status indicator •…
-
Page 58: Force Status Indicator
Chapter 3 Force I/O FORCE Status Indicator If your controller has a FORCE Status Indicator, use it to determine the status of any I/O forces. The FORCE Status Indicator shows only the status of I/O forces. IMPORTANT It does not show that status of SFC forces. FORCE Status Indicator Then •…
-
Page 59: When To Use I/O Force
Force I/O Chapter 3 When to Use I/O Force Use an I/O force to: • override an input value from another controller (that is, a consumed tag). • override an input value from an input device. • override your logic and specify an output value for another controller (that is, a produced tag).
-
Page 60: Force An Input Value
Chapter 3 Force I/O Force an Input Value Forcing an input or consumed tag: • overrides the value regardless of the value of the physical device or produced tag. • does not affect the value received by other controllers monitoring that input or produced tag.
-
Page 61: Remove Or Disable Forces
Force I/O Chapter 3 4. Install the force value. To force a Do this BOOL value Right-click tag and choose Force On or Force Off. Non-BOOL value In the Force Mask column for the tag, type the value that you want to force the tag.
-
Page 62: Remove An Individual Force
Chapter 3 Force I/O Remove an Individual Force If you remove an individual force, forces remain in the ATTENTION enabled state and any new force immediately takes effect. Before you remove a force, determine how the change will effect your machine or process and keep personnel away from the machine area.
-
Page 63: Data Access Control
Chapter Data Access Control Introduction In the Logix platform, software version 18 or later, there are two tag attributes that allow you to control access to tag data. These attributes are: • External Access • Constant The External Access attribute controls how external applications, such as HMIs, can access tags.
-
Page 64: Configure External Access
Chapter 4 Data Access Control Configure External Access You configure external access from a pull-down menu when you create a new tag or data type. You can also modify that value just like other tag attributes. These changes can be made throughout the software. For example, they can be made in the User-defined Data Type Editor, New Tag Dialog, and the Tag Properties Dialog.
-
Page 65
Data Access Control Chapter 4 The default value in the External Access box is dependent on the usage, and type of the tag. The following table describes the values. Default Tag’s External Access If the tag is Default value is Alias Same as its target. -
Page 66: Configure External Access In The New Tag Dialog Box
Chapter 4 Data Access Control Configure External Access in the New Tag Dialog Box You can create these types of tags on the New Tag dialog box: • Base tag • Alias tag • Produced tag • Consumed tag The parameters on the dialog box depend on the type of tag you are creating. page For tag descriptions, see The External Access box on the New Tag dialog box lets you assign the…
-
Page 67
The Connection button (next to the Type box) becomes active when either a produced or consumed tag type is selected. The button accesses a dialog box for setting up produced/consumed tag connections. See the Logix5000 Controllers Produced and Consumed Tags Programming Manual, publication 1756-PM011. Publication 1756-PM004C-EN-P — October 2009… -
Page 68: Set Up External Access In The Tag Properties Dialog Box
Chapter 4 Data Access Control Set Up External Access in the Tag Properties Dialog Box The Tag Properties dialog box is used to edit properties of existing tags. You can change tag attributes and modify tag types, such as base and alias. Follow these steps to choose an external access option for an existing tag.
-
Page 69: View And Select External Access Status On The Tag Editor Window
Data Access Control Chapter 4 View and Select External Access Status on the Tag Editor Window You can view the external access status of a tag in the Tag Editor window. The External Access column displays the tag as ‘Read/Write’, ‘Read Only’, or ‘None’.
-
Page 70: Go To’ Search Menu
Chapter 4 Data Access Control ‘Go To’ Search Menu The external access setting of an alias tag can only be changed through its base tag. The ‘Go To’ option on the Search menu of the RSLogix 5000 programming software is a convenient way to find the base tag among all the cross-reference records.
-
Page 71: External Access Availability
Data Access Control Chapter 4 External Access The following table describes the conditions in which the External Access box is disabled. Availability The External Access box is always disabled for any tag whose IMPORTANT data type is Alarm Analog or Alarm Digital. The external access status is always Read/Write for these data types.
-
Page 72
Chapter 4 Data Access Control External Access Variables Dialog Box/Window Considerations Tag Editor The External Access box is disabled if: • you do not have permission to change the external access settings. • the redundancy controller is in any state that does not allow changes. -
Page 73: User-Defined Type Considerations
Data Access Control Chapter 4 User-defined Type The three external access options—Read/Write (default), Read Only, None— are chosen from the External Access column on the Data Type Considerations dialog box. Three external access rules apply for members of User-defined data types. •…
-
Page 74: Add-On Instructions External Access Considerations
Chapter 4 Data Access Control Add-On Instructions External Access settings can be used with parameters and local tags of Add-On Instructions. For example, if an input parameter is defined with External Access external access of ‘read only’, the member that represents that parameter in the Considerations Add-On Instruction data type cannot be written.
-
Page 75
Data Access Control Chapter 4 For alias parameters, the external access type is equal to the type configured for the base local tag. Add-On Instruction External Access Variables Dialog Box/Window Considerations New Add-On If the current usage is: Instruction Parameter or Local Tag •… -
Page 76
Chapter 4 Data Access Control Add-On Instruction External Access Variables Dialog Box/Window Considerations Add-On Instruction The External Access column is disabled if: Definition — Parameters • InOut parameters, which are blank. • EnableIn and EnableOut parameters, which default ‘Read Only’. •… -
Page 77
Data Access Control Chapter 4 Add-On Instruction External Access Variables Dialog Box/Window Considerations Add-On Instruction Edit Note: External access is not applicable for InOut parameters Tags because they are just references until invoked. The External Access column is disabled if: •… -
Page 78: Tag Mapping Considerations
Chapter 4 Data Access Control Tag Mapping Only tags with external access settings of Read/Write or Read Only can be mapped to a PLC-2 controller and PLC-5/SLC controllers. Considerations PLC-2, PLC-5/SLC External Access Variables Dialog Box/Window Considerations PLC-2, PLC-5/SLC To map a tag: Mapping •…
-
Page 79: Constant Value Tags
Data Access Control Chapter 4 Constant Value Tags In RSLogix 5000 software version 18 and later, you can designate tags as constants to protect them from being changed programatically via: • the controller programming application. • logic in the controller. Tags that cannot be designated as constants are User-defined type members, Add-On Instruction input and output parameters, and local tags.
-
Page 80: Configure Constant Tags
Chapter 4 Data Access Control Configure Constant Tags This section describes the various ways a constant attribute can be configured. Set Up a Constant in the New Tag Dialog Box Follow these steps to configure a tag as a constant on the New Tag dialog box. 1.
-
Page 81: Configure A Constant In The Tag Properties Dialog Box
Data Access Control Chapter 4 Configure a Constant in the Tag Properties Dialog Box Follow these steps to designate a tag as a constant on the Tag Properties dialog box. 1. On the Tag Editor window, right-click a tag and choose Edit (tag name) Properties.
-
Page 82: Designate A Constant In The Tag Editor
Chapter 4 Data Access Control Designate a Constant in the Tag Editor The Constant column on the Tag Editor window lets you designate tags that cannot be modified in the RSLogix 5000 software program. The Constant property applies to an entire tag; all members of the tag take on the same setting.
-
Page 83
Data Access Control Chapter 4 2. Click the checkbox in the Constant column. In the Tag Monitor window, the constant setting of the tag IMPORTANT displays in the same Constant column as shown in the In the above illustration. However, you cannot change the value. The Constant column also is available on the Equipment Phase Tag Edit window and Equipment Phase Tag Monitor window. -
Page 84: Constant Checkbox Availability
Controller Log for future reference. For controller logging, see the Logix5000 Controllers Information and Status Programming Manual, publication 1756-PM015. If the controller is in safety-locked mode, only the safety tags will be disabled from being accessed, the standard tags will have the same behavior as in the unlocked mode.
-
Page 85: Add-On Instructions Constant Value Considerations
Data Access Control Chapter 4 Add-On Instructions The Constant attribute applies only to InOut parameters. The default setting of the property will be ‘not a Constant Value’. Constant Value Considerations The Constant attribute will not apply to Input, Output, EnableIn and EnableOut Add-On Instruction parameters.
-
Page 86: Publication 1756-Pm004C-En-P — October
Chapter 4 Data Access Control Notes: Publication 1756-PM004C-EN-P — October 2009…
-
Page 87
Index constant value access availability 84 external 63 dialog box 80 Add-On Instruction tag editor 82 constant value considerations 85 tag properties 81 external access variables 75 value configuration 80 address value tags 79 assign indirect 49 controller tag 45 tags 29 tag I/O module 21 use of 29… -
Page 88
Index external access 63 ladder logic Add-On Instruction 74 force a value 55 availability 71 override a value 55 configure 64 local data configure tag dialog 66 See scope configure tag properties 68 options 64 user-defined data type consider- ations 73 memory view tag editor 69 allocation for tags 27… -
Page 89
Index symbol memory allocation 27 name 29 See alias. organize 30 overview 25 properties external access 68 address 45 reuse of name 29 alias 46 scope 29 array 34 type 26 assign dimensions 37 constant value 79 configuration 80 user-defined data type create 33 create 40 create alias 48… -
Page 90
Index Notes: Publication 1756-PM004C-EN-P — October 2009… -
Page 92
Rockwell Automation Support Rockwell Automation provides technical information on the Web to assist you in using its products. At http://www.rockwellautomation.com/support/, you can find technical manuals, a knowledge base of FAQs, technical and application notes, sample code and links to software service packs, and a MySupport feature that you can customize to make the best use of these tools.
This handbook is a collection of programming overviews, notes, helps, cheat sheets and whatever that can help you (and me) program an Allen Bradley PLC.
If you have experience with AB then please contribute.
An Introduction to RSLogix5000 Tags
Tags are the method for assigning and referencing memory
locations in Allen Bradley Logix5000 controllers. No longer are there any
physical addresses such as N7:0 or F8:7 which use symbols to describe them.
These have been replaced with tags which are a pure text based addressing
scheme. This is a departure from the more conventional ways of programming
PLC’s, which includes Allen Bradley’s earlier line of PLC5 and SLC 500
controllers.
One of the hardest transitions from the older systems is realizing
how the tag database works. The person with experience in Allen Bradley
systems will recognize many of the instructions and be at home with the editor
in RSLogix 5000. Understanding the tag database is the first major hurdle in
becoming comfortable with the ControlLogix and CompactLogix systems. So let’s
dig in and get started.
The Way We Used To Be
Earlier Allen Bradley PLCs programmed with RSLogix 5 and
RSLogix 500 software had data files to store I/O and other internal values.
These different data files could only hold one data type. A data type defines
the format and the size of the stored value.
Default Data Files
Data File Descriptions
File # |
Type |
Description |
O0 |
Output |
This file stores the state of output terminals for the |
I1 |
Input |
This file stores the state of input terminals for the |
S2 |
Status |
This file stores controller operation information useful |
B3 |
Bit |
This file stores internal relay logic. |
T4 |
Timer |
This file stores the timer accumulator and preset values |
C5 |
Counter |
This file stores the counter accumulator and preset values |
R6 |
Control |
This file stores the length, pointer position, and status |
N7 |
Integer |
This file is used to store bit information or numeric |
F8 |
Floating Point |
This file stores a # with a range of 1.1754944e-38 to |
While this method made it easy for using instructions, it
provided a challenge for logically grouping different data types together
according to function. For instance, in machine control, a motor may have a start,
stop, speed and alarm code each with its own data type. Thus, the data was
“scattered†throughout the data files.
File # |
Name |
Data Type |
I1 |
Start |
Input |
I1 |
Stop |
Input |
F8 |
Speed Setpoint |
Floating Point |
N7 |
Alarm Code |
Integer |
Comparing the Old and New
The Logix5000 controllers have done away with data files and
in its place is the tag database. The tag database organizes memory locations
in one place. Each tag is assigned its own data type. The table below shows
the association between the current data types and the older systems with data
files.
RSLogix 5 / 500 |
RSLogix 5000 |
||
File # |
Type |
||
O0 |
Output |
Input and output modules, when configured, automatically |
|
I1 |
Input |
||
S2 |
Status |
Use the GSV and SSV instructions to get status information |
|
B3 |
Bit |
Assign the Boolean (BOOL) data type to the tag. |
|
T4 |
Timer |
Assign the TIMER data type to the tag. |
|
C5 |
Counter |
Assign the COUNTER data type to the tag. |
|
R6 |
Control |
Assign the CONTROL data type to the tag. |
|
N7 |
Integer |
Assign the double integer (DINT) data type to the tag. |
|
F8 |
Floating Point |
Assign the REAL data type to the tag. |
Creating a Tag
One way to create a new tag is right click on the Controller
Tags in the Controller Organizer and select New Tag. Even faster is the Ctrl+W
hot key.
The following dialog box pops up.
The Name given to the tag has the following rules:
- only alphabetic characters (A-Z or a-z), numeric characters (0-9), and underscores (_)
- must start with an alphabetic character or an underscore
- no more than 40 characters
- no consecutive or trailing underscore characters (_)
- not case sensitive
While tags are not case sensitive, it is good practice to
mix cases for readability. It is much easier to read Line1_Start then
LINE1START or line1start.
In addition, the tag database list sorts alphabetically.
Therefore, it is best to use similar starting characters when you want tags to
be together in the monitor list.
Tags Named for Grouping |
Tags Not Named for Grouping |
|
Level_High |
High_Level |
|
Level_Low |
Insert_Nut |
|
Insert_Nut |
Knife_Stop |
|
Knife_Stop |
Low_Level |
Use the Description field for a longer description of
the tag. It is best to keep names short yet not cryptic. Tag names are
downloaded and stored in the controller but the description is not as it is part
of the documentation of the project.
The tag Type defines how the tag operates in the
project
Base |
A tag that actually defines the memory where the data is |
Alias |
A tag that represents another tag |
Produced |
Send data to another controller |
Consumed |
Receive data from another controller |
Alias tags mirror the base tag to which they refer. When
the base tag value changes so does the alias tag. Use aliases in the following
situations:
- program logic in advance of wiring diagrams
- assign a descriptive name to an I/O device
- provide a more simple name for a complex tag
- use a descriptive name for an element of an array
Produced and consumed tags make it possible to share tags
between controllers in the same rack or over a network. This article does not
cover this aspect.
Select a Data Type for the tag by typing it in or by
clicking on the ellipsis button and selecting it from the list. A data type is
a definition of the size and layout of memory allocated for the created tag.
Data types define how many bits, bytes, or words of data a tag will use.
The term Atomic Data Type refers to the most basic data
types. They form the building blocks for all other data types.
Data Type |
Abbreviation |
Memory bits |
Range |
Boolean |
BOOL |
1 |
0-1 |
Short Integer |
SINT |
8 |
-128 to 127 |
Integer |
INT |
16 |
-32,768 to 32,767 |
Double Integer |
DINT |
32 |
-2,147,483,648 to 2,147,483,647 |
Real Number |
REAL |
32 |
+/-3.402823E38 to +/-1.1754944E-38 |
Logix5000 controllers are true 32-bit controllers, meaning
the memory words are 32-bits wide. No matter what, a tag always reserves 32
bits of memory even if it is a Boolean or integer data type. For this reason,
it is best to use a DINT when dealing with integers. Furthermore, a Logix5000
controller typically compares or manipulates values as 32-bit values (DINTs or REALs).
A Logix5000 controller lets you divide your application into
multiple programs, each with its own data. The Scope of the tag defines
if a tag is global (controller tags) and therefore available to all programs or
local (program tags) to a select program group. Pay careful attention to this
field as creating it in the wrong area may lead to some confusion later on as
to its location.
Controller Tags are available to all programs. You cannot
go wrong using controller scoped tags unless you easily want to copy and paste
programs. A tag must be controller scoped when used in a Message (MSG)
instruction, to produce or consume data and to communicate with a PanelView
terminal.
Program Tags are isolated from other programs. Routines
cannot access data that is at the program scope of another program. Having
program tags make it easy to copy/paste programs and not have to worry about
conflicting tag names. Make sure though that no controller tags are named the
same as program tags.
Style is the form in which to display the tag by
default. The following table provides you with information on the base and
notation used for each style.
Style |
Base |
Notation |
Binary |
2 |
2# |
Decimal |
10 |
|
Hexadecimal |
16 |
16# |
Octal |
8 |
8# |
Exponential |
0.0000000e+000 |
|
Float |
0.0 |
Edit and Monitor Tags
To edit existing tags select the Logic > Edit Tags
menu item. A spread sheet like view lets you create and edit tags.
Clicking the + sign next to a tag reveals its structure.
For a DINT tag this is the 32 individual bits that make up the tag which will
not be of interest if you are using the tag as a number rather then individual
bits. If you do wish to use the individual bits then you can address them in
this way with the tag name followed by a period and then the bit position (e.g.
MyTag.5). Shown below is the expanded structure for a TIMER. Notice it is
made of two DINTs and three BOOLs. In this case, the Booleans are packed into one
DINT and therefore a timer uses three DINTs of memory.
An Easier Way to Create Tags
The easiest way to create tags is on the fly while
programming. When an instruction is first used a “?†will indicated the need
for a tag. There are three options at this point:
- Double click on the “?†and select an existing tag from
the drop down box. - Right click on the “?†and select new tag.
- Double click on the “?†and type in the tag name. If it
does not all ready exist, then right click on the tag name and select
Create “NewTagNameâ€. Be careful with this method not to use spaces or
special characters.
The nice thing about all these methods is that RSLogix5000
will automatically fill in the correct data type according to the instruction
used.
Another quick method is to drag and drop an existing tag to
a new instruction. Make sure to click on the tag name rather then the
instruction.
Conclusion
These are the basics of tags. The advantages are:
- Tags, if done right, create a level of documentation that
is stored in the PLC. - The software does an automatic housekeeping of memory
locations. There’s no more worrying about physical addressing and memory
conflicts. - Structures can be more easily put together based on
function rather then data type.
Advance subjects include arrays, user defined data types
(UDT) and Add-On Instructions. Hopefully, you will continue to learn more
about the power of tags. There is no doubt that if you grasp the principles
presented here you will be well on your way to using and troubleshooting any
Logix5000 controller.
A Quick Tutorial on RSLogix Emulator 5000
RSLogix Emulator 5000 is a software simulator for the Allen Bradley line of Logix 5000 controllers (ControlLogix®, CompactLogix®, FlexLogix®, SoftLogix5800® and DriveLogix®). The goal is to mimic the function of a PLC without the actual hardware and thus do advanced debugging. More information can be found in the AB publication LGEM5K-GR015A-EN-P.
As a quick introduction we’ll go through a simple example of setting up a simulation. This involves three major steps.
- Setting up the chassis monitor.
- Creating a connection in RSLinx.
- Creating a project with associated emulation hardware.
Setting up the Chassis Monitor
To start the Chassis Monitor, click Start > Programs > Rockwell Software > RSLogixEmulate 5000 > RSLogix Emulate 5000 Chassis Monitor.
When the emulator opens up you’re confronted with what looks like an empty chassis. In slot 0 is an RSLinx module which has to be there for the emulator communications to work. Your slot 1 might have another irremovable RSLinx module depending if you are running RSLogix Enterprise.
From here we set up our hardware configuration for simulation. Our first step will be to add the CPU. In this case it is a special one called an Emulation Controller.
- Click Slot > Create Module.
- Choose the Emulator RSLogix Emulate 5000 Controller.
- Chose slot 2 for the controller
- Click OK to add it to the chassis monitor.
- At this point you may be accosted with a message about previous configurations. Just select Reset the Configuration to Default Values and click NEXT.
- The next two dialog screens are for setting up the controller details. Click NEXT and FINISH to accept all the defaults.
Next we’ll add some input/output simulation.
- Click Slot > Create Module.
- Choose the 1789-SIM 32 Point Input/Output Simulator.
- Chose slot 3 for the simulator and click OK.
- Accept the defaults for the setup by clicking NEXT and FINISH.
The chassis monitor will now have two emulation modules in it ready to go.
Creating a connection in RSLinx
- Start RSLinx under Start > Programs > Rockwell Software > RSLinx > RSLinx Classic
- Click Communications > Configure Drivers.
- Select the Virtual Backplane (SoftLogix 58xx) driver from the Available Driver Types list.
- Click Add New. The Add New RSLinx Driver dialog box appears. Click OK.
- The new driver appears in the Configured Drivers list. Click Close.
Using RSLogix Emulator in a Project
To use the emulator in a project you must setup the hardware correctly.
- Start the RSLogix 5000 software and create a new project.
- Under the New Controller window type select an Emulator – RSLogix Emulator 5000 Controller. Give it a name and assign it to the same slot as the one you put in the Chassis Monitor which in our example is slot 2. Click OK.
- In RSLogix 5000’s Controller Organizer, right click on the I/O Configuration folder, and then click New Module. The software displays the Select Module window.
- Open the Other folder. Select the 1756-MODULE from the modules list and then click OK.
- The software displays the New Module window.
a. Add a Name for the card.
b. In the Slot field put the number that corresponds with the Chassis Monitor.
c. For the Connection Parameters put in the following and click OK
Assembly Instance Size Input 1 2 Output 2 1 Configuration 16 0 - On the next Module Properties screen make sure to change the Requested Packet Interval to 50.0 ms.
Ready, Set, Go
You are now ready to use the emulator just like you would any other PLC. Open Who Active and set the path to the RSLogix 5000 Emulator.
The inputs can be simulated in the emulator’s Chassis Monitor by right clicking on the module and selecting Properties. Under the I/O Data tab is the ability to toggle each of the inputs on or off.
Note:
RSLogix Emulator is sometimes erroneously called RSEmulator.
Getting Started with the Logix5000 PIDE Function Block
The PIDE (Enhanced PID) is an Allen Bradley Logix5000 family (ControlLogix, CompactLogix, FlexLogix, SoftLogix) function block that improves on the standard PID found in all their controllers. First impressions of this function block are quite intimidating. If you try to dive into it head first you may just end up banging your head against a wall. Many will be quite happy to stick with the tried and true PID instruction but to compete with the more advanced process control applications the PIDE boasts the following.
- It uses the velocity form of the PID algorithm. This is especially useful for adaptive gains or multiloop selection.
- Control of the instruction can be switched between Program and Operator modes.
- Better support for cascading and ratio control.
- Built in autotuner (requires extra key)
- Support for different timing modes
- More limiting and fault handling selections.
Still interested? What we want to do here is basically get you off the ground with the PIDE, distill all the options to the essentials and get it working.
The PIDE is only available as a function block (sorry, no ladder). Like the PID instruction it is best to set it up in its own periodic task. The period of the task automatically becomes the sample rate (DeltaT) of the PID loop. Just make sure when adding the new routine to the task to select the Type as «Function Block Diagram.»Â
Adding the PIDE Function Block
The PIDE instruction can be added from the Instruction Toolbar under the Process tab.
Once you plop a function block onto a sheet it automatically creates a program tag for the instruction which stores all the settings. The parameters can be set or monitored by wiring input and output references or by clicking on the ellipsis box in the top right corner to reveal the block properties.Â
Opening the block properties for the PIDE instruction before RSLogix5000 version 15 meant you would be accosted with a long list of parameters.
Version 15 has at least organized some of the more common settings (but not all) under tabs and groups.
Â
The most essential settings are:
Name |
V15 Location |
Description |
.PV |
Must be wired in from a tag. |
The Process Variable is the reading (temperature, pressure, flow, etc.) that is to be controlled by the PID loop. |
.PVEUMax |
EUs/Limit tab in the Engineering Units Scaling group |
The Process Variable Engineering Units Maximum and Minimum. The value of PV and SP which corresponds to 100 % span of the process variable. |
.SPProg |
Should be wired in or set in the tag. |
The Set Point is the theoretical perfect value of the process variable. SPProg is the value to use when in program mode and SPOper is used when in operator mode. |
.SPHLimit |
EUs/Limit tab in the SP Limits group |
The Set Point High Limit and Set Point Low Limit clamp the maximum and minimum values of the set point. If SPHLimit > PVEUMax or SPLLimit < PVEUMin then a fault will occur. |
.PGain |
General Configuration tab in the Gains group |
Proportional gain. Enter 0 to disable. |
.IGain |
General Configuration tab in the Gains group |
Integral gain. Enter 0 to disable. |
.DGain |
General Configuration tab in the Gains group |
Derivative gain. Enter 0 to disable. |
Program/Operator Control
The first thing to understand when programming a PIDE block is the different controls and modes available.Â
The Program/Operator control lets you transfer control of the PID loop between the user program and an operator interface such as an HMI. Each control has separate set points and mode controls. It’s important to understand that when in Program Control the set point is determined by SPProg while in Operator Control its SPOper. The SP output indicates the set point that the function block is actually using.
Control is determined by the following inputs:
Name |
Description |
.ProgProgReq |
A program request to go to Program control. |
.ProgOperReq |
A program request to go to Operator control. |
.OperProgReq |
An operator request to go to Program control. |
.OperOperReq |
An operator request to go to Operator control. |
The ProgOper output indicates the control of the PIDE instruction. If the output is a 1 then it is in Program control and if the output is a 0 then it is in Operator control. The Program request inputs take precedence over the Operator requests so that the program can lock out any operator overrides. The ProgValueReset input clears all input requests.
Operating Modes
The PIDE instruction supports the following modes.
Mode |
Description |
Manual |
While in Manual mode the instruction does not compute the change in CV. The value of CV is determined by the control. If in Program control, CV = CVProg and if in Operator control, CV = CVOper. Select Manual mode using either OperManualReq or ProgManualReq. The Manual output bit is set when in Manual mode. |
Auto |
While in Auto mode the instruction regulates CV to maintain PV at the SP value. If in program control, SP = SPProg and if in Operator control, SP = SPOper. Select Auto mode using either OperAutoReq or ProgAutoReq. The Auto output bit is set when in Auto mode. |
Cascade/Ratio |
While in Cascade/Ratio mode the instruction computes the change in CV. The instruction regulates CV to maintain PV at either the SPCascade value or the SPCascade value multiplied by the Ratio value. SPCascade comes from either the CVEU of a primary PID loop for cascade control or from the «uncontrolled» flow of a ratio-controlled loop. Select Cascade/Ratio mode using either OperCasRatReq or ProgCasRatReq. The CasRat output bit is set when in Cascade/Ratio mode. |
Override |
While in Override mode the instruction does not compute the change in CV. CV = CVOverride, regardless of the control mode. Override mode is typically used to set a «safe state» for the PID loop. Select Override mode using ProgOverrideReq. The Override output bit is set when in Override mode. |
Hand |
While in Hand mode the PID algorithm does not compute the change in CV. CV = HandFB, regardless of the control mode. Hand mode is typically used to indicate that control of the final control element was taken over by a field hand/auto station. Select Hand mode using ProgHandReq. The Hand output bit is set when in Hand mode. |
If a fault occurs in the PIDE settings then it is forced into Manual mode and sets a corresponding bit in the Status words. The InstructFault output is the indicator of a fault. For more detail open the block properties and look at the Status at the bottom of the dialog box. Refer to the Logix5000 Controllers Process Control and Drives Instructions (pub 1756-RM006D-EN-P) for details.
Basic Example
Here’s an example where just the essentials are used. This is a temperature control application if you hadn’t guessed all ready. I’ve changed the look of the function block by going into the block properties, selecting the Parameters tab and checking on (or off) the boxes in the Vis column besides the inputs and outputs that are of concern.
Here’s the run down on each of the inputs.
Input | Description |
PV |
The process variable coming in from my TC card |
PVEUMax |
The span of the temperature input that equals 0 to 100%. In this case the temp goes from 0 to 1200 degC. |
SPHLimit |
We could limit the set point but in this test case just set it equal to the PVEUMax/Min. |
SPProg |
I’ve decided to use Program Control so the Set Point needs to come in on this input rather then SPOper. |
CVProg |
When in manual mode the CV is controlled by this input. |
DependIndepend |
I prefer the Dependent form of the PID algorithm. |
PGain |
The essential PID settings of Proportion, Integral and Derivative. |
ProgProgReq |
Set the request to use Program Control. |
ProgAutoReq |
Since we’re in Program Control these inputs control the Auto and Manual modes. To run them off one switch the BNOT block is used to invert the bit. |
Now for the outputs.
Output | Description |
CVEU |
The Control Variable output in engineering units. Every PID control needs an output. In this case it goes from 0 to 100%. |
SP |
The actual set point which in this case equals SPProg. |
ProgOper |
I want to see a 1 here just to make sure we’re in Program Control |
Auto |
Indicates the operating mode. |
InstructFault |
If I screw something up then this bit will come on. |
Common Problems
No output |
|
Output is limited at 100 |
|
Conclusion
Hopefully this basic introduction has gotten you off the ground. Half the battle is just getting it to work. Once that is done you can now really start to tinker with the power of the PIDE function block.
Further Reference
- Logix5000 Controllers Process Control and Drives Instructions (Publication 1756-RM006D-EN-P)
- Using the PIDE Instruction (Publication LOGIX-WP008A-EN-PÂ — August 2005)
- Using a Logix Controller for Barrel Temperature Control on Plastic Injection Molding and Extruding Machines (Publication RA-AP015A-EN-P €“ February, 2004)
Install and Test a MVI46-MCM Modbus Module for SLC-500
by Nugroho Budi from controlmanuals.com
The MVI46-MCM is a Modbus communication module provided by ProSoft Technology. The module can be installed in a SLC500 rack so it can communicate to other Modbus devices.
This article assumes you have an Allen Bradley SLC 5/03, 5/04, or 5/05 processor with a power supply of adequate capacity for the MVI46-MCM plus any Input/Output (I/O) modules you intend to use. For the purposes of this lab, and to match the supplied sample ladder, we will assume a configuration as follows:
- A-B 1747-L551 5/05Processor – 16K Memory, OS500
- A-B 1746-A7 7-Slot Chassis (rack)
- A-B 1746-P1/P7 Power Supply
If different hardware is used, modifications to the sample ladder file, MVI46MCM.RSS will need to be made to obtain a properly functioning program.
Installing the Module
- Before installing the MVI46-MCM into the SLC chassis, check the position of the Interface Configuration Jumpers on the bottom of the module.
The Setup Jumper is only necessary when used to flash a firmware upgrade onto the module. For normal configuration and operation, this jumper must be positioned as shown in the diagram above. We will be using the RS-232 interface, so check that the PRT2 and PRT3 jumpers are positioned as shown above so the module will communicate in RS-232 mode.
- NOTE: For this step, and at any time when you are installing or removing hardware to or from the chassis, you MUST do so with the POWER OFF! SLC modules are NOT HOT SWAPABLE. Attempting to insert or remove modules while the chassis is powered-up can result in damage to the module, the processor, the Power Supply, and/or the Chassis itself!
Chassis slots are numbered sequentially, left to right, starting at zero for the leftmost slot. The processor always goes in Slot 0. Install the MVI46-MCM module into the slot next to the processor. This will place the module in Slot 1. The rest of the chassis slots should be left empty, for now. If done correctly, your installation should look similar to the following illustration:
- Set the processor key switch to the REM position and power up the chassis.
After its boot cycle, the processor will be ready to accept programming. At this point, you may ignore any RED LEDs indicating processor or module faults. Until a valid project (program) is loaded into the processor it may show a fault.
Configure RSLinx to Talk to SLC
- Attach a null modem cable (or the A-B CP3 programming cable) from your PC serial port to the serial port on your SLC processor, called Channel 0.
- Open RSLinx. Click on the “Communications†drop-down menu. Click on the “Configure Drivers†option. If you’re running a newer version of RSLinx, you’ll see a dialog box like this one:
If you already have a RS-232 DF-1 driver configured, skip to the Auto Configure instructions in Step 5.
- Click the down arrow in the “Available Driver Types:†option box and click on “RS-232 DF-1 devicesâ€, as shown, and click the “Add New…†button.
- You will now be prompted to name your driver. For most cases, the default name will be acceptable. To match the sample project used in this lab, accept the default name by clicking the “OK†button.
- Next, you will see the driver setup dialog box.
- First, click the down arrow in the “Comm Port:†option box and click the Comm port that matches the number on your PC (usually Comm1, Comm2, Comm3, or Comm4).Â
- Then, click the down arrow in the “Devices:†option box and click the “SLC-CH0/Micro/PanelView†option.Â
- Finally, click the “Auto Configure†button. RSLinx will then query the processor, establish a communications link, and adjust the driver’s parameters to match the processor’s current port configuration. Don’t worry if the parameters in your driver don’t match the ones shown in the following example. As long as the window reports “Auto Configuration Successful!â€, whatever parameters appear for baud rate, parity, error checking, etc. will be correct. A successful result will look something like this:
In some instances, RSLinx will fail to Auto Configure. If this happens to you, first check that your cable is OK, properly connected, and that you are selecting the correct Comm port. Once this is verified, if Auto Configure fails, you will need to completely wipe the processor memory and reset it to factory defaults. Consult the A-B product documentation, the A-B website, or A-B Tech Support for instruction on how to do this. Once done, the RSLinx should be able to Auto Configure.
Clicking on “OK†will return you to this dialog:
Â
If the driver status is “Runningâ€, you have now successfully configured RSLinx to talk to the processor. Click the “Close†button to close this dialog and then exit butdo not shutdown RSLinx by clicking the “File†menu option and then “Exit and Shutdownâ€. Be sure to click the “Exit†option.
Use RSLogix500 to Modify the Sample Project
- Next, we will load and configure the sample ladder logic program and download it to the processor. Start RSLogix500. It should come up to a blank window, like this:
- Click on the “File†drop-down menu, click “Open†and browse to the folder where you saved the sample ladder and double-click the file, “MVI46MCM.RSS†that is included on the MVI46MCM CD.
This will open the sample project. We can now configure the sample ladder to get it ready for the next exercise.
- You’ll get a window that looks like this. If not, then click on the “View†Menu, and make sure there are check marks beside “Standardâ€, “Onlineâ€, and “Tabbed Instruction Bar†options.
- In the left pane Project Tree area, under the Controller folder, double-click on the “IO Configuration†icon. This will display the I/O Configuration dialog box:
- Click on “OTHER†in Slot 1, as shown, then click the “Adv Config†button.
Make sure the values are as shown. If they are not, set them to these values. Otherwise, the module will not function properly. Details on module setup are contained in the User’s Manual in Section 3.3 “Setting Up the Moduleâ€. After you verify the values, click “OK†or “Cancel†to close this dialog box. Click on the Exit icon () in the upper-right corner of the I/O Configuration dialog to close it and return to the main window.
- In the left pane Project Tree area, under the Data Files folder, double-click on the N10 – MCM CFG icon. Set the values in this file to match the ones shown below.
MCM Ports 1 & 2 Cmds Port 1 / Port 2 — N10:10 / N10:40 Port Enable/Disable — N10:11 / N10:41 Port Type — N10:12 / N10:42 Float Flag — N10:13 / N10:43 Float Start — N10:14 / N10:44 Float Offset — N10:15 / N10:45 Protocol — N10:16 / N10:46 Baud Rate — N10:17 / N10:47 Parity — N10:18 / N10:48 Data Bits — N10:19 / N10:49 Stop Bits — N10:20 / N10:50 RTS On Delay — N10:21 / N10:51 RTS Off Delay — N10:22 / N10:52 Min. Response Delay — N10:23 / N10:53 Use CTS Line — N10:24 / N10:54 Slave ID — N10:25 / N10:55 Bit Input Offset — N10:26 / N10:56 Word Input Offset — N10:27 / N10:57 Output Offset — N10:28 / N10:58 Holding Register Offset — N10:29 / N10:59 Command Count — N10:30 / N10:60 Min. Command Delay — N10:31 / N10:61 Command Error Pointer — N10:32 / N10:62 Response Timeout — N10:33 / N10:63 Retry Count — N10:34 / N10:64 Error Delay Count — N10:35 / N10:65 Reserved — N10:36 / N10:66 Guard Band — N10:37 / N10:67 Guard Band Timeout This configuration data will set module Port1 to be a Modbus Master and Port2 to be a Modbus Slave. Both ports will be set for Modbus RTU mode, 57,600-baud, no parity, 8 data bits, 1 stop bit. Hardware handshaking will be disabled (RTS/CTS not used.) We will be able to use up to 5 Modbus Commands and any Modbus Command Errors will be sent to module memory beginning at register address 300, which will then appear in SLC data table N31, beginning at N31:100. With this configuration, we can use a second null modem
cable and two DB9M-to-RJ45 pigtails to connect the two ports together, which in turn will allow us to send and get data from the module with our sample ladder. Click on the Exit icon () in the upper-right corner of the Data File N10(dec) dialog to close it and return to the main window. - We will now configure our Modbus commands for Port1. In the left pane Project Tree area, under the Data Files folder, double-click on the N11 – P1 CMDS icon. Set the values in this file to match the ones shown below.
MCM Ports 1 & 2 Cmds Port 1 / Port 2 — N11:0 / N12:0 Cmd Enable — N11:1 / N12:1 Internal Address — N11:2 / N12:2 Poll Interval Time — N11:3 / N12:3 Count — N11:4 / N12:4 Swap Code — N11:5 / N12:5 Node Address Device ID — N11:6 / N12:6 Function Code — N11:7 / N12:7 Device Address Register This creates one Modbus command for Port1, our Master port. This command will send a request out Port1 to the Modbus Slave at Slave ID 2 (our Port2), as configured in N10. The command will get twenty 16-bit words (registers) of data from Destination Address 0, our module address 0, the first word of our WRITE DATA area, and move it out Port2, in Port1, and store it in Internal Address 200, our module address 200, the first word of our READ DATA area. This command will execute once each second.  This way, any values we poke into data table addresses N32:0 through N32:19 will, after a short delay, appear in the corresponding addresses in data table N31. Click on the Exit icon () in the upper-right corner of the Data File N11 (dec) dialog to close it and return to the main window.
- In the left pane Project Tree area, under the Data Files folder, double-click on the N12 – P2 CMDS icon. Set all the values in this file to zero and click on the Exit icon () in the upper-right corner to close this window and return.
- In the left pane Project Tree area, under the Data Files folder, double-click on the N32 – WRITE DATA icon. Set the values in this file as shown.
This will give us some beginning data values for the Modbus command we just created. Click on the Exit icon () it the upper-right corner to close this window and return.
- In the left pane Project Tree area, under the Data Files folder, double-click on the N31 – READ DATA icon. Set the values in this file to zero so that we will know that any values that appear there are the result of our ladder logic execution. Click on the Exit icon () in the upper-right corner to close this window and return.
- We are now ready to save our new project before downloading. In the main window, click on “Fileâ€, then “Save As†to get the Save As dialog box. In the File Name: box, type “46Test1â€, as shown, and click the Save button.
Congratulations! You now have a functioning program that will move data to and from the module.
Downloading and Testing the Modified Sample Project
- Make sure your null modem cable (or CP3 programming cable) is still attached between your PC Comm port and the processor RS-232 port. Take the two DB9M-to-RJ45 pigtails and the other null modem cable and connect the lower two ports on the MVI46MCM module,
P2 APPLICATION and P3 APPLICATION, with these cables. - Set the processor key switch to the “PROG†position. In RSLogix500, click the down-arrow next to the “OFFLINE†status and click “Download…†from the menu.
When you see the confirmation dialog, click the “Yes†button.
The sample ladder is currently configured for a 1747-L551 SLC 5/05. If you are using a different processor, when you try to download, you will see the following:
If you get this warning screen, click the “OK†button. RSLogix will automatically determine the actual processor type you are using and adjust the IO Configuration to match your installed processor. You should then see the following window:
When it comes up, make sure the “Clear I/O†box is NOT checked, as shown, and click “OKâ€. A Download Progress dialog will flash through several progress bars as various parts of the program are loaded. Eventually, you should see:
Click the “Yes†button. The RSLogix status box will change to show you are on-line live with the processor. You can also tell you are on-line when you see the colored blocks and ladder rotating in the status box. The faster they rotate, the higher your connection speed. It should look like this (with animated ladder):
If you had to change your processor type, now would be a good time to re-save the program.
- Next, we will change the SLC 500 processor key switch from “PROG†to “RUN†and back to the “REM†position. If you have a good program, the processor RUN LED will light up solid green and, on the MVI46MCM module, the OK LED will change from red to green, the APP STATUS and BP ACT LEDs will be amber and the LEDs for P2 and P3 will flash green about once every second. The RSLogix status box should look like this:
If, however, the processor “FAULT†LED flashes red and you see this,
it indicates some kind of hardware or software problem. Common causes include: hardware failure, ladder logic errors, and installing the MVI46MCM module in a different chassis slot than the one selected in the I/O Configuration, I/O modules in the configuration that are not actually installed in the chassis, and more. Assuming you are still on-line with the processor, to see what might be causing the problem, you can check the “Processor Status†dialog for the Major Error Code causing the fault. In the Project Tree, under the
“Controller†folder, click on “Processor Status†then click on the “Errors†tab to see the fault. An example of having the module in the wrong slot is shown. Your error may be different.Do whatever is required to fix the root cause of the fault and then turn the key switch from “REM†to “PROG†to “RUN†and back to “REM†to get the processor running normally.
- NOW…We’re ready for some real fun. Take a few minutes to look at the three LAD files in our test program. For a detailed explanation of what these files do, look at Chapter 4 – Ladder Logic in the User’s Manual, beginning on page 25.
Now, look in LAD 4 –MCM CMDS at rungs 0002 and 0003. Bit B3:0/0 in rung 0002 is called the Cold Boot bit. Bit B3:0/1 in rung 0003 is called the Warm Boot bit. Either may be toggled to force the module to restart, reload its configuration and any Modbus commands. This is a handy feature that makes it easy to change and test different configurations and commands. It’s quicker and safer to toggle these bits than to recycle the processor or power-down and power-up the chassis to accomplish the same thing. Toggling either of these bits allows configuration and command changes to be performed without halting the processor. This can be very useful when added one of our modules to an existing application already in use at a customer site. As we progress through the rest of this exercise, we will be returning to this ladder and these rungs often as we modify and test our program.
Toggle one of these bits now and watch the LEDs on the front of the module as you do so. You should see the P2 and P3 LEDs stop the regular blinking they had been doing, the OK LED will briefly turn red then go back to green, and then the P2 and P3 LEDs should resume their blinking once a second.
To toggle the bit, right-click on its picture then click on “Toggle Bit†at the bottom of the context menu, as shown. Be sure to watch the face of the MVI46-MCM module as you click.
- Now we can check to be sure our program is moving the data as it should. Remember previously that we zeroed out our READ DATA table and put test values in our WRITE DATA table. If our program is working correctly, we should now have the same values in the same relative addresses in our READ DATA as in the WRITE DATA. First, let’s check the WRITE DATA table to be sure our test values are still there. In the Project Tree, under the Data Files folder, double-click “N32 – WRITE DATAâ€.
Yep! Our test data is still there, just the way we left it. Now, for the moment of truth…does our N31 – READ DATA table look the same?
- Double-click on “N31 – READ DATA†and let’s see. If your tables overlap each other, you can click-and-hold on the blue Title Bar of either one, drag it to a different position in the window, and release. Ready, GO!
YES!!!!! They MATCH! Now, that was easy, wasn’t it? You can experiment further with the above by changing the values in Data File 32, N32:0 through N32:19. With the PLC in Run Mode the values in Date File 31, N31:0 through N31:19 should, after a very short delay match those in Data File 32.
Using ModScan to simulate the Modbus Master
- Using Windows File Explorer, go to the CD and expand the yellow folder in the left side tree pane titled Utilities under the InRAx folder until you see a folder titled Modscan.
- Double-click on the compressed folder in the right side Explorer pane to extract its contents. Choose or create a new folder to contain these files. A suggestion would be to create a new folder titled Modscan, and then extract the compressed files into this new folder.
- After extracting the Modscan files, locate and double-click on the file titled Modscan.exe. You should see the following program appear.
- This is the Windows program called Modscan. This is a shareware program and can be used for 30 days, after which you are asked to purchase it.
- To use the program, click either Cancel or OK to close out the “Registration Information†dialog window. You may have to click once inside the window, and then click OK. Repeat if necessary. Now we are ready to use the program.
- Remove the short RJ45 pigtail cable from Port 1 on the MVI46-MCM and then disconnect it from the RS232 Null Modem cable. Now connect the RS232 Null Modem cable directly to the COM 1 port on your computer. If you currently have another cable connected to
your computer’s COM 1 port for interfacing to the SLC-500, first go offline with RSLogix 500 software, then disconnect that cable and connect the RS232 Null Modem cable that was previously connected to Port 1 of the MVI46-MCM module. We should now have COM1 on our PC connected with a RS232 Null Modem cable directly to Port 2 on our MVI46-MCM module which is configured as a Modbus Slave device. - In the Modscan program, click on the menu choice called “Setupâ€, and then click on Serial. Configure the settings as shown below. Click OK when done.
- Now click Setup, then Display and make sure that Data and Decimal have check marks beside them. Click on Setup, then Protocol and make sure RTU is checked also.
- Now configure the main window as below.
- Now click on the menu item “Actionâ€, then Start Poll. You may have to clear a popup window first, but you should see results like below which shows our original data that was in our Data File 32.
The register addresses are on the left and listed 40001 through 40020 and each registers value is directly to the right of it.
Congratulations, you have just used a Windows software program called Modscan acting as a Modbus Master device to go out and read data from our MVI46-MCM module’s Port 2 which is a Modbus Slave device.
NOTE : Based on my experience the MVIMCM for SLC500 is unable to be a Slave and must be A MASTERÂ to communicate with other Modbus PLC/Devices (Scadapack32, Micromotion, UltraSonic Flow Meter GM868..)
Learn Ladder Logic with a Free Version of RSLogix 500 and RSEmulator 500
One of my most common questions is, “Where can I get a free download of RSLogix 500?â€Â For any serious development with SLC500 or MicroLogix there is no free option but there is a nice free option if you only want to learn and/or program a MicroLogix 1000 or 1100. Programming a MicroLogix is very very similar to programming a SLC500 or in that case a PLC5 too.Â
Allen Bradley offers as a free download a software package called RSLogix Micro Starter Lite which is essentially the same programming environment as RSLogix 500. On top of that, they also offer RSLogix Emulate for free so that you don’t even need a PLC to run and test your ladder logic. Keep reading and I’ll show you how to get the software and set it up.
Getting the Software
The RSLogix Micro Starter Lite software is only available as a download at http://www.ab.com/programmablecontrol/plc/micrologix/downloads.html. If you are starting from scratch and do not have the RSLinx software then download the kit bundled with RSLinx Classic Lite. FYI, I find it a bit confusing but they also sell software called RSLogix Micro Starter which supports the full MicroLogix range.
If you do not have a MicroLogix 1000 or 1100 to play with then download the RSLogix Emulate 500 software. You’ll be able to use this to simulate a real PLC.
Note for Windows XP users: The bundled version of RSLinx only installs on Windows Pro and is not supported on Windows XP Home versions. To get around this I downloaded an older version of RSLinx Lite 2.50 from the Allen Bradley software update page http://www.rockwellautomation.com/support/webupdates/
Once you’ve downloaded the software and extracted it then install RSLogix Micro followed by the RSLinx Classic Lite software. Next, install the RSLogix Emulate 500 software.
First Steps with RSLinx
RSLinx is the software RSLogix will use to communicate with your PLC or in our case to the emulator.
Let’s start by running the RSLinx software under the START > All Programs > Rockwell Software > RSLinx > RSLinx Classic shortcut. Follow these steps to set it up:
- Under the Communications menu select Configure Drivers. Â Â
- Under the Available Drivers Types select the “SLC 500 (DH485) Emulator driver†and click the Add New… button.Â
- You can give the driver a name but I just leave it at the default of EMU500-1.Â
- Leave the configuration options as Station Number 00 and click OK.
Your driver should now be running and look like the picture below.
Ok, that’s ready to go. Close the Configure Drivers dialog box and close RSLinx. Actually RSLinx is now running in the background and you’ll probably see its little icon in the system tray.
RSLogix Micro Starter Lite
Now for the moment we’ve all been waiting for— creating some ladder logic. Open the RSLogix Micro software with the START > All Programs > Rockwell Software > RSLogix Micro English > RSLogix Micro English shortcut. Create a brand new project by pulling down the File menu and selecting New. Every project must start with a designated processor.Â
In my case I’ve chosen the simplest MicroLogix 1000 and then clicked the OK button. FYI, if you ever work with the purchased version of RSLogix 500 then there will be a lot more items in this hardware list. A blank project now opens up.
Let’s make a simple rung to test in our emulator. Make sure the cursor is on the rung with the END on it and then click the New Rung icon in the instruction toolbar.
Now click on the “Examine if Closed† instruction to add it to the rung. Double click on the question mark above it and enter I:0/0 as its input address. Just leave the description pop up box empty by clicking OK.
Next, click on the Output Energize  instruction to add it to the right side of the rung. Double click on the question mark above it and enter O:0/0 as its output address.  Just leave the description pop up box empty by clicking OK.
You should now have something like below.
The next very important step is to verify the project with the Edit > Verify Project menu item. This will compile the project and get it ready for the emulator.
Save the project as something like Test.RSS in an easy place to find like My Documents.
RSEmulator 500
The emulator lets us test our work by running a virtual PLC. We’ll be able to download our program to it and run it in a very similar fashion to a real PLC. Start the emulator with the START > All Programs > Rockwell Software > RSLogix Emulate 500 > RSLogix Emulate 500 shortcut.  The emulator is pictured below. I know. It doesn’t look like much but it gets the job done.
Select File > Open and open the RSLogix project you created earlier (I named mine TEST.RSS). In the dialog box that pops up put the Station # as 1 and click Ok.
Believe it or not but the emulator is now ready. Leave it running and go back to your project in RSLogix Micro.
Testing the Ladder Logic
In RSLogix Micro Starter select the Comms > System Comms menu item. The following dialog box will pop up.
In the left hand pane, drill down and select the “01, MicroLogix 1000, TEST†processor. Yours might look a little different if you selected different hardware or gave the processor a different name. For good measure make sure Apply to Project is checked and then click on Download. When prompted to go Online click on Yes.
If successful you’ll see the ladder picture spinning round on the online toolbar. To scan the ladder logic put the processor into Run mode by clicking on the arrow to the right of mode status (REMOTE PROGRAM).
To test the ladder logic, change the input state by right clicking on the address and selecting toggle bit.
You will see the instruction go green indicating it is true and it will make the output instruction turn green also indicating the output is turned on.
That’s it! You get all that for the cost of a download. Now break out the manuals and start learning about all the different instructions.
RSLogix 5000 Tips and Tricks
Everybody enjoys nifty little tips and tricks to get their work done faster. This listing is for Allen Bradley’s RSLogix 5000 software. Feel free to add your own tips and tricks using the ‘add comment’ link.
General
- To access Release Notes for this version of software, choose Release Notes from the Help menu.
- The Quick View Pane, located below the Controller Organizer, provides «thumbnail» information for the selected component.
- The Watch Pane, located below the language editor window, provides monitoring for all tags referenced in the active routine window.
- The Controller Organizer is dockable. That is, you can drag it to the left or right side of the screen, or float it somewhere in between.
- Hide/show the Controller Organizer via a toolbar button to make more display area for editors.
- RSLogix 5000 supports Cut/Copy/Paste/Drag/Drop of components within the Controller Organizer as well as to other instances of RSLogix 5000.
- Double-clicking on error messages displayed in the Error Window will navigate you to where the error was encountered.F4 and Shift-F4 can be used to move between errors.
- You can reorder the columns in the tag editor by clicking on the title and dragging it to a new position.
- To simultaneously display logic in multiple routines, select Window -> New Window and then arrange the windows manually. Or select Window -> Tile Horizontal.
- To remove a yellow triangle warning symbol on a device, first check the connection status. If the status is «Connection is not scheduled», re-open the RSNetWorx software. Return to RSLogix 5000 software and the yellow triangle should be gone.
- On one computer, you can install and simultaneously launch (run) multiple translated versions of RSLogix 5000 software.
- Once you do a partial import of rungs, add-on instructions, or user-defined data types, you can’t undo the import. If the import didn’t work as expected, close the project without saving.
- When you select a partial import, make sure to select the correct rung or trend file. Both files have L5X extensions and the software doesn’t prevent you from selecting the wrong file. If you try to import a rung where a trend is expected, or vice versa, the software does display an error that the import failed.
- Partial import of rungs works in all ladder routines, including Add-On Instructions.
- In version 15, the Tag Editor added support for New Window.
- To simultaneously display logic in multiple routines, select Window -> New Window and then arrange the windows manually. Or select Window -> Tile Horizontal.
Keyboard
- Keyboard shortcuts are listed in the Online Help, under the «Navigating the Software» topic.
- You can use Ctrl+Page Down and Ctrl+Page Up to move between tabs in a dialog or routine window.
- You can use Ctrl+Tab and Shift+Ctrl+Tab to move between multiple RSLogix 5000 views.
- You can use Ctrl+G to invoke the Go To dialog. The Go To dialog is convenient for navigating the software.
- You can use Alt+Insert to open the Language Element browser in any of the language editors. You can also invoke this browser by pressing the Insert key in the LD, SFC and FBD editors.
- You can use Ctrl+Space to invoke the Tag browser from within the ST editor.
- You can use the Go To dialog (Ctrl+G) to quickly navigate to routines called by the current routine and to routines that call the current routine.
- In the Sequential Function Chart Editor, you can use the Routine Overview (Ctrl+B) tool to view your entire SFC and help navigate to a specific area of your chart.
- Double-clicking on error messages displayed in the Error Window will navigate you to where the error was encountered. F4 and Shift-F4 can be used to move between errors.
- The Language Element browser is a shortcut to adding logic. In the any of the language editors: use Alt+Insert, type the instruction mnemonic, and press Enter. You can also invoke this browser by pressing the Insert key in the LD, SFC and FBD editors. This short cut can be much quicker than using the instruction toolbar.
- As you use the keyboard to move the cursor around grid cells, press Alt+Down arrow to activate any controls that are active for that cell. This works in all grid-based editors, such as the Tag Editor, Data Monitor, etc. This gives you a way to access cell controls via the keyboard, rather than using the mouse.
Controller Projects
- Whenever you go online using RSLogix 5000, changes made to controller are simultaneously made to a temporary copy of the project file (.ACD). Save makes these changes permanent. Therefore, an upload is only necessary to obtain the latest copy of the tag data in the controller.
- Both Rockwell Automation and third-party sample projects are installed with RSLogix 5000. You can find them in the RSLogix 5000 Samples folder. These projects demonstrate program techniques and code that you can use to program select modules.
- Avoid pointing one alias tag to another alias tag to ensure the application maintains the appropriate references after an upload.
- Avoid pointing multiple alias tags to the same base tag to ensure the application maintains the appropriate references after an upload.
- All tag names are downloaded and resident in the controller along with your logic.
- On download, if the ControlNet schedule stored in the offline RSLogix 5000 project file is old, RSLogix 5000 will retrieve the latest ControlNet schedule from the associated RSNetWorx project file. To make an association to an RSNetWorx project file, use the RSNetWorx tab in the Module Properties dialog of the ControlNet scanner.
- RSLogix 5000 supports moving your project from one Logix platform/controller to another.
- ACD, L5K, CSV, and L5X files are independent of which translated version of RSLogix 5000 imports or exports the file. The software doesn’t create language-specific import/export files.
- Use any translated version of RSLogix 5000 software to go online to a controller without having to re-download.
- In a safety controller, standard tags in a safety mapped relationship follow safety restricted states. For example, a standard tag mapped to a safety tag is read-only in a safety locked state.
- Use Add-On Instructions to initialize tag values to specific values at the beginning of each routine or program scan. Then source protect the AOI to assure that values are correctly initialized and not overwritten manually.
- The order of members within a User-Defined Data Type affect the memory size of the data type. Within the UDT, keep members of the same data type together.
I/O Configuration
- Module icons in the I/O Configuration folder change to indicate the module has faulted or the connection to the module has been interrupted.
- To remove a yellow triangle warning symbol, first check the connection status. If the status is «Connection is not scheduled», re-open the RSNetWorx software. Return to RSLogix 5000 software and the yellow triangle should be gone.
- To easily find a module in the Select Module Type dialog, simply start typing any part of the module name or description. When you start typing, the Find Module dialog is launched automatically.
- Use rack optimized communication formats for digital I/O modules to minimize amount of controller memory and communications overhead associated with these modules.
- RSLogix 5000 automatically creates controller tags when you create an input or output module. You can reference these tags directly in your logic.
- Use alias tags to assign names to specific input/output data and/or to provide a short alternative to lengthy structure member names.
- When you configure an analog I/O module, hold the shift key as you move the slider to increment HH, H, L, and LL values in whole numbers.
- Copy I/O data to a User-Defined Type (UDT) so you can synchronize I/O data with program scan. The UDT also enables easier mapping of physical I/O.
Tasks, Programs and Equipment Phases
- An event task in Logix is similar to the processor input interrupt (PII) in the PLC-5. Multiple event tasks can exist in the controller, each configured to execute at the initiation of independent triggers.
- A periodic task in Logix is similar to the selectable timed interrupt (STI) in the PLC-5. Multiple periodic tasks can exist in the controller, each configured to execute at independent rates.
- Double-click on a state in an Equipment Phase to navigate to the logic for that state.
- Use RSBizWare Batch software to create Equipment Phases. Use the Equipment Editor to create the phases, define parameters, and synchronize the phases with an RSLogix 5000 project.
- Use any programming language (Ladder, Structured Text, FBD, or SFC) to program state routines in Equipment Phases.
- The fault routine for an Equipment Phase is the same as the fault routine for a program. Use a fault routine to allow logic to run before the controller faults due to a programming error.
- The Prestate routine runs all the time, even when the Equipment Phase is not active.
- The Prestate routine for an Equipment Phase is optional. Use the Prestate routine to execute the error detection logic for your phases.
- You don’t have to implement all the available states in an Equipment Phase. On the Equipment Phases properties, check the «Complete State if not implemented» option.
- In the Phase Monitor, the states you can write code have action names and have a command word leading into the state, such as Start leads to the Running state. You add routines to these states. Waiting states don’t require routines. The phase waits for a command to move to the next state. For example, Idle and Hold.
Tags, Data Types and Other Data
- As you organize, add, or delete members of a User-Defined Data Type, the software adjusts the associated tag members and values accordingly so that remaining members retain their values.
- In the tag browser, click the >> button to display the tag filter. Use the tag filter to display unused tags or tags of a particular data type.
- The tag browser filters tags in some situations. If you don’t see a tag you expect, change the tag filter.
- In version 15, the Tag Editor added support for New Window.
- You can use arrays to do indirect addressing. RSLogix 5000 supports arrays of one, two, and three dimensions.
- You can create a recipe by creating a new data type and then creating a tag which uses that data type. Your new data type can contain descriptive field names.
- RSLinx uses memory in a Logix controller to read data values. Use the following equation to estimate the memory needed: (1.5Kbyte + (Number of individual tags * 45 bytes) + (Number of array or structure tags * 7))
- The Watch Pane, located below the language editor window, provides monitoring for all tags referenced in the active routine window.
- You can trend a tag by right-clicking the tag and choosing «Trend Tag «.
- You can find all occurrences of a tag by right-clicking the tag in logic and choosing «Find All «.
- Logix controllers are optimized for the DINT and REAL data types. Use these data types to avoid conversion overhead and optimize performance.
- You can optimize the communication performance of acquiring data from Logix controllers by consolidating multiple data values into a User-Defined Data Type (UDT) or array.
- Indexed references to array elements add additional scan time overhead to the application. Use single dimension arrays whenever possible.
- When building a User-Defined Type (UDT), locate all bits or BOOLs adjacent to each other to minimize the amount of controller memory required to store the data.
- RSLogix 5000 automatically creates controller tags when you create an input or output module. You can reference these tags directly in your logic.
- Use alias tags to assign names to specific input/output data and/or to provide a short alternative to lengthy structure member names.
- Avoid pointing one alias tag to another alias tag to ensure the application maintains the appropriate references after an upload.
- Avoid pointing multiple alias tags to the same base tag to ensure the application maintains the appropriate references after an upload.
- Controller tags apply to the entire controller and can be referenced by any program. Program tags apply only to individual programs. This means program tags can have the same names in more than one program, allowing programs to be copied and reused.
- You can reorder the columns in the tag editor by clicking on the title and dragging it to a new position.
- All tag names are downloaded and resident in the controller along with your logic.
- You can export (and import) tag definitions to a comma separated value (CSV) file and manipulate them using external tool, e.g. spreadsheet, text editor.
- For tables of bits (BOOL), use a DINT array to ensure full access via the file and diagnostic instructions COP, DDT, FBC, etc.
- In a safety controller, standard tags in a safety mapped relationship follow safety restricted states. For example, a standard tag mapped to a safety tag is read-only in a safety locked state.
- The order of members within a User-Defined Type affect the memory size of the data type. Within the UDT, keep members of the same data type together.
Routines
- Logix supports four controller programming languages: Ladder, Function Block Diagram, Structured Text, and Sequential Function Chart.
- To simultaneously display logic in multiple routines, select Window -> New Window and then arrange the windows manually. Or select Window -> Tile Horizontal.
- Multiply the number of words in a PLC/SLC program times 18 to estimate the amount memory (in bytes) needed in a Logix controller.
- To display context-specific instruction help, select an instruction or element and press F1.
- The Language Element browser is a shortcut to adding logic. In the any of the language editors: use Alt+Insert, type the instruction mnemonic, and press Enter. You can also invoke this browser by pressing the Insert key in the LD, SFC and FBD editors. This short cut can be much quicker than using the instruction toolbar.
- You can find all occurrences of a tag by right-clicking the tag in logic and choosing «Find All «.
- You can use the Go To dialog (Ctrl+G) to quickly navigate to routines called by the current routine and to routines that call the current routine.
- You can drag and drop from the instruction toolbar in any of the language editors. In SFC editor, the elements auto-connect.
- Use the CPS instruction to provide buffering of communications and I/O data to minimize impact of asynchronous data arrival.
- For tables of bits (BOOL), use a DINT array to ensure full access via the file and diagnostic instructions COP, DDT, FBC, etc.
- Controller tags apply to the entire controller and can be referenced by any program. Program tags apply only to individual programs. This means program tags can have the same names in more than one program, allowing programs to be copied and reused.
- In the Sequential Function Chart Editor, you can use the Routine Overview (Ctrl+B) tool to view your entire SFC and help navigate to a specific area of your chart.
- Logix controllers perform a prescan of logic on startup to perform initialization. A tag used as an index can cause a startup fault if its value is larger than the array length. Use a Fault routine to detect and reset this condition.
- In the Sequential Function Chart Editor, you can use the indicator tag field in an action to specify a tag value to monitor during execution.
- In the Sequential Function Chart Editor, you can select multiple SFC elements and use the Layout SFC Elements feature to automatically rearrange the selected elements as needed to provide adequate spacing, avoid page boundaries, and left or center justify branches.
- In the Sequential Function Chart Editor, you can change the order in which selection branch legs are evaluated from the Set Sequence Priorities dialog.
- Refer to the Online Help for the Action Properties dialog — General Tab Overview for a useful timing diagram that explains how the various action qualifiers affect the execution of an action.
- You can customize the auto-naming of Sequential Function Chart Steps, Actions, Transitions, and Stop elements from the Workstation Options and Routine Properties dialogs.
- You can attach text boxes to language elements in FBD and SFC logic to maintain their relative positions if you move logic.
- You can use Ctrl+Space to invoke the Tag browser from within the ST editor.
- Comments in Structured Text are downloaded to the controller. This includes comments in Structured Text routines and embedded Structured Text in SFC routines.
- In the Structured Text Editor, you see the words colored to indicate keywords, tag names, and other recognized words. You can change the colors used by the editor by choosing Options from the Options menu.
- In the Structured Text Editor, you can configure the instruction’s parameters by right-clicking an instruction name and choosing «Instruction Properties».
- You can use instructions available in Ladder and Function Block Diagram routines also in Structured Text routines.
- You can configure the sheet size for your Function Block Diagram or Sequential Function Chart routines from the Routine Properties dialog.
- In the Function Block Editor, you can configure the block’s parameters by clicking the Browse (…) button on the upper right side of the block.
- RSLogix 5000 supports pending edits on multiple rungs when online editing ladder logic.
- When editing ladder routines, you can create logic using ASCII (for example: «XIC MYTAG») by either typing when a rung is selected, pressing the Enter key when a rung is selected, or double clicking to the left of a rung.
- In the Ladder Diagram Editor, you can insert a branch level above the current level by right clicking the left side of the branch and select Add branch. To insert a branch level below the current level, right click the right side of the branch and select Append New Level.
- Partial import of rungs works in all ladder routines, including Add-On Instructions.
- When performing a partial import of rungs, change tag names to create new tags in the imported logic.
- Once you do a partial import of rungs, add-on instructions, or user-defined data types, you can’t undo the import. If the import didn’t work as expected, close the project without saving.
- On a partial import of rungs, the exported data values are also imported. This includes configured message instructions. Partial imports/exports can save time versus copying and pasting since copying and pasting does not copy data values.
- Copy pieces of logic into other applications like Microsoft Word in a bitmap or metafile format.
- If you want a subroutine to execute every scan, copy the first instruction and paste it right next to the original instruction. Use the same tags on the duplicate instruction as on the first instruction. Then insert an AFI instruction before the duplicate.
- To copy a group of rungs to paste into another routine later, select the rungs and drag them to the desktop. This copies the rungs into a file that you can later drag into another routine.
- You can drag components from the Controller Organizer into the Ladder Editor instruction.
- Double click or press Enter at the end of a ladder rung to create and start a textual edit of that rung.
- To drag a language element from one routine to another, drag the element over the routine tabs at the bottom of the editor to switch the routine.
Add-On Instructions
- To display the logic of an Add-On Instruction, select the instruction and use the context menu (right click) to open the logic.
- You can drag an Add-On Instruction from the Controller Organizer into any language editor.
- Copy an Add-On Instruction Definition from one project and paste into another to move that AOI and referenced AOIs in to the project.
- Use Add-On Instructions to initialize tag values to specific values at the beginning of each routine or program scan. Then source protect the AOI to assure that values are correctly initialized and not overwritten manually.
- Use source protection on an Add-On Instruction to protect local tags, data and logic.
Communications
- Reserve 20% or more of the controller’s memory to accommodate communications and changes in future Logix controller firmware releases.
- Use rack optimized communication formats for digital I/O modules to minimize amount of controller memory and communications overhead associated with these modules.
- Use the CPS instruction to provide buffering of communications and I/O data to minimize impact of asynchronous data arrival.
- On download, if the ControlNet schedule stored in the offline RSLogix 5000 project file is old, RSLogix 5000 will retrieve the latest ControlNet schedule from the associated RSNetWorx project file. To make an association to an RSNetWorx project file, use the RSNetWorx tab in the Module Properties dialog of the ControlNet scanner.
- When working with multiple controller projects in different chassis, use RSLinx shortcuts to identify those chassis with meaningful names.
Drives and Motion
- RSLogix 5000 integrated motion supports camming, gearing, single-axis, and multi-axis instructions in Ladder Diagram, Structured Text, and Structured Text embedded in Sequential Function Charts.
- Execute motion direct commands directly from the context menu for any configured motion axis. The motion direct commands let you control motion instruction execution without creating or adding logic. This can be useful when first commissioning an axis or drive.
- To tune motor and drive parameters, such as gains for velocity and acceleration loops, as well as load dynamics, use the Tune tab or the MRAT and MAAT instructions. You can use the Tune tab in either Remote Program or Remote Run.
- The software automatically populates some SERCOS drive parameters when you configure an Axis_Servo_Drive. Display the axis properties to view or edit these parameters.
- In a SERCOS drive’s configuration, you can change the number of counts returned per revolution to make the counts per inch or degree an rational number.
- In a motion system, you can copy over all motion hardware from an existing project to a new project without losing any axis settings or tuning. First drag the motion control module over to the new project. Then, drag any drives, the Motion Group, and then the axes.
Optimizing Performance
- Logix controllers are optimized for the DINT and REAL data types. Use these data types to avoid conversion overhead and optimize performance.
- You can optimize the communication performance of acquiring data from Logix controllers by consolidating multiple data values into a User-Defined Type (UDT) or array.
- Indexed references to array elements add additional scan time overhead to the application. Use single dimension arrays whenever possible.
- Reserve 20% or more of the controller’s memory to accommodate communications and changes in future Logix controller firmware releases.
- Use rack optimized communication formats for digital I/O modules to minimize amount of controller memory and communications overhead associated with these modules.
- Use the CPS instruction to provide buffering of communications and I/O data to minimize impact of asynchronous data arrival.
- If the memory estimation button is disabled, it means that your estimation is up to date. This happens after an estimate, but it also happens when you go offline with the controller because the offline memory numbers reflect actual use.
- The order of members within a User-Defined Type (UDT) affect the memory size of the data type. Within the UDT, keep members of the same data type together.
Project Documentation
- Comments in Structured Text are downloaded to the controller. This includes comments in Structured Text routines and embedded Structured Text in SFC routines.
- You can print RSLogix 5000 views by clicking on the view and then pressing Ctrl+P or choosing Print from the File menu.
- When you print FBD logic, the editor automatically makes the logic fit the page. A 2:1 ratio is generally readable. For example, set the FBD sheet size to 11 x 17 (B Size) and print on 81/2 x 11 size paper.
- Copy pieces of logic into other applications like Microsoft Word in a bitmap or metafile format.
Security
- If you are have trouble downloading a project even though you have privileges, make sure that you have the project and that you are online with the controller.
- If you can’t access routine source protection when security is enabled, ask your administrator to grant you «Routine: Modify Properties» to obtain access.
- If your system uses FactoryTalk Security with RSLogix5000 software, version 16, software users can log into and log off of RSLogix 5000 software.
- If security functions are enabled, you must have appropriate access to import rungs or to copy/paste tags and data.
User Defined Data Types (UDTs) and OOP
by John Schop
For years now, Object Oriented Programming paradigm (or OOP) has been a commonly used programming practice, and has of course found its way into industrial automation as well.
In the mean time, most PLC manufacturers have found ways to make the programmers life easier by introducing User Defined Types or UDTs. The name says it all; it is a ‘type’ that you, the programmer, can define all by yourself. This means that your programming environment will not only have the regular integers (INT) and Booleans (BOOL), but could also have a ‘VALVE’ type or a ‘MOTOR’ type.
I can’t speak for other brands of PLC’s, but the Allen Bradley ControlLogix series of PLC’s, together with RSLogix 5000 programming software, makes it very easy to work with these UDTs, and since the introduction of RSLogix version 17 earlier this year, it is now even possible to edit your UDTs while online with a running system.
The Controller Organizer has a folder called Data Types > User-Defined with all the UDTs in the project.
I am of the opinion that every PLC program should rely heavily on UDTs to improve readability, and if you are an OOP adept, it can be a great help to organize your classes.
Let’s go over the fundamentals of OOP for a little bit:
- Classes: Classes define the abstract characteristics and behavior of an object. For example, a simple ‘VALVE’ class would have the characteristics (or attributes) that it can be open or closed (the things it can be), and as far as behavior goes, it could have the methods ‘to open’ and ‘to close’ (the things it can do)
- Objects: An object is an instance (occurrence) of a class. In our example, there could be a Valve_001 and a Valve_002, which are both instances of the class ‘VALVE’, with the same attributes and methods.
Of course the definition of OOP goes a lot further than this. There is a very understandable explanation here: http://en.wikipedia.org/wiki/Object-oriented_programming#Fundamental_concepts for those who would like to read more. For now, let’s leave it at this, and see how we can apply this to an industrial environment.
If you look at a valve as an object in a typical industrial automation environment, you should note the following:
- It has inputs and outputs that are specific for the object (proximity switches and solenoids).
- It can be either ‘open’ or ‘closed’
- You can tell it to go ‘open’ or ‘close’.
- It could have an alarm timer, that would tell us if the valve did not open or close in a given time period after a command.
- It might have interlocks, which allow the valve to open or close under certain conditions.
A UDT for this class, would fit all these properties and methods in one simple type. But, as always, we can expect further complications of the class ‘VALVE’ during the realization of a project. To be as flexible as possible, I highly recommend the practice of nesting UDT’s, which will become clear along the way.
Let’s start with defining our class, and keep in mind that it will have to be easily accessible for maintenance people or other programmers.
If we start at the I/O end, the best method is to create sub-classes called VALVE_IN and VALVE_OUT, which will contain our I/O.
The following example uses RSLogix5000 V16. First, create the sub-classes. From the File menu select New Component > Tag. The following dialog box appears to create and edit the members of the UDT.
Now, make a UDT called VALVE, and ‘nest’ these sub-UDTs in it:
As you see, I am allowed to take the types I just created as the data type in this UDT. The real advantage of this feature will become clear if you create a object called Valve001 of the type VALVE, and look at the object in the ‘monitor tags’ window:
Wow! Just by creating a new tag of the type VALVE, it gets all these I/O points right away, and referenced in the program:
Of course, going further with this concept, everything for a valve can be included in one object. Allow me to skip some steps, and show you a possible final result:
The ‘VALVE’ class is now contained in a UDT called VALVE, which looks like this:
As you see, the class VALVE now consists of the sub-classes VALVE_IN, VALVE_OUT, VALVE_TIMER, VALVE_STATUS, etc.
And an instance of this class, the object Valve001, would look like this:
While adding stuff to my class, I did not have to re-create the object Valve001. RSLogix updated it for me, so all the properties and methods are available in my program.
Now, let’s say you’re working on this project with a couple hundred valves, and the customer decides to go with a different type of valve, that also has an analog input, that tells us the exact position of the valve. All we have to do is modify our VALVE_IN sub-class to add this to every instance of the type VALVE:
Of course, you would still have to write code to tell your program what to do with that information, but that is also the reason why PLC programmers still have a job.
For somebody that is not familiar with your program, it might be confusing to look at all your UDT’s. We just made eight UDT’s for one simple valve class! But remember, you only have to do this during the design phase. Once you have a solid design for all your classes (and made sure their names are self-explanatory), you will never have to look at your UDT folder again, and creating a new instance will be a breeze.
Connecting Excel to ControlLogix
by John Schop
Have you ever lost data in a CLX processor, because you downloaded new code? Unfortunately, when you donwload a program to a ControlLogix processor, you also download the values of the tags (variables).
A solution to this problem that could be useful, is an Excel sheet that reads and writes values to the ControlLogix processor using the DDE/OPC capabilities of RSLinx.
In this article, I will show you how to create one of these sheets for your projects.
Here’s what you’ll need:
- Microsoft Excel, with some basic knowledge about programming macro’s in Visual Basic
- RSLinx (not the ‘Lite’ version, because that does not have DDE/OPC capabilities)
- A ControlLogix processor of course
Let’s fire up RSLogix first, and create a bunch of tags with values. In this example, I created 2 arrays, of the types DINT and REAL, each with a length of [10] tags. These arrays I filled with some values:
I’m not going to do anything with the PLC program, I just need some data in a number of tags.
Next, we’re going to set up a DDE/OPC Topic in RSLinx. Depending on the version of RSLinx you use, it might look slightly different, but you should be able to follw this with the screenshots.
Assuming that you know how to setup RSLinx initally to get online with your controller, I’ve skipped some steps. The setup I use looks like this in RSLinx:
As you can see, I have a 10 slot CLX rack, with a 1756-ENBT card in slot 1 (address 134.200.211.16), and two processors, one in slot 0, and one in slot 2. The one in slot 2 is the processor we are going to use for this exercise.
Now, open up the DDE/OPC topic configuration by clicking ‘DDE/OPC’ and then ‘Topic Configuration’ in the top menu of RSLinx.
I’m going to create a new DDE/OPC topic called ‘EXCEL_TEST’, and use the Logix5550 processor in slot 2 as the data source. In order to do this, you have to click the ‘New’ button, give the topic the desired name, and make sure the processor in slot 2 is selected as the source before you click ‘Done’
To test if your setup is working, at this point you can use the OPC test client provided with RSLinx. I’m not going into detail about that, but I did make sure this worked before continuing with the next step, creating the Excel sheet.
Let’s start up good old Excel, and create a new workbook. On this workbook, place a new command button. You can find the Command Button control in the ‘Control Toolbox’ toolbar in Excel. When you have the button, right click on it and choose ‘View Code’. This will take you to the Visual Basic Editor:
First, create a function that will open the DDE topic to Excel:
Now, if I call this function from the CommandButton1_Click event, it will open the link to RSLinx:
The variable ‘rslinx’ will hold the number of the open channel. All subsequent DDE functions use this number to specify the channel.
To save you all the steps to program the rest of the code, here is the final code to get the array of REALs out of the controller, and put them in cells D2 – D11, and the array of DINTs in cells E2-E11.
Now we know how to read, it would of course be a lot of fun if we could write values as well. I would like to be able to change the values in the cells, and then hit a ‘Write Data’ button.
First, make another button on the sheet (mine looks like below now)
And then write some code for the button:
The way this is implemented is of course very rudimentary, but once you get the concept, the sky is the limit.
To make this easier on everybody, I’ve included the Excel file with the code already in it. The only thing you have to do to make this Excel sheet work, is make sure there is an DDE/OPC topic in your RSLinx setup called ‘EXCEL_TEST’, and the arrays REAL_Array and DINT_Array in your controller (of at least length 10).
Предложите, как улучшить StudyLib
(Для жалоб на нарушения авторских прав, используйте
другую форму
)
Ваш е-мэйл
Заполните, если хотите получить ответ
Оцените наш проект
1
2
3
4
5
Заказать оборудование Allen Bradley
Купить Allen Bradley studio 5000 руководство по программированию в компании Олниса можно оптом или в розницу. Доставим Allen Bradley studio 5000 руководство по программированию в любой регион России. Можем предложить точный аналог. Работаем напрямую с производителем, не используя посредников.
Компания Allen Bradley известна собственным программным обеспечением для своей же продукции. Производитель максимально упростил и унифицировал среды проектирования и программирования для операторов и программистов. Наиболее известным и популярным ПО сейчас считается Studio 5000 для контроллеров CompactLogix, ControlLogix и SoftLogix.
Данная среда разработки и проектирования объединяет в себе программное обеспечение для программирования контроллеров, постоянного управления, мониторинга и обеспечения безопасности. Studio 5000 предназначено для работы с коммуникационными модулями протокола Ethernet/IP.
Обзор протокола и первичная настройка рабочей станции
Сети под протоколом Ethernet/IP – это специфический промышленный способ обмена данными. Особенностью этого типа стал большой диапазон возможностей автоматизации, контроля перемещений, синхронизации множества объектов и контроля в реальном времени. Стандарт Ethernet/IP считается универсальным во всем мире и является открытым. Дополнительно протокол позволяет передавать данные безопасности, управления и диагностики одновременно, что значительно снижает временные затраты. Коммуникационные модули данной сети выполняют следующие функции:
- организация обмена сообщений, тегов и распределение ввода/вывода;
- инкапсуляция сообщений в стандартные протоколы;
- разделение данных с протоколами Control/DeviceNet;
- организация отображения интерфейса с помощью стандартных разъемов RJ45;
- работа с оптоволоконными соединениями;
- поддержка связи со скоростью 10/100 Мбит/с.
Такие модули не требуют таблиц маршрутизации и планирования сети. Настройка рабочей станции выглядит следующим образом:
- в программе RSLinx в меню коммуникаций выбрать пункт настройка драйверов;
- в диалоговом окне выбрать драйвер относящийся к протоколам Ethernet/IP (Ethernet);
- в предложенном окне требуется ввести имя нового драйвера и подтвердить действие;
- через кнопку поиска локальной подсети найти требуемую и снова подтвердить;
- после этого драйвер установлен и готов к работе.
В дальнейшем оператор настраивает базовые пункты вроде IP-адресов, супервизоров, адресации DNS, модулей вводов/выводов и т.д. Отдельно стоит упомянуть подключение панелей операторов через Studio 5000, так как данный процесс имеет свою специфику, которая указана в документации «Allen Bradley Studio 5000 руководство по программированию». Добавление панелей оператора PanelView:
- через органайзер контроллера вывести подменю на пункте I/O Configuration найти пункт «новый модуль»;
- во вкладке «По категории» найти требуемый коммуникационный модуль и подтвердить выбор;
- в появившемся окне требуется указать параметры нового модуля (в зависимости от типа модуля количество пунктов может меняться: имя, IP, слот шасси, версию, электронное кодирование, формат обмена данными);
- снова в органайзере контроллера на свежем ком.модуле выбрать пункт «новый модуль»;
- во вкладке «по категориям» отметить маркер «PanelView»;
- в настройках модуля вписать данные панели оператора (допускается до 8 настроек для одной панели или контроллера).
Программное обеспечение от AllanBradley предельно просто в настройке и изучении. При этом руководства для каждой программы максимально простым языком описывают все стадии работы с аппаратурой и возможные ошибки при программировании.
Заказ и доставка
ПО для продукции Allen Bradley и управления сетями на их базе можно приобрести в каталоге компании «Олниса». Поставщик предоставляет полную гарантию на все поставляемые товары. Компания осуществляет доставку в страны СНГ и по всей территории Российской Федерации.