Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

ABB PLC-2 System 1772

Download as pdf or txt
Download as pdf or txt
You are on page 1of 170

Mini-PLC-2 Programmable Controller

(Cat. No. 1772-LN1, -LN2, -LN3)

Programming and Operations Manual


Table of Contents

Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Ladder Diagram Logic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
Memory Structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
Memory Organization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Hardware/Program Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Compatibility . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
Support Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113

Hardware Considerations . . . . . . . . . . . . . . . . . . . . . . . . . 21


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Mode Select Switch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Processor Diagnostic Indicators . . . . . . . . . . . . . . . . . . . . . . . . . 22
Power Supply Diagnostic Indicators . . . . . . . . . . . . . . . . . . . . . . . 24
Switch Group Assembly . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
Industrial Terminal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26

RelayType Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . 31


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
Examine Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
Output Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
Branch Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Programming RelayType Instructions . . . . . . . . . . . . . . . . . . . . . 37

Timer and Counter Instructions . . . . . . . . . . . . . . . . . . . . . 41


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
Timer Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
Counter Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
Cascading Timers or Counters . . . . . . . . . . . . . . . . . . . . . . . . . . 414
Programming Timer and Counter Instructions . . . . . . . . . . . . . . . . 415

Data Manipulation Instructions . . . . . . . . . . . . . . . . . . . . . 51


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
Data Transfer Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
Data Comparison Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
Programming Data Manipulation Instructions . . . . . . . . . . . . . . . . 58
ii Table of Contents

Arithmetic Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . 61


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
Add Instruction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
Subtract Instruction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
Multiply Instruction (1772LN3 Processor Module) . . . . . . . . . . . . . 63
Divide Instruction (1772LN3 Processor Module) . . . . . . . . . . . . . 63
Programming Arithmetic Instructions . . . . . . . . . . . . . . . . . . . . . . 64

Output Override and I/O Update Instructions . . . . . . . . . . . 71


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
Output Override Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
I/O Update Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
Programming Output Override and I/O Update Instructions . . . . . . 77

Writing the User Program . . . . . . . . . . . . . . . . . . . . . . . . . 81


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
Developing the Program . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
Sample Program . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
Developing the Data Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
Sizing the Data Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 812
Program Recommendations . . . . . . . . . . . . . . . . . . . . . . . . . . . . 813
Current Record . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 813

Operating Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91
Data Table Adjustment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91
Addressing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
Editing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
Directories (1770T3 Industrial Terminal) . . . . . . . . . . . . . . . . . . . 96
Search Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
Troubleshooting Aids . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
Clearing Memory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 917

Peripheral Functions Including Report Generation . . . . . . 101


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
Baud Rate Setting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
Contact Histogram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103
Report Generation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104
Digital Cassette Recorder . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1017
Data Cartridge Recorder . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1019
Ladder Diagram Dump . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1021
Total Memory Dump . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1021
Table of Contents iii

Special Programming Techniques . . . . . . . . . . . . . . . . . . . 111


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
Scan Counter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
Block Transfer (1772LN3 Processor Module) . . . . . . . . . . . . . . . 112
OneShot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1115
Programming 0.01 Second Timers . . . . . . . . . . . . . . . . . . . . . . . . 1118

Scan Time and Execution Times . . . . . . . . . . . . . . . . . . . . 121


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121
Scan Time . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121
Watchdog Timer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123
Instruction Execution Times . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123
Block Transfer Programming . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124

Numbering Systems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131


General . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131
Decimal Numbering System . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131
Octal Numbering System . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132
Binary Numbering System . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133
1
Chapter

Introduction

Overview The Bulletin 1772 Mini-PLC-3 Programmable Controller is a rugged, solid state
programmable controller that consists of the Mini-PLC-2 Processor (Cat. No.
1772-LN1, -LN2 or -LN3) and the 1771 I/O Family or racks and modules.
Refer to Figure 1.1.

Figure 1.1
MiniPLC2 Programmable Controller

B<ttery

10779I

With a user-written program and appropriate I/O modules, the Mini-PLC-2


Controller can be used to control many types of industrial applications such as:
Process control
Material handling
Palletizing
Measurement and gaging
Pollution control and monitoring
The Mini-PLC-2 Processor has a Read/Write CMOS memory that stores User
Program instructions, numeric values and I/O device status.

11
Chapter 1
Introduction

The User Program is a set of instructions in a particular order that describes the
operations to be performed and the operating conditions. it is entered into
memory, instruction by instruction, in a ladder diagram format display from the
keyboard of the Industrial Terminal (Cat. No. 1770-T1, -T2 or -T3). some
ladder diagram symbols closely resemble the relay symbols used in hardwired
relay control systems.

During the program operation, the Mini-PLC-2 Processor continuously


monitors the status of input devices and, based on User Program instructions,
either energizes or de-energizes output devices. Because the memory is
programmable, the User Program can be readily changed if required by the
application.

In addition to ON/OFF control, the Mini-PLC-2 Controller can perform


additional functions such as:
Timing/Counting operations
Arithmetic (+,-) operations
Arithmetic (x, ) operations (1772-LN3 Processor)
Data comparisons
Block Transfer (1772-LN3 Processor Module)
I/O Forcing
Data Highway and RS-232-C interfacing
When the Industrial Terminal (Cat. No. 1770-T1, -T2 or -T3) and the
Mini-PLC-2 Programmable Controller are used together or with additional
peripheral devices, application data can be recorded or displayed using a variety
of peripheral functions:
Report generation
Contact histogram (the ON/OFF history of a bit in memory)
Hard-copy printout of the User Program or the complete memory
Recording/loading/verifying the User Program using magnetic tape

12
Chapter 1
Introduction

Ladder Diagram Logic PC ladder diagram logic closely resembles hardwired relay logic. Hardwired
relay control systems require electrical continuity to turn output devices ON and
OFF. For example, the relay diagram in Figure 1.2 shows that limit switch LS1
and relay contact CR2 must be closed to energize relay coil CR4.

Figure 1.2
Ladder Diagram Rung

CR2
LS1
CR4

10628I

Similarly, in each rung of ladder diagram program, logic continuity is needed to


energize or de-energize the output instruction, and ultimately the output device.
For example, the ladder diagram rung in Figure 1.3 shows the input devices and
the output device with their respective Data Table bit addresses. The bit
addresses correspond to the location of the I/O devices wired to the I/O
modules. When the two input instructions are logically TRUE, or the bits in
memory are ON, logic continuity is established. This causes the output
instruction to be TRUE and the output device to be turned ON.

Figure 1.3
Ladder Diagram Rung

LS1 CR2 CR4


113 113 012

02 03 16
10628aI

13
Chapter 1
Introduction

Memory Structure The Data Table of the Mini-PLC-2 Processor memory is made up of an
arrangement of storage points called bits (Binary Digits). A bit is the smallest
unit of memory and can store information as a “1” or a “0” (Figure 1.4). When
a “1” occupies a bit, that bit is ON; when a “0” occupies a bit, that bit if OFF.

Figure 1.4
Memory Word Structure

Upper Byte Lower Byte

17 16 15 14 13 12 11 10 07 06 05 04 03 02 01 00
MSB LSB
1 0 1 0 1 0 0 1 0 1 0 0 1 1 1 0 Word Address 0308
0 1 1 1 1 0 1 0 0 0 1 1 0 1 0 1 Word Address 0318

17 16 15 14 13 12 11 10 07 06 05 04 03 02 01 00

1 0 0 0 1 0 1 0 0 1 1 0 1 0 0 0 Word Address 1708

0 1 1 1 0 0 0 0 1 1 0 0 0 1 0 0 Word Address 1718


10629I

A group of 8 bits forms a single byte. Two bytes, or 16 bits, make up one word.
All Data Table words are identified by their word address which is a 3- digit
octal number. The octal numbering system is explained in Chapter
13-Numbering Systems.

Similarly, each bit in a word is identified by a two-digit number using the octal
numbering system. The memory bits are numbered 00 through 07 and 10
through 17, with the most significant bit 17 (MSB) at the left and the least
significant bit 00 (LSB) at the right.

A specific bit in Data Table can be identified by combining the 3-digit word
address and 2-digit bit number to form the bit address, such as 03012 or 030/12.
The difference depends on the Industrial Terminal used. The 1770-T1 and -T2
display the 5-digit bit address centered above the instruction symbol. the
1770-T3 displays the bit address by placing the 3-digit word address above and
the 2-digit bit number below the instruction symbol. Programming examples
will be illustrated using the 1770-T3 display. however, both displays will be
illustrated in the Instruction Summary Table at the end of each programming
section in this manual.

14
Chapter 1
Introduction

Memory Organization The Mini-PLC-2 Processors have either a 512 word memory size (Cat. No.
1770- LN1) or a 1024 word memory size (Cat. No. 1772-LN2 or -LN3). These
memory words are organized by their word addresses and are divided into the
following major areas. The size of each area can be varied within limits to suit
user needs, but the total cannot exceed the Processor memory size.
Data Table
User Program
Message Storage (if used)
The Data Table stores the information needed in the execution of the User
Program such as the status of input and output devices, timer/counter Preset and
Accumulated values, bit/word storage, etc. Any instruction in the User Program
can address any word or bit in the Data Table except in the Processor Work
Areas.

The Data Table is factory configured to 128 words. The words reserved for
timers and counters can be decreased to any even-number value down to 48
words so that storage capacity for User Program and/or messages can be
increased. Figure 1.5 shows the organization of a factory configured Data Table.

The User Program follows the Data Table in memory. The User Program is the
logic that controls the machine operation. The logic that controls the machine
operation. The logic consists of instructions that are programmed in ladder
diagram format. Each instruction requires 1 word of memory.

Message Storage area begins after the END statement of the User Program.
This area stores the alphanumeric characters of the messages. Two characters
can be stored in one word.

For a detailed description of memory, refer to Publication 1772-700, the


Organization and Structure of the Mini-PLC-2 Memory.

15
Chapter 1
Introduction

Figure 1.5
Data Table Organized, Factory Configured

Word Bit
Decimal Address Address
Total Words
Decimal Per
Words Area
17 16 15 14 13 12 11 10 07 06 05 04 03 02 01 00 000 00
Procesasor Word Area
8 8 N0. 1 007 17
0 0 0 0 1 1 1 0 1 0 0 1 1 0 0 0 010 00

16 Data Bit Word


Output
Image Table
16 8 017 17
020 00
Bit/Word Storage 1

026 17
24 8 Not Available for Word Storage 2 027
030 00
Timer/Counter
Accumulated Values (AC)
(or Bit/Word Storage) 3
64 40 077 17
100 00 Data
Table
Processor Work Area
N0. 2
1 May not be used for Accumulated
72 8 107 17 Values.
2 Not available for bit/word storage.
110 00 Bits in this word are used by the
processor for batterylow condition,
message generation, and data
Input highway.
Image Table 3 Unused timer/counter memory
words can reduce data size and
increase user program area.
80 8 117 17 4 May not be used for Preset Values.
120 00

Bit/Word Storage 4

88 8 127 17
130 00
Timer/Counter
Preset Values (PR)
(or Bit/Word Storage) 3
128 40 177 17
200 00
User Program
512 384
End of Memory

Optional Second Memory Area


(512 words)
1024 512 10630I

16
Chapter 1
Introduction

Hardware/Program Interface The Processor monitors input conditions and controls output devices according
to a user-entered program. The interface between hardware and program occurs
in the Input/Output Image Table.

Image Table
The primary purpose of the Input Image Table is to duplicate the status (ON or
OFF) of the input devices wired to input module terminals. if an input device is
ON (closed), its corresponding Input Image Table bit is ON (“1”). If an input is
OFF (open), its corresponding Input Image Table bit if OFF (“0”). Input Image
Table bits are MONITORED by User Program instructions.
The primary purpose of the Output Image Table is to control the status (ON or
OFF) of the output devices wired to output module terminals. If an Output
Image Table bit is ON (“1”), it corresponding output device is ON (energized).
If a bit is OFF (“0”), its corresponding output device is OFF (de-energized).
Output Image Table bits are CONTROLLED by User Program instructions.
Instruction Address
Instruction addresses in the Input/Output Image Table have a dual role. The 5-
digit bit address references both an I/O Image Table address and a hardware
location. An I/O Image Table word corresponds to two I/O modules located in
a Module Group in the I/O Rack. Both are represented by the upper 3 digits of
the 5-digit bit address. The lower byte of the I/O Image Table word
corresponds to an I/O module in the left slot of the Module Group. The upper
byte corresponds to an I/O module in the right slot of the Module Group. See
Figure 1.6. The remaining two digits represent the bit number in the I/O Image
Table word and the terminal number in the Module Group. Each 5-digit bit
address in the I/O Image Table directly relates to an I/O module terminal as
shown in Figure 1.7.

17
Chapter 1
Introduction

Figure 1.6
Instruction Address Terminology

Concept Example

Hardware Terminology Hardware Terminology


Input (1) or Output (0) Output: 0

Rack No. (Always 1) Rack No.: 1

Module Group No. Module Group No.: 0


(0-7)

Terminal No. Terminal No.: 12


(00-07, 10-17)

XXX/XX 0 1 0/12
Word Bit Word Bit
Address Address Address Address
Data Table Terminology Data Table Terminology
10631-I

18
Chapter 1
Introduction

Figure 1.7
Bit Address to Hardware Relationship

Bit

Word
17 16 15 14 13 12 11 10 07 06 05 04 03 02 01 00 Address
010/12 010

Upper Byte Lower Byte


Output = 0
Input = 1 Terminal
Module Group
Rack Number Module Groups

0 1 2 3 4 5 6 7

A A
00 0 0 10
01 1 1 11
02 2 2 12
03 3 3 13
04 4 4 14
05 5 5 15
06 6 6 16
07 7 7 17
8 8

32 I/O
Left Right
Slot Slot
0 1
64 I/O

10632I
128 I/O

19
Chapter 1
Introduction

Fundamental Operation

The hardware-program interface is illustrated in Figure 1.8 by showing the


operational relationship between the input and output devices, the Input/Output
Image Table and the User Program.

Figure 1.8
HardwareProgram Interface

3digit word addresses

2digit bit 17 16 15 14 13 12 11 10 07 06 05 04 03 02 01 00 0108


and terminal Plant Power
address Output Image Table
Output
module in
I/O rack
Plant Power 1 = ON No. 1
0 = OFF module Output
group no. 3 Terminal
1 0 1 1 0 1 1 0 0 1 0 1 1 0 0 0 0138 013/06
Closed Bit 013/06
Input

Input
module in 0178 Energized
Input I/O rack Output
Terminal No. 1 1108
112/12 module
group no. 3 Input Image Table Plant Power
Return

Bit 112/12
0 1 1 0 0 1 0 0 1 1 0 0 0 1 0 1 1128
Plant Power 1 = ON
Return 0 = OFF

1778

UserProgrammed Rung
Instruction 112 013 Instruction
intensified intensified
when true when enabled
12 06 10633I

110
Chapter 1
Introduction

When an input device connected to terminal 112/12 is closed, the input module
circuitry senses a voltage. The ON condition is reflected in the Input Image
Table bit 112/12. During the Program scan, the Processor examines bit 112/12
for an ON (1) condition. If the bit is ON (1), the EXAMINE ON instruction is
logically TRUE. A TRUE condition is displayed as an intensified instruction.
A path of logic continuity is established and causes the rung to be TRUE. The
Processor then sets Output Image Table bit 013/06 to ON (1). The Processor
turns ON terminal 013/06 during the next I/O scan and the output device wired
to this terminal becomes energized. When the rung condition is TRUE, the
output instruction is intensified.

When the input device wired to terminal 112/12 opens, the input module senses
no voltage. The OFF condition is reflected in the Input Image Table bit 112/12.
During the program scan, the Processor examines bit 112/12 for an ON 91)
condition. Since the bit is OFF (0), logic continuity is not established and the
rung is FALSE. The Processor then sets Output Image Table bit 013/06 to OFF
(0). In the next I/O scan, the Processor turns OFF terminal 013/06 and the
output device wired to this terminal is turned OFF.

Compatibility The Mini-PLC-2 Processors are compatible with the Industrial Terminal, the
Data Highway and RS-232-C interfacing. The 1771-LN3 Processor is
compatible with Bulletin 1771 Block transfer I/O modules.

Industrial Terminal Compatibility

The Mini-PLC2 Controller can be programmed using the Industrial Terminal


(Cat. No. 1770-T1, T2, or T3). it can also be programmed with the PLC-2
Program Panel (Cat. No. 1772-T1) or with the combination of the PLC Program
panel with PLC-2 Program Panel Adapter (Cat. No. 1774-TA and 1772-T4).

This manual will illustrate programming examples using the Industrial


Terminal. The first edition of this manual, dated January 1980, illustrates
programming examples using the (obsolete) PLC-2 Program Panel.

Data Highway Compatibility

The Mini-PLC-2 Controller can be connected to the Allen-Bradley Data


Highway using the Communication Adapter Module (Cat. No. 1771-KA). Data
Highway messages and the Data Highway Communication zone of User
Program must reference only the addresses within the user-configured Data
Table.

111
Chapter 1
Introduction

Block Transfer Compatibility

The Mini-PLC-2 Processor module (Cat. No. 1772-LN3) can be programmed to


communicate with intelligent Bulletin 1771 I/O modules having Block Transfer
capability. These include the Thermocouple, Analog Input, Analog Output,
Encoder/Counter, PD, etc. modules. Section 11.2 of this manual cover Block
Transfer Programming.

User Program Compatibility

User Programs written for the Mini-PLC-2/15, PLC-2/20 or PLC-2/30 should


not be loaded into the Mini-PLC-2 Controller unless the User Program is
compatible in the following areas:

The Data Table is 128 words or less.

The words of memory used do not exceed 512 for the 1772-LN2 Processor;
or 1024 for the 1772-LN2 or -LN3 Processor.

The instruction set contains compatible instructions: block instructions and


sub-routine programming are absent; MULTIPLY or DIVIDE instructions
can only be entered in the 1771-LN3 Processor; divide by 0 is compatible as
stated in Section 6.4.

The Industrial Terminal will prevent the loading of memory from tape or data
cartridge if the Data Table size or the number of memory words exceed the
capacity of the Processor.

If a User Program has a compatible Data Table and memory capacity but
contains incompatible instructions, it could be loaded into a Mini-PLC-2
Controller. When using a 1772-LN3 Processor, the incompatible instructions
would be displayed on a 1770-T3 Industrial Terminal when the Processor was in
PROGRAM mode. Upon switching to TEST or RUN mode, the Processor
would fault before outputs could be energized. The message “PROCESSOR
FAULT” would appear at the top of a blank screen. Upon switching back to
PROGRAM mode, the Industrial Terminal would be initialized to the Mode
Selection display. Options then available include:

a. Remove the incompatible User Program using the Total Memory


Clear function [CLEAR MEMORY] [9][9]

b. Salvage the Use Program by replacing the incompatible instructions


with equivalent programming that the Mini-PLC-2 can handle.

If a User Program with an incompatible instruction set were to be loaded into a


1772-LN3 Processor having a 1770-T1 or -T2 Industrial Terminal, ERR
messages would appear randomly throughout the program when the Processor
was in PROGRAM mode. they would be located adjacent to any instruction
that the Processor was not capable of handling. Upon switching to TEST or
112
Chapter 1
Introduction

RUN mode, the Processor would fault before outputs could be energized. The
options available would be the same as those stated above. The 1770-T1
Industrial terminal would display the message “COMMUNICATION
FAULT-CHECK CABLES FIRST.” Two messages would be alternately
displayed by the 1770-T2 Industrial Terminal: “PROCESSOR FAULT” and
INVALID INSTRUCTION ENCOUNTERED.

Incompatible instructions would be ignored by a 1772-LN1 or -LN2 Processor.


The display would depend on the Industrial terminal. A 1770-T1 or -T2 would
display “ERR” messages in place of incompatible instructions. The 1770-T3
would display incompatible instructions although they could not executed.

Support Documentation The following support documents contain additional information regarding
Mini- PLC-3 Controller components.

Mini-PLC-2 Programmable Controller Assembly and Installation Manual


(Publication 1772-820): contains necessary information on installation,
assembly, maintenance and troubleshooting

PLC-2 Family Support Documentation Manual (Publication 1772-803-1):


contains useful information on memory organization, Data Table expansion,
system features, wiring, module keying and various features of Mini-PLC-2
Controller components and 1771 I/O.

113
2
Chapter

Hardware Considerations

General This section will only describe the hardware features of the Mini-PLC-2
Programmable Controller that are used when inputting or debugging the User
Program. For information on installation, start-up, troubleshooting, etc., refer to
Publication 1772-820, the Mini-PLC-2 Programmable Controller Assembly and
Installation Manual.

Mode Select Switch The Mini-PLC-2 Processor has a three-position keylock Mode Select Switch
(Figure 2.1) that places the Processor in one of three operating modes:
PROGRAM
TEST
RUN

Figure 2.1
Mode Select Keyswitch

TEST
RUN PROG.

10634-I

21
Chapter 2
Hardware Considerations

PROG Position

This switch position places the Processor in the PROGRAM mode. User
Program instructions are entered in this mode. They can be entered from the
Industrial Terminal, or entered from the Digital Cassette Recorder (Cat. No.
1770-SA) or the Data Cartridge Recorder (Cat. No. 1770-SB) when connected
to the Industrial Terminal. All outputs are de-energized in this switch position
and the machine controlled by the Mini-PLC-2 will not operate.

TEST Position

This switch position places the Processor in the TEST mode. The User Program
is tested under simulated operating conditions. Inputs are active and recognized
by the Processor, but user output devices are not energized. All outputs are
disabled in this switch position. Changes to the User Program are NOT
permitted, but Data Table values can be changed using the On-Line Data
Change function or the Bit Manipulation function.

RUN Position

This switch position places the Processor in the RUN mode. The User Program
will be executed and outputs are controlled by the program. Changes to the
User Program are not permitted, but Data Table values can be changed using the
On-Line Data Change function or the Bit Manipulation function.

This is the only switch position that allows removal of the Mode Select Switch
key.

Processor Diagnostic Indicators on the front panel of the Processor Module aid in analyzing controller
Indicators status. (Refer to Figure 2.2). During operation in any mode, the Processor
continuously monitors its own status through checks on timing and data parity.
In addition, the Processor receives a signal from the power supply if user AC
power goes low for longer than one-half cycle.

Figure 2.2
Diagnostic Indicators

PROCESSOR

MEMORY

RUN
DIAGNOSTICS

10635-I

22
Chapter 2
Hardware Considerations

PROCESSOR Indicator

This red indicator illuminates if the Processor is unable to scan the User
Program and Data Table. It is normally OFF. when ON, the Processor has
stopped communication with I/O modules. If this occurs, the Last State Switch
determines the status of energized controller outputs. (Refer to Switch Group
Assembly.)

Reset may be attempted for this type of fault by changing the Mode Select
Switch to the PROGRAM mode, then back to RUN. Reset may also be
accomplished by cycling line power to the system power supply or by reloading
the User Program.

MEMORY Indicator

This red indicator illuminates if the Processor detects loss of User Program, a
discrepancy in memory data, or a parity error. It is normally OFF.

The Processor stops communication with I/O modules if this type of fault is
detected. The Last State Switch determines the status of controller outputs if
this fault occurs. (Refer to Switch Group Assembly)

This error may be reset by turning the Mode Select Switch to the PROG
position then back to RUN, by cycling line power to the system power supply,
or by reloading the User Program.

RUN Indicator

This green indicator illuminates when the Processor is operating with the Mode
Select Switch in the RUN mode. when this indicator is ON, controller outputs
are enabled. This also implies that no Processor-related fault has been detected.

This indicator turns OFF in the RUN mode if the system power supply detects
that voltage on the user AC line has dropped below 98V or 196V for 120V or
220/240V operation, respectively. In this event, the Processor disables all
output devices and stops receiving input module data. This prevents the
Processor from storing input data which might be inaccurate due to a low
voltage level. The indicator also goes OFF when a fault occurs.

In the event of user AC power failure, the restart of the Processor is automatic
with recovery of the line to the normal voltage range.

23
Chapter 2
Hardware Considerations

Power Supply Diagnostic The system Power Supply (Figure 2.3) has two diagnostic indicators on the
Indicators front panel: The BATTERY LOW and DC ON INDICATORS.

Figure 2.3
System Power Supply (Without Battery Pack)

10636I

BATTERY LOW Indicator

When the batteries for memory backup are low, this red indicator flashes ON
and OFF. The Battery Low Bit, bit 027/00, will cycle ON and OFF when a
battery-low condition is detected and the Mode Select Switch is in the RUN or
TEST position. Programming Techniques can be used to examine this bit and to
control some type of alerting device when a battery-low condition exists. The
battery will continue to provide memory backup for about one week after the
indicator begins to flash.

DC ON Indicator

The DC ON is a red indicator that monitors the 5.1V DC line to the logic
circuitry in the Processor, Processor memory, and I/O modules. It is ON when
5.1V DC is present. If the line drops below 5.1V DC, the indicator turns OFF
and the controller shuts down.

24
Chapter 2
Hardware Considerations

Switch Group Assembly When the Processor detects an internal fault, communication with the I/O rack
is terminated. The last state of output terminals in this situation is user-
selectable by the settings on the Switch Group Assembly. it is located on the
left side of the I/O chassis backplane. (Refer to Figure 2.4). Switch #1 must be
set to determine output response to a Processor fault. Switch numbers 2-8 are
not used. There are two switch settings:

ON - Outputs remain in the last state, energized or de-energized, when a fault


is detected.

OFF - Outputs are de-energized when a fault is detected.

Figure 2.4
Switch Group Assembly

When ON: Outputs remain in last state

(energized or deenergized) if fault is


detected

When OFF: Outputs are deenergized


when fault is detected (switch is shown
in OFF position) 10637I

WARNING: Switch #1 should be set to OFF for most


applications. This allows the Processor to turn controlled
devices OFF when a fault is detected. If this switch is set ON,
machine operation can continue after fault detection and damage
to equipment and/or injury to personnel could result.

25
Chapter 2
Hardware Considerations

Industrial Terminal The Industrial terminal (Cat. No. 1770-T1,-T2 or-T3) can be used to program
the Mini-PLC-2.

HookUp

Perform the following steps to connect the Industrial Terminal to the Mini-PLC-
2 Processor: See Figure 2.5.

1. Plug the AC power cord on the Industrial Terminal into a grounded AC


outlet.

2. Connect one end of the PLC-2 Program Panel Interconnect Cable (Cat.
No. 1772-TC) to Channel A on the rear of the Industrial Terminal.

3. Connect the other end of the cable to the socket labeled INTERFACE on
the front of the Mini-PLC-2 Processor.

4. Insert the PLC-2 Keytop Overlay (Cat. No. 1770-KCA). Figure 2.6, on the
Keyboard Module (Cat. No. 1770-FDC).

5. Turn the power switch on the front of the Industrial Terminal to the ON
position. Mode Select display will appear.

Figure 2.5
MiniPLC2 Connection Diagram

MiniPLC2

Industrial
Terminal

Cat. No.
1772To
(10 Ft.)

Channel A
Interface
10638I

26
Chapter 2
Hardware Considerations

Figure 2.6
PLC2 Keytop Overlay (Cat. No. 1770KCA)

MODE
SELECT

RECORD RUNG SEARCH -( ÷ )- -[ G ]- -[ I ]- -(CTU)- -(TON)- -( L )- 7 8 9

DISPLAY INSERT REMOVE -( X )- -[ = ]- -[ L ]- -(CTD)- -(TOF)- -( U )- 4 5 6


CLEAR
MEMORY -( – )- -[ < ]- -[ B ]- -(CTR)- -(RTO)- -(MCR)- 1 2 3

CANCEL
COMMAND
-( + )- -(PUT)- -(IOT)- -(ZCL)- -(RTR)- -( )- FORCE
ON
0 FORCE
OFF

FOR USE WITH PLC-2 CAT. NO. 1770 KCA

 1982 ALLEN-BRADLEY
10639I

For additional information on the Industrial Terminal, refer to the Industrial


Terminal System User’s Manual, Publication No. 1770-805.

Mode Selection and Initialization of the Industrial Terminal

When the Industrial Terminal is turned ON or when communication between


the Industrial Terminal and Processor is interrupted for any reason, the Mode
Selection display will appear. See Figure 2.7 for the 1770-T1 or -T2 display
and Figure 2.8 for the 1770-T3 display. Any of the following occurrences can
cause an interruption in communication and initialization of the Industrial
Terminal
Pressing the [MODE SELECT] Key
Loss of power to the Processor or Industrial Terminal
Disconnecting the Program Panel Interface Cable
To initialize the Industrial Terminal, one of the operating modes shown in
Figure 2.7 or Figure 2.8 must be chosen. If the Industrial Terminal is connected
to a PLC-2 Family Processor, the Processor type (i.e. Mini-PLC-2,
Mini-PLC-2/15, PLC-2/20, PLC-2/30) will be intensified.

To enter Ladder Diagram (PLC-2) mode, press [1][1] on the PLC-2 Keytop
Overlay (Cat. No. 1770-KCA).

When the Industrial Terminal is to be used as an alphanumeric data terminal,


insert the Alphanumeric Keytop Overlay (Cat. No. 1770-KAA) and press [1][2].
Operation of the Industrial Terminal with the Alphanumeric Keytop Overlay is
described in section titled, Report Generation in chapter 10.
27
Chapter 2
Hardware Considerations

Figure 2.7 Figure 2.8


Mode Selection Display 1770T1 or T2 Industrial Terminal Mode Selection Display 1770T3 Industrial Terminal

Mode Selection Mode Selection


Keyboard Module 1770FAC Series A/D Keyboard Module 1770FDC Serires A/B

Insert Insert For use with the


Mode Keytop Overlay Following Processors:
Keytop Overlay
10 = PLC Mode 1770KBA 1 10 = Processor 1770KBA PLC 1
11 = PLC2 Mode 1770KCA 11 = Processor 1770KCA MiniPLC2, PLC2
MiniPLC2/15
12 = Alphanumeric Mode 1770KAA PLC2/20 (LP1)
PLC2/20 (LP2)
PLC2/30
12 = Alphanumeric 1770KAA
Select Desired Mode
Select Desired Mode

1 1
PLC Mode is displayed on the 1770T2 PLC processor selection is displayed on 1770T3
Industrial Terminal. Series B or later models of the Industrial Terminal.

10640I 10641I

Keytop Overlay

The Mini-PLC-2 Processor should be programmed using the PLC-2 Keytop


Overlay (1770-KCA) shown in Figure 2.6. All keys in this overlay are
functional with the 1770-T1, -T2 or -T3 Industrial Terminal. The functions of
the keys will be described in detail starting with Section 3 of this manual.

The PLC-2 Family Keytop Overlay (1770-KCB) can be used with any of the
Processors in the PLC-2 Family. it should be used with the 1770-T3 Industrial
Terminal when programming either the Mini-PLC-2/15 or the PLC-2/30. This
overlay contains keys for some functions that are not possible with the Mini-
PLC-2. When any one of these keys is pressed, the message “FUNCTION
NOT AVAILABLE WITH THIS PROCESSOR” or “INVALID KEY” will
appear on the screen.

28
3
Chapter

RelayType Instructions

General Programmable controllers have many of the capabilities of hardwired relay


control systems. Control functions similar to those available with relay are
provided by the following relay-type instructions:
Examine instructions
Output instructions
Branch instructions

Examine Instructions These are two Examine instructions:


ON -| |-
OFF -|/|-
The Examine instructions can examine the status of bits in any Data Table area
except for Processor Work Areas. When an EXAMINE ON or EXAMINE OFF
instruction is given an address in the I/O Image table, the instruction can
indirectly examine the status of a corresponding I/O device. The status of the
I/O Image Table bit will be a 1 or 0 reflecting the ON or OFF condition,
respectively, of the I/O device. The I/O device and the I/O Image Table bit have
the same address. (See Hardware/Program Interface, Chapter 1).

The condition of the instruction can be either TRUE or FALSE depending on


the status of the examined bit. If the Image Table bit is in the desired state, the
instruction is TRUE. The TRUE-FALSE conditions of the Examine
instructions are as follows:

The EXAMINE ON instruction is TRUE when the addressed memory bit is a


1, meaning that the corresponding I/O device or bit is ON.

The EXAMINE ON instruction is FALSE when the addressed memory bit is


a 0, meaning that the corresponding I/O device or bit is OFF.

The EXAMINE OFF instruction is TRUE when the addressed memory bit is
a 0, meaning that the corresponding I/O device or bit is OFF.

The EXAMINE OFF instruction is FALSE when the addressed memory bit is
a 1, meaning that the corresponding I/O device or bit is ON.

31
Chapter 3
Relay-Type Instructions

The EXAMINE ON and EXAMINE OFF instructions are illustrated in an


example rung in Figure 3.1 and Figure 3.2, respectively.

Figure 3.1
EXAMINE ON Instruction

112 012

04 13

Figure 3.2
EXAMINE OFF Instruction

112 012

05 14

Output Instructions The output instructions set an addressed memory bit to “1” (ON) or reset it to
“0” (OFF). An Output Image Table bit, as a “1” or “0”, can cause an output
device to be turned ON or OFF, respectively.

Output instructions are programmed at the end of the ladder-diagram rungs.


Only one output instruction can be programmed on each rung. The output
instruction will be performed only if the Condition (input) instructions
preceding it provide a path of logical continuity (Figure 3.3).

Figure 3.3
LadderDiagram Rung

Output
Conditions Instruction

A continuous path is needed


for Logical Continuity

These output instructions are:


ENERGIZE -()-
LATCH -(L)-
UNLATCH -(U)-
These instructions are used to set memory bits ON or OFF in any area of the
Data Table, excluding the Processor Work Areas. Generally, they should NOT
be assigned Input Image Table addresses because Input Image Table words are
reset by the I/O scan.
32
Chapter 3
Relay-Type Instructions

OUTPUT ENERGIZE INSTRUCTION

The OUTPUT ENERGIZE instruction tells the Processor to turn an addressed


memory bit ON when rung conditions are TRUE. This memory bit will
determine the ON or OFF status of an output device when addressed to an
output terminal. This instruction can also be used to turn ON a storage bit for
later use in the program.

The OUTPUT ENERGIZE instruction tells the Processor to turn the addressed
memory bit OFF when rung conditions go FALSE. Refer to Figure 3.4.

Figure 3.4
OUTPUT ENERGIZE Instruction

112 012

06 15

The OUTPUT ENERGIZE instruction can be programmed unconditionally for


some types of specialized programming. Its use should be limited to storage
bits for these special purposes. An unconditional OUTPUT ENERGIZE
instruction (Figure 3.5) causes the output instruction to remain energized
continuously. This is not advisable in output device programming for safety
reasons, because the device cannot be turned OFF by program logic. Care
should be taken not to inadvertently enter an unconditional output instruction.

Figure 3.5
Unconditional OUTPUT ENERGIZE Instruction

035

15

OUTPUT LATCH and UNLATCH Instructions

There are two output instructions that are termed “retentive”. These
instructions are:
OUTPUT LATCH
OUTPUT UNLATCH
These instructions are usually used as a pair for any bit address they control.

The OUTPUT LATCH instruction (L) is somewhat similar to the OUTPUT


ENERGIZE instruction. The OUTPUT LATCH instruction tells the Processor
to set an addressed memory bit ON when the rung condition is TRUE. Unlike
the OUTPUT ENERGIZE instruction, the OUTPUT LATCH instruction is

33
Chapter 3
Relay-Type Instructions

“retentive.” This means that once the rung condition goes FALSE, the latched
bit remains ON until reset by an OUTPUT UNLATCH instruction. If power is
lost but Processor back-up battery is maintained, all latched bits will remain
ON. Outputs associated with the latched bits will be OFF with the power OFF.
However, they will turn ON immediately when power is restored.

The OUTPUT UNLATCH instruction (U) is used to turn OFF a memory bit that
has been latched ON. The OUTPUT UNLATCH instruction addresses the same
memory bit that has been latched ON (Figure 3.6). when the rung condition for
the OUTPUT UNLATCH instruction goes TRUE, the addressed memory bit is
reset to zero (OFF). Refer to Figure 3.7. The OUTPUT UNLATCH is also
“retentive”. This means that once the rung condition goes FALSE, the
unlatched bit remains OFF until reset by an OUTPUT LATCH instruction.

Figure 3.6
LATCH/UNLATCH Instructions

113 010
L
04 00
113 010
U
05 00

Figure 3.7
LATCH/UNLATCH Timing Diagram

Latch TRUE
Rung FALSE

TRUE
Unlatch
Rung FALSE

Output ON
Bit OFF
01000

34
Chapter 3
Relay-Type Instructions

When the Mode Select Switch is changed from the RUN position, the last
LATCH or UNLATCH instruction continues to control the addressed memory
bit, but the output device is de-energized by the Processor. When the Mode
Select Switch is turned back to RUN a latched output device will be energized.

The OUTPUT LATCH and UNLATCH instructions, when entered,


automatically set the bit to OFF. The bit can be initially preset ON by entering
the number [1] immediately after the address. The ON or OFF condition will be
displayed below the instruction when the Processor is in the PROGRAM mode
(Figure 3.8). When the Mode Select Switch is turned to the RUN position, the
addressed memory bit and output device, if latched ON, will immediately be
energized, regardless of the rung condition.

Figure 3.8
LATCH/UNLATCH Indication

112 014
L
04 OFF 00
112 014
U
05 ON 16
Indicates
ON or OFF

WARNING: Do not preset a bit ON controlled by


LATCH/UNLATCH instructions if it controls potentially
hazardous machine motion. If the bit is preset ON by the
LATCH/UNLATCH instructions, the output device controlled by
that bit is energized immediately when the Mode Select Switch
is turned to the RUN position. Injury to personnel near the
machine could result.

Both LATCH and UNLATCH instructions can be programmed unconditionally.


This programming technique is generally used with storage bits and should not
be used to control output devices.

35
Chapter 3
Relay-Type Instructions

Branch Instructions The branch instructions allows more than one combination of input conditions
to energize an output device (Figure 3.9).

Figure 3.9
Branching Instructions

Two A Single Branch End


Branch Instruction
Start 111 010
Instructions
11 00
111
Two possible pthas for
Logic Continuity. (Or logic)
12

There are two branch instructions:


BRANCH START
BRANCH END
BRANCH START - This instruction begins each parallel logic branch of a rung.
The BRANCH START is programmed immediately before the first instruction
of each parallel logic path.
BRANCH END - This instruction completes a set of parallel branches. The
BRANCH END is entered after the last instruction of the last branch to end a
set of parallel branches.
Branch instructions must be entered in the correct order for proper logic
function. The only limitation is that a “nested” branch (a branch within a
branch) cannot be programmed directly (Figure 3.10). A total of seven (7)
branches can be programmed in one rung and properly displayed on the
Industrial Terminal.
Figure 3.10
Nested Branching vs. Proper Programming
A C

D
Branch
within a
branch E
A. Desired Logic (cannot be programmed)

A B C

D C
Instruction
Repeated
E

B. Equivalent Logic (can be programmed)

36
Chapter 3
Relay-Type Instructions

Programming RelayType All relay-type instructions are entered from the Industrial Terminal Keyboard
Instructions with the Processor in the PROGRAM mode. when a relay type instruction is
initially entered, it will appear intensified on the screen to indicate the cursor’s
present position. When a bit address is required, the instruction will blink to
indicate information is needed to complete the instruction. The default bit
address, 010/00, is displayed automatically with the instruction. (NOTE: The
term “default” simply means that data is to be added.) A reverse- video
character cursor is positioned at the first digit. This cursor indicates where
information is needed and moves to the next digit as information is entered.
When all information is entered, the instruction stops blinking and remains
intensified until the next instruction is entered.

Refer to Table 3.A for a complete summary of relay-type instructions.

37
Chapter 3
Relay-Type Instructions

Table 3.A
Relay Type Instructions

Note: Examine and Output addresses, X X X/X X , can be assigned to any location on the Data Table, excluding
the Processor Work Areas as noted below.

Keytop Instruction T1,T2 Display 1770T3 Display Description


Symbol Name

XXXXX XXX When the addressed memory bit is


| | EXAMINE ON | | | | ON, the instruction is TRUE.
XX

| / | EXAMINE OFF XXXXX XXX When the addresses memory is OFF,


| / | | / | the instruction is TRUE.
XX

( ) ENERGIZE XXXXX XXX [1]When the rung is TRUE, the


( ) ( ) addressed memory bit is set ON. If
XX the bit controls an output device that
output devise will be ON.

( L ) OUTPUT LATCH XXXXX XXX [1]When the rung is TRUE, the


( L ) ( L ) addressed memory bit is latched ON
ON or ON X X and remains ON until it is unlatched.
OFF or OFF The OUTPUT LATCH instruction is
initially OFF when entered, as
indicated below the instruction. It can
be preset ON by pressing a [1] after
entering the bit address. An ON will
then be indicated below the
instruction in PROGRAM mode.

( U ) OUTPUT XXXXX XXX [1]When the rung is TRUE, the


UNLATCH ( U ) ( U ) addressed bit is unlatched. If the bit
ON or ON X X controls an output devise that devise
OFF or OFF is deenergized. ON and OFF will
appear below the instruction
indicating the status of the bit in
PROGRAM mode only.

BRANCH START This instruction begins a parallel logic


path and is entered at the beginning
of each parallel path.

BRANCH END This instruction ends two or more


parallel logic paths and is used with
BRANCH START instructions.
[1]These instructions should not be assigned Input Image Table addresses because Input Image words are reset by
the I/O scan.

38
4
Chapter

Timer and Counter Instructions

General Timer and Counter instructions are output instructions internal to the Processor.
They provide many of the capabilities available with timing relays and solid
state timing/counting devices. Usually conditioned by Examine instructions,
timers and counters keep track of timed intervals or counted events according to
the logic continuity of the rung. Up to 40 internal timers and/or counters can be
programmed.

Each Timer or Counter instruction has two 3-digit values associated with it, and
thus requires two words of Data Table memory. These 3-digit values are:

Accumulated (AC) Value - Stored in the Accumulated Value area of the Data
Table starting at word address 0308. For timers, this is the number of timed
intervals that have elapsed. For counters, this is the number of events that
have been counted.

Preset (PR) Value - Stored in a Preset Value area of the Data Table, always
1008 words greater than its corresponding AC Value. This value is entered
into memory. The Preset value is the number of timed intervals or events to
be counted. when the Accumulated value equals the Preset value, a status bit
is set ON and can be examined to turn ON or OFF an output device.

The Accumulated and Preset values are stored in the Data Table in 3-digit BCD
(Binary Coded Decimal) format. BCD numbers can range from 000 to 999
when stored in the lower 12 bits of a memory word (Figure 4.1). Each BCD
digit is represented by a group of 4 bits. The arrangement of “1’s” and “0’s” in
a group of 4 bits corresponds to a decimal number from 0 to 9. For more
information or numbering systems, refer to section titled Numbering System,
chapter 13.

Figure 4.1
BCD Format

Lower 12 Bits

23 22 21 20 23 22 21 20 23 22 21 20 Place value of bits*


0 1 1 0 1 0 0 1 0 0 0 1
Data Table Word

6 9 110
* Exponential Form:
20 = 1, 21 = 2, 22 = 4,
23 = 8 10643I

41
Chapter 4
Timer and Counter Instructions

The remaining 4 bits in a word (bits 14-17) are not used to form a BCD number.
In the Accumulated Value word, they are used as status bits. in the Preset Value
word, they are not used and are available for internal storage. With .01 second
timers, these bits are used for internal timing functions and cannot be used for
storage. For more information on bit storage, refer to section titled Bit/Word
Storage Considerations.

Timer Instructions A timer counts elapsed time-base intervals (1.0, 0.1 or .01 seconds) and stores
this count in its Accumulated Value word. When timing is complete (when AC
= PR),. bit 15 is either set ON or OFF depending on the type of timer
instruction. For all timers, bit 17 is set ON when rung conditions are TRUE and
is set OFF when they are FALSE. Both status bits are located in the
Accumulated Value word as shown in Figure 4.2.

Figure 4.2
Timer Accumulated Value Word

Accumulated Value
in BCD form

17 16 15 14 13 12 11 10 07 06 05 04 03 02 01 00

Most Least
Significant Middle Significant
Digit Digit Digit

Enable Bit. Timed Bit.


This Bit is set This bit is set to 1 or 0
to 1 when timer rung when the timeer has
conditions are TRUE timed out, that is AC = PR 10644I

The four timer instructions available with the Mini-PLC-2 Controller are:
TIMER ON-DELAY-(TON)-
TIMER OFF-DELAY-(TOF)-
RETENTIVE TIMER-(RTO)-
RETENTIVE TIMER RESET-(RTR)-
The timers differ in the way they set and reset status bits, respond to rung logic
continuity and reset the Accumulated Value. they are similar in time base
selection. One of the following time bases must be selected when entering the
instruction.
1.0 second
0.1 second
0.01 second (10 milliseconds)

42
Chapter 4
Timer and Counter Instructions

Bit 16 of the timer Accumulated value word reflects the time base. it will go
ON and OFF at the selected time base rate. Therefore, do not use bit 16 of a
timer instruction in User Program as an output or storage bit.

TIMER ONDELAY Instruction

The TIMER ON-DELAY instruction (TON) can be used to run a device ON or


OFF once an interval is timed out.

Refer to Figure 4.3. When the rung condition for a TIMER ON-DELAY
instruction becomes TRUE, the timer begins to count time-base intervals. The
“Enable” bit, bit 17, is set ON whenever the rung condition is TRUE and the
timer is enabled (rung 1). as long as the rung condition remains TRUE, the
timer increments its Accumulated value for each interval. when the
Accumulated value equals the programmed Preset value, the timer stops
incrementing its Accumulated value and sets the “timed” bit, bit 15, of this
word ON. Bit 15 is then used to turn an output device ON or OFF, as a
condition for program logic (rung 2).

Whenever the rung condition for the TON instruction goes FALSE, the
Accumulated value is reset to 000 and bits 15 and 17 of that word are reset to
zero. The Accumulated value and status bits are also reset when the Mode
Select Switch is turned to the PROG position or when there is a loss of power.

43
Chapter 4
Timer and Counter Instructions

Figure 4.3
TIMER ONDELAY Timing Diagram & Programming

Accumulated Value and Status Bits


are reset when Input Switch is
opened.

ON
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
Input Swith 113/02 OFF
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
ON
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
Enable Bit 033/17 OFF
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉ AC = PR
9

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
Preset Value 8
7

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉ 6

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
5
4

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
3
2 2

ÉÉ ÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
1 1

ÉÉ ÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
0 0
Accumulated Value

ÉÉÉÉ
ÉÉÉÉ
ON

Timed Bit 033/15 OFF

ÉÉÉÉ
ÉÉÉÉ
ON

Output Lamp 011/04 OFF

0 1 2 3 4 5 6 7 8 9 10 11 12
Time in seconds

Input Switch Timer on Delay


113 033
Rung 1  Ton Instruction TON
Preset for 9 sec delay
02 1.0
PR 009
AC 009
Timed Bit Output Lamp
033 011
Rung 2  Timer turns on
bit 011.04 when timed out.
15 04

10645I

44
Chapter 4
Timer and Counter Instructions

TIMER OFFDELAY Instruction

The TIMER OFF-DELAY instruction (TOF) can be used to turn a device OFF
or ON after a timed interval. Like the other timer instructions, the TOF
instruction counts time-base intervals which are stored in its Accumulated Value
word. The TOF instruction, however, varies from the other instructions in
significant ways.

Refer to Figure 4.4. The TIMER OFF-DELAY instruction begins to time an


interval as soon as its rung condition goes FALSE. The Enable bit, bit 17, goes
FALSE when the timer begins (rung 1). As long as its rung condition remains
FALSE, the TOF instruction continues to time, until the Accumulated Value
equals the Preset Value. when the TOF instruction times out, bit 15 is set to zero
(OFF) which turns OFF the output (rung 2).

The Accumulated Value is reset to 000 and bit 15 is set ON when the rung
condition again goes TRUE. The next timed interval begins when the rung
condition goes FALSE.

Bit 17, the enabled bit, is controlled by the logic continuity of the rung. When
the rung is TRUE, bit 17 is set to ONE (ON); when it is FALSE, bit 17 is set to
zero (OFF).

45
Chapter 4
Timer and Counter Instructions

Figure 4.4
TIMER OFFDELAY Timing Diagram & Programming

Status Bits are set to 1 and


Accumulated Value is reset when
Input Switch is closed.

ÉÉÉ ÉÉ ÉÉÉÉ
ON
ÉÉÉ
ÉÉÉ ÉÉ ÉÉÉÉ
Input Switch 113/05 OFF

ÉÉÉ ÉÉ
ÉÉ ÉÉÉÉ
ÉÉÉÉ
ÉÉÉ ÉÉ ÉÉÉÉ
ON

Enable BIt 047/17 OFF


AC = PR

ÉÉÉÉÉÉÉÉÉÉÉÉÉ
9
Preset Value 8

ÉÉÉÉÉÉÉÉÉÉÉÉÉ
7
6

ÉÉÉÉÉÉÉÉÉÉÉÉÉ 5

ÉÉÉÉÉÉÉÉÉÉÉÉÉ
4
3
2

ÉÉ ÉÉÉÉÉÉÉÉÉÉÉÉÉ
2
1 1

ÉÉ ÉÉÉÉÉÉÉÉÉÉÉÉÉ
0 0
Accumulated Value

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ ÉÉÉÉ
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ ÉÉÉÉ
ON
Timed BIt 047/15 OFF

ON
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ ÉÉÉÉ
Output Lamp 011/04 OFF
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ ÉÉÉÉ
0 1 2 3 4 5 6 7 8 9 10 11 12
Time in seconds

Input Switch Timer Off Delay


113 047
Rung 1  TOF Instruction TOF
Preset for 9 sec delay
05 1.0
PR 009
AC 009
Timed Bit Output Lamp
047 011
Rung 2  Timer turns off
bit 011/04 when timed out.
15 04

10646I

RETENTIVE TIMER Instruction

The RETENTIVE TIMER instruction (RTO), like the TON instruction, can be
used to turn a device ON or OFF once a programmed Preset value is reached.
46
Chapter 4
Timer and Counter Instructions

Unlike the TIMER ON-DELAY instruction, the RETENTIVE TIMER


instruction retains its Accumulated value when any of the following conditions
occur:
Rung condition goes FALSE
The Mode Select Switch is changed to the PROG position.
A power outage occurs provided memory backup power is maintained.
Refer to Figure 4.5. When the rung condition goes TRUE, the enabled bit (bit
17) is set ON and the timer starts counting time-base intervals (rung 1). Any
time the rung goes FALSE, bit 17 is set OFF but the Accumulated value is
retained. When the timer times out, the timed bit (bit 15) is set ON which turns
ON an output (rung 2).

By retaining its Accumulated value, the RTO instruction measures the


cumulative period during which the rung condition is TRUE. Because this
timer retains its Accumulated value, it must be reset by a separate instruction,
the RETENTIVE TIMER RESET (RTR) instruction (rung 3).

RETENTIVE TIMER RESET Instruction

The RETENTIVE TIMER RESET instruction (RTR) is used to reset the


Accumulated value and timed bit of the Retentive Timer to zero. This
instruction is given the same word address as its corresponding RTO instruction
as shown in Figure 4.5. When the rung condition goes true, the RTR instruction
resets the Accumulated value and status bits of the RTO instruction to zero.

47
Chapter 4
Timer and Counter Instructions

Figure 4.5
RETENTIVE TIMER with RESET Timing Diagram & Programming

When Reset Switch is closed, Timed Bit


is reset. Accumulated Value is reset and
held at zero utnil eset Switch is opened.

ÉÉÉÉ ÉÉÉÉÉÉÉÉÉÉ Enable BIt

ÉÉÉÉ ÉÉÉÉÉÉÉÉÉÉ
is reset when
TRUE Input Switch

ÉÉÉÉ ÉÉÉÉÉÉÉÉÉÉ
is opened.
Input Switch 113/06 FALSE

ÉÉÉÉ ÉÉÉÉÉÉÉÉÉÉ
ÉÉÉÉ ÉÉÉÉÉÉÉÉÉÉ
Enable Bit 052/17 ON
OFF
AC = PR
Preset Value
ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ 8 9

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
7
6

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
AC Value retained when rung 5
condition goes FALSE 4

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
3
2

ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ
1
0
Accumulated Value

ÉÉÉÉ
Timed Bit 052/15
ON
OFF ÉÉÉÉ
ON
ÉÉÉÉ
Output Lamp 01/04 OFF
ÉÉÉÉ
ÉÉ
ÉÉ
ON
Reset Switch 113/07 OFF

0 1 2 3 4 5 6 7 8 9 10 11 12
Time in seconds

Input Switch
113 052
RUNG 1: Retentive RT0
Timer preset for
9 sec delay 06 1.0
PR 009
AC 009
Timed BIt Output Lamp
052 010
RUNG 2 - Timer turns on
Bit 010/04 when times out.
15 04

Reset Switch
113 052
RUNG 3: Resets the RTR
Retentive Timer.
07 PR 009
AC 009 10647I

48
Chapter 4
Timer and Counter Instructions

Timer Accuracy for 10 msec Timers

The accuracy of the 10 msec timer is related to nominal scan time. When scan
timers are 9 msec or less, the 10 msec timer is accurate to plus or minus one
time base )+10 msec). When the scan time is greater than 9 msec, accuracy of
+10 msec can be achieved through special programming techniques described in
Programming 0.01-Second Timers.

Counter Instructions Three types of counter instructions are available with the Mini-PLC-2
Controller. They are:
UP-counter -(CTU)-
COUNTER RESET -(CTR)-
DOWN-COUNTER -(CTD)-
A counter counts the number of events that occur and stores this count in its
Accumulated Value word. the remaining four bits in the Accumulated Value
word are used as status bits. See Figure 4.6.

Figure 4.6
Counter Accumulated Value Word

UpCounter Enable Bit

Set to 1 when
AC > PR

Accumulated Value
in BCD form

17 16 15 14 13 12 11 10 07 06 05 04 03 02 01 00

Most Least
Significant Middle Significant
Digit Digit Digit

Overflow/underflow bit set to 1


when CTU overflows 999 or CTD
underflows 000.

Downcounter Enable Bit 10648I

49
Chapter 4
Timer and Counter Instructions

Bit 14 is the Overflow/Underflow bit. it is set to 1 when the AC value of the


CTU instruction exceeds 999 or the AC value of the CTD instruction goes
below 000.

Bit 15 is set to 1 when a count has been reached or exceeded, that is, when
the AC value is >PR value.

Bit 16 is the Enable bit for a CTD instruction. It is set ON when the rung
condition is TRUE.

Bit 17 is the Enable bit for a CTU instruction. It is set ON when the rung
condition is TRUE.

Counter instructions differ from Timer instructions because they have no time-
base. They count one event each FALSE-to-TRUE transition of the rung
condition.

UPCOUNTER Instruction

The UP-COUNTER instruction (CTU) increments its Accumulated value for


each FALSE-to-TRUE transition of the rung condition. Because only the
FALSE-to-TRUE transition causes a count to be made, the rung condition must
go from TRUE to FALSE and back to TRUE before the next count is registered.
The CTU instruction retains its Accumulated value when:
Mode Select Switch is changed to the PROG position.
The rung condition goes FALSE.
A power outage occurs provided memory backup power is maintained.
Refer to Figure 4.7. Each time the CTU rung goes TRUE, bit 17, the Enable
bit, is set ON (rung 1). when the Accumulated value reaches the Preset value,
the Count Complete bit, bit 15, is set ON (rung 2). Unlike a timer, the CTU
instruction continues to increment its Accumulated value after the Preset value
has been reached. if the Accumulated value goes above 999, bit 14 is set ON to
indicate an overflow condition and the CTU continues up-counting from 000
(rung 3). Bit 14 stays ON until the counter is reset. Bit 14 can be examined to
cascade counters for counts greater than 999 (Refer to Cascading Timers of
Counters). Because this counter retains its Accumulated value, it must be reset
by a separate instruction, the COUNTER RESET (CTR) instruction.

410
Chapter 4
Timer and Counter Instructions

Figure 4.7
UPCOUNTER Diagram & Programming

Overflow BIt comes on at


1000th event. The counter
does not reset.

Accumulated Value 1 2 3 4 5 6 7 8 9 10 11 997 998 999 0 1 2

Event to be
counted, 111/11 ON
OFF

Enable Bit ON
053/17 OFF

ÉÉÉÉÉÉÉÉÉÉÉÉ
ÉÉÉÉÉÉÉÉÉÉÉÉ
Count AC = PR
complete bit ON
053/15 OFF

ON
ÉÉÉÉÉÉÉÉÉÉÉÉ
ÉÉÉÉÉÉÉÉÉÉÉÉ
ÉÉÉÉÉÉÉÉÉÉÉÉ
Output Lamp
013/06 OFF
Overflow Bit
ÉÉÉÉ
ÉÉÉÉ
053/14 ON

ÉÉÉÉ
OFF

ÉÉÉÉ
Overflow output
013/07 ON
OFF

111 Count Switch 053


RUNG 1: CTU CTU
Instruction Preset
to 9. 11 PR 009
AC 009
053 Count complete bit Output Lamp 013
RUNG 2: Counter
turns on bit
013/06 at count 15 06
complete.
053 Overflow bit Overflow lamp 013
RUNG 3: Counter
turns on bit 013/07
at overflow 14 07
10649I

411
Chapter 4
Timer and Counter Instructions

COUNTER RESET Instruction


The COUNTER RESET instruction (CTR) is an output instruction that resets
the CTU Accumulated value and status bits to zero when the reset rung goes
TRUE.
Refer to Figure 4.8. The counter operates in the same manner as described for
the CTU instruction, with the addition of the RESET instruction (rung 3).
In this example, the reset pushbutton is pressed after count 12. When the
pushbutton is released, the next event starts the sequence at count 1.
The CTR instruction is given the same word address as the CTU instruction.
The Preset and Accumulated values are automatically displayed when the word
address is entered.

Figure 4.8
UPCOUNTER with RESET Diagram & Programming

Accumulated Value 1 2 3 4 5 6 7 8 9 10 11 12 1 2

Event to be
counted ON
111/11 OFF

Enable Bit ON
053/17 OFF

Count
ON AC = PR
ÉÉÉÉÉÉÉ When Reset

ÉÉÉÉÉÉÉ
complete bit Pushbutton is
053/15 OFF closed, count

ÉÉÉÉÉÉÉ
complete bit is
reset.

ÉÉÉÉÉÉÉ
Output Lamp ON Accumulated Value
013/06 OFF is held at 0 until

ÉÉ pushbutton is

ÉÉ
released.
Reset
pushbutton ON

ÉÉ
111/05 OFF

111 Count Switch 053


RUNG 1: CTU CTU
instruction
preset to 9. 11 PR 009
AC 009

053 Count complete bit Output lamp 013


RUNG 2: Counter
turns on bit
013/06 at count 15 06
complete.

111 Reset pushbutton 053


RUNG 3: Reset CTR
Switch resets
the CTU 05 PR 009
instruction. AC 009
10650I

412
Chapter 4
Timer and Counter Instructions

DOWNCOUNTER Instruction

The DOWN-COUNTER instruction (CTD) subtracts one from its Accumulated


value for each FALSE-to-TRUE transition of its rung condition. Because only
the FALSE- to-TRUE transition causes a count to be made, the rung condition
must go from TRUE to FALSE and back to TRUE before the next count is
registered.

The CTD instruction Accumulated value is retained when:


Mode Select Switch is changed to the PROG position.
The rung condition goes FALSE.
A power outage occurs provided memory backup power is maintained.
Each time the CTD instruction rung goes TRUE, bit 16, the Enable bit, is set
ON. When the Accumulated value is greater than or equal to the Preset value,
bit 15 is set ON. When the Accumulated value goes below 000, bit 14 is set ON
to indicate an underflow condition and the CTD instruction continues
down-counting from 999.

Normally, the DOWN-COUNTER instruction is paired with the UP-COUNTER


instruction to form an up/down counter, using the same word address, AC value
and PR value as shown in Figure 4.9.

Figure 4.9
UP/DOWN COUNTER Example

110 046
CTU
00 PR 220
AC 114
UpCount Event
110 046
CTD
02 PR 220
AC 114
DownCount Event
110 046
CTR
03 PR 220
AC 114
Counter Reset Event

NOTE: Bit 14 of the Accumulated Value word is set ON when the


Accumulated value either “overflows” or “underflows.” Because of this, bit 14
may require monitoring in some applications. When a DOWN-COUNTER
Preset is set to 000. Underflow bit 14 will not be set ON when the count goes
below zero.

413
Chapter 4
Timer and Counter Instructions

When used alone, the CTD instruction’s Accumulated value may need to be
“reset” in the program to its original value (usually a value other than 000). For
this reason, a GET/PUT transfer (described in Data Transfer Instructions) rather
than a CTR instruction is usually used to load a value in the CTD instruction’s
accumulated Value word.

Cascading Timers or Counters An individual timer or counter can time or count up to 999 intervals or events.
By “cascading” two or more timers or counters, the timing or counting
capability within the program can be increased beyond three digits.

To cascade timers or counters, each timer or counter is assigned a different word


address (Figure 4.10). The status bit of the first timer (bit 15) changes status
each time the Preset value is reached. The status bit of a counter (bit 14) is set
ON each time a counter overflows. The status bit of the timer or counter is then
used to increment the second timer or counter and reset the first to 000.

Figure 4.10
Cascading Counters Example

UpCount Event

110 050
CTU
06 PR 999
Counter 050 Overflow BIt AC 000
first increments counter 051
050 051
CTD
14 PR 999
AC 000
Then overflow bit resets
counter 050
050 110 052
CTR
14 03 PR 999
AC 000
Counter Reset Event

414
Chapter 4
Timer and Counter Instructions

Programming Timer and Timer and Counter instructions are programmed from the Industrial Terminal
Counter Instructions keyboard with the Processor in the PROGRAM mode. Allowable addresses are
0308 through 0778.

Timer instructions are programmed by entering the word address of the


Accumulated value, a time base and a Preset value. With the RTO instruction,
an Accumulated value can also be entered. The time base of 1.0,0.1 or 0.01
second is entered as [1][0],[0][1], or [0][0] respectively.

Counter instructions are programmed by entering the word address of the


Accumulated value, a Preset value, and if desired, an Accumulated value. Press
[CANCEL COMMAND] if no Accumulated value is desired.

When entered, these instructions will be displayed as intensified and blinking.


The default word address above the instruction will have a reverse-video cursor
positioned at the first digit. The instruction will continue to blink until all the
data is entered.

Refer to Table 4.A and Table 4.B for complete summary of Timer and Counter
instructions.
Table 4.A
TIMER INSTRUCTIONS

Note: The Timer word address. X X X, is assigned to the Timer Accumulated area of the Data Table.
The time base, TB, is userselectable and can be 1.0, 0.1, or 0.01 second. Preset values Y Y Y and Accumulated
values Z Z Z can vary from 000 to 999.

KEYTOP INSTRUCTION NAME DISPLAY DESCRIPTION


SYMBOL

(TON) TIMER ON DELAY XXX When the rung is TRUE, the timer begins to
(TON) increment the Accumulated Value at a rate
TB specified by the time base.
PR YYY When the rung is FALSE, the timer resets the
AC ZZZ Accumulated Value to 000.

(TOF) TIMER OFF DELAY XXX When the rung is FALSE, the timer begins to
(TOF) increment the Accumulated Value.
TB
PR YYY When the rung is TRUE, the timer resets the
AC ZZZ Accumulated Value to 000.

(RTO) RETENTIVE TIMER XXX When the rung is TRUE, the timer begins to
(RTO) increment the Accumulated Value. When
TB FALSE, the Accumulated value is retained.
PR YYY It is reset only by the RTR instruction.
AC ZZZ

(RTR) RETENTIVE TIMER XXX X X X Word address of the retentive timer it is


RESET (RTR) resetting.
PR YYY
AC ZZZ YYY, ZZZ Preset and Accumulated Values are
automatically entered by the Industrial Terminal.

When the rung is TRUE, the Accumulated Value


and status bit are reset to zero.

415
Chapter 4
Timer and Counter Instructions

Table 4.B
Counter Instructions

Note: The Counter word address, X X X, is assigned to the counter Accumulated areas of the Data Table.
Preset values Y Y Y and Accumulated values Z Z Z can vary from 000999.

KEYTOP INSTRUCTION NAME DISPLAY DESCRIPTION


SYMBOL

(CTU) UP COUNTER XXX Each time the rung goes TRUE, the
(CTU) Accumulated Value is incremented one count.
PR YYY The counter will continue counting after the
AC ZZZ Preset Value is reached.

The Accumulated Value can be reset by the


CTR instruction.

The Accumulated Value "Overflow" bit is bit 14.

(CTR) COUNTER RESET XXX X X X Word address of the CTU it is resetting.


(CTR)
PR YYY Preset and Accumulated Values are
AC ZZZ automatically entered by the Industrial Terminal.

When the rung is TRUE, the CTU Accumulated


Value and status bits are reset to 000.

(CTD) DOWN COUNTER XXX Each time the rung goes TRUE, the
(CTD) Accumulated Value is decreased one count.
PR YYY
AC ZZZ The Accumulated Value "Underflow" bit is bit 14.
The Enable bit is bit 16.

416
5
Chapter

Data Manipulation Instructions

General The data manipulation instructions are used to transfer or compare data that is
stored in data table words and bytes. There are six data manipulation
instructions:
Get
Put
Les
Equ
Get Byte
Limit Test
The Get and PUT instructions are used together to transfer 16 bits of data from
one word location in the Data Table to another word location. Data can be in
the form of 3–digit Binary coded Decimal numbers.

The LES and EQU instructions compare data such as 3–digit numeric values in
BCD format using the first 12 bits of Data Table word (Figure 5.1). This
3–digit value can be a decimal number ranging from 000 to 999.

Figure 5.1
BCD Word Format

Lower 12 Bits

23 22 21 20 23 22 21 20 23 22 21 20 Place value of bits*

1 0 0 0 0 0 1 0 0 1 1 0 1 0 0 1
Data Table WOrd
2 6 9
Most Middle Least
Significant Digit Significant
Bits 1417not used Digit
for BCD value but Digit
are accessed by
the get instruction.

* Exponential Form:
20 = 1, 21 = 2, 22 = 4, 23 = 8 10652I

51
Chapter 5
Data Manipulation Instructions

The GET BYTE and LIMIT TEST instructions store the data as 3–digit values
in octal format using eight bits (one byte) of a data table word (Figure 5.2).
This 3–digit value is an octal number ranging from 0008 to 3778. Note that two
3–digit values can be stored in a word: one in the upper byte (bits 10–17) and
one in the lower byte (bits 00–07).

A data manipulation instruction can address any word in the data table,
excluding processor work areas.

Figure 5.2
Octal Representation

One byte (8 bits)


>
-----

-----
-----

1 0 2 1 0 2 1 0
2 2 2 2 2 2 2 2
1 1 1 0 1 1 1 1
-----

-----

-----
3 5 78
10652I

Data Transfer Instructions There are two Data Transfer instructions. They are:
GET –[G]–
PUT –(PUT)–

Get Instruction

GET instructions –[G]– are programmed in the condition area of the ladder
diagram rung. When the rung containing the GET/PUT instructions goes
TRUE, the data (16 bits) in the word address of the GET instruction is
duplicated and transferred to the word address of the PUT instruction.
(Figure 5.3).

Figure 5.3
GET and PUT Instruction

Optional Condition

111 130 040


G PUT
11 238 238

52
Chapter 5
Data Manipulation Instructions

If the word addressed by a Get instruction already contains data, the lower 12
bits of the data are displayed automatically beneath the instruction after the
word address is entered. Entry of a new BCD value writes over the BCD value
previously stored in the addressed word.

Although each data table word stores one BCD value, the word address can be
assigned to more than one GET instruction in the same program. This allows
the program to perform several different functions with the same data.

The Get instruction is not a “condition” that determines rung logic continuity.
When the processor is in the run or test mode, the Get instruction is always
intensified regardless of rung logic continuity. This does not mean that data
transfer will occur. Data transfer occurs only when the rung is true.

The Get instruction can be programmed either at the beginning of a rung or with
one or more condition instruction preceding it. Condition instructions, however,
should not be programmed after a Get instruction. When one or more condition
instructions precede the Get instruction, the conditions determine whether the
rung is true or false. Parallel branches of Get instructions cannot be
programmed unless they are paired with a Les or Equ instruction.

Put Instruction

The PUT instruction (PUT) is an output instruction. <it receives 16 bits of data
from its corresponding GET instruction and stores the data at its address as
shown in Figure 5.3. A PUT instruction can have the same address as other
instructions in the program. For example, a PUT instruction having the same
address as a counter Preset will change the counter Preset value to that
transferred from the GET instruction. See Figure 5.4.

Figure 5.4
Changing a Counter Preset

Optional Condition

111 130 140


G PUT
11 238 238
111 040
CTU
12 AC 047
NOTE: The preset of the counter at address 040 is at address 140. PR 238

53
Chapter 5
Data Manipulation Instructions

The lower 12 bits of transferred data are displayed in BCD beneath the PUT
instruction. Bits 14–17 are not displayed but are transferred. While the rung is
TRUE, any change in the data of the GET instruction also changed the data of
the PUT instruction. However, the PUT instruction is retentive, which means
that while the rung is FALSE, any change in the data of the GET instruction
does not change the data of the PUT instruction. Also, during a power loss, the
data is retained.

Data Comparison Instructions The Data Comparison instructions are:


LESS THAN –[<]–
EQUAL TO –[=]–
GET BYTE –[B]–
LIMIT TEST –[L]–
Data Comparison operations differ from Data Transfer operations because Data
Table values are not transferred. Instead, the values at different word locations
are compared.

Data Comparison instructions operate with either BCD values or octal values.
With the LES and EQU instructions, only 12 bits of a word (the BCD values)
are compared. Bits 14–17 are not compared. With the GET BYTE and LIMIT
TEST instructions, 8 bits (one byte) of a word are compared.

LES and EQU Instructions

The LES (less than) and EQU (equal to) instructions, [<] and [=] are used with
the GET instruction to perform data comparisons. They compare BCD values
and are programmed in the condition area of the ladder diagram rung.

A GET/LES or GET/EQU pair of instructions forms a single condition for logic


continuity. Alone or with other conditions, each pair can be used to energize an
output device or other output instruction. In all cases, the GET instruction must
be programmed before the LES or EQU instruction. If other conditions are also
programmed, they should be entered before the GET instruction or after the
LES or EQU instruction.

Data comparisons are made by comparing a changing BCD value to a reference


BCD value. The reference value need not be fixed. The following types of data
comparisons of BCD values can be made:
Less than
Greater than
Equal to
Less than or equal to
Greater than or equal to

54
Chapter 5
Data Manipulation Instructions

LESS THAN – A less–than comparison is made with the GET/LES pair of


instructions. The BCD value of the GET instruction is the changing value. it is
compared to the BCD value of the LES instruction which is the reference value
(Figure 5.5). when the GET value is less than the LES value, the comparison is
TRUE and logic continuity is established.

Figure 5.5
LESS THAN Comparison

Optional Condition

120 030 037 010


G <
01 YYY 654 00
Reference Value
When YYY <654, Get/Les comparison is TRUE and 010/00 is energized

GREATER THAN – A greater–than comparison is also made with the


GET/LES pair of instructions. This time the GET instruction BCD value is the
reference and the LES instruction BCD value is the changing value.

The LES value is compared to the GET value for a greater–than condition
Figure 5.6). When the LES value is greater than the GET value, the comparison
is TRUE and logic continuity is established.

Figure 5.6
GREATER THAN Comparison

Optional Condition

120 030 031 010


G <
02 499 YYY 01
Reference Value
When YYY > 499, Get/Les comparison is TRUE and 010/01 is energized

55
Chapter 5
Data Manipulation Instructions

EQUAL TO – An equal–to comparison is made with the GET and EQU


instructions (Figure 5.7). The GET value is the changing variable and is
compared to the reference value of the EQU instruction for an equal to
condition. When the GET value equals the EQU value, the comparison is
TRUE and logic continuity is established.

Figure 5.7
EQUAL TO Comparison

Optional Condition

120 030 035 010


G =
03 YYY 100 02
Reference Value
When YYY = 100, Get/Equ comparison is TRUE and 010/02 is energized

LESS THAN OR EQUAL TO – This comparison is made using the GET, LES
and EQU instructions. The GET value is the changing value. The LES and
EQU instructions are assigned a reference value (Figure 5.8). when the GET
value is either less than or equal to the value at the LES and EQU instructions,
the comparison is TRUE and logic continuity is established.

Figure 5.8
Less Than or Equal To Comparison

Optional Condition

120 030 040 010


G =
04 YYY 237 03
040
=
237 Reference Value

When YYY < 237, Get/LesEqu comparison is TRUE and 010/03 is energized

NOTE: Only one GET instruction is required for a parallel comparison. The
LES and EQU instructions are programmed on parallel branches.

56
Chapter 5
Data Manipulation Instructions

GREATER THAN OR EQUAL TO – This comparison is made using the GET,


LES and EQU instructions. The GET value is assigned a reference value. The
LES and EQU values are changing values that are compared to the GET value
(Figure 5.8). when the LES and EQU values are greater than or equal to the
GET value, the comparison is TRUE and logic continuity is established.

Figure 5.9
GREATER THAN or EQUAL TO Comparison
NOTE: Only one GET instruction is required for this parallel comparison. The
LES and EQU instructions are programmed on parallel branches.

Optional Condition

120 030 042 010


G <
05 440 YYY 04
042
Reference Value =
YYY

When YYY > 440, Get/LesEqu comparison is TRUE and 010/04 is energized

GET BYTE and LIMIT TEST Instructions

The GET BYTE and LIMIT TEST instructions [B] and [L] are used together to
compare an octal value to upper and lower limits that are also octal values.
These values can range from 0008 to 3778.

The GET BYTE and LIMIT TEST instructions are programmed in the
condition area of the ladder diagram rung. Together they form a single
condition for logic continuity. Condition instructions can be programmed
before the GET BYTE instruction or after the LIMIT TEST instruction but not
between them.

The GET BYTE instruction addresses either the upper or lower byte of a Data
Table word. A “1” is entered after the word address for an upper byte; a “0” is
entered for the lower byte.

57
Chapter 5
Data Manipulation Instructions

The LIMIT TEST instruction addresses one Data Table word that stores both
the upper and lower limits. The upper limit is stored in the upper byte and the
lower limit is stored in the lower byte. The upper byte of word 0458 would be
addressed as 0451. See Figure 5.10.

Figure 5.10
GET BYTE/LIMIT TEST Comparison

Optional Condition Reference Value

120 0451 050 200 010


G L
06 YYY 170 04

When 1708 < YYY8 <2008, Get/LesEqu comparison is TRUE and 010/05 is energized

The Processor makes a duplicate of the upper or lower byte of the word
addressed by the GET BYTE instruction. The octal value stored at that byte is
then compared to the upper and lower octal values of the LIMIT TEST
instruction. If the GET BYTE value is equal to or between the LIMIT TEST
values, the comparison is TRUE and logic continuity is established.

Programming Data The Data Manipulation instructions are programmed from the Industrial
Manipulation Instructions Terminal keyboard with the Processor in the PROGRAM mode. When entered,
they are displayed intensified and blinking. The default word address above the
instruction will have a reverse–video cursor positioned at the first digit. The
instruction will continue to blink until all information is entered.

Refer to Table 5.A for a summarized description of these instructions.

58
Chapter 5
Data Manipulation Instructions

Table 5.A
Data Manipulation Instructions

Note: Data Manipulation instructions operate upon BCD values and/or 16 bit data in the Data Table. The word address
XXX is displayed above the instruction; the BCD value or data operated upon YYY is displayed beneath it. The BCD
value is stored in the lower 12 bits of the word address and can be any value from 000 to 9099, except as noted.

KEYTOP SYMBOL INSTRUCTION NAME INSTRUCTION DESCRIPTION


DISPLAY NAME
DISPLAY

-[G]- GET XXX The GET instruction is used with other Data
-[G]- YYY Manipulation or Arithmetic Instructions.
When the rung is TRUE, all 16 bits at the GET
instruction are duplicated and the operation of
the instruction following it is performed.

-(PUT)- PUT XXX The PUT instruction should be preceded by the


-(PUT)- YYY GET instruction.
When the rung is TRUE, all 16 bits at the GET
instruction address are transferred to the PUT
instruction address.

-[<]- LESS THAN XXX The LESS THAN instruction should be preceded
-[<]- YYY by a GET instruction.
3-Digit BCD values at the GET and LESS
THAN word address are compared. If the logic
is TRUE, the rung is enabled.

-[=]- EQUAL TO XXX The EQUAL TO instruction should be preceded


-[=]- by a GET instruction.
YYY 3-Digit BCD values at the GET and EQUAL TO
word addresses are compared. If equal, the
rung is enabled.

-[B]- GET BYTE XXXD D- Designates the upper or lower byte of the
-[B]- YYY word. 1=upper byte,0=lower byte.
YYY-Octal value from 000sub8 to 377sub8 is
stored in the upper or lower byte of the word
address.
The GET BYTE instruction should be followed
by a LIMIT TEST instruction.

-[L]- LIMIT TEST XXX AAA AAA-Upper limit of LIMIT TEST, an octal value
-[L]-- from 000sub8 to 377sub8.
BBB BBB-Lower limit of LIMIT TEST, an octal value
from 000sub8 to 377sub8.
The LIMIT TEST instruction should be preceded
by a GET BYTE instruction. Compares the
value at the GET BYTE instruction with the
values at the LIMIT TEST instruction. If found to
be between or equal to the limits, the rung is
enabled.

59
6
Chapter

Arithmetic Instructions

General The Mini-PLC-2 Processor can be programmed to perform arithmetic


operations with two 3-digit BCD values using a set of Arithmetic instructions.
These output instructions are:
ADD -(+)-
SUBTRACT -(-)-
MULTIPLY-(X)-(X)- (1772-LN3 Processor)
DIVIDE -(÷)-(÷)- (1772-LN3 Processor)
The two 3-digit BCD values to be computed are stored in two GET instruction
words. The GET instructions, programmed in the condition area of the ladder
diagram rung, should be followed by the Arithmetic instruction. Other
condition instructions, if used, should be programmed before the GET
instructions.

The Arithmetic instructions are programmed in the output position of the ladder
diagram rung. They are assigned either one or two Data Table words to store
the computed results, depending on the arithmetic operation performed. The
ADD and SUBTRACT instructions use one Data Table word to store the result.
The MULTIPLY and DIVIDE use two Data Table words to store the result.

The computed result is stored in BCD format in the lower 12 bits of the
Arithmetic instruction word (Figure 6.1). Two of the remaining bits (bits 14 and
16) are used to indicate overflow and underflow conditions.

Figure 6.1
Arithmetic Instruction Word

BCD Value
holds arithmetic result

17 16 15 14 13 12 11 10 07 06 05 04 03 02 01 00

Most Least
Significant Middle Significant
Digit Digit Digit

Overflow Bit set to 1 when sum


exceeds 999
Underflow Bit set to 1 when difference is
negative number

61
Chapter 6
Arithmetic Instructions

Add Instruction The ADD instruction (+) tells the Processor to add the two values stored in the
GET words. The sum is then stored at the ADD instruction word address.
When the sum exceeds 999, the overflow bit (bit 14) in the ADD instruction
word is set ON (Figure 6.2). In the RUN or TEST mode, the overflow
condition is displayed on the Industrial Terminal screen as a “1” preceding the
sum.

Figure 6.2
ADD Instruction

Must be TRUE to allow


arithmetic operation Result stored at this
address

111 030 031 032


G G +
11 520 514 1034

Overflow will cause A


1 to b3 displayed but
not used

NOTE: If an overflowed value (4 digits) is used for subsequent comparisons or


other arithmetic operations, inaccurate results could occur. The Processor
performs arithmetic and data manipulation operations with 3-digit BCD values,
only.

Subtract Instruction The SUBTRACT instruction (-) tells the Processor to subtract the second GET
word value from the first GET word value (Figure 6.3).

Figure 6.3
SUBTRACT Instruction

Must be TRUE to allow Result stored at this


arithmetic operation word address

111 040 041 042


G G -
14 100 109 -009

Underflow will cause


negative sign to be
displayed but not used

62
Chapter 6
Arithmetic Instructions

The difference is then stored at the Data Table word addressed by the
SUBTRACT instruction.

If the difference is a negative number, the underflow bit of the SUBTRACT


word (bit 16) is set ON. In the RUN or TEST mode, the negative sign will
appear on the Industrial Terminal screen preceding the difference.

NOTE: If a negative BCD value is used for subsequent operations, inaccurate


results could occur. The Processor only compares, transfers and computes the
absolute BCD value.

Multiply Instruction (1772LN3 The MULTIPLY (X) instruction tells the Processor to multiply the two BCD
Processor Module) values stored at the GET instruction words. The result is then stored in two
Data Table words addressed by the MULTIPLY instruction (Figure 6.4).

Figure 6.4
MULTIPLY Instruction

Must be TRUE to allow


arithmetic operation

111 030 031 051 052


G G X X
12 123 061 007 503

For ease of programming, two consecutive Data Table words should be chosen
to store the product. If the product is less than 6 digits, leading zeros will
appear in the product.

Divide Instruction (1772LN3


Processor Module)
The DIVIDE instruction (:) tells the Processor to divide the first GET
instruction value by the second GET instruction value. The result is stored in
two Data Table word addressed by the DIVIDE instruction (Figure 6.5). Usually
two consecutive Data Table words are chosen to store the quotient for ease of
programming

Figure 6.5
DIVIDE Instruction

Must be TRUE to allow


arithmetic operation

111 040 041 066 067


G G : :
13 050 025 002 000

63
Chapter 6
Arithmetic Instructions

The quotient is rounded off and expressed as a decimal number. The decimal
point is automatically inserted between the two DIVIDE instruction values by
the Industrial Terminal. Leading and trailing zeros in the quotient are also
entered automatically by the Industrial Terminal.

Although division by 0 is undefined mathematically, the division of a number


including zero by 0 will give the results of 999.999. (This differs from the
PLC-2/20 and PLC-2/30 where 0 : 0 = 1.000.)

Programming Arithmetic Arithmetic instructions are programmed from the Industrial Terminal keyboard
Instructions with the Mini-PLC-2 Processor in the PROGRAM mode. when entered, these
instructions will be intensified and blinking. The default word address above the
instruction will have a reverse-video cursor positioned at the first digit. The
instruction will continue to blink until the word address is entered.

Refer to Table 6.A for a summarized description of these instructions.

64
Chapter 6
Arithmetic Instructions

Table 6.A
ARITHMETIC INSTRUCTIONS

Note: Arithmetic instructions operate on BCD values in the Data Table. The word address XXX is displayed
above the instruction; the BCD value YYY which is the result of the arithmetic operation is displayed beneath it.
The BCD value is stored in the lower 12 bits of the word address and can be any value from 000 to 999.

KEYTOP INSTRUCTION NAME DISPLAY DESCRIPTION


SYMBOL

(+) ADD XXX The ADD instruction is an output instruction.


(+) It is always preceded by two GET
YYY instructions which store the BCD values to
be added.
When the sum exceeds 999, bit 14 is set to
1, and a 1 is displayed in front of the result
YYY.

() SUBTRACT XXX The SUBTRACT instruction is an output


() instruction. It is always preceded by two
YYY GET instructions. The value in the second
GET address is subtracted from the value in
the first.
When the difference is negative, bit 16 is set
to 1, and a minus sign is displayed in front of
the result YYY.

(X) MULTIPLY(1772LN3 XXX XXX The MULTIPLY instruction is an output


Processor) (X)(X) instruction. It is always preceded by two
YYY YYY GET instruction which store the values to be
multiplied.
Two word addresses are required to store
the 6 digit product.

(÷) DIVIDE(1772LN3 XXX XXX The DIVIDE instruction is an output


Processor) (:)(:) instruction. It is always preceded by two
YYY.YYY GET instructions. The value of the first is
divided by the value of the second.
Two word addresses are required to store
the 6 digit quotient. Its decimal point is
placed automatically by the Industrial
Terminal.

65
7
Chapter

Output Override and I/O Update Instructions

General Programming instructions may be needed for certain applications requiring


output overrides or I/O updates. They are:
MASTER CONTROL RESET Instructions
ZONE CONTROL LAST STATE Instruction
IMMEDIATE INPUT Instruction
IMMEDIATE OUTPUT Instruction

Output Override Instructions The two output instructions that can be used to override a group of outputs are:
MASTER CONTROL RESET -(MCR)-
ZONE CONTROL LAST STATE -(ZCL)-
These instructions are similar to a hardwired Master Control Relay in that they
can affect a group of outputs in the User Program. The MCR and ZCL
instructions, however, and NOT a substitute for a hard-wired relay, which
provides emergency stop capabilities for all I/O devices.

WARNING: A PC system should not be operated without a


hard-wired Master Control Relay and Emergency Stop switches
to provide emergency I/O power shutdown. Emergency Stop
switches can be monitored but should not be controlled by the
User Program. these devices should be wired as described in the
Mini-PLC-2 Assembly and Installation Manual (Publication
1772-820). The purpose of these devices is to guard against
damage to equipment and/or injury to personnel.

The MCR and ZCL instructions control the zoned outputs differently:

MCR - When FALSE, all nonretentive outputs within the MCR zone are
de-energized or turned OFF.

ZCL - When FALSE, the outputs within the ZCL zone are held in their last
state: either ON or OFF.

71
Chapter 7
Output Override and I/O
Update Instructions

To override a group of output devices, two MCR or ZCL instructions are


required one to begin the zone and one to end the zone (Figure 7.1). The Start
Fence begins the zone and is always programmed with a set of input conditions.
The End Fence ends the zone and must be programmed unconditionally.

Figure 7.1
MCR and ZCL Zone Programming

ZCL Start Fence

When ZCL zone is


FALSE all Outputs
remain in their last
state

ZCL Unconditional
End Fence

MCR Start Fence

When MCR zone is


FALSE nonretentive
Outputs are de-energized

MCR Unconditional
End Fence

72
Chapter 7
Output Override and I/O
Update Instructions

When the MCR or ZCL Start Fence is TRUE, all outputs within the zone are
controlled by their respective rung conditions. When the MCR or ZCL Start
Fence is FALSE, the outputs within the zone are controlled by the MCR or ZCL
Start Fence as stated above.

WARNING: MCR or ZCL zones must not be overlapped or


nested. Each zone must be separate and complete. Common
outputs must not be shared between MCR zones. Overlapping
MCR or ZCL zones could result in unpredictable machine
operation with possible damage to equipment and/or injury to
personnel.

Sharing common outputs in more than one ZCL zone is permitted, provided that
only one ZCL zone is enabled at a time. Common outputs can be examined in
more than one MCR or ZCL zone.

I/O Update Instructions Two instructions used to accelerate the update I/O during the execution of the
User Program are:
IMMEDIATE INPUT -[I]-
IMMEDIATE OUTPUT -(IOT)-
These instructions are used to transfer critical I/O data ahead of the normal scan
sequence. The status of inputs is made immediately available to User Program
and output decisions are accelerated to the output devices.

The IMMEDIATE I/O instructions are usually used where I/O modules
interface with I/O devices that operate in a shorter period than the Processor
scan time. These may include TTL-logic or fast response input or output
devices.

Most electromechanical devices have a response time longer than the Processor
scan time. Thus, data to and from these devices need not be updated ahead of
the normal I/O scan.

73
Chapter 7
Output Override and I/O
Update Instructions

Scan Sequence

The Mini-PLC-2 Processor scan sequence can be divided into 2 parts


(Figure 7.2):
I/O Scan
Program Scan

Figure 7.2
Scan Sequence

I/O SCAN
Performs I/O
updating
typically
End of 1 msec./128 I/O
Program
Instruction
Start of
Program
Instruction

Program scan, instructions


scanned sequentially, as
enetered (typically 22 msec.
for 900 instructions).
10255-I

Upon power up, the Processor begins the scan sequence with the I/O scan.
During the I/O scan, data from input modules is transferred to the Input Image
Table. Data from the Output Image Table is transferred to the output modules.

After completing the I/O scan, the Processor begins the program scan. here, all
User Program instructions are generally scanned and executed in the order they
were entered.

The I/O scan and program scan are performed one after the other. The time
required to complete both scans is typically 23 msec for 900 instructions.

Typically 23 msec may pass before I/O data is updated in a 1K system. The
purpose of IMMEDIATE I/O instructions is to interrupt the program scan to

74
Chapter 7
Output Override and I/O
Update Instructions

update a word of critical input data or to transfer a word of critical data from the
Output Image Table to the module in advance of the normal update sequence.

IMMEDIATE INPUT Instruction

the IMMEDIATE INPUT instruction [1] updates one word of the Input Image
Table data in advance of the normal scan sequence (Figure 7.3). The Image
Table word represents one Module Group in the I/O Chassis.

Figure 7.3
IMMEDIATE INPUT Instruction

I/O Scan

Program Scan

Immediate Input Instruction


Interrupts Program Scan

2
Examine Bits in
Word 112 Here Returns to
in Program Program
Scan

Word 112

16 Bits from Module


One Module Group Group
Written into Input (Input)
Image Table Word

10151-I

75
Chapter 7
Output Override and I/O
Update Instructions

The IMMEDIATE INPUT instruction is programmed in the condition area of


the ladder-diagram rung. The IMMEDIATE INPUT instruction can be
considered as always TRUE; it is always executed whether or not other rung
conditions allow logic continuity.
Program the IMMEDIATE INPUT instruction only when necessary. The need
depends on both the response time of the input devices and modules being used,
and on the position in the program of the rungs examining these inputs. it is
best to program the IMMEDIATE INPUT instruction just before input
instructions addressed to the applicable Module Group are examined.
IMMEDIATE OUTPUT Instruction
The IMMEDIATE OUTPUT instruction (IOT) updates one Module Group with
data from one Output Image Table word ahead of the normal scan sequence
(Figure 7.4).
Figure 7.4
IMMEDIATE OUTPUT Instruction

I/O Scan

Program Scan

Control Bits
of Word 014
Here in Immediate Output Instruction
Program Interrupts Program Scan

Returns to
Program
Scan
Word 014
4
Writes All 16 Bits from
One Output Image Table
Word to One Module Group

Module
Group
(Output)
10152I

76
Chapter 7
Output Override and I/O
Update Instructions

The IMMEDIATE OUTPUT instruction is programmed as an output instruction


in the ladder-diagram rung. This instruction is executed when rung conditions
allow logic continuity. unconditional programming can also be used to cause
the Module Group to be updated during each program scan.

Program the IMMEDIATE OUTPUT instruction only when necessary. This


depends on the response time of output modules and devices, and on the
position of the rungs addressing the applicable Module Group.

The IMMEDIATE OUTPUT instruction should be programmed just after the


rungs that control the bits in the addressed Output Image Table word.

In PC applications, this instruction only gives a slight advantage when entered


near the end of the program scan; since the output data will soon be updated in
the I/O scan. this instruction is best applied when entered near the middle of the
User Program.

Programming Output Override Instructions are programmed from the Industrial Terminal keyboard with the
and I/O Update Instructions Processor in PROGRAM mode. when entered, they will be displayed as
intensified and blinking with the reverse-video cursor positioned on the first
digit of the default word address. The instruction will continue to blink until the
word address is entered.

Refer to Table 7.A for a summarized description of these instructions.

77
Chapter 7
Output Override and I/O
Update Instructions

Table 7.A
Output Override and I/O Update Instructions

Note: The MCR and ZCL boundary instructions have no word address.
The word addresses XXX of the IMMEDIATE INPUT and OUTPUT instructions are limited to the Input and Output Image Tables
respectively.

KEYTOP SYMBOL INSTRUCTION NAME DISPLAY DESCRIPTION

(MCR) MASTER CONTROL RESET (MCR) Two MCR instructions are required to control
a group of outputs. The first MCR
instruction is programmed with input
conditions to begin the zone. The second
MCR instruction is programmed
unconditionally to end the zone.
When the first MCR rung is FALSE, all
outputs within the zone, except those forced
ON, latched ON, or any other retentive
output will be deenergized.
Do not overlap MCR zones, or nest with ZCL
zones. Do not share common outputs
between MCR zones.

(ZCL) ZONE CONTROL LAST (ZCL) Two ZCL instructions are required to control
STATE a group of outputs. The first ZCL instruction
is programmed with input conditions to begin
the zone. The second ZCL instruction is
programmed unconditionally to end the
zone.
When the first ZCL rung is FALSE, outputs
in the zone will remain in their last state.
Do not overlap ZCL zones, or nest with MCR
zones.

( I ) IMMEDIATE INPUT XXX Processor interrupts program scan to update


[ I ] Input Image Table with data from the
corresponding module group. It is updated
before the normal I/O scan and executed
each program scan

( IOT) IMMEDIATE OUTPUT XXX When the rung is TRUE, Processor


(IOT) interrupts program scan to update module
group with data from corresponding Output
Image Table word address. It is updated
before the normal I/O scan and executed
each program scan when the rung is TRUE.
Can be programmed unconditionally.

78
8
Chapter

Writing the User Program

General The basic tools for writing the User Program include the programming
instructions and an understanding of Processor operation as described in section
titled Hardware/Program Interface, chapter 1. Although approaches to and
methods of writing programs that control machine operation vary, there are
some guidelines that should be followed.

Developing the Program The first step in developing the User program is to establish an operating
sequence for input and output devices. The sequence must be evaluated to
determine what the devices must do, what the conditions must be and the order
in which they must operate.

After evaluating the operating sequence, the action of the different devices
should be described in proper sequence with proper conditions for energizing
each output device. This description is then used to develop the ladder diagram
program. If a process diagram exists, it can be used as an aid in developing a
ladder diagram program.

81
Chapter 8
Writing the User Program

Sample Program The way a ladder diagram program is developed is best described by a simple
example.

The application is one of separating good parts from bad parts. Figure 8.1
shows a part moving along a conveyor belt. Each part will trip a series of limit
switches and will be sorted according to its size. The desired part size is 1.0”
+0.1”.

If a part trips 2LS but not 3LS, the part is greater than or equal to 0.0” and less
than or equal to 1.1”. Because it is a good part, a storage bit (3SB) is latched
ON. when the part trips 4LS, SOL1 is energized which moves the swingarm
actuator, directing the part onto the good part conveyor.

Figure 8.1
Conveyor Belt Example

Movement of Part

1LS 2LS 3LS 4LS 5LS

SOL 1 SOL 2

CTR

Swingarm Swingarm
Acutator Acutator
0.9" < Part Height < 1.1"
2LS Set at 0.9" Good Part Bad Part
3LS Set at 1.1" Conveyor Bin

10654I
SOL 3

If the part trips both or neither 2LS and 3LS, the part is too large or too small.
When either condition occurs, a storage bit (4SB), 4CR is latched ON.
Although the part will trip 4LS, it will continue along and trip 5LS, which
energizes SOL2. The swingarm actuator will direct the part into the bad part
bin. Each time a part enters the bad part bin, a counter is incremented. When
the bin is full (count complete), SOL3 is energized, which opens the bottom of
the bin long enough to empty it. The counter will then reset automatically.
Each time a new part enters the conveyor belt, 1LS is tripped which unlatches
the storage bits and begins a new cycle.

82
Chapter 8
Writing the User Program

The conveyor motor can be started or stopped with pushbutton START or STOP
switches. Motor starter, MS1, controls the conveyor motor. A watchdog timer
is used to monitor the follow of parts. If parts should become jammed causing a
delay between 1LS and 4LS, the timer will time-out and turn OFF the conveyor
motor. Another watchdog timer detects if a part becomes jammed beneath 4LS
or 5LS. A conveyor RUN indicator and a parts JAM indicator allow remote
observation of the conveyor operation. Additional documentation (not shown)
would include a Power Distribution schematic showing a hardwired master
control relay and emergency stop switches.

The logic can be written as a PC ladder diagram program (Figure 8.2). Data
Table addresses are assigned to the hardwired devices. (Table 8.A). The ladder
diagram should be developed by analyzing the logic required to operate the
machine. A rung by rung description of the logic follows.

Rung 1 - This rung provides 3-wire control of the conveyor motor with jam
detection for automatic shut down.

Rung 2 - The auxiliary contact of the motor starter is monitored to provide a


conveyor RUN indication.

RUNG 3,4,5,6 - The part trips the first limit switch and unlatches storage bits
1-4 to begin a new cycle.

Rung 7 - The first limit switch enables a Retentive Timer which is latched by
the timer Enable bit. A jam condition is detected if the timer times out.

Rung 8 - Limit switch 4 (or the START pushbutton) reset the timer. If reset
prior to 5 seconds, no jam has occurred between 1LS and 4LS. A jam beneath
4LS or to the right of it is not detected by this rung.

Rung 9 - A art passing 2LS latches SB1 if the height>0.9 inch. SB1 remains
unlatched in the height <0.9 inch.

Rung 10 - A part passing 3LS latches SB2 if the height >1.1 inch. SB2 remains
unlatched if the height<1.1 inch.

Rung 11 - A part within tolerance latches SB3.

Rung 12 - A part out of tolerance latches SB4.

Rung 13 - A good part at 4LS actuates SOL1 with swingarm actuator to direct
the part to the good part conveyor.

Rung 14 - A bad part at 5LS actuates SOL2 with swingarm actuator to direct
the part to the bad part bin.

Rung 15 - SOL2 increments the Up-counter, one count for each bad part.

83
Chapter 8
Writing the User Program

Table 8.A
Data Table Addresses for Hardwired Devices

Input Device Address

STOP Pushbutton 112/00


START Pushbutton 112/01
Motor Starter Auxiliary 112/02
Limit Switch (1LS) 112/03
Limit Switch (2LS) 112/04
Limit Switch (3LS) 112/05
Limit Switch (4LS) 112/06
Limit Switch (5LS) 112/07
Output Device
Motor Starter (MS1) 014/00
Conveyer RUN Indicator 014/01
Good Part Solenoid (SOL 1) 014/02
Bad Part Solenoid (SOL 2) 014/03
Bin Dump Solenoid (SOL 3) 014/04
JAM Detect Indicator 014/05
Internal Functions
Storage Bit 1 (SB1) 012/01
Storage Bit 2 (SB2) 012/02
Storage Bit 3 (SB3) 012/03
Storage Bit 4 (SB4) 012/04
Storage Bit 5 (SB5) 012/05
Retentive Time, Watchdog 050
Timer, Bin dump 051
Time, Watchdog 052
Counter 060

84
Chapter 8
Writing the User Program

Figure 8.2
LADDER DIAGRAM PROGRAM
Rung # Stop Start MS1
112 112 050 052 014
1
00 01 15 15 00
MS1 Starter
014 112 Auxiliary
00 02 Conveyor Run
Starter Indicator
112 Auxiliary 014
2
02 01
1LS SB1
112 012
3 U
03 01
1LS SB2
112 012
4 U
03 02
1LS SB3
112 012
5 U
03 03
1LS SB4
112 012
6 U
03 04
1LS Watchdog
112 050
7 RTO
03 0.1
050 PR 050
AC 000
17
4LS
112 050
8 RTR
06 PR 050
Start AC 000
050

01
2LS SB1
112 012
9 L
04 01
2LS SB1
112 012
10 L
04 01
SB1 SB2 SB3
012 012 012
11 L
01 02 03

85
Chapter 8
Writing the User Program

SB1 SB2 SB4


012 012 012
12 L
01 02 04
SB1 SB2
012 012

01 02
4LS SB3 Good Parts SOL1
012 012 014
13
06 03 02
5LS SB4 Bad Parts SOL2
012 012 014
14
07 04 03
SOL2 Bad Parts
014 060
15 CTU
03 PR 020
AC 000
SB5
060 012
16 L
15 05
SB5 Bin dump
012 051
17 TON
05 0.1
PR 060
AC 000
SB5 Bad Parts
012 060
18 CTR
05 PR 020
AC 000
SB5 Bin dump SOL3
012 014
19
05 04
SB5
051 012
20 U
15 05
4LS Watchdog
112 052
21 TON
06 0.1
5LS PR 050
AC 000
112
Jam Detect
07 Indicator
050 014
22
15 05
052

15

86
Chapter 8
Writing the User Program

Rung 16 - When AC = PR = 20, the Count Complete bit latches SB5.

Rung 17 - SB5 starts a timer to maintain a 6 second bin dump.

Rung 18 - SB5 reset the bad part counter.

Rung 19 - SB5 actuates SOL3 to dump the bad part bin by gravity feed.

Rung 20 - The Timed-out bit of timer 0518 unlatches SB5 which in turn resets
the timer.

Rung 21 - 4LS or 5LS enables the watchdog times 0528. If 4LS or 5LS is held
closed by a jam, this timer will time out.

Rung 22 - Timed-out bits are monitored to provide a JAM indication to the


operator.

Developing the Data Table The factory configured Data Table shown in Figure 1-5, chapter 1 should be
used as a guide when developing the Data Table. Determining the number of
words needed and assigning addresses is a procedure that requires care and
attention to detail.

The Data Table should be roughed-out in advance but formally developed as the
User Program is being written. Each Data Table word and bit address and its
function should be logged as it is assigned.

Data Table Documentation Forms

The Data Table documentation forms presented at the end of this section can be
reproduced or revised as needed. They include two general types:

1. Data Table Map to describe the Data Table as a whole. Publication 5045.

2. Data Table Bit and Word Assignment Sheets to log and describe the
function of assigned addresses. Publication 5046 and 5047.

An example showing how each form is used accompanies the description.

DATA TABLE MAP (128-WORD)

This form can be used to log the bit status of a word and to describe the function
of groups of related words within a 128-word Data Table section.

The lower two digits of the 3-digit word addresses are pre-numbered in the
left-hand column. the bit numbers, 00-17, complete the 5-digit bit address. The
starting word address can be written once for the entire 64 word column.

87
Chapter 8
Writing the User Program

for example, Figure 8.3 shows a completed portion of the Data Table Map. The
left-hand column represents the addresses 200/00 through 277/17 because a “2”
is written in the starting word address blank at the top of the column.

Figure 8.3
Example of a Data Table Map

Starting Word Address


2 00

Bit Number
17 10 07 00 Description
2 00
01

36
37
40 0 1 1 0 1 0 1 1 0 1 1 0 1 11 1 FFM 062
41 0 0 1 0 1 0 0 1 1 1 0 1 0 00 1 (Binary)
42 0 1 0 1 1 1 0 1 0 0 1 0 1 01 0
43 1 0 1 0 1 0 1 0 0 1 0 1 0 10 0
44 A C 3 B
45 2 4 F 8
46 FFM 063
C 3 D 5 (Hex)
47 5 B 4 E
50
51
10655I

DATA TABLE WORD ASSIGNMENTS (64 WORD)

This form can be used to write functional descriptions of word addresses used in
the Data Table for word storage, timers and counters, etc.

The form is divided into two 32-word columns. the words can be numbered
consecutively through the entire 64 words. or, the right-hand column can be
numbered 1008 greater than the left-hand column to conveniently track
Accumulated and preset values. In either case, the lowest digit of the 3-digit
word address is pre-numbered, 0-7.

88
Chapter 8
Writing the User Program

For example, a portion of the Data Table Word Assignment Sheet is shown in
Figure 8.4. It illustrates timer and counter functional descriptions for
Accumulated values starting at word address 0308 and Preset values starting at
1308. An “03” and “13” were written into the left-hand and right-hand word
address boxes, respectively.

Figure 8.4
Example of Data Table Word Assignments

Word Addr Description Word Addr Description


03 0 Master cycle time, AC 13 0 Master cycle time, AC
1 Drillhead #1, dwell time, AC 1 Drillhead #1, dwell time, AC
5 No. of passes, AC 5 No. of passes, AC
6 No. of reject parts, AC 6 No. of reject parts, AC
7 7 10656I

DATA TABLE BIT ASSIGNMENTS

This form can be used to log the function of input, output and storage bits.

Similar to the Word Assignment Sheet, the Bit Assignment Sheet is divided into
two 2-word columns. The words can be numbered consecutively. Or, the right-
hand column can be numbered 1008 greater than the left-hand column for the
convenient logging of input, output and/or storage bits having the same module
group number. The bit numbers are pre-numbered, 00-17.

For example, a portion of the Data Table Bit Assignment Sheet is shown in
Figure 8.5. it illustrates logging the input devices associated Module Group 2
and the storage bits of the corresponding storage word 0128 (complement of
word 1128). word addresses “012” and “112” have been entered into
corresponding word address boxes in the left-and right-hand columns,
respectively. the 3-digit word address is entered once for all 16 bits.

Figure 8.5
Example of Data Table Bit Assignments

Word Addr Bit Description Word Addr Bit Description


012 0 0 CR1. run auto (sta) 112 0 0 LS1 Forward overtravel
0 1 CR2, past present latch (sta.) 0 1 PRS1 Part detect
0 2 CR3, op. compl. (sta) 0 2 PB1 Up-jog

10657I

89
Chapter 8
Writing the User Program

I/O Assignment Considerations

Once the description of the application is complete, Data Table bit addresses
can be assigned to the input and output devices wired to the Controller. the 5-
digit bit address directly corresponds to the location of each I/O device with
respect to the Rack number (always 1). Module Group and Terminal number.
Bit addresses cannot be assigned arbitrarily to I/O devices because bit addresses
are hardware-related. Review Hardware/Program Interface, chapter 1, if
necessary. Analog modules and other intelligent I/O modules use word
addresses rather than 5-digit bit addresses. Refer to the module Users Manual
for more information on addressing and wiring.

The installer and programmer should work closely together to determine the
best placement of the I/O modules within the I/O chassis. To simplify
installation and troubleshooting procedures, it may be desirable to group like
modules together. Also, module locations should be assigned to minimize
electrical noise radiation from AC lines. It is helpful to document I/O
assignments on a form such as Publication 5039 found at the end of this section.

This form can be used as follows. the titles of the modules can be written in the
spaces immediately below the Module Group labels. The spaces immediately to
the left of the LED indicators and the screw terminations can be used to identify
the I/O devices and to label the wire numbers connecting the devices to the
terminals, respectively.

Recommendations for I/O wiring and module placement can be found in


Publication 1772-820, the Mini-PLC-2 Assembly and Installation Manual.

Timer/Counter Assignment Considerations

Timers and counters require two Data Table word addresses, one for the
Accumulated value, the other for the Preset value. The instruction address is the
address where the Accumulated value is stored. Timer and counter instructions
can be assigned Data Table addresses beginning at word address 0308 through
0778. The Preset value is located at the word address 1008 greater than the
Accumulated value word address. timer and counter addresses and descriptions
should be entered on Data Table Word Assignment Sheets.

If Block Transfer programming is used, the addresses of the pair of GET


instructions must be entered into the timer/counter areas of the Data Table
starting at word 0308. These instructions also use two Data Table word
addresses, one at an address 1008 greater than the other. Each Block Transfer
rung will decrease by one (1) the number of available equivalent timers and/or
counters from the maximum quantity of 40. For more information on Block
Transfer, see chapter 11.

810
Chapter 8
Writing the User Program

Bit/Word Storage Considerations

Bit/word storage addresses can be located in all areas of the Data Table
excluding the Input Image Table and Processor Work areas. Bit an word
storage addresses should be chosen carefully to conserve memory. The
following recommendations for bit and word storage should be considered:

Bits 14-17 of a timer or counter Preset word can be used for bit storage,
provided data is NOT transferred to the Preset word by a GET/PUT transfer,
or the time base of the timer is NOT .01 second.

Unused Data Table words in the timer/counter areas can be used for bit/word
storage. To conserve memory, use both the Accumulated and corresponding
Preset words for storage.

Output Image Table words can be used for storage when the corresponding
Input Image Table words are used for input modules (Block Transfer
modules excluded). However, when there is a vacant module group or slot in
the I/O Chassis, do not use the corresponding I/O Image Table words for
storage. Reserve these words for future system expansion.

Unused Input Image Table words can not be used for storage. They are
cleared to zero during each I/O scan.

Word 0278 should not be used for storage or control of output devices. many
of the bits are used by the Processor for control functions.

The number of bit/word storage addresses will depend on User Program


requirements and is sometimes difficult to estimate in advance.

811
Chapter 8
Writing the User Program

Sizing the Data Table The Data Table is factory configured to 128 words. The Data Table can be
reduced in size to 48 words by reducing the number of words available for
timers, counters and equivalent word storage in the Accumulated and Preset
value areas. If less than 40 equivalent timers/counters are assigned, the size of
the Data Table should be reduced to allow additional memory to be used for
User Program instructions. Up to 80 instructions can be added to User
Program, two instructions for each equivalent timer/counter not used. See
Figure 8.6.

Figure 8.6
Data Table Adjusted for Additional User Program

Word Address
ÉÉÉÉÉÉÉÉÉ
030

035
ÉÉÉÉÉÉÉÉÉ
ÉÉÉÉÉÉÉÉÉ
User AC Words

Accumulated Values >


(AC)

Area usable to expand


instruction storage:
07 From first unused ACPR

130
ÉÉÉÉÉÉÉÉÉ pair to end of

ÉÉÉÉÉÉÉÉÉ
Timer/Counter area
User PR Words
135

Preset Values >


(PR)

177 10658I

After completing the User Program and logging all addresses on Data Table
Assignment Sheets, the highest address assigned will determine the size of the
Data Table.

The size of the Data Table also can be computed. The computation is made
using the following formula:

ET = T + C + IS/2

where ET=# equivalent timers/counters, T=# timers, C = # counters and IS = #


storage words. Any partially assigned or unassigned storage word from the
highest assigned AC-PR pair to the beginning of the timer/counter area must be
considered as an assigned storage word.

The number of equivalent timers/counters is used to adjust the Data Table in


Processor memory before entering the User Program. The Data Table
Adjustment procedure is described in chapter 9.
812
Chapter 8
Writing the User Program

Program Recommendations The program recommendations listed below for constructing a ladder diagram
rung should be considered:

Note: Special considerations are given for MULTIPLY and DIVIDE


instructions. The rung size limitations exist because of the Industrial Terminal
screen size.

Only one Output instruction can be programmed in a rung.

Generally, program only one rung to energize an output device to simplify


troubleshooting and maximize safety.

Up to 12 Condition instructions in series can be programmed in a rung; up to 11


if the output is a MULTIPLY or DIVIDE instruction.

When the desired number of series Condition instructions exceeds the


horizontal limit of the screen (Figure 8.7), use a storage bit to make two rungs.

Up to 7 parallel branches can be programmed in a rung.

Current Record A hard-coPy printout and/or a tape recording of Data Table, User Program and
messages should be made after the machine operation is working as desired.
Before reproducing Processor memory content, set all Data Table values to
start-up conditions. Record a total memory dump that includes the start-up Data
Table values.

The Data Table Assignment Sheets, hardcopy printout and/or the tape recording
constitute the current record of the machine operation. If subsequent changes
are required, all back-up records should be kept up to date.

Figure 8.7
Storage Bit Example
Exceeds Horizontal Limit
>

1 2 3 4 5 6 7 8 9 10 11 12 13 Output

A. Exceeds 12 Input instructions in series

1 2 3 4 5 6 7 Storage Bit

Storage Bit
8 9 10 11 12 13 Output

B. Use of Storage Bit

813
Chapter 8
Writing the User Program

ALLEN-BRADLEY
Programmable Controller
PAGE OF
DATA TABLE WORD ASSIGNMENTS
ADDRESS TO
(64  WORD)
(Publications 5046 - February, 1982)
PROJECT NAME PROCESSOR
DESIGNER DATA TABLE SIZE
Starting Word Address Starting Word Address
00 00
Bit Number Bit Number
17 10 07 00 Description 17 10 07 00 Description
00 00
01 01
02 02
03 03
04 04
05 05
06 06
07 07
10 10
11 11
12 12
13 13
14 14
15 15
16 16
17 17
20 20
21 21
22 22
23 23
24 24
25 25
26 26
27 27
30 30
31 31
32 32
33 33
34 34
35 35
36 36
37 37
40 40
41 41
42 42
43 43
44 44
45 45
46 46
47 47
50 50
51 51
52 52
53 53
54 54
55 55
56 56
57 57
60 60
61 61
62 62
63 63
64 64
65 65
66 66
67 67
70 70
71 71
72 72
73 73
74 74
75 75
76 76 10659I
77 77
814
Chapter 8
Writing the User Program

ALLEN-BRADLEY
Programmable Controller
DATA TABLE WORD ASSIGNMENTS PAGE OF
(64  WORD) ADDRESS TO
(Publications 5046 - February, 1982)

PROJECT NAME PROCESSOR

DESIGNER DATA TABLE SIZE

WORD ADDR DESCRIPTION WORD ADDR DESCRIPTION


0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7
0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7
0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7
0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7

Comments

10660I
815
Chapter 8
Writing the User Program

ALLEN-BRADLEY
Programmable Controller
DATA TABLE BIT ASSIGNMENTS PAGE OF
(Publications 5047 - February, 1982) ADDRESS TO

PROJECT NAME PROCESSOR

DESIGNER DATA TABLE SIZE

WORD ADDR DESCRIPTION WORD ADDR DESCRIPTION


0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7
0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7
0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7
0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7

Comments

10661I

816
Chapter 8
Writing the User Program

Bulletin 1771 I/O Chassis


CONNECTION DIAGRAM ADDRESSING
(Publication 5039 - September, 1980)

PAGE OF
DATE
PROJECT NAME DESIGNER

MiniPLC2
Processor
or
PLC2
I/O Adapter
or
Remote
I/O Adapter

10208I

817
9
Chapter

Operating Instructions

General This section contains the operating instructions that are used to move through
the program and perform a variety of functions. The instructions are grouped
by function and are summarized in Table 9.A through Table 9.F at the end of
this section. They include:
Data Table Adjustment (Table 9.A)
Addressing
Editing Functions (Table 9.B)
Directories (Table 9.C)
Search Functions (Table 9.D)
Troubleshooting Aids (Table 9.E)
Clear Memory Functions (Table 9.F)

Data Table Adjustment After the size of the Data Table has been determined as described in Sizing the
Data Table, the SEARCH 50 function is used to adjust the Data Table. The
following display will appear when the [SEARCH] [5] [0] keys are pressed in
PROGRAM mode.

DATA TABLE ADJUSTMENT

Number of Input/Output Racks 2


Number of Timers/Counters 040
Data Table Size 128

NOTE: The default value of 2 I/O racks will be displayed. It is not a user-
entered value for the Mini-PLC-2.

The Data Table is factory configured to 128 words for 1 I/O rack and 40
timers/counters. The Data Table can be reduced in 2-word increments to a
minimum of 48 words is no equivalent timers/counters are selected.

The number of equivalent timers/counters to be entered is prompted by a


reverse video cursor. When this number has been entered, the Industrial
Terminal will compute and enter the Data Table size.

Anytime the Data Table is reduced in size, the Processor searches for
instructions in those areas. If an instruction exists in an area to be deleted, the
change will not be allowed and the following message will be displayed:
“INSTRUCTION EXISTS IN DELETED AREA.” To display the rung that is
preventing the change, press [SEARCH]. At that time, the decision can be
made whether to keep or delete the instruction.
91
Chapter 9

Press [CANCEL COMMAND] to terminate the Data Table Adjustment display.

The instructions for adjusting the Data Table are summarized in Table 9.A.

Table 9.A
Data Table Adjustment

INDUSTRIAL
FUNCTION MODE TERMINAL KEY SEQUENCE DESCRIPTION

Data Table PROGRAM Any[1] [SEARCH] Enter the number of equivalent


Adjustment [5][0] timers/counters. The Industrial
[Numbers] Terminal displays the size of the
reduced Data Table.

Processor Any 1770T3 [SEARCH} Displays the number of words in


Memory Layout [5][4] the Data Table Area, User
Program Area, Message Area
and unused Memory.

Either [CANCEL To terminate.


COMMAND]
[1] 1770T1, T2 or T3

Memory Layout Display (1770T3 Industrial Terminal)

The SEARCH 54 function displays a diagram of the areas of memory including


the Data Table, User Program, Message Area and the unused memory. the
number of words in each area is indicated in decimal numbers.

Press [SEARCH][5][4] to initiate this display, and press [CANCEL


COMMAND] to terminate this display.

Addressing The ladder diagram instructions are entered with the Processor in the
PROGRAM mode. When entered, they are displayed as intensified and
blinking to indicate cursor position and that information is needed.

When entering addresses and data, the reverse-video character cursor can be
manipulated to the left and right using the [←] and [→] key to make corrections.
The character cursor cannot be moved to the left past the first digit. If the
character cursor is moved off the instruction address to the right, the instruction
will be entered. it will stop blinking but will remain intensified until the next
instruction is pressed or the instruction cursor is moved to the right.

Any time a digit being entered is not within the proper limits, the message
“DIGIT OUT OF RANGE” will be displayed. The cursor will remain in the
same position until a valid digit is entered.

92
Chapter 9

Editing Changes to an existing program can be made through a variety of editing


functions when the Processor is in PROGRAM mode. Instructions and rungs
can be added or deleted; addresses, data and bits can be changed; a rung left
incomplete due to an interruption while programming can be located and
corrected. The Editing instructions are summarized in Table 9.B.

Table 9.B
EDITING FUNCTIONS

FUNCTION MODE INDUSTRIAL KEY SEQUENCE DESCRIPTION


TERMINAL

Inserting a PROGRAM Any [1] [INSERT] Position the cursor on the instruction that
Condition [Instruction] will precede the instruction to be
Instruction [Address] inserted. Then press the key sequence.
or
[INSERT] [←] Position the cursor on the instruction that
[Instruction] will follow the instruction to be inserted.
[Address] Then press key sequence.

Removing a PROGRAM Any [1] [REMOVE] Position the cursor on the instruction to
Condition [Instruction] be removed and press the key
Instruction sequence.

Inserting a rung PROGRAM Any [1] [INSERT] Position the cursor on any instruction in
[RUNG] the preceding rung and press the key
sequence. Enter instructions. Editing is
prevented until Output is entered.

Removing a rung PROGRAM Any [1] [REMOVE] Position the cursor anywhere on the rung
[RUNG] to be removed and press the key
sequence.
NOTE: Only addresses corresponding to
OUTPUT ENERGIZE, LATCH and
UNLATCH instructions are cleared to
zero.

Change data of a PROGRAM Any [1] [INSERT] Position the cursor on the word whose
word instruction [Data] data is to be changed. Press the key
sequence.

Change the PROGRAM Any [1] [INSERT] Position the cursor on a word instruction
address of a word [First Digit] with data and press [INSERT]. Enter first
instruction [←] digit of the first data value of the
[Address] instruction. Then use the [←] and [→]
keys as needed to cursor to the word
address or data. Enter the appropriate
digits.

Replace an PROGRAM Any [1] [Instruction] Position cursor on the instruction to be


Instruction or [Address] replaced or whose address is to be
change Address of changed. Press the key sequence.
Instructions without
Data

93
Chapter 9

FUNCTION MODE INDUSTRIAL KEY SEQUENCE DESCRIPTION


TERMINAL

OnLine Data RUN Any [1] [SEARCH] Position cursor on the word whose data
Change [5][1] is to be changed. Press key sequence.
[Data] Cursor keys can be used.

[INSERT] Press [INSERT] to enter new data into


memory.
[CANCEL
COMMAND] To terminate OnLine Data Change

All Editing As Any [1] [CANCEL Aborts the operation at the current cursor
Functions Applicable COMMAND] position.
[1] 1770T1, T2 or T3

Inserting an Instruction

Only non-output instructions can be inserted in a rung. There are two ways of
doing this.

One way is to press the key sequence [INSERT] [Instruction] [Key sequence of
Address]. the new instruction will be inserted after the cursor’s present
position. If an instruction is to be entered at the beginning of a rung, the cursor
must be positioned on the output instruction of the previous rung. However, if
the cursor is on the END statement, the instruction will be inserted in the
position preceding the cursor.

The other way to insert an instruction is to press the key sequence [INSERT]
[←] [Instruction] [Key sequence of Address]. The new instruction will be
inserted before the cursor’s present position.

If, at any time, the memory is full, the instruction cannot be entered and a
“MEMORY FULL” message will be displayed.

Removing an Instruction

Only non-output instructions can be removed from a rung. Output instructions


can be removed only by removing the complete rung.

To remove an instruction, place the cursor on the appropriate instruction and


press the key sequence [REMOVE] [Instruction]. If the wrong instruction is
pressed, an “INSTRUCTIONS DO NOT MATCH” message will be displayed.

Note: Bit values and data of word instructions are not cleared. However, the
Input Image Table bits will be rewritten during the next I/O scan except if the
instruction had been removed in a forced ON condition. the force function
would prevail until removed.

94
Chapter 9

Inserting a Rung

a rung can be inserted anywhere within a program by pressing [INSERT]


[RUNG] and entering the instructions. The cursor can be positioned anywhere
in the previous rung. The new rung will be inserted after the rung which
contains the cursor. If it is necessary to remove a newly entered instruction, the
rung must be completed first. if the cursor is on the END statement, the
[INSERT] [RUNG] keys need not be used. The rung can be entered just as in
initial program entry.

If, by chance, the rung was inserted in the wrong position, it must be completed
(press [-( )-][CANCEL COMMAND]) before it can be removed.

If, at any time, the memory is full, a “MEMORY FULL” message will be
displayed and more instructions will not be accepted.

Removing a Rung

Removing a rung is the only way an output instruction can be removed. Any
rung, except the last one containing the END statement, can be removed.

To remove a rung, position the cursor anywhere on the rung and press
[REMOVE] [RUNG].

Note: Only bits corresponding to OUTPUT ENERGIZE, LATCH or


UNLATCH instructions addresses are cleared to zero. All other word and bit
addresses are not cleared when a rung is removed.

Changing Data of a Word Instruction

The data of any word instruction, except the Arithmetic and PUT instructions,
can be changed in the PROGRAM mode without removing and re-entering the
instruction. This is done by positioning the cursor on the appropriate word
instruction and pressing [INSERT] [Data Digits]. When the last digit of the
data is entered, the function is terminated and the data is entered into memory.
The function can also be terminated and entered into memory before the last
digit is entered by pressing [CANCEL COMMAND]. Also, once the first digit
has been entered, the [→] and [→] keys can be used to cursor to any digit in the
address or value to make a correction.

Replacing an Instruction or Changing the Address of an Instruction Without Data

To replace one instruction with another, place the cursor on the instruction. then
press [Instruction] [Key Sequence of the Address]. This procedure also can be
used when changing the address of an instruction that does not contain data.

95
Chapter 9

OnLine Data Change

The lower 12 bits of a word or word instruction excluding Arithmetic and PUT
instructions can be changed while the Processor is in the RUN or TEST mode.
this is done by positioning the cursor on the appropriate instruction and pressing
[SEARCH] [5] [1]. The message “ON-LINE DATA CHANGE, ENTERING
DIGITS” will be displayed near the bottom of the screen. the new digits will be
displayed to the right of the message as they are entered. Use the [→] and

[←] cursor control keys as needed. After the new data is displayed, press
[INSERT] to enter the data into memory.

To terminate this function, press [CANCEL COMMAND].

WARNING: When the address of an instruction whose data is


to be changed duplicates the address of other instructions in User
Program, the consequences of the change for each instruction
should be thoroughly explored beforehand. This is to guard
against unexpected machine operation which could result in
damage to equipment and/or injury to personnel.

Directories (1770T3 Industrial Directories have been developed as an aid in using the Industrial Terminal.
Terminal) They list the several functions common to a single multi-purpose key such as
the [SEARCH] key. The directories are summarized in Table 9.C.

Table 9.C
Directories

INDUSTRIAL
FUNCTION MODE TERMINAL KEY SEQUENCE DESCRIPTION

Help Directory Any 1770T3 [HELP] Displays a list of keys that


are used with the [HELP] key
to obtain further directories.

Control Function Any 1770T3 [SEARCH] Provides a list of all control


Directory [HELP] functions that use the
[SEARCH] key.

Record Function Any 1770T3 [RECORD] Provides a list of functions


Directory [HELP] that use the [RECORD] key.

Clear Memory PROGRAM 1770T3 [CLEAR MEMORY] Provides a list of all functions
Directory [HELP] that use the [CLEAR
MEMORY] key.

All Directory As Applicable 1770T3 [CANCEL COMMAND] To terminate


Functions

96
Chapter 9

The Help directory, accessed by pressing the [HELP] key gives a master list of
directories and the key sequence to access them. Three other directories that
can be accessed from the Help directory are:
Control functions by pressing [SEARCH] [HELP]
Record functions by pressing [RECORD] [HELP]
Clear memory functions by pressing [CLEAR MEMORY] [HELP]
The other directories listed in the Help directory cannot be accessed. Certain
functions listed in the Control function and Record function directories are not
available with the Mini-PLC-2 Processor. If the keys to select any one of these
are pressed, the Industrial Terminal will issue a “FUNCTION NOT
AVAILABLE WITH THIS PROCESSOR” message.

Search Functions The Industrial Terminal can be used to search the User Program for a specific
instruction or address, the first or last rung, the first or last instruction of a rung
or for an incomplete rung using the [SEARCH] key as part of the key sequence.
In addition, the Industrial Terminal allows either a single rung or multiple rungs
to be displayed. The Search instructions are summarized in Table 9.D.

Table 9.D
Search Functions

INDUSTRIAL
FUNCTION MODE TERMINAL KEY SEQUENCE DESCRIPTION

Locate first rung of Any Any [1] [SEARCH] [↑] Positions cursor on the first instruction of
program the program.

Locate last rung of Any Any [1] [SEARCH] [↓] Positions cursor on the TEMPORARY
program END instruction, if present, or the END
statement.

Locate first instruction of PROGRAM Any [1] [SEARCH] [←] Positions cursor on first instruction of the
current rung current rung.

Locate output instruction Any Any [1] [SEARCH] [→] Positions cursor on the output instruction
of current rung of the current rung.

Locate rung without an Any 1770T3 [SHIFT] Locates any rung left incomplete due to
output instruction [SEARCH] an interruption in programming.

Locate specific Any Any [1] [SHIFT] Locates instruction searched for. Press
instruction [Instruction keys] [SEARCH] to locate the next occurrence
[Address] of instruction.

Locate specific word Any Any [1] [SEARCH] [8] Locates this address in the program
address [Address] (excluding | | and | / | instructions).
Press [SEARCH] to locate the next
occurrence of this address.

Single rung display Any Any [1] [SEARCH] Displays the first rung of a multiple rung
[DISPLAY] display. Press key sequence again to
view multiple rungs.
[1] 1770T1, T2 or T3

97
Chapter 9

Search for First Rung

The first rung of the program can be located from any point within the program
in any mode of operation by pressing [SEARCH][^]. This positions the cursor
on the first instruction of the program.

Search for Last Rung

The last rung of the program (END statement) can be located from any position
in the program by pressing [SEARCH][V]. The cursor will stop at the
TEMPORARY END instruction, if present, or the END statement. With the
1770-T3 Industrial Terminal, if the cursor was the TEMPORARY END
instruction, the END statement can be reached by pressing the [SEARCH][v]
keys again. With the 1770-T1 or -T2 Industrial Terminal, the temporary END
statement must be removed in order to locate the END statement.

Search for First Instruction of a Rung

With the Processor in the PROGRAM mode, the first instruction of the rung
containing the cursor can be located by pressing [SEARCH] [<]. If not in
PROGRAM mode, the cursor will move off the screen to the left. To bring it
back, press the [>] key. The cursor is displayed by blinking the instruction.

Search for Output Instruction of a Rung

With the Processor in any mode, the output instruction of the rung containing
the cursor can be located by pressing [SEARCH] [>].

Search For Incomplete Rung (1770T3 Industrial Terminal)

In the event that an interruption in programming occurred and a rung was


inadvertently left without an Output instruction, this rung can be located by
pressing the [SHIFT] [SEARCH] keys. The Processor can be in any mode.

Search For Specific Instruction and Specific Address

The procedures for finding a specific instruction or an address are similar. Any
instruction in User Program can be located by pressing [SEARCH] {Instruction]
[Key Sequence of Address]. Any address (excluding those associated with
EXAMINE ON and EXAMINE OFF instructions) can be located by pressing
the keys. [SEARCH] [8] [Key Sequence of Address]. the address entered is the
word address. for the OUTPUT ENERGIZE, LATCH and UNLATCH
instructions, the Industrial Terminal will locate all of the bit addresses
associated with the word address.

98
Chapter 9

The message “SEARCH FOR” and the entered key sequences will be displayed
at the bottom of the screen. The message “EXECUTING SEARCH” will appear
temporarily. The 1770-T3 Industrial Terminal will begin to search for the
address and/or instruction from the cursor’s position. It will look past the
TEMPORARY END boundary to the END statement. Then it will continue
searching from the beginning of the program to the point where the search
began.

A 1770-T1 or -T2 Industrial Terminal will not look past the temporary END
statement. It will continue searching from the beginning of the program to the
point where it began the search.

If found, the rung containing the first occurrence of the address and/or
instruction will be displayed as well as the rungs after it. If the [SEARCH] key
is pressed again,the next occurrence of the address and/or instruction will be
displayed. When it cannot be located or all addresses and/or instructions have
been found, a “NOTE FOUND” message will be displayed at the bottom of the
screen.

This function can be terminated at any time by pressing [CANCEL


COMMAND]. All other keys are ignored during the search.

Single Rung Display

Upon power-up, a multiple rung display appears on the screen. A single rung
can be viewed by pressing [SEARCH] [DISPLAY]. To return to the multiple
rung display, press [SEARCH][DISPLAY] again.

Troubleshooting Aids The following troubleshooting aids are useful during starting-up and when
troubleshooting a system:
Bit Manipulation and Monitor Functions (1770-T3 Industrial Terminal)
FORCE ON and FORCE OFF Functions
TEMPORARY END Instruction (1770-T3 Industrial Terminal)
ERR Message Display
The Troubleshooting aids are summarized in Table 9.E.

99
Chapter 9

Table 9.E
Troubleshooting Aids

FUNCTION MODE INDUSTRIAL KEY SEQUENCE DESCRIPTION


TERMINAL

Bit Monitor Any 1770T3 [SEARCH] Displays the ON/OFF status of all 16 bits at
[5] [3] specified word address and corresponding
[Address] force conditions if they exist.

[↓] or [↑] Displays the status of 16 new bits at the next


lowest or highest word address, respectively.

Bit PROGRAM or 1770T3 [SEARCH] Displays the ON/OFF status of all 16 bits at
Manipulation TEST [5] [3] specified word address and corresponding
[Address] force conditions if they exist.

[→] or [←] Moves cursor to the bit to be changed.

[1] or [10] Enter a "1" to set bit ON or a "0" to set bit


OFF.

See FORCING Forcing or removing forces from input bits or


below output devices.

Either of above [CANCEL To terminate.


COMMAND]

FORCE ON or TEST or RUN Any [1] [FORCE ON] Position the cursor on the Image Table bit or
FORCE OFF [INSERT] bit instruction to be forced ON or OFF and
instruction or press the key sequence. The input bit or
[FORCE OFF] output device will be forced ON or OFF. [2]
[INSERT]

Removing a TEST or RUN Any [1] [FORCE ON] Position the cursor on the Image Table bit or
FORCE ON or [REMOVE] bit instruction whose force ON is to be
FORCE OFF or removed and press the key sequence.
instruction [FORCE OFF]
[REMOVE]

Removing all TEST or RUN Any [1] [FORCE ON] Position cursor anywhere in program and
FORCE ON [CLEAR press key sequence.
instructions MEMORY]

Removing all TEST or RUN Any [1] [FORCE OFF] position the cursor anywhere in program and
FORCE OFF [CLEAR press key sequence.
instructions MEMORY]

Forced Any 1770T3 [SEARCH] Displays a list of the bit addresses that are
Address [FORCE ON] forced ON or OFF.
Display or The [SHIFT] [↓] and [SHIFT] [↑] keys can
[SEARCH] be used to display additional forces.
[FORCE OFF]

Any of the [CANCEL To terminate


above COMMAND]

Inserting a PROGRAM 1770T1, T2 [INSERT] Position the cursor on the instruction that will
Temporary [|/|] [8] precede the temporary END statement.
END Statement Press the key sequence and END will be
displayed on the screen. The remaining
rungs will not be displayed or scanned.

910
Chapter 9

FUNCTION MODE INDUSTRIAL KEY SEQUENCE DESCRIPTION


TERMINAL

Inserting a PROGRAM 1770T3 [INSERT] Position the cursor on the instruction that will
TEMPORARY [T. END] precede the TEMPORARY END instruction
END Instruction and press the key sequence. TEMPORARY
END will be displayed on the screen. The
remaining rungs, although displayed and
accessible , are not scanned.

Removing a PROGRAM 1770T1, T2 [REMOVE] [|/|] Position cursor on END statement and press
Temporary key sequence. If temporary, it can be
END Statement removed. If it cannot be removed, it is an
END of program statement.

Removing a PROGRAM 1770T3 [REMOVE] Position cursor on the TEMPORARY END


TEMPORARY [T. END] instruction and press key sequence.
END Instruction
[1] 1770T1, T2, or T3
[2] when in TEST mode, the Processor will hold outputs Off regardless of attempts to force them ON.

Bit Manipulation and Monitor (1770T3 Industrial Terminal)

Bit Monitor allows the status of all 16 bits of any Data Table word to be
displayed. Bit Manipulation allows the status of the displayed bits to be
selectively changed or forced, and is useful in setting initial conditions in the
data of word instructions.

BIT MONITOR

Bit Monitor can function when the Processor is in any mode. By pressing the
key sequence [SEARCH][5][3] Key Sequence of Word Address], the status of
all 16 bits of the desired word will be displayed. While the cursor is in the word
address field, the [←] and [→] keys can be used to change address digits.

The status of the 16 bits in the next highest or next lowest word address also can
be displayed by pressing the [↓] or [↑] keys, respectively. Bit Monitor also can
display the status of Force conditions, if any. See FORCE ON and FORCE OFF
Functions below.

BIT MANIPULATION

Bit Manipulation can function when the Processor is in Program mode. When in
TEST mode, the User Program may override the bit status in the next scan.

The [←] and [→] keys can be used to cursor over to any bit. With the cursor on
the desired bit, its status can be changed by pressing the (1) or (0) key. Bit
Manipulation also allows the forcing of Image Table bits as described in
FORCE ON and FORCE OFF Functions below.

To terminate this function, press [CANCEL COMMAND].

911
Chapter 9

WARNING: : If it is necessary to change the status of any


Data Table bit, be sure that the consequences of the change are
thoroughly understood beforehand. if not, unpredictable
machine operation could occur directly or indirectly as a result
of changing the bit status. Damage to equipment and/or injury
to personnel could occur.

FORCE ON and FORCE OFF Functions

The Force functions are used to selectively force an input bit or output device
ON or OFF. The Processor must be in the TEST or RUN mode.

The Force function determine the ON/OFF status of input bits and output
devices by overriding the I/O scan. An input bit can be forced ON or OFF
regardless of the actual state of the corresponding input device. However,
forcing an output terminal will cause the corresponding output device to be ON
or OFF regardless of the rung logic of the status of the Output Image Table bit.

From 1 to 16 bits of an Input Image Table word and from 1 to 16 terminals of


an Output Module Group can be forced ON or OFF separately or in
combination.

NOTE: When in TEST mode, the Processor will hold outputs OFF regardless
of attempts to force then ON, even though the output bit instruction will be
intensified.

USING THE 1770-T1, -T2 or 1770-T3 (Series A Rev A) INDUSTRIAL


TERMINAL

The same force, ON or OFF, can be applied to any of the bits within a word.
However, if a bit in a different Input Image Table word, or a terminal in a
different Output Module Group is forced the same way, all previous forces in
that word or module group are instantly removed. For example, if any terminal
in Output Module Group 013 is forced OFF, and another terminal such as
012/01 is then forced OFF, all force conditions in the Output Module Group 013
will be removed.

Forcing functions can be applied in Ladder Diagram display by placing the


cursor on the desired Examine or Energize instruction. After positioning the
cursor, any one of the following key sequences can be used for placing or
removing a forced condition:
[FORCE ON] [INSERT]
[FORCE OFF] [INSERT]
FORCE ON] [REMOVE]
[FORCE OFF] [REMOVE]

912
Chapter 9

USING THE 1770-T3 (Series A Rev. B or later) INDUSTRIAL TERMINAL

Simultaneous forcing of bits in different Input Image Table words or terminals


in different Output Module Groups is prevented by the 1770-T3 Series A Rev B
or later model Industrial Terminal. If attempted, one of the following messages
would appear.

SIMULTANEOUSLY FORCING BITS ON (OR OFF) IN TWO INPUT


IMAGE TABLE WORDS IS NOT ALLOWED

SIMULTANEOUSLY FORCING BITS ON (OR OFF) IN TWO OUTPUT


MODULE GROUPS IS NOT ALLOWED

A bit that is already forced, cannot be forced in the opposite mode. For
example, if bit 012/03 is forced ON and an attempt is made to force it OFF, the
following message will be displayed.

BIT ALREADY FORCED. EXISTING FORCE MUST BE REMOVED

Forcing functions can be applied using the 1770-T3 Industrial Terminal in either
of two ways using: 1) Bit Manipulation/Monitor display of an I/O word or b)
Ladder Diagram display of User Program. by pressing the key sequence
[SEARCH][5][3] Key sequence of Address], the bit status and force status of
the 16 corresponding input bits or output terminals of the desired word can be
displayed. The [>] and [<] keys can be used to cursor over to the desired bit.
Or, in the Ladder Diagram display, forcing can be applied by placing the cursor
on an Examine or Energize instruction.

ALL MODELS

When in TEST mode, the Processor will hold outputs OFF regardless of
attempts to force them ON even though the output bit instructions will be
intensified.

In every mode except the PROGRAM mode, the ON or OFF status of a forced
bit will appear beneath the bit instruction in the rung. In all Processor modes, a
“FORCED I/O” message will be displayed near the bottom of the screen when
bits are forced ON or OFF.

Note: The ON or OFF status of OUTPUT LATCH/UNLATCH instructions is


also displayed below the instruction. However, this is displayed only in
PROGRAM mode.

All Force ON or all Force OFF functions can be removed at once in Ladder
Diagram Display by pressing either of the following key sequences:
[FORCE ON] [CLEAR MEMORY]
[FORCE OFF] [CLEAR MEMORY]

913
Chapter 9

All force functions will be removed immediately if any of the following


conditions should occur: the Industrial Terminal or Processor is disconnected or
loses AC power; the [MODE SELECT] key is pressed; or a terminal of a
different Output Module Group or a bit in a different Input Image Table word is
forced (excluding 1770-T3 Series A Rev B or later).

WARNING: : When an energized output is being forced OFF,


keep personnel away from the machine area. Accidental
removal of Force functions will instantly turn ON the output
device. Injury to personnel could result.

Forced Address Display (1770T3 Industrial Terminal)

A complete list of bit addresses that are forced ON and OFF can be displayed
by the Industrial Terminal. Either of the following key sequences can be used.
[SEARCH] [FORCE ON]
[SEARCH] [FORCE OFF]
If all the bits forced ON or OFF cannot be displayed at one time, the [SHIFT]
[V] and [SHIFT] [^] keys can be used to display additional forced bits.

To terminate this display, press [CANCEL COMMAND].

TEMPORARY END Instruction

The TEMPORARY END instruction (or temporary END statement) can be used
to test or debug a program up to the point where it is inserted. It acts as a
program boundary because instructions below it in User Program are not
scanned or operated upon. Instead, the Processor immediately scans the I/O
Image Table followed by User Program from the first instruction to the
TEMPORARY END instruction, or temporary END statement.

USING THE 1770-T3 INDUSTRIAL TERMINAL

When the TEMPORARY END instruction is inserted, the rungs below it,
although visible and accessible, are not scanned. Their content can be edited, if
desired. The displayed section of User Program made inactive by the
TEMPORARY END instruction will contain the message “INACTIVE AREA”
in the lower right- hand corner of the screen.

914
Chapter 9

The TEMPORARY END instruction can be inserted in either of two ways:

a. Cursor to the last rung of the User Program to be kept active.


Position the cursor on the output instruction. Press [INSERT][>]
[T.END]

b. Cursor to the first rung of the User Program to be made inactive.


Position the cursor in the first instruction in the rung. Press
[INSERT][←][T.END].

To remove this instruction, position the cursor on it and press


[REMOVE][T.END].

To enter a rung after the T.END instruction, place the cursor on the T.END
instruction and press [INSERT] [RUNG]. Then enter the new rung.

Although more than one TEMPORARY END instruction can be inserted, no


rungs will be executed beyond the TEMPORARY END instruction closest to
the beginning of the program. The TEMPORARY END instruction uses one
word of User Program.

USING THE 1770-T1 OR -T2 INDUSTRIAL TERMINAL

The temporary END statement is similar in function to the TEMPORARY END


instruction described above with the following exceptions. When the temporary
END statement is inserted, the rungs below it are not shown (nor are they
scanned) and no rungs can be entered below it. The temporary END statement
will look just like the normal END statement.

The temporary END statement can be inserted in two ways:

a. Cursor to the 1st rung of the User Program to be kept active. Position
the cursor on the output instruction. Press [INSERT][-|/|-][8].

b. Cursor to the first rung of User Program to be made inactive.


Position the cursor on the first instruction in the rung. Press
[INSERT[ [<] [-|/|-] [8].

To remove this instruction, position the cursor on the END statement and press
[REMOVE] [-|/|-]. If it is temporary, it will be removed and the subsequent
program instructions will be displayed.

ERR Message for an ILLEGAL OPCODE

An illegal opcode is an instruction code that the Processor does not recognize. It
will cause the Processor to fault and will be displayed as an ERR message in the
ladder diagram rung in which it occurs. The 4-digit hex value of the illegal
opcode is displayed above the ERR message by the 1770-T3 Industrial

915
Chapter 9

Terminal. The 1770-T1 or -T2 Industrial Terminal will display the ERR
message without the hex value.

If an illegal opcode should occur, the rung containing it can be compared with
the equivalent rung in a hard copy printout of the program. a decision must be
made either to replace the error with its correct instruction, see paragraph 9.3.6
Replacing an Instruction, or to remove it. The ERR message due to an illegal
opcode cannot be removed directly. Instead, remove and replace the entire rung
as described in paragraphs 9.3.3 and 9.3.4 Inserting and Removing a Rung. The
cause of the problem should be identified and corrected in to correcting the
ERR message.

916
Chapter 9

Clearing Memory The option of clearing the Data Table, User Program and Messages is available
with various CLEAR MEMORY functions. The Clearing Memory instructions
are summarized in Table 9.F.

Table 9.F
Clear Memory Function

INDUSTRIAL
FUNCTION MODE TERMINAL KEY SEQUENCE DESCRIPTION

Data Table PROGRAM 1770T3 [CLEAR Displays a start address and an end address
Clear MEMORY] [7] [7] field.

[Start Address] Start and end word address determine


[End Address] boundaries for Data Table clearing.

[CLEAR Clears the Data Table within and including


MEMORY] addressed boundaries.

User PROGRAM 1770T3 [CLEAR Clears User Program from the position of the
Program MEMORY] cursor to the END statement or
Clear [8] [8] TEMPORARY END instruction. Does not
clear Data Table or Messages.

Partial PROGRAM Any [1] [CLEAR Clears User Program and messages from
Memory MEMORY] position of the cursor to end of memory.
Clear [9] [9] Does not clear Data Table.

Total PROGRAM Any [1] [SEARCH] [↑] Position the cursor on the first instruction of
Memory [CLEAR the program. Clears total memory (Data
Clear MEMORY] Table, User Program and Messages).
[9] [9]
[1] 1770T1. T2 or T3

Data Table Clear (1770T3 Industrial Terminal)

Part of all of the Data Table can be cleared by pressing [CLEAR


MEMORY][7][7], entering a start and end word address, and then pressing
[CLEAR][MEMORY] again. The Data Table will be cleared between and
including these two word addresses.

User Program Clear (1770T3 Industrial Terminal)

Part of all of the User Program can be cleared by pressing [CLEAR


MEMORY][8][8]. The User Program will be cleared from the cursor position
to the TEMPORARY END instruction, or the END statement. Neither the Data
Table nor Messages are cleared.

917
Chapter 9

Partial Memory Clear

Part of the User Program and the Messages can be cleared by pressing [CLEAR
MEMORY] [9] [9]. The User Program and Messages are cleared from the
cursor position to the end of memory. None of the bits in the Data Table are
cleared.

Total Memory Clear

The complete memory can be cleared by pressing [SEARCH] [^] to position the
cursor on the first instruction of the program and then pressing [CLEAR
MEMORY] [9] [9]. This resets all the Data Table bits to zero. A total memory
clear should be done before entering the User Program.

918
10
Chapter

Peripheral Functions Including Report Generation

General There are several functions that can be performed with Mini-PLC-2 and the
Industrial Terminal. the functions include:
Contact Histogram
Report Generation
Cassette Recorder Dump and Load
Data Cartridge Recorder Dump and Load (1770-T3 Industrial Terminal)
Ladder Diagram Dump
Total Memory Dump (1770-T3 Industrial Terminal)
Except for the contact histogram and report generation, the remaining functions
require the use of a peripheral device connected to Channel C of the Industrial
Terminal.

Baud Rate Setting The baud rate for Channel C must be set to match the baud rate of the peripheral
device when a peripheral device other than the Digital Cassette Recorder (Cat.
No. 1770-SA) or Digital Cartridge Recorder (Cat. No. 1770-SB)is used. The
baud rate is the number of bits per second sent to/from Channel C. The baud
rate for Channel C can be set in one of two ways:

Setting switches 1, 2 and 3 of the Switch Group Assembly on the Industrial


Terminal’s main logic board (Table 10.A).

Table 10.A
Switch Group Settings

BAUD
SWITCH RATE
1 2 3
Down Down Down 110

Down Up Up 300

Down Down Down 600

Down Up Up 1200

Up Down Down 2400

Up Down Up 4800

Up Up Down 9600

101
Chapter 10
Peripheral Functions Including Report
Generation

Pressing [RECORD][n] and a number from 2 to 8 on the Industrial Terminal


(Table 10.B).

Table 10.B
Key Sequence for Setting Baud Rate

KEY SEQUENCE BAUD RATE

[RECORD] [2] 110


[RECORD] [3] 300
[RECORD] [4] 600
[RECORD] [5] 1200
[RECORD] [6] 2400
[RECORD] [7] 4800
[RECORD] [8] 9600

A baud rate entered via the keyboard will override the default setting of the
Switch Assembly Group if initially set to some other (often used) baud rate.

USING THE 1770-T3 INDUSTRIAL TERMINAL

Channel C must be ON to receive input from a peripheral device. Channel C is


initially ON. It can be turned OFF by pressing [RECORD] [9] and ON by
pressing [RECORD] [9] again. The ON/OFF status of Channel C and the baud
rate will be displayed at the bottom of the screen when setting the baud rate
using the [RECORD][n] keys where 2<n<8.

USING THE 1770-T1 OR -T2 INDUSTRIAL TERMINAL

Channel C must be ON to receive input from a peripheral device. Channel C is


initially OFF. It can be turned ON by setting the baud rate using the
[RECORD][n] keys. Another way of turning ON channel C is as follows:
Change to the Alphanumeric Keytop Overlay, 1770-KAA.
Press [1][2], Mode Selection on the Alphanumeric Keytop Overlay.
Press [4], the Channel C Alphanumeric Mode Option.
Press [1] for ON [0] for OFF.
Pressing the [1] key returns the display to the Alphanumeric Mode Option
which displays the ON/OFF status of Channel C. Pressing the [Mode Select]
key will terminate the Alphanumeric Mode Option and will turn OFF Channel
C.

102
Chapter 10
Peripheral Functions Including Report
Generation

Contact Histogram The Contact Histogram function displays the ON/OFF history of a specific
memory bit. This can be monitored on the Industrial Terminal and can also be
printed by a peripheral printer. If a peripheral device is used, the baud rate for
Channel C of the Industrial Terminal must be set.

Any Data Table bit, excluding the Processor Word Areas, can be accessed by
the Contact Histogram command. The status of the bit (ON or OFF) and the
length of time the bit remained ON or OFF (in hours, minutes and seconds) will
be displayed. the seconds are displayed to within 00.01 second (10 msec.)
resolution.

There are two operating modes for the contact histogram, shown in Table 10.C:

Continuous: It is accessed by pressing [SEARCH][6]. Once started, the


histogram is displayed continuously until stopped.

Paged: It is accessed by pressing [SEARCH][7]. The histogram is displayed


one page at a time by user command.

Table 10.C
Contact Histogram Function

FUNCTION MODE KEY SEQUENCE DESCRIPTION

Continuous RUN [SEARCH] [6] Provides a continuous display of the


Contact Histogram or [Bit Address] ON/OFF history of the addressed bit in
TEST [DISPLAY] hours, minutes and seconds.
Obtain a hard copy printout of contact
histogram by connecting a peripheral device
to Channel C and selecting proper baud rate
before entering indicated key sequence.

Pages Contact RUN [SEARCH] [7] Displays 11 lines ON/OFF history of the
Histogram or [Bit Address] addressed bit in hours, minutes and
TEST [DISPLAY] seconds.

[DISPLAY] Displays the next 11 lines of contact


histogram.
Obtain a hard copy printout of contact
histogram by connecting peripheral device
to Channel C and selecting proper baud
rate.

Either RUN [CANCEL To terminate.


or COMMAND]
TEST

After pressing [SEARCH][6] or [SEARCH][7], enter the bit address to be


monitored.

After pressing [DISPLAY], the data of the histogram will be displayed on every
other line with 5 frames of data per line. Each frame of data contains the ON or

103
Chapter 10
Peripheral Functions Including Report
Generation

OFF status and the length of time in hours, minutes and seconds [read between
the dash (-) symbols] in the format shown in Figure 10.1.

Figure 10.1
Contact Histogram Display

hr. mn. sec.

OFF ot ON 00:00:00.00

-ON 00:00:00.00OFF 00:00:00.0ON 00:00:00.00


>

>

>
ON TIME OFF TIME ON TIME 10662I

If the bit is changing states faster than can be printed or displayed, a buffer is
maintained to store these changes. If the buffer becomes full, all monitoring
stops and a “BUFFER FULL” message will be displayed. Subsequent changes
in the ON-OFF status of the device are lost until the histogram function finishes
printing out or displaying the data in the buffer. Then a BUFFER RESET
message will be displayed and the histogram function will resume.

The Industrial Terminal screen can display up to 11 lines of data at one time. In
the continuous mode, the screen will automatically display a new page of data
when the screen is full.

In the page mode, 11 lines will fill the screen and stop. Subsequent changes are
stored in the buffer until [DISPLAY] is pressed. The data stored in the buffer
will then be displayed, one page at a time.

To terminate the contact histogram, press [CANCEL COMMAND].

Report Generation Report Generation is a function of the Industrial Terminal. The 1770-T1 or T2
Industrial Terminal can generate up to 6 messages while the 1770-T3 Industrial
Terminal (1770-FD Keyboard Series A Rev. B or later) can generate up to 70
messages. Report Generation is performed in the PLC-2 mode. )The
Alphanumeric mode converts the Industrial Terminal into a peripheral device.)
Messages can contain ASCII and graphic characters and variable Data Table
information. Messages are stored in Processor memory after the END
statement.

104
Chapter 10
Peripheral Functions Including Report
Generation

Messages can be entered into memory from either the Industrial Terminal or a
peripheral device connected to Channel C of the Industrial Terminal. If the
Industrial Terminal is used, one of two keytop overlays can be used, depending
on whether graphic characters are desired (Figure 10.2):
Alphanumeric Keytop Overlay (Cat. No. 1770-KAA)
Alphanumeric/Graphics Keytop Overlay (Cat. No. 1770-KAB)
Figure 10.2
Alphanumeric Keytop Overlays

Alphanumeric Keytop
Overlay
(CAT. NO. 1770-KAA)

MODE ’ ” # $ % & , ( ) – * =
SELECT 1 2 3 4 5 6 7 8 9 0 : _

@
ESC LINE
FEED RETURN
Q W E R T Y U I O P

[ \ + RUB REPT
CTR
OUT LOCK
A S D F G H J K L ;

^ ] < > ? SHIFT


SHIFT
Z X C V B N M , . / LOCK

ALPHANUMERIC CAT. NO. 1770 KAA

 1982 ALLEN-BRADLEY
Alphanumeric/Graphics
Keytop Overlay
(CAT. NO. 1770-KAB)

MODE ’ ” # $ % & , ( ) – * =
SELECT 1 2 3 4 5 6 7 8 9 0 : _

@
ESC LINE
FEED RETURN
Q W E R T Y U I O P

[ \ + RUB REPT
CTR
OUT LOCK
A S D F G H J K L ;

] < > ? SHIFT


SHIFT
Z X C V B N M , . / LOCK

ALPHANUMERIC GRAPHICS CAT. NO. 1770 KAB

 1982 ALLEN-BRADLEY
10160-I

105
Chapter 10
Peripheral Functions Including Report
Generation

The messages can be manually displayed or printed on the Industrial Terminal


or peripheral device by a key sequence each time a message is desired. They
can also be activated through program control by programming specific Data
Table bits in the ladder diagram program (Automatic Report Generation)

Report Generation Commands

The report generation function is entered by pressing [RECORD][DISPLAY] on


the PLC-2 Keytop Overlay (Cat. No. 1770-KCA). A prompt CHANGE TO
ALPHANUMERIC KEYTOP OVERLAY will be given. Or, set the baud rate.
Then enter the desired report generation command from the peripheral device.

There are 5 report generation commands used to store, print, report and delete
messages and to display an index of existing messages. These are summarized
in Table 10.D.

Table 10.D
Report Generation Commands

COMMAND KEY SEQUENCE DESCRIPTION

Enter Report [RECORD][DISPLAY] Puts industrial Terminal into Report


Generation or Generation Function.
Function set baud rate
[message codes] Same (entered from a peripheral device).

Message Store [M] [S] [ , ] [message number] [RETURN] Stores message in Processor memory. Use
[ESC] to end message.

Message Print [M] [P] [ , ] [message number] [RETURN] Prints message exactly as entered.

Message Report [M][R][,][message number] Prints message with current Data Table
[RETURN] values or bit status.

Message Delete [M][D][.][message number] Removes message from Processor memory.


[RETURN]

Message Index [M] [1] [RETURN] Lists messages used and the number of
words in each message.

Automatic Report [SEARCH][4][0] Allows messages to be printed through


Generation or program control.

[M][R][RETURN] Same (entered for a peripheral device).

Exit Automatic [ESC] Terminates AUtomatic Report Generation.


Report Generation or
[CANCEL COMMAND][1] Same (entered for a peripheral device).

Exit Report [ESC] Returns to ladder diagram display.


Generation or
Function [CANCEL COMMAND][1] Same (entered from a peripheral device).
[1] [CANCEL COMMAND] can only be used if the funcction was entered by a command from a peripheral

106
Chapter 10
Peripheral Functions Including Report
Generation

MESSAGE STORE

Accessible only in the PROGRAM mode, this command is used to enter


messages in memory. the Message Store command is accessed by pressing
[M][S][,] [message number] [RETURN]. Valid message numbers are 1-6 for the
177-T1, -T2 or -T3 Rev A Industrial Terminal. Valid message numbers for the
177-T3 Industrial Terminal, Rev B or later are 1-6, 010-017, 110=117, 210-217,
310=-317, 410-417, 510-517, 610-617 and 710-717.

After pressing the key sequence, a READY FOR INPUT message is presented
as a prompt to enter the desired message. any subsequent keys pressed then
become part of the message.

While entering a message, each key pressed except the [SHIFT][CTR;][ESC] or


[RUB OUT] key, generates a code that is stored in one byte of memory. This
includes ASCII and graphic characters as well as other keys such as [LINE
FEED], [RETURN] or the [SPACE] keys. The [RUB OUT] key is not stored in
memory. The [SHIFT] and [CTRL] keys and the next character in the sequence
are stored together in one byte of memory.

Messages can be entered which when reported will give the current value of a
Data Table bit by using the delimiters shown in Table 10.E. The desired
delimiter is entered before and after the bit, byte or word address. The delimiter
is used to tell the Industrial Terminal to print the current status or value of the
bit, byte, or word at the address. As many addresses as needed can be entered
consecutively by sharing the same delimiter, such as *XXX*XXX*XXX*.

Table 10.E
Address Delimiters

DELIMITER EXPLANATION MESSAGE REPORT FORMAT


FORMAT

*XXX* enter 3digit word address Displays BCD value at assigned


between delimiters. (1770T1, word address.
T2, or T3)

#XXX# Same (1770T3) Same

*XXX* or *XXX0* Enter 3digit word address and a Displays the octal value of byte at
"1" for upper byte or a "0" for assigned address.
lower byte between delimiters.0

*XXXXX* Enter 5digit bit address between Displays the ON or OFF status of
delimiters. (1770T1, T2, T3) the assigned bit address.

∧XXXXX∧ Same (1770T3) Same

107
Chapter 10
Peripheral Functions Including Report
Generation

As an example, suppose it was desired to report the output condition, On or


OFF, of a device SR6, during each cycle of machine operation. Delimiters
would be used to denote the output address 013/05, and the cycle counter
Accumulative value (stored at 0308). The desired message, SR6 is (ON or
OFF) in CYCLE (XXX), would be entered into memory with the following
keystrokes:
[S][R][6][ ]
[I][*][0][1][3][0][5][*][][I][N][][C][Y][C][L][E][][*][0][3][0][*][.][ESC].

The message entry must be terminated with the escape ([ESC]) key. Until
([ESC]) is pressed, all key strokes become part of the message. Pressing [ESC]
again will return to ladder diagram display. Pressing [CANCEL COMMAND]
on the PLC-2 Family Keytop Overlay will also terminate the Message Store
command and return to ladder diagram display if a peripheral device was used
to enter report generator mode.
When entering a message, there are several keys and special Industrial Terminal
control codes that are used to move through the display and perform a variety of
functions (Table 10.F and Table 10.G). For example, graphic capability can be
accessed by the control code, [CTRL][P][5][G]. In addition, standard ASCII
control codes can be used with the Industrial Terminal (Table 10.H). These
codes, although not displayed, can be interpreted and acted on by a peripheral
device connected to Channel C.
Table 10.F
Alphanumeric/Graphic Keytop Definitions

KEY FUNCTION

[LINE FEED] Moves the cursor down one line in the same
column.
[RETURN] Returns the cursor to the beginning of the
next line.
[RUB OUT] Deletes the last character or control code
that was entered.
[REPT LOCK] Allows the next character that is pressed to
be repeated continuously until [REPT LOCK]
is pressed.
[SHIFT] Allows the next key pressed to be a shift
character.
[SHIFT LOCK] Allows all subsequent keys pressed to be
shift characters until [SHIFT] or [SHIFT
LOCK] is pressed.
[CTRL] Used as part of a key sequence to generate
a control code.
[ESC] Terminates the present function.
[MODE SELECT] Terminates all functions and returns the
Mode Select display to the screen.
Blank Yellow Keys Space keys. They move the cursor one
position to the right.

108
Chapter 10
Peripheral Functions Including Report
Generation

Table 10.G
Industrial Terminal Control Codes

CONTROL CODE KEY SEQUENCE FUNCTION

[CTRL] [P] [Column #] [ ; ] [Line #] [A] Positions the cursor at the specified
column and line number.
[CTRL] [P] [A] will position the cursor at
the top left corner of the screen.
[CTRL] [P] [F] Moves the cursor one space to the right.
[CTRL] [P] [U] Moves the cursor one line up the same
column.
[CTRL] [P] [5] [C] Turns cursor ON.
[CTRL] [P] [4] [C] Turns cursor OFF.
[CTRL] [P] [5] [G] Turns ON graphics capability.
[CTRL] [P] [4] [G] Turns OFF graphics capability.
[CTRL] [P] [5] [P] Turns Channel C Outputs ON.
[CTRL] [P] [4] [P] Turns Channel C Outputs OFF.
[CTRL] [ I ] Horizontal tab that moves the cursor to
the next preset 8th position.
[CTRL] [K] Clears the screen from cursor position
to end of screen and moves the cursor
to the top left corner of the screen.

KEY SEQUENCE ATTRIBUTE [1]

[CTRL] [P] [0] [T] Attribute 0=Normal Intensity


[CTRL] [P] [1] [T] Attribute 1=Underline
[CTRL] [P] [2] [T] Attribute 2=Intensify
[CTRL] [P] [3] [T] Attribute 3=Blinking
[CTRL] [P] [4] [T] Attribute 4=Reverse Video
[1] Any three attributes can be used at one time using the following key sequence:
[CTRL] [P] [Attribute #] [; ] [Attribute 3] [ ; ] [Attribute #] [T]

109
Chapter 10
Peripheral Functions Including Report
Generation

The Industrial Terminal screen size is an 80 x 24 format: 80 columns across by


24 lines down. An example message using graphic and alphanumeric characters
is shown in Figure 10.3.

Figure 10.3
Example Graphic/Alphanumeric Message

Tank

Liquid
Steam Inlet Inlet

Heater
Coil

Outlet
Steam Return Temperature
Sensor

PV

SP

10261I

The control code, [CTRL][P] [Column #] [;] [Line][A], should be used for
cursor positioning to conserve memory when possible. For example,
[CRTL][P][3][9][;][9][A] uses 3 words of memory, storing CRTL P in one byte
and each remaining character in one byte. If the cursor had been at column 0,
line 0 and normal space and line feed commands were used, it would have taken
24 words of memory to accomplish the same thing! Note that the column and
line numbers begin at zero rather than one.

MESSAGE PRINT

Accessible in any mode, the Message Print command is used to print the
contents of a message to verify it. This command is accessed by pressing [M]
[P] [,] [message number] [RETURN]. Valid message numbers are listed under
MESSAGE STORE.

In the example, the message print command would give the following:

SR6 IS *01305* IN CYCLE *030*.

The Message Print command is self-terminating. [ESC] or [CANCEL


COMMAND] can be used to return to Ladder Diagram display.

1010
Chapter 10
Peripheral Functions Including Report
Generation

MESSAGE REPORT

Accessible in any mode, the Message Report command is used to print a


message with the current Data Table value or bit status that corresponds to an
address between the delimiters. This command is accessed by pressing [M] [R]
[,] [message number] [RETURN]. Valid message numbers are listed under
MESSAGE STORE.

In the example, the Message Report command would give the following: (eg.
bit 013/05 is ON and counter 0308 Accumulated value is 5)

SR6 IS ON IN CYCLE 005

The Message Report command is self-terminating. When (ESC) or [CANCEL


COMMAND] is pressed, ladder diagram operation will resume.

MESSAGE DELETE

Accessible only in PROGRAM mode, the Message Delete command is used to


clear messages from memory. This command is accessed by pressing [M] [D]
[,] [message number] [RETURN]. Valid message numbers are listed under
MESSAGE STORE.

The Message Delete command cannot be terminated before completion. It will


self-terminate after the message has been cleared from memory and a
MESSAGE DELETE prompt will be printed. [ESC] or [CANCEL
COMMAND] can be used to return to ladder diagram display.

MESSAGE INDEX

Accessible in any mode, the Message Index command prints a list of the
message numbers used and the amount of memory (in words) used for each
message. In addition, the number of unused memory words available will be
listed.

The Message Index command is accessed by pressing [M] [I] [RETURN]. This
command cannot be terminated before completion. It will self-terminate after
the list is completed. To return to ladder diagram display, press [ESC] or
[CANCEL COMMAND].

1011
Chapter 10
Peripheral Functions Including Report
Generation

Automatic Report Generation

Messages can be printed through program control “automatically” by energizing


specific message request bits using OUTPUT LATCH and OUTPUT
UNLATCH instructions.

Automatic report generation can be accessed in the TEST or RUN modes by


pressing [SEARCH] [4] [0] on the 1770-KCA overlay or by pressing [M][R]
[RETURN] on the 1770-KAA overlay. It can also be activated automatically
upon initialization of the 1770-T3 Industrial Terminal by setting parity switches
4 and 5 UP on the Industrial Terminal’s main logic board (Figure 10.4).

Figure 10.4
Parity Switch

10664I

Once automatic report generation is activated, the message request bits are
scanned by the Industrial Terminal for a 0-to-1 transition. Each time one of the
request bits goes TRUE, the corresponding message will be printed
automatically.

Messages 1-6 use bits 10-15 of word 0278 as message request bits. For the
1770- T3 Industrial Terminal, Rev B or later, all other messages use control bits
in a user-defined set of message control words. These two categories will be
discussed separately below.

Automatic report generation can be terminated by pressing [ESC]. To return to


ladder diagram display, press [ESC] again. Pressing [CANCEL COMMAND]
will also terminate automatic report generation and return to ladder diagram
display if automatic report generation was entered by a command from a
peripheral device.

MESSAGES 1-6

The upper byte of word 0278 is used to control messages 1-6. Bit 027/10 is the
request bit for message number 1, bit 027/11 is the request bit for message
number 2 and so on. bit 027/16, the Busy bit is set ON when any of messages
1-6 are requested and will remain ON until all requested messages have been
printed. Once all messages are generated, bit 027/17 will stay ON for 300 ms
and is then set OFF.

1012
Chapter 10
Peripheral Functions Including Report
Generation

Table 10.H
ASCII Control Codes

CONTROL [1] ASCII CODE DISPLAY [2] MNEMONIC NAME

CTRL 0 [3] Nu NUL NULL

CTRL A [3] Sh SOH START OF HEADER

CTRL B [3] Sx STX START OF TEXT

CTRL C [3] Ex ETX END OF TEXT

CTRL D Et EOT END OF TRANSMISSION

CTRL E Eq ENQ ENQUIRE

CTRL F Ak ACK ACKNOWLEDGE

CTRL G Bi BEL BELL

CTRL H Bs BS BACKSPACE

CTRL I Ht HT HORIZONTAL TAB

CTRL J Lf LF LINE FEED

CTRL K Vt VT VERTICLE TAB

CTRL L Ff FF FORM FEED

CTRL M Cr CR CARRIAGE RETURN

CTRL N So SO SHIFT OUT

CTRL O Si SI SHIFT IN

CTRL P Di DLE DATA LINK ESCAPE

CTRL Q D1 DC1 DEVICE CONTROL 1

CTRL R D2 DC2 DEVICE CONTROL 2

CTRL S D3 DC3 DEVICE CONTROL 3

CTRL T D4 DC4 DEVICE CONTROL4

CTRL U Nk NAK NEGATIVE


ACKNOWLEDGE

CTRL V Sy SYN SYNCHRONOUS IDLE

CTRL W Eb ETB END OF TRANSMISSION


BLOCK

CTRL X Cn CAN CANCEL

CTRL Y Em EM END OF MEDIUM

CTRL Z Sb SUB SUBSTITUTE

ESCAPE Ec ESC ESCAPE

CTRL , Fs FS FILE SEPARATOR

1013
Chapter 10
Peripheral Functions Including Report
Generation

CONTROL [1] ASCII CODE DISPLAY [2] MNEMONIC NAME

CTRL  Gs GS GROUP SEPARATOR

CTRL . Rs RS RECORD SEPARATOR

CTRL / Lf US UNIT SEPARATOR

DELETE Dt DEL DELETE

[1] Some ASCII control codes are generated using non standard keystrokes.
[2] Will be displayed when Control Code Display option is set ON in
Alphanumeric mode only. (Not in Report Generation mode.)
[3] Valid key in Report Generation mode for 1770FD Keyboard Series B Rev A
or later.

ADDITIONAL MESSAGES (1770-T3 Industrial Terminal, Rev B or later)

Bits from eight consecutive user-selected words are used to control the 64
additional messages.

The eight message control words are determined by establishing a 2-word


message in memory, called message 0. Message 0 is stored as follows:

[M][S][,][0][RETURN]

A prompt, MESSAGE CONTROL WORDS (3 DIGITS REQUIRED): will be


printed. The word address of the first message control word must be entered. the
Industrial Terminal will calculate and display the ending word address. The set
of Message Control words can be located anywhere in the Data Table except
Processor Work areas and Input Image Table. Once the first word address is
entered, the Industrial Terminal will also display a Table which shows the
message numbers associated with each message control word (Table 10.I).

1014
Chapter 10
Peripheral Functions Including Report
Generation

The upper byte of each message control word contains the request bits for eight
messages. There is an easy way to determine the message number from the bit
which requests it. The three right-most digits in the bit address are coded to the
message number. For example, if message number 31‘2 were of interest, bit 12
of the third message control word would request message 312. See Figure 10.5.

Figure 10.5
Bit AddressMessage Number Relationship

CONTROL WORD CONTROL WORD MESSAGE NUMBERS


NUMBER ADDRESS

0 170 010017
1 171 110117
2 172 210217
3 173 310317
4 174 410417
5 175 510517
6 176 610617
7 177 710717

THE CONTROL WORD ADDRESSES ARE USER SELECTED.

MESSAGE NUMBER 3XX HAS A MESSAGE REQUEST BIT AT ADDRESS


173/XX. MESSAGE REQUEST BIT 173/XX, WHEN ENABLED, WILL ACTIVATE
MESSAGE NUMBER 3XX WHERE XX ARE BIT NUMBER 00178. 10665I

Unlike messages 1-6 which share a common Done bit (027/17), the additional
64 messages each have a separate Done bit. After a particular message has been
printed, the Done bit is set until the User Program resets the request bit. Done
bits are located in the lower byte of the message control words. Figure 10.6
shows this relationship. For example, if 124/15 is the request bit for a message,
the Done bit is located at 124/05, 108 (one byte) below the request bit.

Figure 10.6
Message Request Bit  Done Bit Relationship

MESSAGE REQUEST BITS MESSAGE DONE BITS

17 10 07 00
MESSAGE
CONTROL
WORD

1015
Chapter 10
Peripheral Functions Including Report
Generation

The Message Print command is valid for message 0. It will print out the
message control word addresses in tabular form such as shown in Table 10.I. If
the location of the message control file is to be changed of if message 0 is no
longer needed, it can be deleted with the Message Delete command and
re-entered at any time.

WARNING: Message control words should not be used for any


other purpose. if a message control word is assigned to an Output
Image Table address, be sure that neither slot of the corresponding
module group contains an output module. Otherwise, a Request or
Done bit would turn ON n output terminal in either module.
unexpected machine operation could result with possible damage
to equipment and/or injury to personnel.

Table 10.I
EXAMPLE MESSAGE CONTROL WORDMESSAGE NUMBER RELATIONSHIP

CONTROL WORDS [1] MESSAGE NUMBERS

170 010017
171 110117
172 210217
172 310317
174 410417
175 510517
176 610617
177 710717
[1] This table assumes user selected message control words begin at 170
8.

EXAMPLE PROGRAMMING

Using LATCH and UNLATCH instructions, automatic report generation can


easily be programmed to handle multiple or simultaneous message requests.
Simultaneous requests are handled by a priority system, the lower the message
number, the higher the priority.

Figure 10.7 shows a sample program that can be used to activate each message.
When the event occurs which requests the message, the request bit is latched.
After the event has occurred and the message is printed (the Done bit comes
ON), the request bit is unlatched.

1016
Chapter 10
Peripheral Functions Including Report
Generation

Figure 10.7
EXAMPLE PROGRAM TO REQUEST A MESSAGE

Event Request
L

U
Done Event Request

Digital Cassette Recorder The Digital Cassette Recorder (Cat. No. 1770-SA) is a peripheral device that
connects to Channel C of the Industrial Terminal. It is used to dump memory
onto tape, to load memory from tape and to verify memory.

Dumping Memory to Cassette Tape

The Cassette Dump command is used to dump (record) the contents of the Data
Table, user Program and Messages onto a cassette tape. Although accessible in
any mode, it is recommended that the dump be performed only in the
PROGRAM mode because Data Table values are constantly changing in other
modes.

To dump the complete memory onto the cassette tape, position the cursor on the
first rung. The Cassette Dump command is then activated by pressing
[RECORD][0] on the PLC-2 Overlay, and by pressing [RECORD ON TAPE]
on the Cassette Recorder.

As memory is being recorded, the Industrial Terminal will count and display the
number of Data Table words and Program words that were recorded on tape.

The Cassette Dump command is self-terminating. At completion, the content


on the tape will be verified automatically by comparison with the Processor
memory content unless the operation is terminated by pressing [CANCEL
COMMAND].

Loading Memory from Cassette Tape

Loading the Processor memory from cassette tape can be done only in
PROGRAM mode. The Data Table must be configured to the size which will
match the Data Table of the taped program. Set the Data Table size as described
in Data Table Adjustment. If the size of the Data Table on tape is not
immediately available and the Processor is configured differently, the load
operation will abort automatically. The Industrial Terminal will display the
Data Table configuration contained on the tape along with a prompt to configure
the Processor Data Table.

1017
Chapter 10
Peripheral Functions Including Report
Generation

The Cassette Load command is accessed by pressing [RECORD][0] on the


PLC-2 Overlay and by pressing either [READ FROM TAPE] or [PLAY] on the
Cassette Recorder. To load the complete memory, rewind the tape to the
beginning of the program.

As memory is being loaded, the number of Data Table words and Program
words will be counted and displayed. When loading is complete, the Processor
memory content will be verified automatically with the content on tape unless
the cassette function is terminated by pressing [CANCEL COMMAND].

Automatic Verification

This command can be accessed immediately after dumping or loading memory


to/from the cassette tape to verify that an error-free transfer was made. The
Processor must be in the PROGRAM mode to verify the Data Table.

This command is accessed by first pressing [REWIND] and then either [READ
FROM TAPE] or [PLAY] on the Cassette Recorder. During verification, the
number of Data Table words and Program words will be counted and displayed.

Once verification is complete, the number of program errors and whether the
Data Table was verified will be displayed. The Automatic Verification
command will-self-terminate when complete. If program errors exist, they can
be displayed and located by the procedure in Displaying and Locating Errors
unless the cassette function is terminated by pressing [CANCEL COMMAND].

Program Verification

Accessible in any mode, this command is used to verify the User Program and
messages in memory with the version on the cassette tape, or vice versa.
Although the Data Table size and configuration are checked, the Data Table
values are not verified.

This command is accessed by pressing [RECORD][1] on the PLC-2 Overlay


and by pressing either [READ FROM TAPE] or [PLAY] on the Cassette
Recorder. Rewind the tape to the beginning of the program beforehand.

When verification is complete, the command will self-terminate and display the
number of program discrepancies, if any. If discrepancies are found, either the
tape can be re-recorded using the memory dump procedure, or the Processor
memory can be corrected using the procedure in Displaying and Locating
Errors.

1018
Chapter 10
Peripheral Functions Including Report
Generation

Displaying and Locating Errors

During automatic or program verification, the Processor will identify


discrepancies between memory content and the content on the cassette tape. By
pressing [SEARCH][9] on the PLC-2 Overlay, the number of program and Data
Table discrepancies found and whether or not the Data Table was verified will
be displayed. Up to 19 discrepancies can be detected.

Each program discrepancy can be searched for and located by pressing


[SEARCH] and a number from [0][1] to [1][9]. Each time a discrepancy is
searched for, the rung containing it will be displayed with the cursor positioned
on the instruction that doesn’t match the corresponding instruction on tape. a
hard copy printout of the tape program is required for visual comparison. if the
Processor memory is in error, it can be corrected using the editing procedure
described in Chapter 9-Editing.

this function can be terminated at any time by pressing the [CANCEL


COMMAND] key.

Data Cartridge Recorder The Data Cartridge Recorder (Cat. No. 1770-SB) is a peripheral device used for
program storage and retrieval. It connects to Channel C of the Industrial
Terminal and uses a magnetic data cartridge tape to record (dump), load and
verify Processor memory.

The Data Cartridge Recorder can be operated from the 1770-T3 Industrial
Terminal keyboard. It can also be operated in the same manner as a Digital
Cassette Recorder (Cat. No. 1770-Sa) using both the recorder control panel and
the Industrial Terminal Keyboard. In either case, the baud rate switch in the
Data Cartridge Recorder must be set to 1200.

It should be noted that when a data cartridge tape is inserted and the recorder in
ON, the recorder will automatically rewind the tape to correct tape tension.
This process should not be confused with the dump, load or verify operation.

Remote operation of the Data Cartridge recorder from the industrial Terminal
keyboard is discussed in the following paragraphs. For operation in the same
manner as a Digital Cassette Recorder, refer to Digital Cassette Recorder.

Dumping Memory to Data Cartridge Tape

Data Table, User program and messages can be recorded onto a data cartridge
tape and the transfer verified by a single command from the Industrial Terminal.
The Processor should be in PROGRAM mode to ensure that the Data Table
values are not changing.

Once the cursor is positioned on the first instruction in User Program, the
Cartridge Dump command is initiated by pressing [RECORD][SHIFT][B].
1019
Chapter 10
Peripheral Functions Including Report
Generation

As memory content is being recorded on tape, the Industrial Terminal will count
and display the number of User Program and Data Table words.

After memory content has been recorded, the tape is automatically rewound and
the content verified with the content in memory to be sure that no discrepancies
occurred during the recording operation. During verification, the number of
User Program and Data Table words are again counted and displayed.

Once verification is complete, a message stating the number of discrepancies


between processor memory and tape content, if any, will be displayed. if one or
more discrepancies are found, the entire recording operation should be repeated.

This command can be aborted any any time by pressing [CANCEL


COMMAND].

Loading Memory From Data Cartridge Tape

Processor memory can be loaded from a data cartridge tape and the transfer
verified automatically by pressing [RECORD][SHIFT][A] on the Industrial
Terminal keyboard. The Processor must be in PROGRAM mode.

The Data Table must be configured to the size which will match the Data Table
of the taped program. Set the Data Table size as described is Section 9.1 Data
Table Adjustment. If the size of the Data Table on tape is not immediately
available and the Processor is configured differently, the load operation will
abort automatically. The Industrial Terminal will display the Data Table
configuration contained on the tape along with a prompt to configure the
Processor Data Table.

The number of Use Program and Data Table words are counted and displayed
while memory content is loaded and again during verification. After
verification, a message displays the number of discrepancies found, if any.
Instructions in memory that don’t match corresponding instructions on the data
cartridge tape can be located and displayed using the procedure described in
Displaying and Locating Errors. The discrepancies can be corrected if a hard
copy printout of the program is available showing the correct instructions.
Otherwise erase the entire memory (put the cursor on the first instruction and
press [CLEAR MEMORY] [9][9] and repeat the memory loading procedure.

This command can be aborted at any time by pressing [CANCEL


COMMAND].

1020
Chapter 10
Peripheral Functions Including Report
Generation

Data Cartridge Verification

This command is used to verify User Program and messages in processor


memory with the content in data cartridge tape, or vice versa. Although the
Data Table size and configuration are checked, the Data Table content is not
verified.

With the Processor in any mode, verification can be done by pressing the keys
[RECORD] [SHIFT] [C] on the Industrial Terminal Keyboard. The number of
User Program and Data Table words are counted and displayed while tape
content and memory content are being compared. When verification is
complete, the number of discrepancies, if any, is displayed. If discrepancies are
found, either the tape can be re-recorded using the Dumping Memory procedure
in Dumping Memory into Data Cartridge Tape, or the Processor memory can be
corrected using the procedure in Displaying and Locating Errors.

The verification process can be aborted at any time by pressing [CANCEL


COMMAND].

Ladder Diagram Dump Accessible in any mode, the Ladder Diagram Dump command is used to print
out a hard copy of the User Program using a peripheral printer that is connected
to Channel C.

After setting the baud rate for the printer, this command is accessed by pressing
the keys [SEARCH][4][4] on the PLC-2 Overlay. The printout will begin from
the current rung, allowing all or part of the program to be printed.

When the printout is complete, this command is automatically terminated. This


command can be terminated before completion by pressing [ESC] on the
peripheral device or [CANCEL COMMAND] on the PLC-2 Overlay.

Total Memory Dump The Total Memory Dump command is accessible in the PROGRAM mode only.
it is used to print out a hard copy of the Data Table, User Program and
Messages using a peripheral printer connected to Channel C.

After setting the baud rate for the printer, this command is accessed by pressing
the keys [SEARCH][4][5] on the PLC-2 Overlay and will print out the complete
memory, regardless of cursor position (1770-T3, only).

1021
Chapter 10
Peripheral Functions Including Report
Generation

The Data Table will be printed in hexadecimal. The bit pattern for each Data
Table word will be as shown in Figure 10.8. In each row, the 4-digit octal word
address is the address where the left-most hex value is stored. For example, the
hex values ECCB16 and 024C16 are stored in word addresses 00208 and 00258,
respectively. For more information on the hexadecimal numbering system, refer
to Numbering Systems.

Figure 10.8
Data Table Printout in Hexadecimal

DATA TABLE
Word Data
Addr
0010 26C1 A4FF 952B F073 D572 43CE FFFF 300F
0020 ECCB 9A00 4721 002F 5101 024C 312B AC0B
" " " " " " " " "
" " " " " " " " "
" " " " " " " " "
0177 2EC4 6F6D ABCD 1C2D 4FGC D10D 21F6 5BA2
" " " " " " " " "
" " " " " " " " "

The Data Table printout will be followed by the User Program in ladder
diagram and block format. The messages will be printed out and identified by
number.

When the printout is complete, this command is automatically terminated. The


Total Memory Dump Command can be terminated prior to completion by
pressing [ESCV] on the peripheral printer or [CANCEL COMMAND] on the
PLC-2 Overlay.

1022
11
Chapter

Special Programming Techniques

General There are several programming techniques that offer versatile control of the
process or machine operation. They include:
Scan Counter
Block Transfer (1772-LN3 Processor Module)
One-Shot
Programming 0.01-Second Timers

Scan Counter The scan counter is a programming technique that can be used where timing
may be an important consideration. For example, it can be used in diagnostics
to compute and compare average scan times of an operation with predicted scan
times, and to detect if repeated requests for an operation are being ignored due
to a malfunction.

The scan counter is programmed using two rungs as shown in Figure 11.1. The
first rung contains optional condition instructions and a CTU instruction whose
Preset value equals the number of scans to be counted. the second rung is
started with a BRANCH END instruction to open the rung and is ended with the
same CTU instruction.

Figure 11.1
Scan Counter

050
CTU
Condition(s) PR 040
(Optional) AC 000
050
Branch End ? CTU
Instruction
PR 040
AC 000

When the first rung goes TRUE, bit 17 of the CTU instruction is set to 1 and the
CTU instruction Accumulated value will increment one count. The second rung
will never go TRUE because it is an open rung. It is used to reset the CTU
instruction Enable bit (bit 17) to zero so the CTU instruction can increment its
count during the next scan. The CTU instruction will continue to increment
past the Preset value unless it is reset by a CTR instruction.

111
Chapter 11
Special Programming Techniques

Block Transfer (1772LN3 Block Transfer can be performed with the 1772-LN3 Processor and any Bulletin
Processor Module) 1771 I/O Module with Block Transfer capability.

Introduction

Block Transfer is a programming technique used to transfer up to 64 16-bit


words of data in one scan from I/O modules to the Data Table and vice versa. It
is used with intelligent 1771 I/O modules such as the Analog, Thermo-couple,
or Encoder/Counter modules which have this capability. Block Transfer can be
compared with single transfer programming in which only one word of data is
transferred per scan.

Block Transfer can be performed as a Read, Write or Bidirectional operation,


depending on the I/O Module being used. An input module uses the Block
Transfer Read operation, an output module uses the Block Transfer Write
operation and a Bidirectional module can use either or both the Read and Write
operations. During a Read operation, data is read into the Processor’s memory
from the input module. during a Write operation, data is written to the output
module from the Processor’s memory.

The number of words transferred in one scan can range from 1 to 64, depending
on the I/O module being used. The time required to perform Block Transfer
depends on the number of words being transferred.

The Processor uses two I/O Image Table bytes to communicate with Block
Transfer modules. The byte corresponding to the module’s address in the
Output Image Table (Control byte) contains the Read or Write bit for initiating
the transfer of data. The byte corresponding to the module’s address in the
Input Image Table (Status byte) is used to signal the completion of the transfer.

112
Chapter 11
Special Programming Techniques

Whether the upper or lower byte of the I/O Image Table word is used depends
on the position of the module in the Module Group. when in the lower slot, the
lower byte is used and vice versa. See Figure 11.2. For double slot modules,
the slot number must always be entered as a “0” because the overlapping of
module groups is note permitted.

Figure 11.2
Module Position/Image Table Byte Relationship

DATA TABLE
I/O Rack

ÉÉÉÉÉ
Output Image 17
Bit Numbers
10 07 00 ÉÉÉÉÉ
ÉÉÉÉÉ
ÉÉÉÉÉÉ ÉÉÉÉÉ
Table Word, 010
Upper byte Output Image Table

ÉÉÉÉÉÉ
ÉÉÉÉÉÉ
012
ÉÉÉÉÉ
ÉÉÉÉÉ
Control Byte

017 ÉÉÉÉÉ
ÉÉÉÉÉ
Block
Transfer
Module

Input Image
Table, Word,
ÉÉÉÉÉÉ
Input Image Table
110
ÉÉÉÉÉ
ÉÉÉÉÉ
ÉÉÉÉÉÉ ÉÉÉÉÉ
Upper byte Module
Status Byte Position

ÉÉÉÉÉÉ 112
ÉÉÉÉÉ
Image table
byte
117
ÉÉÉÉÉ relationship

ÉÉÉÉÉ
ÉÉÉÉÉ Lower Upper
Slot Slot
The upper byte of the I/O image table words are used when the
module is in the upper slot and vice versa. 10785I

When Block Transfer is requested in the ladder diagram program, the output
part of the next I/O scan is interrupted (Figure 11.3). If the I/O module is ready
for Block Transfer, the transfer will be performed. When the transfer of data is
complete, the Read bit (or Write bit) is set in the corresponding Input Image
Table byte. The processor then continues its normal scan.

113
Chapter 11
Special Programming Techniques

Figure 11.3
Block Transfer Request

Block Transfer Request

Output Input
Scas Scan

Program Scan 10377I

The I/O module may not be ready for Block Transfer 100% of the time. For a
short time, the I/O module must preform internal checks on its own operation.
If Block Transfer is requested when the I/O module is not ready, the Read or
Write bit in the corresponding Input Image Table byte (done bit) is held at zero.
The Processor will then continue with its normal I/O scan.

A Block Transfer read or write operation is requested by only one rung of


program. A bidirectional Block Transfer is requested by two program rungs.
Other support rungs, described later, may be necessary to support the Block
Transfer operation. Of these support rungs, buffering data must be programmed
to ensure validity of Block Transfer data.

114
Chapter 11
Special Programming Techniques

Block Transfer Rungs

The Block Transfer rung must be programmed in a certain format (Figure 11-4).
It consists of condition instructions that are optional, two GET instructions and
an OUTPUT ENERGIZE instruction.

Figure 11.4
Block Transfer Rung

WYZ XYZ 0RGST


G G
RGS ABC

Condition(s)
(Optional)

WYZ = First available T/C Address (Accumulated Area)


XYZ = T/C Address 1008 higher than WYZ (Preset Area).
RGS = Location of Block Transfer module were R=Rack, G=Module Group and S=Module Slot.
S is a zero for the left slto and a one for the right slot. For a 2slot module,
S is alwyas zero.
ABC = Starting address where data is transferred to/from.
0RGST=OUTPUT ENERGIZE initiates Block Transfer where O=Output byte, R=Rack,
G=Module Group, S=Module SLot, T=6 for write operation; 7 for read operation

FIRST GET INSTRUCTION

The first GET instruction (Figure 11.4) is used to identify the rack location of
the block transfer module. The location must be stored in the first available
address in the timer/counter Accumulated value area of the Data Table, starting
with 0308. When more than one block Transfer module is used, consecutive
addresses must be assigned in this area.

As its “data”, the first GET instruction stores the location of the Block Transfer
module by R=Rack, G=Module Group and S=Slot number. When Block
Transfer is performed, the Processor searches the timer/counter Accumulated
value area for a match of the module’s Rack, Group and Slot number.

115
Chapter 11
Special Programming Techniques

SECOND GET INSTRUCTION

The second GET instruction (Figure 11-4) must be assigned an address in the
timer/counter Preset area of the Data Table, 1008 words above the first GET
address.

As its “data”, the second GET instruction stores a Data Table address that
designates the beginning of the area reserved for Block Transfer data. During a
read operation, data is loaded into consecutive word locations starting with the
designated address. During a write operation, data is sent to the module from
consecutive word locations starting with the designated address.

When reserving an area for Block Transfer data, an appropriate address must be
selected to ensure that a) none of the Block Transfer data can overrun word
0778 or the upper boundary of the Data Table, word 1778; (if so, the transfer is
prevented) and b) that none of the Block Transfer data can write over addresses
assigned to other functions. The reserved area begins with the starting address
of the Block Transfer data (ABC in Figure 11-4) and requires consecutive word
storage locations equal to the number of words to be transferred.

OUTPUT ENERGIZE INSTRUCTION

The OUTPUT ENERGIZE instruction (Figure 11-4) is used to initiate Block


Transfer. It is given an address that indicates the module location and the type of
Block Transfer operation. the first digit of the address is always “0” for output
byte, even though an input or output Block Transfer module can be used. The
next three digits identify the module location by Rack, Group and Slot. The last
digit is either a “6” for a write operation or a “7” for a read operation. When
Block Transfer is successfully completed, the Read bit (or Write bit) is set in the
corresponding Input Image Table byte.

116
Chapter 11
Special Programming Techniques

PROGRAMMING EXAMPLE

An example rung for performing a Block Transfer Read operation and the Data
Table areas used by the rung are shown in Figure 11.5. The following
parameters have been chosen for the example:

Figure 11.5
Data Table Locations for a Block Transfer Read Operation

010
Data Table Output image table
Output R byte contains read
Image Block Length enable bit and block
Table 1 012
Code length in Binary Code

017

027 Storage word


1 2 1 030 contains module
address in BCD
Timer/
Counter
Accumulated 060 First word of
Area Block Transfer Data
Block Transfer Data
067 Last Word of Data

110
R Input image table
Input byte contains
Image 1 112 done bit
Table
117

0 6 0 130 Storage word contains


address of first data
Timer/ word in BCD
Counter
Preset
Area
R = BIT 17 = Read

Optional Condition

113 030 130 012


G G
02 121 060 17

10786I

117
Chapter 11
Special Programming Techniques

Module Address 121

Storage word containing the Module Address 030

Address of first word of Block Transfer data 060

Storage word containing address


of first word of data 130

The module is located in Module Group 2, Slot 1. Therefore, the Control and
Status bytes corresponding to the module’s address in the Output and Input
Image Tables are at word address 0128 and 1128 (upper bytes) respectively. The
address of the Read bit and Done bit is 012/17 and 112/17, respectively.

During the program scan when input switch 11302 is closed, the rung is enabled
and Read bit 012/17 is set to “1”. In the next scan of the Output Image Table,
the upper byte data of word address 012 is sent to the module. The module
responds that it is ready for transfer. The Processor interrupts the Output Image
Table scan and starts searching the timer/counter Accumulated area of the Data
Table. It finds the Module Address 1218 in word address 0308. The Processor
then transfers the data from the module to Data Table addresses 0608 through
0678. When the number of words to be transferred is not programmed, the
module will transfer its maximum (default) number which in this example was
eight.

118
Chapter 11
Special Programming Techniques

BIDIRECTIONAL BLOCK TRANSFER

A bidirectional operation requires one rung for a read operation and one rung
for a write operation. Consecutive addresses in the timer/counter area of the
Data Table should be selected for the GET instructions (Figure 11.6). for
example, the first GET instruction of both rungs should be assigned consecutive
word addresses such as 0408 and 0418. Both will have the same “data” to
identify the module location at address 1308.

Figure 11.6
Data Table Locations for Bidirectional Block Transfer

R W
1 1 013

R W
1 1 3 0 040
1 1 3 0 041
5 words of Data are to be written to
the bidirectional Block Transfer module
stargin from word 0508
050
Block Transfer Write
Data 5 words of Data are to be read from
060
Block Transfer Read the module and loaded into the Data table
Data starting at word 0608

1 1 113 Corresponding Done Bits are set


after successful transfer occurs

0 5 0 140
0 6 0 141

040 140 013


G G
130 050 06
041 141 013
G G
130 060 07
040

16
041

17

10787I

119
Chapter 11
Special Programming Techniques

The second GET instruction of both rungs will be assigned addresses 1008
words above the first GET instructions. As “data”, they will store the starting
address for Block Transfer data such as 0508 and 0608.

The OUTPUT ENERGIZE instruction is addressed for a read operation in one


rung and a write operation in the other rung. To let the Processor know whether
a read or write operation is to be performed, bit 16 or 17 of the first GET
instructions must be set ON. This can be done by programming an OUTPUT
ENERGIZE or OUTPUT LATCH instruction unconditionally. For example, bit
16 of word 0408 is set ON to indicate a write operation. Bit 17 of word 0418 is
set ON to indicate a read operation.

Support Rungs

there are additional techniques that can be used to support the Block Transfer
operation:
Loading Zeros
Setting the number of words to be transferred
Buffering data
Of these support rungs, buffering data must be programmed to ensure the Block
Transfer data is valid. Other techniques, such as an IMMEDIATE OUTPUT
instruction or a Scan Monitor, can also be programmed. The IOT instruction is
used to request Block Transfer more than once per scan by assigning it the word
address corresponding to the module’s location. A Scan Monitor is used to
monitor the number of scans that have occurred between each Block Transfer
operation. For programming information on the Scan Monitor, refer to the
respective User’s Manual for the Block Transfer module.

LOADING ZEROS

When programming Block Transfer rungs, the first address(es) in the


timer/counter Accumulated areas of the Data Table starting at address 0308
must be used to store the location(s) of the Block Transfer module(s). After the
last module location is stored, the next consecutive address should be loaded
with zeros. This serves as a boundary to prevent the Processor from searching
the remaining timer/counter Accumulated value addresses where it could by
chance, find a BCD value identical to the Rack, Module Group and Slot number
of a Block Transfer module.

The boundary word data bits can be set to zero manually using Bit Manipulation
[SEARCH [5][3], or by GET/PUT transfer. The GET/PUT transfer can be
programmed by assigning the GET and PUT instructions to the address
immediately following the last Block Transfer Data Address (Figure 11.7). The
value of the GET instruction can be set to 000 when programmed.

1110
Chapter 11
Special Programming Techniques

Figure 11.7
Loading Zeros

Data Table
First word in accumulated
1 0 0 030 area of Data Table
1 1 0 031

0 0 0 032 Last consecutive data


address
contains zeros to separate
Block Transfer addresses
from Timer, Counter and
Storage addresses
032 032
G PUT
000 000

10788I

SETTING THE NUMBER OF WORDS TO TRANSFER

Each Block Transfer module has a default value that specifies the maximum
number of words that can be transferred. Either the default value or some lesser
value can be selected. For Bidirectional Block Transfer, use the default value of
the module. Because the default value can vary from one kind of module to
another, consult the appropriate module documentation.

When a lesser number of words are desired, the number of words to be


transferred must be set when programming the Block Transfer support rungs.
The number of words is stored in the upper or lower Output Image Table byte
that corresponds to the module’s location. The appropriate bits must be set ON
to specify a binary value that equals the number of words to transfer
(Figure 11.8). these bits can be set ON by programming unconditional
OUTPUT ENERGIZE or OUTPUT LATCH instructions.

1111
Chapter 11
Special Programming Techniques

For example, 5 words can be transferred by setting bits 00 and 02 high


unconditionally in Output Image Table word 014. The binary equivalent of 5,
as stated in the look-up table, is 000101.

If the number of words to be transferred or the location of Block Transfer data


must change at different times, special programming techniques must be used.
Refer to the appropriate documentation for the Block Transfer module for these
programming technique.

Figure 11.8
Setting the Number of Transfer Words

Read 5 words
from module Bit Pattern
# Words
To Transfer 7 6 5 4 3 2 1 0
DEFAULT 0 0 0 0 0 0
RW
1 0 0 0 0 0 1
1 0 0 0 0 1 0 1 014
2 0 0 0 0 1 0
3 0 0 0 0 1 1
4 0 0 0 1 0 0
1 4 0 030 5 0 0 0 1 0 1

62 1 1 1 1 1 0
050
63 1 1 1 1 1 1
Block Transfer Data
64 0 0 0 0 0 0
054

1 1 0 1 114

0 5 0 130

014
Sets the
00
014 number
of words
02
030 130 014
G G
140 050 07 10789I

1112
Chapter 11
Special Programming Techniques

BUFFERING DATA

The purpose of Block Transfer data buffering is to allow the data to be validated
before it can be used. Data that is read from the Block Transfer module and
transferred to Data Table locations must be buffered. Data that is written to the
module need not be buffered because Block Transfer modules perform this
function internally.

Transferred data is buffered to ensure that both the transfer and the data are
valid. As an example, readings from an open-circuited temperature sensor
(invalid data) could have a valid transfer from an analog input module to the
Data Table. The Processor examines data-valid and/or diagnostic bits contained
in the transferred data to determine whether or not the DATA is valid. The Read
bit (or Write bit) is set in the Input Image Table byte if the TRANSFER is valid.

The data-valid and/or diagnostic bits differ for each Block Transfer module.
Some modules set one or both for the entire group of words transferred, while
others set a data-valid diagnostic bit in each word. Refer to the respective User’s
Manual for the Block Transfer module to determine the correct usage of the
diagnostic and/or data valid bit(s).

One technique for buffering data is to store the transferred data in a temporary
storage location. If the data is valid, it is immediately transferred to another
storage location in the Data Table where it can be used. If invalid, it is not
transferred but written over in the next transfer. Another technique uses only
one storage location. This technique prevents invalid data from being operated
upon by preconditioning the rungs that would transfer data out of storage one
word at a time.

Data can be moved from storage word-by-word using GET/PUT transfers.


Generally, this method is used when one diagnostic bit is contained in each
word. Diagnostic bits are examined as conditions for enabling the GET/PUT
transfers.

1113
Chapter 11
Special Programming Techniques

Figure 11.9
Buffering Data

R
Block Length
1 0 Code
014 Data in the Buffer File,
050052, will be moved
to 150152 when:

1 4 0 030 A. Done Bit 114.07


is set (valid transfer
and)
050
Block Transfer Data (Buffer) B. Diagnostic Bit is TRUE
for each word to be
052 moved in RUngs 57
R
(valid data)
1 0 114 Done Bit

0 5 0 130

150
Block Transfer Data (valid)
152

010 114 010


Rung 1
00 07 02
010
Rung 2 U
00
111 030 130 014
Rung 3 G G
11 140 050 07
014 010
Rung 4 L
07 00
010 050 150
Rung 5 G PUT
02 111 111
010 051 151
Rung 6 G PUT
02 222 222
010 052 152
Rung 7 G PUT
02 333 333

Diagnostic Bit 10790I

1114
Chapter 11
Special Programming Techniques

The example in Figure 11.9 shows the memory map and ladder diagram rungs
for buffering 3 words of data that are read from the Block Transfer module. Two
storage locations are used. The data is read and buffered in the following
sequence:

1. When Rung 3 goes TRUE, bit 014/07 (the Read bit) will be turned ON and
Block Transfer will be requested. This latches ON storage bit 010/00 in
Rung 4.

2. Block Transfer will be requested during the program scan. The transfer
will be performed during an interruption of the next I/O scan. Data from
the module will be loaded into words 0508-0528. When Block Transfer is
complete, the Read bit 114/07 is set in the Input Image Table byte. This
indicates Block Transfer was successfully performed. The Processor then
continues with the I/O scan and program scan.

3. During the Program scan, Rung 1 will be TRUE because bit 010/00 is still
latched ON and bit 114/07 is ON because Block Transfer was performed.
This will turn bit 010/02 ON. In Rung 2, bit 010/00 is then unlatched.

4. In Rung 5, bit 010/02 is still ON and a diagnostic bit is examined to ensure


the data read from the module is valid. Assuming the data is valid, the
diagnostic bit will be ON and the data will be transferred from word 0508
to 1508. In rungs 5 and 6, the data in words 0518 and 0528 will be
transferred to words 1518 and 1528 if the diagnostic bits are ON.

OneShot The one-shot programming technique is used for certain applications to set a bit
ON for one scan only. there are two types of one-shots that can be
programmed:
Leading Edge
Trailing Edge

Leading Edge OneShot

A leading edge one-shot is used to set a bit ON for one scan when its input
condition has made a FALSE-to-TRUE transition. The FALSE-to-TRUE
transition represents the leading edge of the input pulse. The programming for
a leading edge one-shot is shown in Figure 11.10.

1115
Chapter 11
Special Programming Techniques

Figure 11.10
Leading Edge OneShot

Oneshot
112 011 253. Storage
Bit

04 14 00
253 011
L
00 14
253 011
U
00 00
253
Oneshot
Output
00
Leading Edge

Bit 112/04 ON
OFF Input Pulse

Bit 253/00 ON
OFF One Scan

When bit 112/04 makes a FALSE-to-TRUE transition, the one-shot bit (bit
053/00) is set ON for one scan. The length of time bit 112/04 remains ON does
not affect the one-shot bit due to the next two rungs. bit 011/14 will be latched
ON when bit 112/04 is ON or bit 011/14 will be unlatched when bit 112/04 is
OFF. During the next scan, either set of conditions will prevent bit 053/00 from
being set ON. The one-shot bit is set ON for another scan only when bit 112/04
makes another FALSE-to-TRUE transition.

1116
Chapter 11
Special Programming Techniques

Trailing Edge OneShot

A trailing edge one-shot is used to set a bit ON for one scan when its input
condition has made a TRUE-to-FALSE transition. The TRUE-to-FALSE
transition represents the trailing edge of the input pulse. Programming for a
trailing edge one-shot is shown in Figure 11.11.

Figure 11.11
Trailing Edge OneShot

112 011
L
04 14
Oneshot
112 011 253 Storage
Bit
04 14 00
253 011
U
00 14
253
Oneshot
Output
00
Trailing Edge

Bit 112/04 ON
OFF Input Pulse

Bit 253/00 ON
OFF One Scan

When bit 112/04 goes TRUE, bit 011/14 is latched ON. As soon as bit 112/04
makes a TRUE-to-FALSE transition, the one shot bit (bit 053/00) is set ON and
bit 011/14 is unlatched. Bit 053/00 will remain ON for only one scan. The
input bit 112/04 must go TRUE and FALSE to set the one-shot bit ON for
another scan.

1117
Chapter 11
Special Programming Techniques

Programming 0.01 Second Introduction


Timers
The Bulletin 1772 Mini-PLC-2 programmable controller permits the user to
enter On Delay Timer (TON), Off Delay Timer (TOF) and Retentive Timer
(RTO) Instructions with a 0.01-second time base. These are also referred to as
10 millisecond (10-msec) timers.

Timers with a 10-msec time base provide the user with greater timing resolution
and accuracy than is possible with a 0.1-second time base. Ten-msec timers are
used when timer delays from 0.02 to 9.99 seconds are required.

Time Base Selection

When a timer Instruction is entered into a program, the programmer must


specify:
Timer word address
Time base
Preset value
Accumulated value (for RTO only)
Note that the user selection of preset value and time base are closely related.
The Processor executes the time-delay functions by incrementing the timer
accumulated value one unit for each time base unit that elapses. In other words,
the preset value represents a specific number of increments of the time base.

Note, however that the preset value is not an absolute length of time. For
example, if the present value is 010, the time delay will be:
10 seconds if a 1.0-second time base is entered
1.0 second if a 0.1-second time base is entered
0.10 second if a 0.01-second (10-msec) time base is entered
The smaller the time base, the larger the preset value must be to obtain the same
time delay. To obtain a 5-second time delay, the program could contain:
1.0-second time base and preset = 005
0.1-second time base and preset = 050
0.01-second time base and preset = 500

1118
Chapter 11
Special Programming Techniques

Timer Accuracy

Given any preset value, a Mini-PLC-2 controller timer is accurate to within one
interval of its time base. Specifically, the timed interval does not exceed the
preset interval, but it may be as much as 1 time-base unit shorter than the preset.
These examples illustrate this accuracy:

TON: Time base 1.0-second; preset value 100. This time interval will be
greater than 99 seconds, but less than or equal to 100 seconds as given in the
equation below.

99 seconds<TON timed out<100 seconds

TON: Time base 0.1-second; preset value 100. This time interval will be
greater than 9.9 seconds, but less than or equal to 10.0 seconds as given in
the equation below.

9.9 second<TON timed out<10.0 seconds

TON: Time base 10-msec; preset value 100. This time interval will be
greater than 0.99 seconds, but less than or equal to 1.00 second as given in
the equation below.

0.99 seconds<TON timed out<1.00 second

Note that special programming techniques are required to use the 10-msec timer
in a program. These techniques are explained in Scan Time and Program
Execution, 11.4.6 and 11.4.7 below.

Programmed timers examine internal timing pulses of the Mini-Processor.


(Refer to Figure 11.12.) A change in the state of this internal clock causes the
timer to increment its accumulated value. Note, however that the timing pulses
are continuous and are only examined by the Mini-Processor when a timer
Instruction is being executed in the program. As Figure 11.12 shows, when the
Mini-Processor initially examines this internal clock, the clock may have just
changed state or may be just about to change state. This variable makes it
possible for the inaccuracy of up to 1 time-base increment.

1119
Chapter 11
Special Programming Techniques

Figure 11.12
Timing Diagram

Example: [TON], Preset = 003; any time base


One unit of time base
Internal
Clock 1
Pulses 0

1
Enabled
Bit 17 0

Timed 1
Bit 15 0
T=3
2<T<3
Begin Timing
10667I

Note that these timing accuracies refer only to internal Mini-Processor


operation. That is, these intervals refer to the length of time which occurs
between the moment that a timer is initialized (bit 17 set) and the moment that a
timed interval is complete (bit 15 set). Other factors add to this timer
inaccuracy. Chief among these are the response time of the actual hardware
devices controlled and monitored by the Mini-PLC-2 controller. (Refer to
Hardware and Processor Considerations below.)

The user is urged not to over specify timing accuracy. In many applications
timing within 0.1 second will provide accuracy comparable to, or better than,
typical electromechanical timing relays. In general, these rules may be applied:
For delays of 99 to 999 seconds, use the 1.0-second time base
For delays of 2.00 to 99.9 seconds, use a 0.1-second time base
For delays of 0.02 to 2.00 seconds, use the 10-msec time base
When time delays are incorporated in a program to provide a warm-up or
initializing period, or to prevent the simultaneous application of power to
high-current devices, inaccuracies on the order of 50 to 250 msec are probably
insignificant. The 1.0- or 0.1-second time bases are more than adequate for
these uses. Applications for the 10-msec timer are discussed below.

1120
Chapter 11
Special Programming Techniques

Typical Applications

In general, 10-msec timers are used for these functions:

Monitor events on a high-speed assembly or transfer line, such as that used in


canning and bottling machines

Generate short-duration pulses for accurate positioning control

For example, on a bottling or canning line, photoelectric sensors or


electromagnetic proximity switches can be used to detect the movement of
bottles. Each time a bottle passes a detector, an On Delay or Off Delay timer
can be started. The next bottle down the line will turn the sensor on (or off),
thereby resetting the timer. Once the second bottle is past the sensor, the timer
is started again. If the bottles are moving too slowly, or if a bottle is missing,
the timer will time out. The timed bit in the Data Table of the Mini-PLC-2
controller can be programmed to set off an alarm, or to stop the machine until
the problem is corrected.

With the speeds encountered on a typical high-speed bottling machine, a timer


with a 0.1-second time base would probably be too slow for this application.
By computing the minimum bottle travel speed, the maximum time between
bottles could be determined. The time in 10-msec increments could then be
entered as the timer preset.

As another typical example, 10-msec timers could also be used to operate


sorting mechanisms for high speed machines. Two methods could be used.

In the first method, the sort mechanism could be energized, for example, 60
msec after a REJECT is sensed by a particular sensor.

In the second method, the REJECT sense switch could immediately apply a
40-msec pulse to the sort mechanism. In this case, the pulse is just long enough
for the mechanism to pull only one rejected bottle off the line.

Yet another example for the generating of short-duration pulses can also be
found in machine tools and similar applications requiring accurate positioning
control. Typically, 10-msec timers are used to generate one short duration
pulse, or a series of pulses, when a limit switch or proximity switch detects end
of travel, depth reached, or similar data. Detection that machining depth has
been reached could, for example, generate a 130-msec pulse to the motor
reverse circuit, thus plugging or braking the spindle with great accuracy.

1121
Chapter 11
Special Programming Techniques

Programmable control offers additional advantages in these applications. For


example, consider a bottling machine capable of filling and capping 12-ounce
and 16-ounce bottles. The larger bottles may move more slowly, or the spacing
between bottles may be different. Detection of 16-ounce bottles could cause the
Mini-PLC-2 Processor to GET different timer preset values and PUT them into
monitoring and sorting timers such as those discussed above.

Changing the timer presets in this manner also enables the programmer to find-
tune the system without physically adjusting the locations of detection devices:

Hardware and Processor Considerations

When considering use of the 10-msec timer, the user must consider other timing
factors, both within the programmable controller and in the hardware devices:

Every input device requires a length of time to change state. Photoelectric


devices and electromagnetic proximity switches typically operate in the
range of 3 to 50 msec. Mechanical switches and magnetic control relays can
require longer times for operation.

Some Input Modules may provide a slight delay resulting from the input
filter time constant (typically 10-25 msec).

The execution of each program Instruction requires a certain length of time.


instruction execution times are discussed below in relation to program scan
time computation.

Scan time (I/O scan + program scan) depends on the number and type of
Instructions, as discussed below. Incorporation of Immediate Input and
Immediate Output Instructions can compensate for the length of scan time.

DC Output Modules typically respond in 1 to 5 msec. AC Output Modules


respond in 3 to 10 msec, depending on the instantaneous value of the AC
wave when the turn-on signal is applied.

User output devices may take 50 to 100 msec or longer to operate after
current is applied. Inductive loads, or devices with substantial surge
suppression circuitry, may also have longer response time.

Each of the items discussed above will have an impact on the actual time delay
obtained from a programmable timer. Selection of fast-response input devices
is the responsibility of the user, and is beyond the scope of this document. For
selection of suitable I/O Modules contact your local Allen-Bradley
representative for further assistance.

1122
Chapter 11
Special Programming Techniques

The remainder of this section will discuss programming techniques which the
programmer must use to effectively program the 10-msec timer. The required
programming is based on 2 concepts:
Scan time
Sequential program scan

Scan Time

The Mini-PLC-2 Processor performs an I/O scan and then a program scan, in
sequence. Scan time is the sum of the times required for both these scans.
(Note that the Processor does not scan unused memory, nor does it scan that
portion of the memory used to store Messages.)

During an I/O scan, the Processor examines Output Image Table bits, and
updates or corrects the ON/OFF signals applied to the Output Modules. It also
examines the ON/OFF signals from the Input Modules and updates the ON/OFF
status of the corresponding Input Image Table bits.

During a program scan, the Processor scans each instruction in the Program,
one at a time. It executes Examine and Branching Instructions, but it executes
Output Instructions only if the rung is TRUE. The sequential nature of this scan
is discussed further below.

Scan time cannot be specified exactly for all processors because each user
program is different. The length of the scan time depends on both the number
and the type of Instructions the program contains. (Actual scan time
computation is discussed below.) For purposes of discussion, scan time is
generally assumed to be about 25 msec, though in practice it will range from
about 25 msec to 50 msec., or more in certain extreme cases.

Program Execution

The second consideration for 10-msec timer programming is the sequential


nature of the program scan. The Processor executes one program Instruction at
a time. After it executes and Instruction, it cannot examine that Instruction
again until the next scan of memory. With respect to timer Instructions,
particularly, the Processor cannot increment the accumulated value except when
it is executing that instruction.

Furthermore, the only states of any memory bits that affect the execution of any
single Instruction are the states those bits have at the instant the Processor
executes the Instruction. If a bit changes state after the Instruction is executed,
the change of state will not affect the instruction until it is executed the next
time.

1123
Chapter 11
Special Programming Techniques

For example, suppose one program Instruction is Examine On 110/13. If the


device is open, the Processor will detect an OFF signal from the Input Module
during the I/O scan, and will clear (reset to “0”) the corresponding Input Image
Table bit. After the I/O scan, the program scan begins.

Suppose, in this case, that the input device wired to a terminal at address 110/13
closes when the program scan begins. The corresponding Image Table bit will
remain “0” (device is open) until the next I/O scan after the current program
scan is finished, or until the Processor executes an Immediate Input Instruction
address to word 110.

The Processor can also update a timer only at the instant it is executing that
timer instruction. Remember that an integral timing clock (see Section 11.4.3)
puts out pulses for the 1.0-second, 0.1-second and 10-msec timers. When 1.0-
second and 0.1-second timers are used in a program, the timing pulses are
always longer than the Processor scan time. No special programming is
required; these timers will not miss a timing pulse.

Timing pulses for the 10-msec time base, however, are usually shorter than the
program scan time. Since the Processor can only increment a timer while it is
executing that Instruction, the 10-msec timer could miss one or more timing
pulses on each program scan. The solution is to instruct the Processor to
execute the timer Instruction often enough that it will not miss a pulse.

Programming Compensation

In order to compensate for the length of the scan time and to assure accurate
timing, 10-msec timer programming must be repeated several places in the
program.

A typical program using the total memory can nominally be assumed to have a
scan time of less than 30 msec. (See Program Scan Time Computation) In such
a program, enter the same timer rung at 3 different places in the program: once
near the beginning of the program, once near the middle, and once near the end.
The Processor will update the timer accumulated value each time it scans that
timer Instruction. Refer to Figure 11.13 and note the following:

The rung must be identical each time it is used: the same Examine
Instructions to condition the rung, the same timer word address, the same
time base, and the same preset value.

Use this technique only for 0.01-second timers. (The program scan is fast
enough to assure accurate operation of the 1.0-second and 0.1-second timers
with only one timer rung per program.)

1124
Chapter 11
Special Programming Techniques

Figure 11.13
Typical Timing Diagram for 0.01Second Timer

Scan time = 25 msec. (typical)


Start of program scan

89
msec. 0.01sec
timer rungs
Same 0.01sec.
timer rungs

89 msec. 89 msec.

Same 0.01sec timer rungs 10668I

Multiple entry of the timer rung will help to assure that the accuracy of the
timer accumulated value is within the accuracy limits discussed above.
Additional programming techniques can help to assure that output devices
controlled by the timer are energized or de-energized after as precise a time
delay as possible. The programmer may want to include:

Multiple entries of rungs which examine the timed bit of the timer to condition
an Output Energize Instruction.

Immediate Input Instructions to help assure that the timer is enabled as quickly
as possible after the external event occurs.

Immediate Output Instructions to help assure that the output device is


energized/de-energized as quickly as possible after the Mini-Processor sets the
Output Image Table bit to “1” or clears it to “0”.

Example 10-msec timer rungs are shown in Figure 11.14. In Rung No. 1, the
Immediate Input Instruction precedes the Examine Instruction addressed to a bit
in Input Image Table word 110. When used near the middle or end of a
program, the Immediate Input Instruction helps to assure that the Processor will
be executing the Instruction based on accurate data.

1125
Chapter 11
Special Programming Techniques

Figure 11.14
Example 0.01Second Programming

110 110 030


1 I TON
05 0.01
PR 025
AC 000
030 014
TON
15 05
014
2 IOT

Repeat these rungs 3 or more places in the program.


1 When used near the beginning of the program, the [I] instruction can be omitted.
2 When used near the end of the porgram, this rung can be omitted.

In Rung No. 2, the Output Energize Instruction conditioned by the timer bit
should also be repeated in the program. when used near the beginning or
middle of the program, the Immediate Output Instruction addressed to Output
Image Table word 014 will help to assure that the Output Module will respond
quickly to timer cycling.

By repeating the timer rung and related rungs, the programmer can assure that
the Processor will update timer accumulated values more frequently than the
timing pulses change state. As shown in Figure 11.13 repetition within 8 or 9
msec will be adequate for this purpose.

Program Scan Time Computation

In order to evaluate programming needs, the user may wish to calculate the
approximate scan time. An exact computation is not practical, but a reasonable
approximation can be obtained using the approximate execution times listed in
chapter 12, Table 12-1. Enter the 10-msec timer rungs 3 times per 1K (1024)
words of program, then compute the scan time. A sample computation follows:

1126
Chapter 11
Special Programming Techniques

Assume the Processor is using a 128-word Data Table and has 1024 words of
memory. If all memory words are used, the program will contain 896
Instructions. A program of this size might typically have the following
distribution:
546 Instructions x 18 µsec = 9.8 msec
306 Instructions x 28 µsec = 8.6 msec
44 Instructions x 83 µsec = 3.7 msec
Total (rounded): = 22 msec
The I/O scan time adds
approximately 1.0 msec + 1 msec

Program Panel interaction


requires about 3.0 msec + 3 msec

Total: 26 msec

If a 10-msec timer is used in a program of this duration, the timer rung and
related rungs must occur at least 3 times in the program at evenly spaced
intervals. For longer programs, it may be necessary to repeat the timer
instruction and related rungs several more times to assure that timing is
accurate.

1127
12
Chapter

Scan Time and Execution Times

General In order for the Processor to implement the User Program, it must evaluate the
action that it must take based on monitoring the status of input conditions. in
addition, it must control the status of output devices in accordance with the
program logic. Every instruction in User Program requires execution time.
Execution times vary greatly depending upon the instruction, the amount of data
to be operated on and whether the instruction is FALSE or TRUE.

Scan Time Scan time is the amount of time it takes the Processor to monitor and update
inputs and outputs, and to execute instructions in memory in accordance with
user Program. The scan is performed serially, first the I/O Image Table is
updated, (other parts of the Data Table are not scanned), then the User Program.

Scan time is typically 23 msec for a program of 900 instructions. The scan time
is increased approximately 3 msec when the Industrial Terminal is connected to
the Processor. When the Communication Adapter Module or the PLC-2
Family/RS-232-C Interface Module, 1771-KA or 1771-KG, respectively, is
connected to the Processor, the scan time is increased by approximately 5 msec.

Determination of Average Scan Time (1772LN3 Processor)

Using the scan counter described in Chapter 11, a brief program can be written
to display average scan time (See Figure 12.1). For example, the time required
to complete 1000 scans can be monitored using a timer and GET/PUT transfer
instructions. With a time base of 0.1 seconds, the average scan time can be read
directly in milliseconds.

121
Chapter 12
Scan Time and
Instruction Execution TImes

Figure 12.1
Scan Time Program

050
1 CTU
PR 999
Branch End Instruction AC 000
050
2 ? CTU
PR 999
AC 000
050 051
3 RTO
14 0.1
PR 999
AC xxx
050 050 Store 1 Store 2 Store 3
4 : :
14 xxx 010 xxx . xxx

050 051
5 RTR
14 PR 999
AC 000
050 050
6 CTR
14 PR 999
AC 000

The scan time is displayed as the timer Accumulated value beneath the GET or
PUT instruction.

NOTE: The displayed average scan time includes both the I/O scan time of
approximately 1 msec and the User Program scan time.

WARNING: : The lower limit of input device cycle time


should not be less than the scan time of the Processor. If so,
incorrect input data could be used during program execution.
This could cause unpredictable machine operation and possibly
cause damage to equipment and/or injury to personnel.

Critical inputs can be monitored and critical outputs can be controlled in an


accelerated manner using the I/O Update Instructions described in Chapter 7.

122
Chapter 12
Scan Time and
Instruction Execution Times

Watchdog Timer The Processor contains an internal watchdog timer that sets an upper limit for
the scan time. If the scan time should exceed the limit, a Processor fault would
occur and the Processor would shut down. The watchdog timer is factory set at
180 MS.

Instruction Execution Times Execution times in microseconds for each instruction are presented in
Table 12.A. Two execution times are given: when the instruction is FALSE,
and an average execution time when the instruction is TRUE. For some
instructions, the execution time will depend on other circumstances described
below.

Table 12.A
Instruction Execution Times

Approximate Execution Time per scan (in microseconds)

Instruction Name Instruction FALSE Instruction TRUE (avg)

EXAMINE ON, EXAMINE 17 17


OFF

OUTPUT ENERGIZE 28 28

OUTPUT LATCH, OUTPUT 22 27


UNLATCH

GET  28

PUT 22 36

EQUAL 36 36

LESS THAN 41 41

GET BYTE  15

LIMIT TEST 28 28

COUNTER RESET 23 35

RETENTIVE TIMER RESET 23 43

TIMER ONDELAY 45 80

RETENTIVE TIMER 46 81
ONDELAY

TIMER OFFDELAY 60 102

UP COUNTER 63 105

DOWN COUNTER 82 100

ADD 22 56

123
Chapter 12
Scan Time and
Instruction Execution TImes

Instruction Name Instruction FALSE Instruction TRUE (avg)

SUBTRACT 26 77 for (+) or 100 for ()

MULTIPLY 35 230520 (See Multiply and


Divide Instructions)

DIVIDE 35 162775 (See Multiplyand


Divide Instructions)

MASTER CONTROL RESET 31 31

ZONE CONTROL LAST 45(See Instructions Within A 35


STATE ZCL Zone)

BRANCH START 24 24

BRANCH END 26 26

IMMEDIATE INPUT 92 92

IMMEDIATE OUTPUT 22 120

MULTIPLY and DIVIDE Instructions (1772LN3 Processor)

The execution times for these instructions depend on the values of the numbers
being computed. Generally, the larger the number, the longer the execution
time.

Instructions Within a ZCL Zone

In addition to the ZCL instruction itself, when the rung containing the ZCL
instruction is FALSE (i.e., outputs are controlled by the zone), the time required
to scan each instruction between the Start Fence and End Fence is 15
microseconds.

Block Transfer Programming In addition to the time required to execute the instruction in the program scan,
the I/O scan is also interrupted while data is transferred. The delay is
proportional to the number of words transferred and may vary from one kind of
module to another. Consult the I/O Module User’s Manual.

124
13
Chapter

Numbering Systems

General There are four numbering systems used with Allen-Bradley programmable
controllers. They are:
Decimal
Octal
Binary
Hexadecimal
These numbering systems differ by their number sets and place values.

Decimal Numbering System The decimal numbering system uses a number set made up of ten digits: the
numbers 0 through 9. All decimal numbers are composed of these digits. The
value of a decimal number depends on the digits used and the place value of
each digit.

Each place value in a decimal number represents a power of ten (Figure 13.1),
starting with 100. (Any number raised to the zero power is equal to 1). The
value of a decimal number is determined by multiplying each digit by its
corresponding place value and adding these numbers together.

Figure 13.1
Decimal Numbering System

2 x 102 = 20010
200
3 x 101 = 3010 30
9
9 x 100 = 910 23910

2 3 9 10 10238I

131
Chapter 13
Numbering Systems

Octal Numbering System The octal numbering system is used to address word and bit locations in the
Data Table. Its number set is composed of eight digits: the numbers 0 through
7.

Each digit is an octal number has a certain place value, represented by a power
of eight (Figure 13.2).

Figure 13.2
Octal Numbering System

3 x 82 = 192
192
5 x 81 = 40 40
7
7 x 80 = 7 23910

23910 = 3578

3 5 7 8 10669I

The decimal value of an octal number is computed by multiplying each octal


digit by its place value and adding these numbers together.

132
Chapter 13
Numbering Systems

Binary Numbering System The binary numbering system is a number set that consists of two digits: the
numbers 0 and 1. All information in memory is stored as an arrangement of 1’s
and 0’s.

Each digit in a binary number has a certain place value expressed as a power of
two (Figure 13.3). The decimal equivalent of a binary number is computed by
multiplying each binary digit by its corresponding place value and adding these
numbers together.

Figure 13.3
Binary Numbering System

1 x 27 = 128
1 x 26 = 64
1 x 25 = 32
0 x 24 = 0
128
1 x 23 = 8 64
32
1 x 22 = 4 8
4
1 x 21 = 2 2
1
1 x 20 = 1 23910

1 1 1 0 1 1 1 1 2
111011112 = 23910

10240I

By grouping several binary digits together, values can be formed to represent


decimal, hexadecimal or octal numbers.

133
Chapter 13
Numbering Systems

Binary Coded Decimal

Binary Coded Decimal (BCD) uses an arrangement of 12 binary digits to


represent a 3-digit decimal number from 000 to 999 (Figure 13.4). Each group
of 4 binary digits is used to represent a decimal number from 0 to 9. The place
values for each group of 4 digits are 20, 21, 22 and 23 (Table 13.A).

Figure 13.4
Binary Coded Decimal

0 x 23 = 0
0 x 22 = 0
2
1 x 21 = 2

0 x 20 = 0

0 x 23 = 0
0 x 22 = 0
3
1 x 21 = 2

1 x 20 = 1

1 x 23 = 8
0 x 22 = 0

0 x 21 = 0
910
1 x 20 = 1

0 0 1 0 0 0 1 1 1 0 0 1

2 3 9 10241I

134
Chapter 13
Numbering Systems

Table 13.A
BCD Representation

PLACE VALUE DECIMAL


EQUIVALENT

23 22 21 20
(8) (4) (2) (1)

0 0 0 0 0
0 0 0 1 1
0 0 1 0 2
0 0 1 1 3
0 1 0 0 4
0 1 0 1 5
0 1 1 0 6
0 1 1 1 7
1 0 0 0 8
1 0 0 1 9

The decimal equivalent for a group of 4 binary digits is determined by


multiplying the binary digit by its corresponding place value and adding these
numbers.

Octal Representation

Octal Representation is an arrangement of 8 bits (one byte) to represent a 3-


digit octal number from 0008 to 3778 (Figure 13.5). The 8 bits are separated
into three groups: 2 bits, 3 bits and 3 bits.

Figure 13.5
Octal Representation

1 0 2 1 0 2 1 0
2 2 2 2 2 2 2 2

1 1 1 0 1 1 1 1

3 5 78 10670I

135
Chapter 13
Numbering Systems

The octal number for each group of bits is determined by multiplying the binary
digit by its corresponding place value and adding these numbers together.
(Table 13.B).

Table 13.B
Octal Representation

PLACE VALUE OCTAL


EQUIVALENT

22 21 20
(4) (2) (1)

0 0 0 0
0 0 1 1
0 1 0 2
0 1 1 3
1 0 0 4
1 0 1 5
1 1 0 6
1 1 1 7

Table 13.C
Numbering System Conversion Chart

HEXADECIMAL BINARY DECIMAL

0 0000 0
1 0001 1
2 0010 2
3 0011 3
4 0100 4
5 0101 5
6 0110 6
7 0111 7
8 1000 8
9 1001 9
A 1010 10
B 1011 11
C 1100 12
D 1101 13
E 1110 14
F 1111 15

136
Chapter 13
Numbering Systems

A hexadecimal number can be converted to a decimal number by multiplying


the hexadecimal digit by its corresponding place value (Figure 13.6).

Figure 13.6
Example of Hexadecimal to Decimal Conversion

0 x 163 = 0
1 x 162 = 256
256
10 x 161 = 160 160
7
7 x 160 = 7 42310 = 01A716

0 1 A 7
10671I

Because each hexadecimal digit represents 4 binary digits, it is easy to convert a


hexadecimal number to a binary number. this is done by writing out the 4-bit
binary pattern for each hexadecimal digit (Figure 13.7).

Figure 13.7
Example of Hexadecimal to Binary Conversion

C 2 A F

1 1 0 0 0 0 1 0 1 0 1 0 1 1 1 1
10672I

137
Index

A COUNTER, RESET -(CTR)-, 49


Accumulated value, 41 COUNTER, UP -(CTU)-, 49
Accumulated value word, 42, 410
ADD; (+), 61 D
Address, Terminology, 17 Data cartridge recording, 1019
Address delimites, 107 Data highway compatability, 111
Addressing, Method, 91, 92 Data table
Alphanumeric (Cat. No. 1770-KAA), 105 Adjustment, 91
Factory configured, 16
Alphanumeric/Grapic (Cat. No. 1770-KAB),
105 Size determination, 812
ASCII control codes, 1013 Data table ducumentation forms, 87
Delimiter, 107
Diagnostic bit, 1113
B
Diagnostic indicators, 22, 24
Baud rate setting, 101 Directories, 96
BCD format, 41, 51, 134
Bit, 14
E
Bit manipulation and monitor, 911
Bit number, 14 Editing functions, 93
Bit/Word storage considerations, 811 EQU -|=|-, 54
Block transfer ERR message, ILLEGAL OPCODE, 915
Bidirectional, 119 EXAMINE OFF -| /|-, 31
Buffering data, 1113 EXAMINE ON -| |-, 31
Loading zeros, 1111
Execution time, 123
Operation, 112
Programming, 117
Block transfer instructions, 115, 119 F
Boundaries to user program Forced address display, 914
Cursor to, 98
END statement, 914 Forcing functions, 912
TEMPORARY END, 914
BRANCHING, START and END, 36 G
Buffering data, 1113
GET -[G]-, 52
Byte, 14
GET BYTE -[B]-, 54
Graphic display, 1012
C
Cascading timers or counters, 414 I
Cassette recording, 1017
I/O image table, 17
Clear memory functions, 917
Illegal opcode, 915
Connection diagram, 26
IMMEDIATE INPUT -[I]-, 73
Contact Histogram, 103
IMMEDIATE OUTPUT -(IOT)-, 73
COUNTER, DOWN -(CTU)-, 49
I–2 Index

Incompatible instructions, 112 Number of words transferred, 1111


Industrial terminal Numbering systems, 131
Compatability when using 1770-T1, or
-T2, 111
Control codes and special commands, O
108
One-shot, 1115
Initialization, 27
OUTPUT ENERGIZE -( )-, 32
Instruction Tables, Arithmetic instructions,
65 OUTPUT LATCH -(L)-, 32
Instruction tables OUTPUT UNLATCH -(U)-, 32
Counter instructions, 415
Data manipulation instructions, 59
I/O update instructions, 78
P
Output override instructions, 78 PC operation, 15
Relay-Type instructions, 37
Preset value, 41
Timer instructions, 415
Print out
Intelligent I/O modules, 112
Automatic report generation, 1012
Contact histogram, 103
Total memory dump, 1021
K
Programming
Keytop overlay, PLC-2 (Cat. No. Developing the data table, 87
1770-KCA), 26 Hardware program interface, 17
Programming considerations, 813
Sample program, 82
L
PUT -(PUT)-, 52
Last state of outputs, 25
LES -[
, 5-4 R
Report generation
LIMIT TEST -[L]-, 54 Direct access at power up, 1012
Simultaneous message requests, 1016

M
S
MASTER CONTROL RESET -(MCR)-,
71 Sample program, 0.01 Second timers,
Memory layout display, 92 1118
Memory organization Scan counter, 111
Adjusting the data table, 91 Scan sequence, 74
Definition, 15 Scan time
Developing the data table, 87 Determination of:, 121
Storage considerations, 811 Typical, 74
Word assignment considerations, 810
Search functions, 97
Message control word, 1014
Single rung display, 99
Message generation, 1012
Status/Control bits, Operation of, Counter
Modes of processor operation, 21 instructions, 49
Module address, block transfer, 116 Status/Control bits, Operation of:
Module group, 16, 19 Arithmetic instruction, 61
Timer instructions, 42
Status/Control bits, operation of:, Automatic
N report generation, 1012
Nested programming, 36 SUBTRACT -(-)-, 61
Index I–3

Switch group assembly, 25 V


Valid transfer of data, 1113
T
TEMPORARY END, 914 W
Timer accuracy, 49 Word structure, Definition, 14
TIMER, OFF DELAY-(TOF)-, 42 Write bit, block transfer, 116
TIMER, ON-DELAY-(TON)-, 42
TIMER, RETENTIVE RESET-(RTR)-, 42
Z
TIMER, RETENTIVE-(RTO)-, 42
Troubleshooting aids, 99 ZONE CONTROL LAST STATE -(ZCL)-,
71
As a subsidiary of Rockwell International, one of the world’s largest technology
companies — Allen-Bradley meets today’s challenges of industrial automation with over
85 years of practical plant-floor experience. More than 13,000 employees throughout the
world design, manufacture and apply a wide range of control and automation products
and supporting services to help our customers continuously improve quality, productivity
and time to market. These products and services not only control individual machines but
integrate the manufacturing process, while providing access to vital plant floor data that
can be used to support decision-making throughout the enterprise
With offices in major cities worldwide
WORLD EUROPE/MIDDLE ASIA/PACIFIC CANADA LATIN AMERICA
HEADQUARTERS EAST/AFRICA HEADQUARTERS HEADQUARTERS HEADQUARTERS
1201 South Second Street HEADQUARTERS Allen-Bradley (Hong Kong) Allen-Bradley Canada 1201 South Second Street
Milwaukee, WI 53204 USA Allen-Bradley Europa B.V. Limited Limited Milwaukee, WI 53204 USA
Tel: (414)382-2000 Amsterdamseweg 15 2901 Great Eagle Center 135 Dundas Street Tel: (414)382-2000
Telex: 43 11 016 1422 AC Uithoorn 23 Harbour Road Cambridge, Ontario N1R Telex: 43 11 016
FAX: (414)382-4444 The Netherlands G.P.O. Box 9797 5X1 FAX: (414)382-2400
Tel: (31)2975/60611 Wanchai, Hong Kong Canada
Telex: (844) 18042 Tel: (852)5/739391 Tel: (519)623-1810
FAX: (31)2975/60222 Telex: (780) 64347 Telex: (069) 59317
FAX: (852)5/834 5162 FAX: (519)623-8930

Publication 1772-6.8.4 – December 1983 P/N 955094-60


Supersedes Publication 1772-821 – December 1983 Copyright 1983 Allen-Bradley Company, Inc. Printed in USA

You might also like