directsoft5 chapter 5
directsoft5 chapter 5
Introduction
DL05 Micro PLCs offer a wide variety of instructions to perform many different types of
operations. This chapter shows you how to use each standard Relay Ladder Logic (RLL)
instruction. In addition to these instructions, you may also need to refer to the Drum instruction
in Chapter 6, or the Stage programming instructions in Chapter 7.
There are two ways to quickly find the instruction you need.
• If you know the instruction category (Boolean, Comparative Boolean, etc.) just use the
title at the top of the page to find the pages that discuss the instructions in that category.
• If you know the individual instruction name, use the following
table to find the page(s) that discusses the instruction.
Instruction Page Instruction Page
Accumulating Timer (TMRA) 5–38 Decode (DECO) 5–86
Accumulating Fast Timer (TMRAF) 5-38 Decrement (DEC) 5–76
Add (ADD) 5–68 Decrement Binary (DECB) 5–77
Add Binary (ADDB) 5–78 Disable Interrupts (DISI) 5–109
Add Double (ADDD) 5–69 Divide (DIV) 5–74
And (AND) 5–13 Divide Binary (DIVB) 5–81
And (AND) 5–30 Divide Double (DIVD) 5–75
And (AND) 5–60 Enable Interrupts (ENI) 5–108
And Bit-of-Word (ANDB) 5-14 Encode (ENCO) 5–85
And Double (ANDD) 5–61 End (END) 5–99
And If Equal (ANDE) 5–27 Exclusive Or (XOR) 5–64
And If Not Equal (ANDNE) 5–27 Exclusive Or Double (XORD) 5–65
And Immediate (ANDI) 5–32 Fault (FAULT) 5–111
And Negative Differential (ANDND) 5–21 For / Next (FOR) (NEXT) 5–101
And Not (ANDN) 5–13 Goto Subroutine (GTS) (SBR) 5–103
And Not (ANDN) 5–30 Gray Code (GRAY) 5–93
And Not Bit-of-Word (ANDNB) 5-14 HEX to ASCII (HTA) 5–91
And Not Immediate (ANDNI) 5–32 Increment (INC) 5–76
And Positive Differential (ANDPD) 5–21 Increment Binary (INCB) 5–77
And Store (AND STR) 5–15 Interrupt (INT) 5–108
ASCII Constant (ACON) 5–112 Interrupt Return (IRT) 5–108
ASCII to HEX (ATH) 5–90 Interrupt Return Conditional (IRTC) 5–108
Binary (BIN) 5–87 Invert (INV) 5–89
Binary Coded Decimal (BCD) 5–88 Load (LD) 5–53
Compare (CMP) 5–66 Load Address (LDA) 5–56
Compare Double (CMPD) 5–67 Load Double (LDD) 5–54
Counter (CNT) 5–41 Load Formatted (LDF) 5–55
Data Label (DLBL) 5–112 Load Label (LDLBL) 5–97
The following paragraphs show how these instructions are used to build simple ladder programs.
END Statement
All DL05 programs require an END statement as the last instruction. This tells the CPU that
this is the end of the program. Normally, any instructions placed after the END statement will
not be executed. There are exceptions to this such as interrupt routines, etc.. This chapter will
discuss the instruction set in detail.
X0 Y0
OUT
All programs must have
an END statement
END
Simple Rungs
You use a contact to start rungs that contain both contacts and coils. The boolean instruction
that does this is called a Store or, STR instruction. The output point is represented by the
Output or, OUT instruction. The following example shows how to enter a single contact and
a single output coil.
DirectSOFT
DirectSOFT Example Handheld Mnemonics
X0 Y0 STR X0
OUT Y0
OUT END
END
DirectSOFT
Direct SOFT32 Example Handheld Mnemonics
X0 Y0 STRN X0
OUT OUT Y0
END
END
Contacts in Series
Use the AND instruction to join two or more contacts in series. The following example shows
two contacts in series and a single output coil. The instructions used would be STR X0, AND
X1, followed by OUT Y0.
DirectSOFT
Direct SOFT32 Example Handheld Mnemonics
X0 X1 Y0 STR X0
AND X1
OUT OUT Y0
END
END
Midline Outputs
Sometimes it is necessary to use midline outputs to get additional outputs that are conditional
on other contacts. The following example shows how you can use the AND instruction to
continue a rung with more conditional outputs.
DirectSOFT
Direct SOFT32 Example Handheld Mnemonics
X0 X1 Y0 STR X0
AND X1
OUT OUT Y0
AND X2
X2 Y1 OUT Y1
AND X3
OUT OUT Y2
END
X3 Y2
OUT
END
Parallel Elements
You also have to join contacts in parallel. The OR instruction allows you to do this. The
following example shows two contacts in parallel and a single output coil. The instructions
would be STR X0, OR X1, followed by OUT Y0.
END
Comparative Boolean
Some PLC manufacturers make it really difficult to do a simple comparison of two numbers.
Some of them require you to move the data all over the place before you can actually perform
the comparison. The DL05 Micro PLCs provide Comparative Boolean instructions that allow
you to quickly and easily solve this problem. The Comparative Boolean provides evaluation
of two 4-digit values using boolean contacts. The valid evaluations are: equal to, not equal to,
equal to or greater than, and less than.
In this example when the value in V-memory location
V1400 K1234 Y3
V1400 is equal to the constant value 1234, Y3 will
OUT
energize.
Boolean Stack
There are limits to how many elements you can include in a rung. This is because the DL05
PLCs use an 8-level boolean stack to evaluate the various logic elements. The boolean stack is
a temporary storage area that solves the logic for the rung. Each time the program encounters a
STR instruction, the instruction is placed on the top of the stack. Any other STR instructions
already on the boolean stack are pushed down a level. The ANDSTR, and ORSTR instructions
combine levels of the boolean stack when they are encountered. An error will occur during
program compilation if the CPU encounters a rung that uses more than the eight levels of the
boolean stack.
The following example shows how the boolean stack is used to solve boolean logic.
X0 X1 ORSTR AND X4 Y0
STR
STR OUT Output
X2 AND X3
STR ANDSTR
X5 OR
8 8 8
ANDSTR
1 XO AND (NOT X5 or X4) AND {X1 or (X2 AND X3)}
2
3
.
.
Immediate Boolean
The DL05 Micro PLCs can usually complete an operation cycle in a matter of milliseconds.
However, in some applications you may not be able to wait a few milliseconds until the next
I/O update occurs. The DL05 PLCs offer Immediate input and outputs which are special
boolean instructions that allow reading directly from inputs and writing directly to outputs
during the program execution portion of the CPU cycle. You may recall that this is normally
done during the input or output update portion of the CPU cycle. The immediate instructions
take longer to execute because the program execution is interrupted while the CPU reads or
writes the I/O point. This function is not normally done until the read inputs or the write
outputs portion of the CPU cycle.
NOTE: Even though the immediate input instruction reads the most current status from the input point,
it only uses the results to solve that one instruction. It does not use the new status to update the image
register. Therefore, any regular instructions that follow will still use the image register values. Any immediate
instructions that follow will access the I/O again to update the status. The immediate output instruction will
write the status to the I/O and update the image register.
CPU Scan
X11 ... X2 X1 X0
OFF ... ON OFF OFF ON X0
Input Image Register
OFF X1
ON X0
OFF X1
Write Outputs
Diagnostics
Boolean Instructions
Store (STR)
The Store instruction begins a new rung or an additional
DS5 Implied Aaaa
branch in a rung with a normally open contact. Status of the
HPP Used
contact will be the same state as the associated image register
point or memory location.
Store Not (STRN)
DS5 Implied The Store Not instruction begins a new rung or an Aaaa
HPP Used additional branch in a rung with a normally closed contact.
Status of the contact will be opposite the state of the
associated image register point or memory location.
In the following Store example, when input X1 is on, output Y2 will energize.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 Y2 $ B ENT
STR 1
OUT
GX C ENT
OUT 2
In the following Store Not example, when input X1 is off output Y2 will energize.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 Y2 SP B ENT
OUT STRN 1
GX C ENT
OUT 2
In the following Store Bit-of-Word example, when bit 12 of V-memory location V1400 is on,
output Y2 will energize.
DirectSOFT
DirectSOFT32
B1400.12 Y2
OUT
STR SHFT B V 1 4 0 0
K 1 2 ENT
OUT 2 ENT
In the following Store Not Bit-of-Word example, when bit 12 of V-memory location V1400
is off, output Y2 will energize.
DirectSOFT
DirectSOFT32
B1400.12 Y2
OUT
STRN SHFT B V 1 4 0 0
K 1 2 ENT
OUT 2 ENT
Or (OR)
DS5 Implied The Or instruction logically ors a normally open contact
HPP Used in parallel with another contact in a rung. The status of the Aaaa
contact will be the same state as the associated image register
point or memory location.
Or Not (ORN)
DS5 Implied The Or Not instruction logically ors a normally closed
HPP Used contact in parallel with another contact in a rung. The status Aaaa
of the contact will be opposite the state of the associated
image register point or memory location.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
Inputs ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠X 0–377
Outputs ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠Y 0–377
Control Relays ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠C 0–777
Stage ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠S 0–377
Timer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ T 0–177
Counter ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠CT 0–177
Special Relay ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠SP 0–777
X1 Y5 $ B ENT
STR 1
OUT
Q C ENT
OR 2
X2
GX F ENT
OUT 5
In the following Or Not example, when input X1 is on or X2 is off, output Y5 will energize.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 Y5 $ B ENT
OUT STR 1
R C ENT
ORN 2
X2
GX F ENT
OUT 5
Or Bit-of-Word (ORB)
The Or Bit-of-Word instruction logically ors a normally
DS5 Implied open contact in parallel with another contact in a rung.
HPP Used Status of the contact will be the same state as the bit Aaaa.bb
referenced in the associated memory location.
Or Not Bit-of-Word (ORNB)
The Or Not Bit-of-Word instruction logically ors a
DS5 Implied normally closed contact in parallel with another contact
HPP Used Aaaa.bb
in a rung. Status of the contact will be opposite the state
of the bit referenced in the associated memory location.
In the following Or Bit-of-Word example, when input X1 or bit 7 of V1400 is on, output Y7
will energize.
DirectSOFT
DirectSOFT32
X1 Y7
OUT
B1400.7
STR 1 ENT
OR SHFT B V 1 4 0 0
K 7 ENT
OUT 7 ENT
In the following Or Bit-of-Word example, when input X1 is on or bit 7 of V1400 is off, output
Y7 will energize.
DirectSOFT
DirectSOFT32
X1 Y7
OUT
B1400.7
STR 1 ENT
ORN SHFT B V 1 4 0 0
K 7 ENT
OUT 7 ENT
And (AND)
DS5 Implied The And instruction logically ands a normally open Aaaa
HPP Used contact in series with another contact in a rung.
The status of the contact will be the same state as the
associated image register point or memory location.
And Not (ANDN)
Aaaa
DS5 Implied The And Not instruction logically ands a normally
HPP Used closed contact in series with another contact in a rung.
The status of the contact will be opposite the state of the
associated image register point or memory location.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
Inputs ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠X 0–377
Outputs ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠Y 0–377
Control Relays ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠C 0–777
Stage ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠S 0–377
Timer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ T 0–177
Counter ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠CT 0–177
Special Relay ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠SP 0–777
In the following And example, when input X1 and X2 are on output Y5 will energize.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 X2 Y5 $ B ENT
STR 1
OUT
V C ENT
AND 2
GX F ENT
OUT 5
In the following And Not example, when input X1 is on and X2 is off output Y5 will energize.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 X2 Y5 $ B ENT
OUT STR 1
W C ENT
ANDN 2
GX F ENT
OUT 5
In the following And Bit-of-Word example, when input X1 and bit 4 of V1400 is on output
Y5 will energize.
DirectSOFT 5
X1 B1400.4 Y5
OUT
STR 1 ENT
AND SHFT B V 1 4 0 0
K 4 ENT
OUT 5 ENT
In the following And Not Bit-of-Word example, when input X1 is on and bit 4 of V1400 is
off output Y5 will energize.
DirectSOFT 5
X1 B1400.4 Y5
OUT
STR 1 ENT
ANDN SHFT B V 1 4 0 0
K 4 ENT
OUT 5 ENT
X1 X2 X3 Y5 $ B ENT
STR 1
OUT
$ C ENT
STR 2
X4
V D
ENT
AND 3
Q E
ENT
OR 4
L ENT
ANDST
GX F ENT
OUT 5
In the following Or Store example, the branch consisting of X1 and X2 have been ORed with
the branch consisting of X3 and X4.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 X2 Y5 $ B ENT
STR 1
OUT
V C
ENT
AND 2
X3 X4
$ D ENT
STR 3
V E ENT
AND 4
M ENT
ORST
GX F ENT
OUT 5
Out (OUT)
The Out instruction reflects the status of the rung (on/off) and outputs Aaaa
DS5 Used the discrete (on/off) state to the specified image register point or memory OUT
HPP Used location.
Multiple Out instructions referencing the same discrete location should
not be used since only the last Out instruction in the program will control the physical output
point. Instead, use the next instruction, the Or Out.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
Inputs ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠X 0–377
Outputs ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠Y 0–377
Control Relays ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠C 0–777
In the following Out example, when input X1 is on, output Y2 and Y5 will energize.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 Y2 $ B ENT
STR 1
OUT
GX C ENT
OUT 2
Y5
GX F ENT
OUT OUT 5
X1 Y2
$ B ENT
OR OUT STR 1
O D F ENT ENT C ENT
INST# 3 5 2
$ E ENT
STR 4
X4 Y2 O D F C
ENT ENT ENT
INST# 3 5 2
OR OUT
In the following Out Bit-of-Word example, when input X1 is on, bit 3 of V1400 and bit 6 of
V1401 will turn on.
DirectSOFT 5
X1 B1400.3
OUT
B1401.6
OUT
STR 1 ENT
OUT SHFT B V 1 4 0 0
K 3 ENT
OUT SHFT B V 1 4 0 1
K 6 ENT
The following Out Bit-of-Word example contains two Out Bit-of-Word instructions using the
same bit in the same memory word. The final state bit 3 of V1400 is ultimately controlled by
the last rung of logic referencing it. X1 will override the logic state controlled by X0. To avoid
this situation, multiple outputs using the same location must not be used in programming.
OUT
X1 B1400.3
OUT
Not (NOT)
DS5 Used The Not instruction inverts the status of the rung at
HPP Used the point of the instruction.
In the following example when X1 is off, Y2 will energize. This is because the Not instruction
inverts the status of the rung at the Not instruction.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
X1 Y2 $ B ENT
STR 1
OUT
SHFT N O T ENT
TMR INST# MLR
GX C ENT
OUT 2
NOTE: DirectSOFT Release 1.1i and later supports the use of the NOT instruction. The above example rung
is merely intended to show the visual representation of the NOT instruction. The rung cannot be created or
displayed in DirectSOFT versions earlier than 1.1i.
In the following example, every time X1 makes an off to on transition, C0 will energize for
one scan.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
X1 C0 $ B ENT
STR 1
PD
SHFT P SHFT D A ENT
CV 3 0
In the following example, each time X1 is makes an Off-to-On transition, Y4 will energize for
one scan.
DirectSOFT Handheld Programmer Keystrokes
DirectSOFT32
X1 $ SHFT P D B ENT
Y4 STR CV 3 1
OUT GX E ENT
OUT 4
In the following example, each time X1 is makes an On-to-Off transition, Y4 will energize for
one scan.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
X1 $ SHFT N D B ENT
Y4 STR TMR 3 1
OUT GX E
ENT
OUT 4
In the following example, Y 5 will energize whenever X1 is on, or for one CPU scan when X2
transitions from Off to On.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ B ENT
X1 Y5 STR 1
OUT Q SHFT P D C ENT
OR CV 3 2
X2 GX F
ENT
OUT 5
In the following example, Y 5 will energize whenever X1 is on, or for one CPU scan when X2
transitions from On to Off.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ B ENT
X1 Y5 STR 1
OUT Q N D C
SHFT ENT
OR TMR 3 2
X2 GX F
ENT
OUT 5
In the following example, Y5 will energize for one CPU scan whenever X1 is on and X2
transitions from Off to On.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ B ENT
X1 X2 Y5 STR 1
OUT Q SHFT P D C ENT
OR CV 3 2
GX F
ENT
OUT 5
In the following example, Y5 will energize for one CPU scan whenever X1 is on and X2
transitions from On to Off.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
X2 $ B ENT
X1 Y5 STR 1
OUT Q N D C
SHFT ENT
OR TMR 3 2
GX F
ENT
OUT 5
Set (SET)
DS5 Used
The Set instruction sets or turns on an image register Optional
memory range
HPP Used
point/memory location or a consecutive range of image
A aaa aaa
register points/memory locations. Once the point/
SET
location is set it will remain on until it is reset using
the Reset instruction. It is not necessary for the input
controlling the Set instruction to remain on.
Reset (RST)
Optional
DS5 Used The Reset instruction resets or turns off an image register Memory. range
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
X2 $ B
Y2 Y5 ENT
STR 1
RST
S C F ENT
RST 2 5
In the following example when X1 turns on, bit 1 in V1400 is set to the on state.
DirectSOFT
DirectSOFT32
X1
B1400.1
SET
STR 1 ENT
SET SHFT B V 1 4 0 0
K 1 ENT
In the following example when X2 turns on, bit 1 in V1400 is reset to the off state.
DirectSOFT
DirectSOFT32
X2
B1400.1
RST
STR 2 ENT
RST SHFT B V 1 4 0 0
K 1 ENT
Pause (PAUSE)
DS5 Used The Pause instruction disables the output update on a
HPP Used range of outputs. The ladder program will continue to Y aaa aaa
run and update the image register. However, the outputs PAUSE
in the range specified in the Pause instruction will be
turned off at the output points.
In the following example, when X1 is ON, Y5-Y7 will be turned OFF. The execution of the
ladder program will not be affected.
DirectSOFT
DirectSOFT32
X1 Y5 Y7
PAUSE
Since the D2–HPP Handheld Programmer does not have a specific Pause key, you can use the
corresponding instruction number for entry (#960), or type each letter of the command.
Handheld Programmer Keystrokes
$ B ENT
STR 1
O J G A ENT ENT D F ENT
INST# 9 6 0 3 5
In some cases, you may want certain output points in the specified pause range to operate
normally. In that case, use Aux 58 to over-ride the Pause instruction.
Comparative Boolean
Store If Equal (STRE)
The Store If Equal instruction begins a new rung or
DS5 Used
additional branch in a rung with a normally open V aaa B bbb
HPP Used
comparative contact. The contact will be on when
Vaaa is equal toBbbb .
Store If Not Equal (STRNE)
DS5 Used The Store If Not Equal instruction begins a new rung V aaa B bbb
HPP Used or additional branch in a rung with a normally closed
comparative contact. The contact will be on when
Vaaa does not equal Bbbb.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠B aaa bbb
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V All (See page 3–28) All (See page 3–28)
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P All (See page 3–28) All (See page 3–28)
Constant ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠K –– 0–9999
In the following example, when the value in V-memory location V2000 = 4933, Y3 will
energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
In the following example, when the value in V-memory location V2000 is not equal to 5060,
Y3 will energize.
DirectSOFT Handheld Programmer Keystrokes
DirectSOFT32
Y3 SP SHFT E C A A A
V2000 K5060
STRN 4 2 0 0 0
OUT
F A G A ENT
5 0 6 0
GX D ENT
OUT 3
Or If Equal (ORE)
DS5 Implied The Or If Equal instruction connects a normally open
comparative contact in parallel with another contact. V aaa B bbb
HPP Used
The contact will be on when Vaaa is equal to Bbbb.
Or If Not Equal (ORNE)
DS5 Implied The Or If Not Equal instruction connects a normally
HPP Used closed comparative contact in parallel with another V aaa B bbb
contact. The contact will be on when Vaaa does not
equal Bbbb.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠B aaa bbb
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V All (See page 3–28) All (See page 3–28)
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P All (See page 3–28) All (See page 3–28)
Constant ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠K –– 0–9999
In the following example, when the value in V-memory location V2000 = 4500 or
V2002 = 2345 , Y3 will energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ SHFT E C A A A
V2000 K4500 Y3
STR 4 2 0 0 0
OUT
E F A A ENT
4 5 0 0
In the following example, when the value in V-memory location V2000 = 3916 or
V2002 is not equal to 2500, Y3 will energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ SHFT E C A A A
V2000 K3916 Y3 STR 4 2 0 0 0
OUT D J B G ENT
3 9 1 6
In the following example, when the value in V-memory location V2000 = 5000 and
V2002 = 2345, Y3 will energize.
In the following example, when the value in V-memory location V2000 = 2550 and V2002
does not equal 2345, Y3 will energize.
DirectSOFT 5 Handheld Programmer Keystrokes
Store (STR)
A aaa B bbb
DS5 Used The Comparative Store instruction begins a new rung or
HPP Used additional branch in a rung with a normally open comparative
contact. The contact will be on when Aaaa is equal to or greater
than Bbbb.
Store Not (STRN) A aaa B bbb
DS5 Used The Comparative Store Not instruction begins a new rung or
HPP Used additional branch in a rung with a normally closed comparative
contact. The contact will be on when Aaaa is less than Bbbb.
In the following example, when the value in V-memory location V2000 M 1000, Y3 will
energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
In the following example, when the value in V-memory location V2000 < 4050, Y3 will
energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
Or (OR)
DS5 Implied The Comparative Or instruction connects a normally
A aaa B bbb
HPP Used open comparative contact in parallel with another
contact. The contact will be on when Aaaa is equal to or
greater than Bbbb.
Or Not (ORN)
DS5 Implied The Comparative Or Not instruction connects A aaa B bbb
HPP Used a normally open comparative contact in parallel
with another contact. The contact will be on when
Aaaa is less than Bbbb.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ A/B aaa bbb
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V All (See page 3–28) All (See page 3–28)
Pointer⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ p All (See page 3–28) All (See page 3–28)
Constant ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠K –– 0–9999
Timer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ T 0–177
Counter ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠CT 0–177
In the following example, when the value in V-memory location V2000 = 6045 or
V2002 M 2345, Y3 will energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ SHFT E C A A A
V2000 K6045 Y3 STR 4 2 0 0 0
OUT G A E F ENT
6 0 4 5
In the following example when the value in V-memory location V2000 = 1000 or
V2002 < 2500, Y3 will energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ SHFT E C A A A
V2000 K1000 Y3 STR 4 2 0 0 0
OUT B A A A ENT
1 0 0 0
R SHFT V C A A C
V2002 K2500 ORN AND 2 0 0 2
C F A A ENT
2 5 0 0
GX D ENT
OUT 3
And (AND)
DS5 Implied The Comparative And instruction connects a normally A aaa B bbb
HPP Used open comparative contact in series with another contact.
The contact will be on when Aaaa is equal to or greater
than Bbbb.
And Not (ANDN) A aaa B bbb
DS5 Implied The Comparative And Not instruction connects a
HPP Used normally open comparative contact in parallel with
another contact. The contact will be on when Aaaa is less than Bbbb.
In the following example, when the value in V-memory location V2000 = 5000, and
V2002 M 2345, Y3 will energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
In the following example, when the value in V-memory location V2000 = 7000 and
V2002 < 050, Y3 will energize.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ SHFT E C A A A
V2000 K7000 V2002 K2500 Y3 STR 4 2 0 0 0
OUT H A A A ENT
7 0 0 0
W SHFT V C A A C
ANDN AND 2 0 0 2
C F A A ENT
2 5 0 0
GX D ENT
OUT 3
Immediate Instructions
Store Immediate (STRI)
The Store Immediate instruction begins a new rung or X aaa
DS5 Used
additional branch in a rung. The status of the contact will be
HPP Used
the same as the status of the associated input point at the time
the instruction is executed. The image register is not updated.
Store Not Immediate (STRNI)
The Store Not Immediate instruction begins a new rung or
additional branch in a rung. The status of the contact will be X aaa
DS5 Used
HPP Used opposite the status of the associated input point at the time the
instruction is executed. The image register is not updated.
X1 Y2 $ SHFT I B ENT
STR 8 1
OUT
GX C ENT
OUT 2
Or Immediate (ORI)
DS5 Implied The Or Immediate connects two contacts in parallel. The X aaa
HPP Used status of the contact will be the same as the status of the
associated input point at the time the instruction is executed.
The image register is not updated.
Or Not Immediate (ORNI)
DS5 Implied The Or Not Immediate connects two contacts in parallel. X aaa
HPP Used The status of the contact will be opposite the status of the
associated input point at the time the instruction is executed.
The image register is not updated.
X1 X2 Y5 $ B ENT
STR 1
OUT
W SHFT I C ENT
ANDN 8 2
GX F ENT
OUT 5
In the following example, when X1 is on, output point Y2 on the output module will turn
on. For instruction entry on the Handheld Programmer, you can use the instruction number
(#350) as shown, or type each letter of the command.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
X1 Y2 $ B ENT
STR 1
OUTI
O D F A ENT ENT
INST# 3 5 0
C ENT
2
$ B ENT
X1 Y2
STR 1
OR OUTI O D F A ENT ENT
INST# 3 5 0
C ENT
X4 Y2 2
OR OUTI $ E ENT
STR 4
O D F A ENT ENT
INST# 3 5 0
C ENT
2
In the following example, when X1 is on, Y2 through Y5 will be set on in the image register
and on the corresponding output points.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
$ B ENT
X1 Y2 Y5 STR 1
SETI X I C F
SHFT ENT
SET 8 2 5
In the following example, when X1 is on, Y5 through Y22 will be reset (off) in the image
register and on the corresponding output module(s).
DirectSOFT
DirectSOFT32
Handheld Programmer Keystrokes
X1 Y5 Y22
$ B ENT
RSTI STR 1
S SHFT I F C C ENT
RST 8 5 2 2
Seconds
0 1 2 3 4 5 6 7 8 X1
TMR T1
X1 K30
Timer Preset
T1
T1 Y0
OUT
Current 0 10 20 30 40 50 60 0
Value 1/10 Seconds
There are those applications that need an accumulating timer, meaning it has the ability to
time, stop, and then resume from where it previously stopped. The accumulating timer works
similarly to the regular timer, but two inputs are required. The start/stop input starts and stops
the timer. When the timer stops, the elapsed time is maintained. When the timer starts again,
the timing continues from the elapsed time. When the reset input is turned on, the elapsed
time is cleared and the timer will start at 0 when it is restarted. There is a tenth of a second and
a hundredth of a second timer available with a maximum time of 9999999.9 and 999999.99
seconds respectively. The timing diagram below shows the relationship between the timer
input, timer reset, associated discrete bit, current value, and timer preset.
Seconds
0 1 2 3 4 5 6 7 8 X1
TMRA T0
K30
X1 Enable
X2
X2
Reset Input
T0
Current 0 10 10 20 30 40 50 0
Value 1/10 Seconds
NOTE: Timer preset constants (K) may be changed by using a handheld programmer, even when the CPU
is in Run Mode. Therefore, a V-memory preset is required only if the ladder program must change the
preset.
You can perform functions when the timer reaches the specified preset using the discrete status
bit. Or, use comparative contacts to perform functions at different time intervals, based on one
timer. The examples on the following page show these two methods of programming timers.
DirectSOFT
Direct SOFT32 Timing Diagram
X1 Seconds
TMR T2 0 1 2 3 4 5 6 7 8
K30
X1
T2 Y0
OUT
T2
Y0
Handheld Programmer Keystrokes
Current 0 10 20 30 40 50 60 0
$ B ENT Value
STR 1
N C D A ENT
TMR 2 3 0
$ SHFT T C ENT
STR MLR 2
GX A ENT
OUT 0
DirectSOFT
Direct SOFT32 Timing Diagram
X1 Seconds
TMR T20
K45 0 1 2 3 4 5 6 7 8
Y3 X1
TA20 K10
OUT
Y3
TA20 K20 Y4 Y4
OUT
Y5
TA20 K30 Y5
T2
OUT
Current 0 10 20 30 40 50 60 0
Value
$ B ENT
STR 1
N C A E F ENT
TMR 2 0 4 5
$ SHFT T C A B A ENT
STR MLR 2 0 1 0
GX D ENT
OUT 3
$ SHFT T C A C A ENT
STR MLR 2 0 2 0
GX E ENT
OUT 4
$ SHFT T C A D A ENT
STR MLR 2 0 3 0
GX F ENT
OUT 5
The following examples show two methods of programming timers. One performs functions
when the timer reaches the preset value using the discrete status bit, or use comparative contacts
to perform functions at different time intervals.
X1
K30
C10
C10
Y7 T6
T6
OUT Current 0 10 10 20 30 40 50 0
Value
$ B ENT D A ENT
STR 1 3 0
$ SHFT C B A ENT $ SHFT T G ENT
STR 2 1 0 STR MLR 6
N SHFT A G GX B A ENT
TMR 0 6 OUT 1 0
K45 X1
C10
C10
Y4
TA21 K1
Y5
1/10 Seconds
OUT
$ B ENT $ T C A C A
SHFT ENT
STR 1 STR MLR 2 0 2 0
$ C B A V E T C B A
SHFT ENT SHFT SHFT ENT
STR 2 1 0 AND 4 MLR 2 1 0
N A C A E F Q E T C B B
SHFT ENT SHFT SHFT ENT
TMR 0 2 0 4 5 OR 4 MLR 2 1 1
$ SHFT T C A B A ENT GX E ENT
STR MLR 2 0 1 0 OUT 4
V E T C B A $ T C A D A
SHFT SHFT ENT SHFT ENT
AND 4 MLR 2 1 0 STR MLR 2 0 3 0
Q E T C B B V E T C B B
SHFT SHFT ENT SHFT SHFT ENT
OR 4 MLR 2 1 1 AND 4 MLR 2 1 1
GX D ENT GX F ENT
OUT 3 OUT 5
Using Counters
Counters are used to count events. The counters available are up counters, up/down counters,
and stage counters (used with RLLPLUS programming).
The up counter has two inputs, a count input and a reset input. The maximum count value is
9999. The timing diagram below shows the relationship between the counter input, counter
reset, associated discrete bit, current value, and counter preset.
X1
CNT CT1
X1
Up K3
X2
X2
Reset
CT1
Current 1 2 3 4 0 Counter preset
alue
Counts
The up down counter has three inputs, a count up input, count down input and reset input.
The maximum count value is 99999999. The timing diagram below shows the relationship
between the counter input, counter reset, associated discrete bit, current value, and counter
preset.
X1
X1 UDC CT2
Up K3
X2 X2
X3
Down
X3
CT2
Reset
Current 1 2 1 2 3 0
Value Counts
Counter Preset
The stage counter has a count input and is reset by the RST instruction. This instruction is
useful when programming using the RLLPLUS structured programming. The maximum count
value is 9999. The timing diagram below shows the relationship between the counter input,
associated discrete bit, current value, counter preset and reset instruction.
X1 X1
SGCNT CT2
K3
CT2
Current 1 2 3 4 0
Value Counts Counter preset
RST
CT2
Counter (CNT)
Counter#
DS5 Used
The Counter is a two input counter that increments
HPP Used
when the count input logic transitions from off to on.
When the counter reset input is on the counter resets to Count CNT CT aaa
0. When the current value equals the preset value, the B bbb
counter status bit comes on and the counter continues to Reset
count up to a maximum count of 9999. The maximum
value will be held until the counter is reset.
Instruction Specifications Preset
Counter Reference (CTaaa): Specifies the counter The counter discrete status bit and the
number. current value are not specified in the
counter instruction.
Preset Value (Bbbb): Constant value (K) or a
V-memory location as a BCD value.
Current Values: Counter current values are accessed by referencing the associated V or CT
memory locations*. The V-memory location is the counter location + 1000. For example, the
counter current value for CT3 resides in V-memory location V1003 as a BCD value.
Discrete Status Bit: The discrete status bit is accessed by referencing the associated CT memory
location. It will be on if the value is equal to or greater than the preset value. For example the
discrete status bit for counter 2 would be CT2.
NOTE: Counter preset constants (K) may be changed by using a programming device, even when the CPU
is in Run Mode. Therefore, a V-memory preset is required only if the ladder program must change the
preset.
CT2 or
CT2 Y7 Y7
OUT Current Value 1 2 3 4 0
CTA2 K1 Y3 Y3
OUT
Y4
CTA2 K2 Y4
Y5
OUT
Current 1 2 3 4 0
Value
CTA2 K3 Y5
OUT
DirectSOFT
DirectSOFT32 Counting diagram
X1
SGCNT CT7
X1
K3
CT7 Y7 Y7
OUT Current 1 2 3 4 0
Value
C5 CT7 RST
RST CT7
$ B ENT GX B A ENT
STR 1 OUT 1 0
CT2 K1 Y3
Y3
OUT
Y4
CT2 K2 Y4
OUT
Y5
Y5 Current 1 2 3 4 0
CT2 K3
Value
OUT
RST
CT2
DirectSOFT
DirectSOFT32 Counting Diagram
X1
UDC CT2
K3 X1
X2
X2
X3
X3
CT2
CT2 Y7
Current 1 2 1 2 3 0
OUT Value
$ B ENT D ENT
STR 1 3
$ C ENT $ SHFT C SHFT T C ENT
STR 2 STR 2 MLR 2
$ D ENT GX B A ENT
STR 3 OUT 1 0
SHFT U D C C
ISG 3 2 2
X2
X3
X3
CTA2 K1 Y3 Y3
OUT
Y4
CTA2 K2 Y4 1 2 3 4 0
Current
Value
OUT
$ B ENT B ENT
STR 1 1
$ C ENT GX D ENT
STR 2 OUT 3
$ D ENT $ SHFT C SHFT T C
STR 3 STR 2 MLR 2
SHFT U D C C C ENT
ISG 3 2 2 2
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 $ B ENT
Data Input SR STR 1
$ C ENT
STR 2
From C0
X2 $ D
Clock Input ENT
STR 3
C0 C17
1 0-1-0 0
0 0-1-0 0
0 0-1-0 0
1 0-1-0 0
0 0-1-0 0
0 0 1
Indicates Indicates
ON OFF
V2000
X1 LD 8 9 3 5
V2000
Unused accumulator bits
Copy data from V2000 to the
are set to zero
lower 16 bits of the accumu-
lator
Acc. 0 0 0 0 88 99 33 55
OUT
V2010 8 9 3 5
Since the accumulator is 32 bits and V-memory locations are 16 bits the Load Double and
Out Double (or variations thereof) use two consecutive V-memory locations or 8 digit
BCD constants to copy data either to the accumulator from a V-memory address or from a
V-memory address to the accumulator. For example if you wanted to copy data from V2000
and V2001 to V2010 and V2011 the most efficient way to perform this function would be as
follows:
X1 V2001 V2000
LDD
V2000 6 7 3 9 5 0 2 6
Acc. 6 7 3 9 55 00 22 66
OUTD
V2010 6 7 3 9 5 0 2 6
Copy data from the accumulator to
V2010 and V2011 V2011 V2010
X1 LD Constant 4 9 3 5
K4935
Shifted out of
accumulator
SHFR 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
K4 Acc. 0 0 0 0 0 1
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0 1 0 0 1 1
OUT
V2010
0 4 9 3
Output the lower 16 bits of the ac-
cumulator to V2010 V2010
Some of the data manipulation instructions use 32 bits. They use two consecutive V-memory
locations or an 8 digit BCD constant to manipulate data in the accumulator.
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded into
the accumulator using the Load Double instruction. The value in the accumulator is added
with the value in V2006 and V2007 using the Add Double instruction. The value in the
accumulator is copied to V2010 and V2011 using the Out Double instruction.
V2001 V2000
X1 6 7 3 9 5 0 2 6
LDD
V2000
OUTD
V2010 8 7 3 9 9 0 7 2
X1 LD Constant 3 2 4 5
K3245
Current Acc. value
Accumulator Stack
Load the value 3245 into the Acc. 0 0 0 0 3 2 4 5
accumulator Level 1 X X X X X X X X
Previous Acc. value X X X X X X X
Level 2 X X X X X X X X
X X X X X X X
Acc. X X X X X
X X X X
Level 3 X X X X X X X X
Level 4 X X X X X X X X
Level 5 X X X X X X X X
Level 6 X X X X X X X X
Constant 5 1 5 1 Level 7 X X X X X X X X
LD
K5151 Level 8 X X X X X X X X
Current Acc. value
6 3 6 3 Level 7 X X X X X X X X
LD Constant
Level 8 X X X X X X X X
K6363 Current Acc. value
Acc. 0 0 0 0 66 33 66 33
Load the value 6363 into the Bucket
accumulator, pushing the value Previous Acc. value Accumulator Stack
5151 to the 1st stack location
and the value 3245 to the Acc. 0 0 0 0 55 1 5 1 Level 1 0 0 0 0 5 1 5 1
2nd stack location Level 2 0 0 0 0 3 2 4 5
0 0 0 0
Level 3 X X X X X X X X
Level 4 X X X X X X X X
Level 5 X X X X X X X X
Level 6 X X X X X X X X
Level 7 X X X X X X X X
Level 8 X X X X X X X X
Bucket
The POP instruction rotates values upward through the stack into the accumulator. When a
POP is executed the value which was in the accumulator is cleared and the value that was on
top of the stack is in the accumulator. The values in the stack are shifted up one position in
the stack.
Acc. X X X X XX XX XX X
Acc. 0 0 0 0 44 55 44 55
Using Pointers
Many of the DL05 series instructions will allow V-memory pointers as a operand (commonly
known as indirect addressing). Pointers allow instructions to obtain data from V-memory
locations referenced by the pointer value.
NOTE: DL05 V-memory addressing is in octal. However, the pointers reference a V-memory location
with values viewed as HEX. Use the Load Address (LDA) instruction to move an address into the pointer
location. This instruction performs the Octal to Hexadecimal conversion automatically.
In the following simple example we are using a pointer operand in a Load instruction.
V-memory location 2000 is being used as the pointer location. V2000 contains the value 440
which the CPU views as the Hex equivalent of the Octal address V-memory location V2100.
The CPU will copy the data from V2100 which in this example contains the value 2635 into
the lower word of the accumulator.
X1 V2076 X X X X
LD
V2077 X X X X
P2000
V2100 2 6 3 5
V2000 (P2000) contains the value 440 V2101 X X X X
HEX. 440 HEX. = 2100 Octal which
contains the value 2635. V2102 X X X X
V2000 V2103 X X X X
Accumulator
0 4 4 0 V2104 X X X X
2 6 3 5
V2105 X X X X
OUT
V2200
The following example is identical to the one above with one exception. The LDA (Load
Address) instruction automatically converts the Octal address to Hex.
Acc. 0 0 0 0 00 44 44 00
V2076 X X X X
V2077 X X X X
Load (LD)
DS5 Used The Load instruction is a 16 bit instruction that loads the LD
HPP Used value (Aaaa), which is either a V-memory location or a 4 A aaa
digit constant, into the lower 16 bits of the accumulator.
The upper 16 bits of the accumulator are set to 0.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
Constant ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠K 0–FFFF
NOTE: Two consecutive Load instructions will place the value of the first load instruction onto the
accumulator stack.
In the following example, when X1 is on, the value in V2000 will be loaded into the accumulator
and output to V2010.
DirectSOFT
Direct SOFT32
V2000
X1 LD 8 9 3 5
V2000
OUT
V2010
$ B X
STR 1 SET
SHFT L D
ANDST 3
C A A A ENT
2 0 0 0
GX SHFT V C A B A ENT
OUT AND 2 0 1 0
NOTE: Two consecutive Load instructions will place the value of the first load instruction onto the
accumulator stack.
In the following example, when X1 is on, the 32 bit value in V2000 and V2001 will be loaded
into the accumulator and output to V2010 and V2011.
DirectSOFT
Direct SOFT32
X1 LDD V2001 V2000
V2000 6 7 3 9 5 0 2 6
6 7 3 9 5 0 2 6
OUTD
V2010 V2011 V2010
$ B ENT
STR 1
SHFT L D D
ANDST 3 3
C A A A ENT
2 0 0 0
GX SHFT D
OUT 3
C A B A ENT
2 0 1 0
NOTE: Two consecutive Load instructions will place the value of the first load instruction onto the
accumulator stack.
In the following example, when C0 is on, the binary pattern of C10–C16 (7 bits) will be
loaded into the accumulator using the Load Formatted instruction. The lower 7 bits of the
accumulator are output to Y0–Y6 using the Out Formatted instruction.
DirectSOFT
Direct SOFT32
C0 Location Constant
LDF C10 C16 C15 C14 C13 C12 C11 C10
K7 C10 K7 OFF OFF OFF ON ON ON OFF
OUTF Y0
K7
Location Constant Y6 Y5 Y4 Y3 Y2 Y1 Y0
Copy the value from the
specified number of bits in Y0 K7 OFF OFF OFF ON ON ON OFF
the accumulator to Y0 – Y6
Handheld Programmer Keystrokes
$ SHFT C A ENT
STR 2 0
SHFT L D F
ANDST 3 5
SHFT C B A H ENT
2 1 0 7
GX SHFT F
OUT 5
A H ENT
0 7
NOTE: Two consecutive Load instructions will place the value of the first load instruction onto the
accumulator stack.
In the following example when X1 is on, the octal number 40400 will be converted to a HEX
4100 and loaded into the accumulator using the Load Address instruction. The value in the
lower 16 bits of the accumulator is copied to V2000 using the Out instruction.
DirectSOFT
Direct SOFT32
X1 LDA Octal Hexadecimal
O 40400 4 0 4 0 0 4 1 0 0
4 1 0 0
OUT
V2000 V2000
$ B ENT
STR 1
SHFT L D A
ANDST 3 0
E A E A A ENT
4 0 4 0 0
GX SHFT V C A A A ENT
OUT AND 2 0 0 0
In the following example, when X1 is on, the value in V2000 will be loaded into the lower
16 bits of the accumulator using the Load instruction. The value in the lower 16 bits of the
accumulator are copied to V2010 using the Out instruction.V2000
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 LD V2000 $ B ENT
8 9 3 5 STR 1
V2000
SHFT L D
Load the value in V2000 into ANDST 3
the lower 16 bits of the The unused accumulator
accumulator bits are set to zero C A A A ENT
2 0 0 0
Acc. 0 0 0 0 88 99 33 55
OUT GX SHFT V C A B A ENT
OUT AND 2 0 1 0
V2010
In the following example, when X1 is on, the 32 bit value in V2000 and V2001 will be loaded
into the accumulator using the Load Double instruction. The value in the accumulator is
output to V2010 and V2011 using the Out Double instruction.
DirectSOFT
Direct SOFT32 V2001 V2000 Handheld Programmer Keystrokes
6 7 3 9 5 0 2 6
X1 $ B ENT
LDD STR 1
V2000
SHFT L D D
Load the value in V2000 and ANDST 3 3
V2001 into the accumulator Acc. 6 7 3 9 55 00 22 66
C A A A ENT
2 0 0 0
OUTD
GX SHFT D
V2010 OUT 3
Copy the value in the 6 7 3 9 5 0 2 6 C A B A ENT
accumulator to V2010 and V2011 V2010 2 0 1 0
V2011
In the following example, when C0 is on, the binary pattern of C10–C16 (7 bits) will be
loaded into the accumulator using the Load Formatted instruction. The lower 7 bits of the
accumulator are output to Y0–Y6 using the Out Formatted instruction.
DirectSOFT 5
C0 Location Constant
LDF C10 C16 C15 C14 C13 C12 C11 C10
K7 C10 K7 OFF OFF OFF ON ON ON OFF
$ SHFT C A ENT
STR 2 0
SHFT L D F
ANDST 3 5
SHFT C B A H ENT
2 1 0 7
GX SHFT F
OUT 5
A H ENT
0 7
POP
DS5 Used The POP instruction moves the value from the first level of the POP
HPP Used accumulator stack (32 bits) to the accumulator and shifts each
value in the stack up one level.
OUT Level 4 X X X X X X X X
V2000 Level 5 X X X X X X X X
V2000 4 5 4 5 Level 6 X X X X X X X X
Copy the value in the lower 16 bits of
the accumulator to V2000 Level 7 X X X X X X X X
Level 8 X X X X X X X X
POP
Previous Acc. value
Acc. 0 0 0 0 44 55 44 55
Pop the 1st. value on the stack into the
accumulator and move stack values Current Acc. value Accumulator Stack
up one location
Acc. 0 0 0 0 3 7 9 2 Level 1 0 0 0 0 7 9 3 0
Level 2 X X X X X X X X
OUT Level 3 X X X X X X X X
V2001
Level 4 X X X X X X X X
Pop the 1st. value on the stack into the Previous Acc. value
accumulator and move stack values
up one location Acc. 0 0 0 0 3 7 9 2
The discrete status flag indicates if the result of the And is zero.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 will be loaded into the accumulator
using the Load instruction. The value in the accumulator is anded with the value in V2006
using the And instruction. The value in the lower 16 bits of the accumulator is output to
V2010 using the Out instruction.
DirectSOFT
Direct SOFT32
X1 V2000
LD
2 8 7 A
V2000
Load the value in V2000 into The upper 16 bits of the accumulator
the lower 16 bits of the will be set to 0
accumulator
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
AND
V2006 Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
OUT
V2010
2 8 3 8
Copy the lower 16 bits of the
accumulator to V2010 V2010
$ B ENT
STR 1
SHFT L D C A A A ENT
ANDST 3 2 0 0 0
V SHFT V C A A G ENT
AND AND 2 0 0 6
GX SHFT V C A B A ENT
OUT AND 2 0 1 0
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded into
the accumulator using the Load Double instruction. The value in the accumulator is anded
with 36476A38 using the And double instruction. The value in the accumulator is output to
V2010 and V2011 using the Out Double instruction.
DirectSOFT
Direct SOFT32 V2000 V2000
X1 LDD 5 4 7 E 2 8 7 A
V2000
ANDD
K36476A38 Acc. 0 1 0 1 0 1 0 0 0 1 1 1 1 1 1 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
OUTD
V2010 1 4 4 6 2 8 3 8
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
V SHFT D SHFT K D G E H G SHFT A SHFT D I ENT
AND 3 JMP 3 6 4 7 6 0 3 8
GX SHFT D C A B A ENT
OUT 3 2 0 1 0
Or (OR)
DS5 Used
The Or instruction is a 16 bit instruction that logically ors the
OR
HPP Used
value in the lower 16 bits of the accumulator with a specified
A aaa
V-memory location (Aaaa). The result resides in the accumulator.
The discrete status flag indicates if the result of the OR is zero.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 will be loaded into the accumulator
using the Load instruction. The value in the accumulator is OR’ed with V2006 using the Or
instruction. The value in the lower 16 bits of the accumulator are output to V2010 using the
Out instruction.
DirectSOFT
Direct SOFT32
X1 V2000
LD
2 8 7 A
V2000
Load the value in V2000 into The upper 16 bits of the accumulator
the lower 16 bits of the will be set to 0
accumulator
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
OR
V2006 Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
OUT
V2010
6 A 7 A
Copy the value in the lower
16 bits of the accumulator to V2010
V2010
Handheld Programmer Keystrokes
$ B ENT
STR 1
SHFT L D C A A A ENT
ANDST 3 2 0 0 0
Q SHFT V C A A G ENT
OR AND 2 0 0 6
GX SHFT V C A B A ENT
OUT AND 2 0 1 0
Or Double (ORD)
DS5 Used The Or Double is a 32 bit instruction that ors the value in
the accumulator with the value (Aaaa), which is either two ORD
HPP Used
consecutive V-memory locations or an 8 digit (max.) constant K aaa
value. The result resides in the accumulator. Discrete status
flags indicate if the result of the Or Double is zero or a negative
number (the most significant bit is on).
Operand Data Type DL05 Range
aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
Constant ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠K 0–FFFFFFFF
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded into
the accumulator using the Load Double instruction. The value in the accumulator is OR’ed
with 36476A38 using the Or Double instruction. The value in the accumulator is output to
V2010 and V2011 using the Out Double instruction.
DirectSOFT
Direct SOFT32
X1 V2001 V2000
LDD
5 4 7 E 2 8 7 A
V2000
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Acc. 0 1 0 1 0 1 0 0 0 1 1 1 1 1 1 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
ORD
K36476A38 Acc. 0 1 0 1 0 1 0 0 0 1 1 1 1 1 1 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
OUTD
V2010
7 6 7 F 6 A 7 A
Copy the value in the
accumulator to V2010 and V2011 V2010
V2011
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
Q SHFT D SHFT K D G E H G SHFT A SHFT D I ENT
OR 3 JMP 3 6 4 7 6 0 3 8
GX SHFT D C A B A ENT
OUT 3 2 0 1 0
Exclusive Or (XOR)
DS5 Used The Exclusive Or instruction is a 16 bit instruction that
performs an exclusive or of the value in the lower 16 bits of XOR
HPP Used
the accumulator and a specified V-memory location (Aaaa). A aaa
The result resides in the in the accumulator. The discrete
status flag indicates if the result of the XOR is zero.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 will be loaded into the accumulator
using the Load instruction. The value in the accumulator is exclusive OR’ed with V2006 using
the Exclusive Or instruction. The value in the lower 16 bits of the accumulator are output to
V2010 using the Out instruction.
DirectSOFT
Direct SOFT32
X1 V2000
LD
2 8 7 A
V2000
Load the value in V2000 into The upper 16 bits of the accumulator
the lower 16 bits of the will be set to 0
accumulator
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
XOR
V2006 Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 1 0
OUT
V2010
4 2 4 2
Copy the lower 16 bits of the
accumulator to V2010 V2010
$ SHFT X B ENT
STR SET 1
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded
into the accumulator using the Load Double instruction. The value in the accumulator is
exclusively OR’ed with 36476A38 using the Exclusive Or Double instruction. The value in the
accumulator is output to V2010 and V2011 using the Out Double instruction.
DirectSOFT
Direct SOFT32 V2001 V2000
X1 LDD 5 4 7 E 2 8 7 A
V2000
OUTD Acc. 0 1
0 1
0 0 0 0
1 1
0 0 0 0 1
0 1
0 1
0 0 0 1
0 0 1 0 0 0 0 1 0 0 1 0 0 0 0 1 0
V2010
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
Compare (CMP)
DS5 Used The compare instruction is a 16 bit instruction that compares the
CMP
HPP Used value in the lower 16 bits of the accumulator with the value in a
A aaa
specified V-memory location (Aaaa). The corresponding status flag
will be turned on indicating the result of the comparison.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example when X1 is on, the constant 4526 will be loaded into the lower 16
bits of the accumulator using the Load instruction. The value in the accumulator is compared
with the value in V2000 using the Compare instruction. The corresponding discrete status
flag will be turned on indicating the result of the comparison. In this example, if the value in
the accumulator is less than the value specified in the Compare instruction, SP60 will turn on
energizing C30.
DirectSOFT
Direct SOFT32
X1 LD CONSTANT
K4526 4 5 ?
2 ?
6
Compared
with
CMP
V2000
8 9 4 5
Compare the value in the
accumulator with the value V2000
in V2000
SP60 C30
OUT
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example when X1 is on, the value in V2000 and V2001 will be loaded into
the accumulator using the Load Double instruction. The value in the accumulator is compared
with the value in V2010 and V2011 using the CMPD instruction. The corresponding discrete
status flag will be turned on indicating the result of the comparison. In this example, if the
value in the accumulator is less than the value specified in the Compare instruction, SP60 will
turn on energizing C30.
Direct SOFT32
DirectSOFT
X1 V2001 V2000
LDD
4 5 2 6 7 2 9 9
V2000
Acc. 4 5 ?
2 6 77 72 9 9
Compared
CMPD with
V2010
6 7 3 9 5 0 2 6
Compare the value in the
accumulator with the value V2011 V2010
in V2010 and V2011
SP60 C30
OUT
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
Math Instructions
Add (ADD)
Add is a 16 bit instruction that adds a BCD value in the ADD
DS5 Used accumulator with a BCD value in a V-memory location (Aaaa). A aaa
HPP Used The result resides in the accumulator.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 will be loaded into the accumulator
using the Load instruction. The value in the lower 16 bits of the accumulator are added to the
value in V2006 using the Add instruction. The value in the accumulator is copied to V2010
using the Out instruction.
DirectSOFT
Direct SOFT32 V2000
X1 4 9 3 5
LD
V2000
OUT
V2010 7 4 3 5
$ B ENT
STR 1
SHFT L D C A A A ENT
ANDST 3 2 0 0 0
SHFT A D D C A A G ENT
0 3 3 2 0 0 6
GX SHFT V C A B A ENT
OUT AND 2 0 1 0
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded into
the accumulator using the Load Double instruction. The value in the accumulator is added
with the value in V2006 and V2007 using the Add Double instruction. The value in the
accumulator is copied to V2010 and V2011 using the Out Double instruction.
Direct SOFT V2001 V2000
X1 6 7 3 9 5 0 2 6
LDD
V2000
OUTD
V2010 8 7 3 9 9 0 7 2
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
SHFT A D D D C A A G ENT
0 3 3 3 2 0 0 6
GX SHFT D SHFT V C A B A ENT
OUT 3 AND 2 0 1 0
Subtract (SUB)
SUB
DS5 Used
Subtract is a 16 bit instruction that subtracts the BCD value (Aaaa) in
A aaa
HPP Used
a V-memory location from the BCD value in the lower 16 bits of the
accumulator. The result resides in the accumulator.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 will be loaded into the accumulator
using the Load instruction. The value in V2006 is subtracted from the value in the accumulator
using the Subtract instruction. The value in the accumulator is copied to V2010 using the Out
instruction.
DirectSOFT
Direct SOFT32 V2000
2 4 7 5
X1 LD
V2000
SUB _
1 5 9 2 (V2006)
V2006
Acc. 0 8 8 3
Subtract the value in V2006
from the value in the lower
16 bits of the accumulator
OUT 0 8 8 3
V2010
V2010
Copy the value in the lower
16 bits of the accumulator to
V2010
Handheld Programmer Keystrokes
$ B ENT
STR 1
SHFT L D C A A A ENT
ANDST 3 2 0 0 0
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded
into the accumulator using the Load Double instruction. The value in V2006 and V2007
is subtracted from the value in the accumulator. The value in the accumulator is copied to
V2010 and V2011 using the Out Double instruction.
Direct SOFT V2001 V2000
0 1 0 6 3 2 7 4
X1 LDD
V2000
OUTD 0 0 3 9 0 8 9 9
V2010
V2011 V2010
Copy the value in the
accumulator to V2010 and
V2011
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
Multiply (MUL)
DS5 Used
Multiply is a 16 bit instruction that multiplies the BCD MUL
HPP Used
value (Aaaa), which is either a V-memory location or a 4– A aaa
digit (max.) constant, by the BCD value in the lower 16
bits of the accumulator The result can be up to 8 digits and
resides in the accumulator.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
Constant ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠K 0–9999
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 will be loaded into the accumulator
using the Load instruction. The value in V2006 is multiplied by the value in the accumulator.
The value in the accumulator is copied to V2010 and V2011 using the Out Double instruction.
DirectSOFT
Direct SOFT32 V2000
X1 1 0 0 0
LD
V2000
The unused accumulator
Load the value in V2000 into bits are set to zero
the lower 16 bits of the
accumulator 0 0 0 0 1 0 0 0 (Accumulator)
(V2006)
X 2 5
MUL
V2006 Acc. 0 0 0 2 5 0 0 0
0 0 0 2 5 0 0 0
OUTD
V2011 V2010
V2010
$ B ENT
STR 1
SHFT L D C A A A ENT
ANDST 3 2 0 0 0
SHFT M U L C A A G ENT
ORST ISG ANDST 2 0 0 6
GX SHFT D C A B A ENT
OUT 3 2 0 1 0
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following example, when X1 is on, the constant Kbc614e hex will be loaded into the
accumulator. When converted to BCD the number is ”12345678”. That number is stored in
V1400 and V1401. After loading the constant K2 into the accumulator, we multiply it times
12345678, which is 24691356.
DirectSOFT
Direct SOFT32 Display
1 2 3 4 5 6 7 8 (Accumulator)
X1 LDD Load the hex equivalent
of 12345678 decimal into
Kbc614e the accumulator.
2 4 6 9 1 3 5 6
MULD Multiply the accumulator
contents (2) by the
V1400 V1403 V1402
8-digit number in V1400
and V1401.
$ B ENT
STR 1
SHFT B C D ENT
1 2 3
GX SHFT D B E A A ENT
OUT 3 1 4 0 0
SHFT M U L D B E A A ENT
ORST ISG ANDST 3 1 4 0 0
GX SHFT D B E A C ENT
OUT 3 1 4 0 2
Divide (DIV)
DS5 Used Divide is a 16 bit instruction that divides the BCD value
HPP Used in the accumulator by a BCD value (Aaaa), which is either DIV
a V-memory location or a 4-digit (max.) constant. The A aaa
first part of the quotient resides in the accumulator and
the remainder resides in the first stack location.
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, the value in V2000 will be loaded into the accumulator
using the Load instruction. The value in the accumulator will be divided by the value in V2006
using the Divide instruction. The value in the accumulator is copied to V2010 using the Out
instruction.
DirectSOFT
Direct SOFT32 V2000
5 0 0 0
X1 LD
V2000
OUT 1 0 2
V2010 V2010
$ B ENT
STR 1
SHFT L D C A A A ENT
ANDST 3 2 0 0 0
SHFT D I V C A A G ENT
3 8 AND 2 0 0 6
GX SHFT V C A B A ENT
OUT AND 2 0 1 0
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following example, when X1 is on, the value in V1400 and V1401 will be loaded into
the accumulator using the Load Double instruction. The value in the accumulator is divided
by the value in V1420 and V1421 using the Divide Double instruction. The first part of the
quotient resides in the accumulator an the remainder resides in the first stack location. The
value in the accumulator is copied to V1500 and V1501 using the Out Double instruction.
DirectSOFT 5 V1401 V1400
X1 LDD 0 1 5 0 0 0 0 0
V1400
0 1 5 0 0 0 0 0 (Accumulator)
OUTD
V1500 0 0 0 3 0 0 0 0
$ B ENT SHFT L D D
STR 1 ANDST 3 3
B E A A ENT SHFT D I V
1 4 0 0 3 8 AND
B E C A ENT GX SHFT D
1 4 2 0 OUT 3
B F A A ENT
1 5 0 0
Increment (INC)
INC
DS5 Used The Increment instruction increments a BCD value in a
A aaa
HPP Used specified V-memory location by “1” each time the instruction
is executed.
Decrement (DEC)
DS5 Used The Decrement instruction decrements a BCD value in a DEC
HPP Used specified V-memory location by “1” each time the instruction A aaa
is executed.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following increment example, when C5 is on the value in V1400 increases by one.
DirectSOFT
Direct SOFT32 V1400
C5 8 9 3 5
INC
V1400
SHFT I N C B E A A ENT
8 TMR 2 1 4 0 0
In the following decrement example, when C5 is on the value in V1400 is decreased by one.
Direct SOFT32 V1400
DirectSOFT
C5 8 9 3 5
DEC
V1400
SHFT D E C B E A A ENT
3 4 2 1 4 0 0
In the following example when C5 is on, the binary value in V2000 is increased by 1.
DirectSOFT
Direct SOFT32 V2000 Handheld Programmer Keystrokes
C5 4 A 3 C
INCB $ SHFT C F ENT
STR 2 5
V2000
SHFT I N C B C A A A ENT
Increment the binary value 8 TMR 2 1 2 0 0 0
in the accumulator by“1” V2000
4 A 3 D
DECB
DS5 Used Decrement Binary (DECB)
HPP Used A aaa
The Decrement Binary instruction decrements a binary
value in a specified V-memory location by “1” each time
the instruction is executed.
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following example, when X1 is on, the value in V1400 will be loaded into the accumulator
using the Load instruction. The binary value in the accumulator will be added to the binary
value in V1420 using the Add Binary instruction. The value in the accumulator is copied to
V1500 and V1501 using the Out Double instruction.
DirectSOFT
DirectSOFT 5 Use either OR Constant
V-memory
V1400
X1 0 A 0 5
LD LD
V1400 K2565
ADDB + 1 2 C 4 (V1420)
V1420 Acc. 1 C C 9
The binary value in the
accumulator is added to the
binary value in V1420
OUTD 1 C C 9
V1500
V1500
Copy the value in the lower
16bits of the accumulator to
V1500 and V1501
SHFT L D V 1 4 0 0 ENT
SHFT A D D B V 1 4 2 0 ENT
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following example, when X1 is on, the value in V1400 will be loaded into the accumulator
using the Load instruction. The binary value in V1420 is subtracted from the binary value in
the accumulator using the Subtract Binary instruction. The value in the accumulator is copied
to V1500 using the Out instruction.
DirectSOFT
DirectSOFT32 Display Use either OR Constant
V-memory
X1 LD LD
V1400 K1024
V1400
Load the value in V1400
into the lower 16 bits of BIN 1 0 2 4
the accumulator
Acc. 0 6 1 9
OUT
V1500
V1500
Handheld Programmer Keystrokes
SHFT L D V 1 4 0 0 ENT
SHFT S SHFT U B B
V 1 4 2 0 ENT
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following example, when X1 is on, the value in V1400 will be loaded into the accumulator
using the Load instruction. The binary value in V1420 is multiplied by the binary value in the
accumulator using the Multiply Binary instruction. The value in the accumulator is copied to
V1500 and V1501 using the Out Double instruction.
Use either OR Constant
DirectSOFT
DirectSOFT32 Display V-memory
X1 V1400
LD
LD 0 A 0 1
V1400 K2561
Load the value in V1400
into the lower 16 bits of
the accumulator BIN
The unused accumulator
bits are set to zero
0 0 0 0 0 A 0 1 (Accumulator)
MULB
x 0 0 2 E (V1420)
V1420
Acc. 0 0 0 1 C C 2 E
The binary value in V1420 is
multiplied by the binary
value in the accumulator
OUTD
V1500 0 0 0 1 C C 2 E
STR X 1 ENT
SHFT L D V 1 4 0 0 ENT
SHFT M U L B V 1 4 2 0 ENT
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following example, when X1 is on, the value in V1400 will be loaded into the accumulator
using the Load instruction. The binary value in the accumulator is divided by the binary value
in V1420 using the Divide Binary instruction. The value in the accumulator is copied to
V1500 using the Out instruction.
Use either OR Constant
DirectSOFT
DirectSOFT32 Display V-memory
X1 V1400
LD LDD
F A 0 1
V1400 K64001
SHFT L D V 1 4 0 0 ENT
SHFT D I V B V 1 4 2 0 ENT
In the following example, when X1 is on, the value formed by discrete locations X10–X17 is
loaded into the accumulator using the Load Formatted instruction. The number of bits in the
accumulator set to “1” is counted using the Sum instruction. The value in the accumulator is
copied to V1500 using the Out instruction.
DirectSOFT
Direct SOFT32 Display
X17 X16 X15 X14 X13 X12 X11 X10
X1 ON ON OFF OFF ON OFF ON ON
LDF X10
K8 The unused accumulator
bits are set to zero
Load the value represented by
discrete locations X10–X17
into the accumulator 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 0 1 0 1 1
Acc. 0 0 0 0 0 0 0 5
SUM
OUT 0 0 0 5
V1500
V1500
Copy the value in the lower
16 bits of the accumulator
to V1500
Handheld Programmer Keystrokes
$ B ENT
STR 1
SHFT L D F B A I ENT
ANDST 3 5 1 0 8
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded into
the accumulator using the Load Double instruction. The bit pattern in the accumulator is
shifted 2 bits to the left using the Shift Left instruction. The value in the accumulator is copied
to V2010 and V2011 using the Out Double instruction.
DirectSOFT
Direct SOFT32
V2001 V2000
X1 LDD 6 7 0 5 33 31 10 01
V2000
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
SHFL Acc. 0 1 1 0 0 1 1 1 0 0 0 0 0 1 0 1 0 0 1 1 0 0 0 1 0 0 0 0 0 0 0 1
K2
OUTD
V2010
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Copy the value in the Acc. 0
1 0 0 0
1 0
1 1 0 0 0 0 0 0
1 0 0
1 0 0 1 1 0 0 0 1 0 0 0 0 0 0 0 1 0 0
accumulator to V2010 and
V2011
9 C 1 4 C 4 0 4
V2011 V2010
Handheld Programmer Keystrokes
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded into
the accumulator using the Load Double instruction. The bit pattern in the accumulator is
shifted 2 bits to the right using the Shift Right instruction. The value in the accumulator is
copied to V2010 and V2011 using the Out Double instruction.
DirectSOFT
... .
The bit pattern in the
accumulator is shifted 2 bit
positions to the right Shifted out of the
accumulator
OUTD
V2010 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
1 9 C 1 4 C 4 0
V2011 V2010
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
Encode (ENCO)
DS5 Used The Encode instruction encodes the bit position in the
HPP Used accumulator having a value of 1, and returns the appropriate
binary representation. If the most significant bit is set to 1 (Bit ENCO
31), the Encode instruction would place the value HEX 1F
(decimal 31) in the accumulator. If the value to be encoded
is 0000 or 0001, the instruction will place a zero in the
accumulator. If the value to be encoded has more than one bit
position set to a “1”, the least significant “1” will be encoded
and SP53 will be set on.
Discrete Bit Flags Description
SP63 On when the result of the instruction causes the value in the accumulator to be zero.
SP70 On anytime the value in the accumulator is negative.
NOTE: The status flags are only valid until another instruction that uses the same flags is executed.
In the following example, when X1 is on, The value in V2000 is loaded into the accumulator
using the Load instruction. The bit position set to a “1” in the accumulator is encoded to the
corresponding 5 bit binary value using the Encode instruction. The value in the lower 16 bits
of the accumulator is copied to V2010 using the Out instruction.
DirectSOFT
Direct SOFT32 V2000
1 0 0 0
X1 LD
V2000
Bit postion 12 is
converted
to binary
ENCO
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Encode the bit position set
to “1” in the accumulator to a Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 0
5 bit binary value
OUT
V2010
$ B ENT
STR 1
SHFT L D C A A A ENT
ANDST 3 2 0 0 0
SHFT E N C O ENT
4 TMR 2 INST#
GX SHFT V C A B A ENT
OUT AND 2 0 1 0
Decode (DECO)
DS5 Used The Decode instruction decodes a 5 bit binary value of 0–31
HPP Used (0–1F HEX) in the accumulator by setting the appropriate bit DECO
position to a 1. If the accumulator contains the value F (HEX),
bit 15 will be set in the accumulator. If the value to be decoded
is greater than 31, the number is divided by 32 until the value is
less than 32 and then the value is decoded.
In the following example when X1 is on, the value formed by discrete locations X10–X14 is
loaded into the accumulator using the Load Formatted instruction. The five bit binary pattern
in the accumulator is decoded by setting the corresponding bit position to a “1” using the
Decode instruction.
DirectSOFT
Direct SOFT32
X14 X13 X12 X11 X10
X1 LDF X10 OFF ON OFF ON ON
K5
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Decode the five bit binary Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0
pattern in the accumulator
and set the corresponding
bit position to a “1”
$ B ENT
STR 1
SHFT L D F B A F ENT
ANDST 3 5 1 0 5
SHFT D E C O ENT
3 4 2 INST#
X1 0 0 0 2 8 5 2 9
LDD
V2000
8 4 2 1 8 4 2 1 8 4 2 1 8 4 2 1 8 4 2 1 8 4 2 1 8 4 2 1 8 4 2 1
Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 1 0 1 0 0 1 0 1 0 0 1
BCD Value
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Convert the BCD value in Acc. 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 1 1 1 1 0 1 1 1 0 0 0 1
the accumulator to the
binary equivalent value 2 1 5 2 1 6 3 1 8 4 2 1 5 2 1 6 3 1 8 4 2 1 5 2 1 6 3 1 8 4 2 1
1 0 3 6 3 7 3 6 3 1 0 0 2 6 3 5 2 6 1 0 0 0 1 5 2 4 2 6
4 7 6 8 4 1 5 7 8 9 9 4 4 2 1 5 7 3 9 9 4 2 2 6 8
7 3 8 4 2 0 5 7 8 4 7 8 2 1 0 3 6 8 2 6 8 4
4 7 7 3 1 8 4 7 6 3 1 5 8 4 7 6 8 4
4 4 0 5 7 8 4 2 0 0 5 7 8 4 2
8 1 9 4 7 6 3 1 8 4 2 6
3 8 1 5 2 4 2 6
6 2 2 6 8
4 4
8
OUTD
V2010 The Binary (HEX)
0 0 0 0 6 F 7 1 value copied to
Copy the binary data in the
V2010
accumulator to V2010 and V2011 V2011 V2010
Standard RLL
Instructions
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
SHFT B I N ENT
1 8 TMR
GX D C A B A
SHFT ENT
OUT 3 2 0 1 0
DirectSOFT
DirectSOFT32 V2001 V2000
X1 0 0 0 0 6 F 7 1
LDD
V2000 Binary Value
BCD
16384 + 8192 + 2048 + 1024 + 512 + 256 + 64 + 32 + 16 + 1 = 28529
OUTD
V2010
$ B ENT
STR 1
L D D C A A A
SHFT ENT
ANDST 3 3 2 0 0 0
B C D
SHFT ENT
1 2 3
GX SHFT D C A B A ENT
OUT 3 2 0 1 0
Invert (INV)
DS5 Used The Invert instruction inverts or takes the one’s complement INV
HPP Used of the 32 bit value in the accumulator. The result resides in
the accumulator.
In the following example, when X1 is on, the value in V2000 and V2001 will be loaded into
the accumulator using the Load Double instruction. The value in the accumulator is inverted
using the Invert instruction. The value in the accumulator is copied to V2010 and V2011 using
the Out Double instruction.
DirectSOFT
Direct SOFT32 V2001 V2000
X1 0 4 0 5 00 22 55 00
LDD
V2000
INV
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Acc. 1 1 1 1 1 0 1 1 1 1 1 1 1 0 1 0 1 1 1 1 1 1 0 1 1 0 1 0 1 1 1 1
Invert the binary bit pattern
in the accumulator
OUTD F B F A F D A F
V2010 V2011 V2010
Copy the value in the
accumulator to V2010 and
V2011
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
SHFT I N V ENT
8 TMR AND
GX SHFT D C A B A ENT
OUT 3 2 0 1 0
In the example on the following page, when X1 is ON the constant (K4) is loaded into the
accumulator using the Load instruction and will be placed in the first level of the accumulator
stack when the next Load instruction is executed. The starting location for the ASCII table
(V1400) is loaded into the accumulator using the Load Address instruction. The starting
location for the HEX table (V1600) is specified in the ASCII to HEX instruction. The table
below lists valid ASCII values for ATH conversion.
ASCII Values Valid for ATH Conversion
ASCII Value HEX Value ASCII Value HEX Value
30 0 38 8
31 1 39 9
32 2 41 A
33 3 42 B
34 4 43 C
35 5 44 D
36 6 45 E
37 7 46 F
DirectSOFT
Direct SOFT32 Hexadecimal
ASCII TABLE Equivalents
X1 LD Load the constant value
into the lower 16 bits of the
K4 accumulator. This value
defines the number of V
memory location in the
ASCII table
V1400 33 34
LDA Convert octal 1400 to HEX
O 1400
300 and load the value into
the accumulator
1234 V1600
V1401 31 32
ATH V1600 is the starting
location for the HEX table
V1600
$
STR
B
1
ENT V1402 37 38
SHFT L
ANDST
D
3
PREV E
4
ENT 5678 V1601
L D A B E A A
SHFT
ANDST 3 0 1 4 0 0
ENT
V1403 35 36
SHFT A T H B G A A ENT
0 MLR 7 1 6 0 0
In the following example, when X1 is ON the constant (K2) is loaded into the accumulator
using the Load instruction. The starting location for the HEX table (V1500) is loaded into
the accumulator using the Load Address instruction. The starting location for the ASCII table
(V1400) is specified in the HEX to ASCII instruction.
DirectSOFT
Direct SOFT32
Hexadecimal
X1 LD Equivalents ASCII TABLE
K2
HTA 37 38 V1402
V1400
$ B ENT
STR 1
SHFT L D A B F A A ENT
ANDST 3 0 1 5 0 0
SHFT H T A B E A A ENT
7 MLR 0 1 4 0 0
The table below lists valid ASCII values for HTA conversion.
ASCII Values Valid for HTA Conversion
Hex Value ASCII Value Hex Value ASCII Value
0 30 8 38
1 31 9 39
2 32 A 41
3 33 B 42
4 34 C 43
5 35 D 44
6 36 E 45
7 37 F 46
DirectSOFT
Direct SOFT32
X27 X26 X25 X12 X11 X10
X1 LDF K16 OFF OFF OFF ON OFF ON
X10
GX V C A B A 0000000100 0007
SHFT ENT
OUT AND 2 0 1 0
1000000001 1022
1000000000 1023
Bit Positions 8 7 6 5 4 3 2 1
B C E F 0 D A 9
Result (accumulator)
In the following example when X1 is on, The value in the first level of the accumulator stack
will be reorganized in the order specified by the value in the accumulator.
Example A shows how the shuffle digits works when 0 or 9 –F is not used when specifying the
order the digits are to be shuffled. Also, there are no duplicate numbers in the specified order.
Example B shows how the shuffle digits works when a 0 or 9–F is used when specifying the
order the digits are to be shuffled. Notice when the Shuffle Digits instruction is executed, the
bit positions in the first stack location that had a corresponding 0 or 9–F in the accumulator
(order specified) are set to “0”.
Example C shows how the shuffle digits works when duplicate numbers are used specifying the
order the digits are to be shuffled. Notice when the Shuffle Digits instruction is executed, the
most significant duplicate number in the order specified is used in the result.
DirectSOFT
Direct SOFT32
A B C
X1 LDD V2001 V2000 V2001 V2000 V2001 V2000
V2000 9 A B C D E F 0 0 F E D C B A 9 9 A B C D E F 0
New bit 8 7 6 5 4 3 2 1 8 7 6 5 4 3 2 1 8 7 6 5 4 3 2 1
SFLDGT Positions
B C E F 0 D A 9 Acc. 0 0 0 0 E D A 9 Acc. 0 0 0 0 9 A B C Acc.
OUTD
B C E F 0 D A 9 0 0 0 0 E D A 9 0 0 0 0 9 A B C
V2010
V2011 V2010 V2011 V2010 V2011 V2010
Copy the value in the
accumulator to V2010 and
V2011
$ B ENT
STR 1
SHFT L D D C A A A ENT
ANDST 3 3 2 0 0 0
SHFT L D D C A A G ENT
ANDST 3 3 2 0 0 6
Table Instructions
Move (MOV)
The Move instruction moves the values from a V-memory
table to another V-memory table the same length (a table is MOV
DS5 Used V aaa
a consecutive group of V-memory locations). The function
HPP Used
parameters are loaded into the first level of the accumulator
stack and the accumulator by two additional instructions.
The MOV instruction can be used to write data to non-volatile V-memory (see Appendix F).
Listed below are the steps necessary to program the MOV function.
Step 1:— Load the number of V-memory locations to be moved into the first level of the
accumulator stack. This parameter is a HEX value (K40 max, 100 octal).
Step 2:— Load the starting V-memory location for the locations to be moved into the
accumulator. This parameter is a HEX value.
Step 3:— Insert the MOVE instruction which specifies starting V-memory location (Vaaa)
for the destination table.
Helpful Hint: — For parameters that require HEX values when referencing memory locations,
the LDA instruction can be used to convert an octal address to the HEX equivalent and load
the value into the accumulator.
Operand Data Type DL05 Range
⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠A aaa
V-memory ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V See memory map
Pointer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠P See memory map
In the following example, when X1 is on, the constant value (K6) is loaded into the accumulator
using the Load instruction. This value specifies the length of the table and is placed in the first
stack location after the Load Address instruction is executed. The octal address 2000 (V2000),
the starting location for the source table is loaded into the accumulator. The destination table
location (V2030) is specified in the Move instruction.
DirectSOFT
Direct SOFT32
SHFT L D A C A A A ENT
ANDST 3 0 2 0 0 0
SHFT M O V C A D A ENT
ORST INST# AND 2 0 3 0
DirectSOFT
Direct SOFT32
Data label area X1
programmed after LD
the END instruction K4
.
DLBL K1 . Load the value 4 into the
accumulator specifying the
N C O N 1 2 3 4 V2000 number of locations to be
copied.
K 1 2 3 4
N C O N 4 5 3 2 V2001 LD
K 4 5 3 2 K0
SHFT L D L B L B ENT
ANDST 3 ANDST 1 ANDST 1
SHFT M O V M C C A A A ENT
ORST INST# AND ORST 2 2 0 0 0
SHFT N O P ENT
NOP TMR INST# CV
End (END)
The End instruction marks the termination point of the normal program
DS5 Used
scan. An End instruction is required at the end of the main program END
HPP N/A
body. If the End instruction is omitted an error will occur and the CPU
will not enter the Run Mode. Data labels, subroutines and interrupt
routines are placed after the End instruction. The End instruction is not
conditional; therefore, no input contact is allowed.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
SHFT E N D ENT
4 TMR 3
END
Stop (STOP)
DS5 Used The Stop instruction changes the operational mode of the CPU from STOP
HPP N/A Run to Program (Stop) mode. This instruction is typically used to
stop PLC operation in an error condition.
In the following example, when C0 turns on, the CPU will stop
operation and switch to the program mode.
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
C0 $ SHFT C A ENT
STR 2 0
STOP S T O P
SHFT SHFT ENT
RST MLR INST# CV
SHFT R S T W T ENT
ORN RST MLR ANDN MLR
RSTWT
In the following example, when X1 is on, the application program inside the For / Next loop
will be executed three times. If X1 is off the program inside the loop will not be executed. The
immediate instructions may or may not be necessary depending on your application. Also, The
RSTWT instruction is not necessary if the For / Next loop does not extend the scan time larger
the Watch Dog Timer setting. For more information on the Watch Dog Timer, refer to the
RSTWT instruction.
DirectSOFT
Direct SOFT32
X1 1 2 3
K3
FOR
RSTWT
X20 Y5
OUT
NEXT
$ B ENT
STR 1
SHFT F O R D ENT
5 INST# ORN 3
SHFT R S T W T ENT
ORN RST MLR ANDN MLR
$ SHFT I C A ENT
STR 8 2 0
GX F ENT
OUT 5
SHFT N E X T ENT
TMR 4 SET MLR
In the following example, when X1 is on, Subroutine K3 will be called. The CPU will jump to
the Subroutine Label K3 and the ladder logic in the subroutine will be executed. If X35 is on
the CPU will return to the main program at the RTC instruction. If X35 is not on Y0–Y17 will
be reset to off and then the CPU will return to the main body of the program.
DirectSOFT
Direct SOFT32 Display X1 K3
GTS
C0
LD
K10
END
SBR K3
X20 Y5
OUTI
X21 Y10
OUTI
X35
RTC
X35 Y0 Y17
RSTI
RT
$ B ENT
STR 1
SHFT G T S D ENT
6 MLR RST 3
?
?
SHFT E N D ENT
4 TMR 3
SHFT R T C ENT
ORN MLR 2
SP SHFT I D F ENT
STRN 8 3 5
S SHFT I A B H ENT
RST 8 0 1 7
SHFT R T ENT
ORN MLR
In the following example, when X1 is on, Subroutine K3 will be called. The CPU will jump to
the Subroutine Label K3 and the ladder logic in the subroutine will be executed. The CPU will
return to the main body of the program after the RT instruction is executed.
DirectSOFT
Direct SOFT 32
X1 K3
GTS
END
SBR K3
X20 Y5
OUT
X21 Y10
OUT
RT
$ B ENT
STR 1
SHFT G T S D ENT
6 MLR RST 3
SHFT E N D ENT
4 TMR 3
SHFT R T ENT
ORN MLR
DirectSOFT
Direct SOFT32
X0 K1
When contact X0 is ON, logic under the first MLS
MLS will be executed.
X1 Y7
OUT
X2 K2
When contact X0 and X2 are ON, logic under the
MLS
second MLS will be executed.
X3 Y10
OUT
K1
MLR
The MLR instructions note the end of the Master
K0 Control area.
MLR
X10 Y11
OUT
MLS/MLR Example
In the following MLS/MLR example logic between the first MLS K1 (A) and MLR K0 (B)
will function only if input X0 is on. The logic between the MLS K2 (C) and MLR K1 (D) will
function only if input X10 and X0 is on. The last rung is not controlled by either of the MLS
coils.
DirectSOFT
DirectSOFT32 Handheld Programmer Keystrokes
X0 K1
A $ A ENT
MLS STR 0
Y B ENT
X1 C0 MLS 1
OUT $ B ENT
STR 1
X2 C1 GX SHFT C A ENT
OUT 2 0
OUT
$ C ENT
STR 2
X3 Y0
GX SHFT C B ENT
OUT OUT 2 1
$ D ENT
X10 K2 STR 3
C
GX A ENT
MLS
OUT 0
X5 $ B A ENT
Y1
STR 1 0
OUT Y C ENT
MLS 2
X4 Y2 $ F ENT
STR 5
OUT
GX B ENT
OUT 1
K1
D $ E
MLR ENT
STR 4
GX C ENT
X5 C2 OUT 2
OUT T B ENT
MLR 1
X6 Y3 $ F ENT
STR 5
OUT
GX SHFT C C ENT
OUT 2 2
K0
B
$ G ENT
MLR STR 6
GX D ENT
X7 Y4 OUT 3
OUT T A ENT
MLR 0
$ H ENT
STR 7
GX E C ENT
OUT 4 2
Interrupt Instructions
Interrupt (INT)
The Interrupt instruction allows a section of ladder logic INT O aaa
DS5 Used to be placed below the main body of the program and
HPP Used executed only when needed. High-Speed I/O Modes
10, 20, and 40 can generate an interrupt. With Mode INT 1
40, you may select an external interrupt (input X0), or a
time-based interrupt (5–999 ms).
Typically, interrupts are used in an application when a
fast response to an input is needed or a program section must execute faster than the normal
CPU scan. The interrupt label and all associated logic must be placed after the End statement
in the program. When an interrupt occurs, the CPU will complete execution of the current
instruction it is processing in ladder logic, then execute the interrupt routine. After interrupt
routine execution, the ladder program resumes from the point at which it was interrupted.
See Chapter 3, the section on Mode 40 (Interrupt) Operation for more details on interrupt
configuration. In the DL05, only one hardware interrupt is available.
Operand Data Type DL05 Range
Constant ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠O 0, 1
DirectSOFT
SHFT D I S I ENT
3 8 RST 8
SHFT E N D ENT
END 4 TMR 3
SHFT I N T A ENT
8 TMR MLR 0
INT O0
$ SHFT I B ENT
STR 8 1
X1 Y5
X SHFT I F ENT
SETI SET 8 5
$ SHFT I D ENT
X3 Y7 STR 8 3
SETI
X SHFT I H ENT
SET 8 7
X4
DISI
SHFT E N D ENT
4 TMR 3
SHFT I N T A ENT
8 TMR MLR 0
END
$ SHFT I C ENT
STR 8 2
INT O0
X SHFT I F ENT
SET 8 5
SP SHFT I D ENT
X2 Y5 STRN 8 3
SETI X SHFT I A H ENT
SET 8 0 7
SHFT I R T ENT
X3 Y0 Y7 8 ORN MLR
RSTI
IRT
Message Instructions
Fault (FAULT)
The Fault instruction is used to display a message on the handheld
DS5 Used programmer or in the DirectSOFT status bar. The message has FAULT
HPP Used a maximum of 23 characters and can be either V-memory data, A aaa
numerical constant data or ASCII text.
To display the value in a V-memory location, specify the V-memory location in the instruction.
To display the data in ACON (ASCII constant) or NCON (Numerical constant) instructions,
specify the constant (K) value for the corresponding data label area.
Fault Example
DS5 Used
In the following example when X1 is on, the message SW 146 will
HPP Used
display on the handheld programmer. The NCONs use the HEX FAULT :
*SW 146
ASCII equivalent of the text to be displayed. (The HEX ASCII for a
blank is 20, a 1 is 31, 4 is 34 ...)
DirectSOFT
Direct SOFT32 Handheld Programmer Keystrokes
X1 FAULT $ B ENT
K1 STR 1
SHFT F A U L T B ENT
5 0 ISG ANDST MLR 1
END
DLBL E N D
K1 SHFT ENT
4 TMR 3
SHFT D L B L B ENT
ACON
3 ANDST 1 ANDST 1
A SW
SHFT A C O N S W ENT
0 2 INST# TMR RST ANDN
SHFT N C O N C A D B ENT
NCON TMR 2 INST# TMR 2 0 3 1
K 2031
SHFT N C O N D E D G ENT
TMR 2 INST# TMR 3 4 3 6
NCON
K 3436
DirectSOFT
Direct SOFT32
END
DLBL
K1
ACON
A SW
NCON
K 2031
NCON
K 3436
SHFT E N D ENT
4 TMR 3
SHFT D L B L B ENT
3 ANDST 1 ANDST 1
SHFT A C O N S W ENT
0 2 INST# TMR RST ANDN
SHFT N C O N C A D B ENT
TMR 2 INST# TMR 2 0 3 1
SHFT N C O N D E D G ENT
TMR 2 INST# TMR 3 4 3 6
You may recall from the CPU specifications in Chapter 4 that the DL05’s ports are capable
of several protocols. Port 1 cannot be configured for the non-sequence protocol. To configure
port 2 using the Handheld Programmer, use AUX 56 and follow the prompts, making the same
choices as indicated below on this page. To configure a port in DirectSOFT, choose the PLC
> Setup > Setup Secondary Comm Port.
• Port: From the port number list box at the top, choose “Port 2”.
• Protocol: Click the check box to the left of “Non-sequence”,
and then you’ll see the dialog box shown below.
• Baud Rate: Choose the baud
rate that matches your printer.
• Stop Bits, Parity: Choose
number of stop bits and parity
setting to match your printer.
• Memory Address: Please choose
a memory address with 64 words
of contiguous free memory for use
by the Non-Sequence Protocol.
NOTE: See Chapter 4 for a detail of the non-
sequence setup.
Port 2 on the DL05 has standard RS232 levels, and should work with most printer serial input
connections.
Text element – this is used for printing character strings. The character strings are defined as
the character (more than 0) ranged by the double quotation marks. Two hex numbers preceded
by the dollar sign means an 8-bit ASCII character code. Also, two characters preceded by the
dollar sign is interpreted according to the following table:
# Character code Description
1 $$ Dollar sign ($)
2 $” Double quotation (”)
3 $L or $l Line feed (LF)
4 $N or $n Carriage return line feed (CRLF)
5 $P or $p Form feed
6 $R or $r Carriage return (CR)
7 $T or $t Tab
The following examples show various syntax conventions and the length of the output to the
printer.
Example:
” ” Length 0 without character
”A” Length 1 with character A
” ” Length 1 with blank
” $” ” Length 1 with double quotation mark
” $ R $ L ” Length 2 with one CR and one LF
” $ 0 D $ 0 A ” Length 2 with one CR and one LF
” $ $ ” Length 1 with one $ mark
In printing an ordinary line of text, you will need to include double quotation marks before
and after the text string. Error code 499 will occur in the CPU when the print instruction
contains invalid text or no quotations. It is important to test your PRINT instruction data
during the application development.
The following example prints the message to port 2. We use a PD contact, which causes the
message instruction to be active for just one scan. Note the $N at the end of the message, which
produces a carriage return / line feed on the printer. This prepares the printer to print the next
line, starting from the left margin.
V-memory element - this is used for printing V-memory contents in the integer format or real
format. Use V-memory number or V-memory number with “-” and data type. The data types
are shown in the table below. The Character code must be capital letters.
NOTE: There must be a space entered before and after the V-memory address to separate it from the text
string. Failure to do this will result in an error code 499.
Example:
V2000 Print binary data in V2000 for decimal number
V2000 : B Print BCD data in V2000
V2000 : D Print binary number in V2000 and V2001 for decimal number
V2000 : D B Print BCD data in V2000 and V2001
Example: The following example prints a message containing text and a variable. The “reactor
temperature” labels the data, which is at V2000. You can use the : B qualifier after the V2000
if the data is in BCD format, for example. The final string adds the units of degrees to the line
of text, and the $N adds a carriage return / line feed.
V-memory text element ¨This is used for printing text stored in V-memory. Use the %
followed by the number of characters after V-memory number for representing the text. If you
assign “0” as the number of characters, the print function will read the character count from the
first location. Then it will start at the next V-memory location and read that number of ASCII
codes for the text from memory.
Example:
V2000 % 16 16 characters in V2000 to V2007 are printed.
V2000 % 0 The characters in V2001 to Vxxxx (determined by the number in V2000) will
be printed.
Bit element – this is used for printing the state of the designated bit in V-memory or a relay bit.
The bit element can be assigned by the designating point (.) and bit number preceded by the
V-memory number or relay number. The output type is described as shown in the table below.
Example:
V2000.15 Prints the status of bit 15 in V2000, in 1/0 format
C100 Prints the status of C100 in 1/0 format
C100 : BOOL Prints the status of C100 in TRUE/FALSE format
C100 : ON/OFF Prints the status of C00 in ON/OFF format
V2000.15 : BOOL Prints the status of bit 15 in V2000 in TRUE/FALSE format
The maximum numbers of characters you can print is 128. The number of characters for each
element is listed in the table below:
Element Type Maximum Characters
Text, 1 character 1
16 bit binary 6
32 bit binary 11
4 digit BCD 4
8 digit BCD 8
Floating point (real number) 12
Floating point (real with exponent) 12
V-memory/text 2
Bit (1/0 format) 1
Bit (TRUE/FALSE format) 5
Bit (ON/OFF format) 3
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following example when X1 is ON, the RD instruction will read six bytes of data from a
intelligent module in base 1, slot 2 starting at address 0 in the intelligent module and copy the
information into V-memory loacations V1400-V1402.
CPU Intelligent Module
Direct SOFT 5
Data
}
{
X1 The constant value K0102
LD specifies the base number V1400 3 4 1 2 12 Address 0
K0102 (01) and the base slot V1401 7 8 5 6 34 Address 1
number (02).
V1402 0 1 9 0 56 Address 2
R D B E A A
SHFT ENT
ORN 3 1 4 0 0
NOTE: Status flags are valid only until another instruction uses the same flag.
In the following example, when X1 is on, the WT instruction will write six bytes of data to an
intelligent module in base 1, slot 2 starting at address 0 in the intelligent module and copy the
data from V-memory locations V1400-V1402.
CPU Intelligent Module
Data
{
Direct SOFT 5 12
V1377 X X X X Address 0
}
X1 The constant value K0102 34 Address 1
LD specifies the base number V1400 3 4 1 2
K0102 (01) and the base slot 56 Address 2
V1401 7 8 5 6
number (02). 78
0 1 9 0 Address 3
V1402
The constant value K6 90 Address 4
LD V1403 X X X X
specifies the number of 01 Address 5
K6 bytes to be written. V1404 X X X X
Network Instructions
Read from Network (RX)
The Read from Network instruction causes the master device on
DS5 Used a network to read a block of data from a slave device on the same
HPP Used RX
network. The function parameters are loaded into the accumulator
A aaa
and the first and second level of the stack. Listed below are the
program steps necessary to execute the Read from Network
function.
Step 1: — Load the slave address (0–90 BCD) into the low byte and “F2” into the high byte
of the accumulator (the next two instructions push this word down to the second layer of the
stack).
Step 2: — Load the number of bytes to be transferred into the accumulator, 2 - 128 bytes are
allowed, (the next instruction pushes this word onto the top of the stack).
Step 3: — Load the starting Master CPU address into the accumulator. This is the memory
location where the data read from the slave will be put. This parameter requires a HEX value.
Step 4: — Insert the RX instruction which specifies the starting V-memory location (Aaaa)
where the data will be read from in the slave.
Helpful Hint: For parameters that require HEX values, the LDA instruction can be used to
convert an octal address to the HEX equivalent and load the value into the accumulator.
In the following example, when X1 is on and the port busy relay SP116 (see special relays)
is not on, the RX instruction will access port 2 operating as a master. Ten consecutive bytes
of data (V2000 – V2004) will be read from a CPU at station address 5 and copied into
V-memory locations V2300–V2304 in the CPU with the master port.
DirectSOFT
DirectSOFT
X1 SP116 LD
KF205
LD
K10
V2277 X X X X X X X X V1777
The constant value K10 V2300 3 4 5 7 3 4 5 7 V2000
specifies the number of
bytes to be read (2-128 V2301 8 5 3 4 8 5 3 4 V2001
bytes allowed) V2302 1 9 3 6 1 9 3 6 V2002
RX
V2000
HandheldProgrammer Keystrokes
$ B ENT
STR 1
W SHFT SP B B G ENT
ANDN STRN 1 1 6
SHFT L D A C D A A ENT
ANDST 3 0 2 3 0 0
SHFT R X C A A A ENT
ORN SET 2 0 0 0
Helpful Hint: For parameters that require HEX values, the LDA instruction can be used to
convert an octal address to the HEX equivalent and load the value into the accumulator.
In the following example when X1 is on and the module busy relay SP116 (see special relays)
is not on, the WX instruction will access port 2 operating as a master. Ten consecutive bytes
of data is read from the Master CPU and copied to V-memory locations V2000–V2004 in the
slave CPU at station address 5.
DirectSOFT
DirectSOFT
X1 SP116 LD
KF205
LD
K10
V2277 X X X X X X X X V1777
The constant value K10 V2300 3 4 5 7 3 4 5 7 V2000
specifies the number of
bytes to be written (2-128 V2301 8 5 3 4 8 5 3 4 V2001
bytes allowed) V2302 1 9 3 6 1 9 3 6 V2002
WX
V2000
HandheldProgrammer Keystrokes
$ B ENT
STR 1
W SHFT SP B C E ENT
ANDN STRN 1 1 6
SHFT L D A C D A A ENT
ANDST 3 0 2 3 0 0
SHFT W X C A A A ENT
ANDN SET 2 0 0 0
Memory IBoxes
Instruction Ibox # Page
Move Single Word (MOVEW) IB-200 5-150
Move Double Word (MOVED) IB-201 5-151
Math IBoxes
Instruction Ibox # Page
Math - BCD (MATHBCD) IB-521 5-152
Math - Binary (MATHBIN) IB-501 5-154
Square BCD (SQUARE) IB-523 5-156
Square Binary (SQUAREB) IB-503 5-157
Sum BCD Numbers (SUMBCD) IB-522 5-158
Sum Binary Numbers (SUMBIN) IB-502 5-159
Communication IBoxes
Instruction Ibox # Page
ECOM100 Configuration (ECOM100) IB-710 5-160
ECOM100 Disable DHCP (ECDHCPD) IB-736 5-162
ECOM100 Enable DHCP (ECDHCPE) IB-735 5-164
ECOM100 Query DHCP Setting (ECDHCPQ) IB-734 5-166
ECOM100 Send E-mail (ECEMAIL) IB-711 5-168
ECOM100 Restore Default E-mail Setup (ECEMRDS) IB-713 5-171
ECOM100 E-mail Setup (ECEMSUP) IB-712 5-174
ECOM100 IP Setup (ECIPSUP) IB-717 5-178
ECOM100 Read Description (ECRDDES) IB-726 5-180
ECOM100 Read Gateway Address (ECRDGWA) IB-730 5-182
ECOM100 Read IP Address (ECRDIP) IB-722 5-184
ECOM100 Read Module ID (ECRDMID) IB-720 5-186
ECOM100 Read Module Name (ECRDNAM) IB-724 5-188
ECOM100 Read Subnet Mask (ECRDSNM) IB-732 5-190
ECOM100 Write Description (ECWRDES) IB-727 5-192
ECOM100 Write Gateway Address (ECWRGWA) IB-731 5-194
ECOM100 Write IP Address (ECWRIP) IB-723 5-196
ECOM100 Write Module ID (ECWRMID) IB-721 5-198
ECOM100 Write Name (ECWRNAM) IB-725 5-200
ECOM100 Write Subnet Mask (ECWRSNM) IB-733 5-202
ECOM100 RX Network Read (ECRX) IB-740 5-204
ECOM100 WX Network Write(ECWX) IB-741 5-207
NETCFG Network Configuration (NETCFG) IB-700 5-210
Network RX Read (NETRX) IB-701 5-212
Network WX Write (NETWX) IB-702 5-215
ANLGCMB Example
In the following example, the ANLGCMB instruction is used to setup the pointer method for
an analog I/O combination module that is installed in option slot 2. Four input channels are
enabled and the analog data will be written to V2000 - V2003 in BCD format. Two output
channels are enabled and the analog values will be read from V2100 - V2101 in BCD format.
ANLGIN Parameters
• Base # (K0-Local): must be 0 for DL05 PLC
• Slot #: specifies the single PLC option slot that is occupied by the module
• Number of Input Channels: specifies the number of input channels to scan
• I nput Data Format (0-BCD 1-BIN): specifies the analog input data format (BCD
or Binary) - the binary format may be used for displaying data on some OI panels
• I nput Data Address: specifies the starting V-memory location
that will be used to store the analog input data
Parameter DL05 Range
Base # (K0-Local) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0 (local base only)
Slot # ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K1
Number of Input Channels ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K1-8
Input Data Format (0-BCD 1-BIN)⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K BCD: K0; Binary: K1
Input Data Address ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
ANLGIN Example
In the following example, the ANLGIN instruction is used to setup the pointer method for an
analog input module that is installed in option slot 1. Eight input channels are enabled and the
analog data will be written to V2000 - V2007 in BCD format.
ANLGOUT Parameters
• Base # (K0-Local): must be 0 for DL05 PLC
• Slot #: specifies the single PLC option slot that is occupied by the module
• Number of Output Channels: specifies the number of
analog output channels that will be used
• O
utput Data Format (0-BCD 1-BIN): specifies the format
of the analog output data (BCD or Binary)
• Output Data Address: specifies the starting V-memory location
that will be used to source the analog output data
ANLGOUT Example
In the following example, the ANLGOUT instruction is used to setup the pointer method for
an analog output module that is installed in option slot 3. Two output channels are enabled
and the analog data will be read from V2100 – V2101 in BCD format.
ANSCL Parameters
• Raw (0-4095 BCD): specifies the V-memory location of the
unipolar unsigned raw 0-4095 unscaled value
• High Engineering: specifies the high engineering value when the raw input is 4095
• Low Engineering: specifies the low engineering value when the raw input is 0
• Engineering (BCD): specifies the V-memory location where
the scaled engineering BCD value will be placed
Parameter DL05 Range
Raw (0-4095 BCD) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V,P See DL05 V-memory map - Data Words
High Engineering ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-9999
Low Engineering ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-9999
Engineering (BCD)⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V,P See DL05 V-memory map - Data Words
ANSCL Example
In the following example, the ANSCL instruction is used to scale a raw value (0-4095 BCD)
that is in V2000. The engineering scaling range is set 0-100 (low engineering value - high
engineering value). The scaled value will be placed in V2100 in BCD format.
ANSCLB Parameters
• Raw (12-bit binary): specifies the V-memory location of the unipolar
unsigned raw decimal unscaled value (12-bit binary = 0-4095 decimal)
• High Engineering: specifies the high engineering value
when the raw input is 4095 decimal
• Low Engineering: specifies the low engineering value when the raw input is 0 decimal
• Engineering (binary): specifies the V-memory location where
the scaled engineering decimal value will be placed
ANSCLB Example
In the following example, the ANSCLB instruction is used to scale a raw value (0-4095 binary)
that is in V2000. The engineering scaling range is set 0-1000 (low engineering value - high
engineering value). The scaled value will be placed in V2100 in binary format.
The Filter Divisor Constant is an integer in the range K1 to K100, such that if it equaled K1
then no filtering would be done.
The rate at which the calculation is performed is specified by time in hundredths of a second
(0.01 seconds) as the Filter Freq Time parameter. Note that this Timer instruction is embedded
in the IBox and must NOT be used anywhere else in your program. Power flow controls
whether the calculation is enabled. If it is disabled, the Filter Value is not updated. On the first
scan from Program to Run mode, the Filter Value is initialized to 0 to give the calculation a
consistent starting point.
FILTER Parameters
• Filter Frequency Timer: specifies the Timer (T) number
which is used by the Filter instruction
• Filter Frequency Time (0.01sec): specifies the rate at which the calculation is performed
• Raw Data (BCD): specifies the V-memory location of the raw unfiltered BCD value
• Filter Divisor (1-100): this constant used to control the filtering effect. A larger value
will increase the smoothing effect of the filter. A value of 1 results with no filtering.
• Filtered Value (BCD): specifies the V-memory location
where the filtered BCD value will be placed
FILTER Example
In the following example, the Filter instruction is used to filter a BCD value that is in V2000.
Timer(T0) is set to 0.5 sec, the rate at which the filter calculation will be performed. The filter
constant is set to 2. A larger value will increase the smoothing effect of the filter. A value of 1
results with no filtering. The filtered value will be placed in V2100.
The Filter Divisor Constant is an integer in the range K1 to K100, such that if it equaled K1
then no filtering would be done.
The rate at which the calculation is performed is specified by time in hundredths of a second
(0.01 seconds) as the Filter Freq Time parameter. Note that this Timer instruction is embedded
in the IBox and must NOT be used anywhere else in your program. Power flow controls
whether the calculation is enabled. If it is disabled, the Filter Value is not updated. On the first
scan from Program to Run mode, the Filter Value is initialized to 0 to give the calculation a
consistent starting point.
FILTERB Parameters
• Filter Frequency Timer: specifies the Timer (T) number
which is used by the Filter instruction
• Filter Frequency Time (0.01sec): specifies the rate at which the calculation is performed
• Raw Data (Binary): specifies the V-memory location of
the raw unfiltered binary (decimal) value
• Filter Divisor (1-100): this constant used to control the filtering effect. A larger value
will increase the smoothing effect of the filter. A value of 1 results with no filtering.
• Filtered Value (Binary): specifies the V-memory location where
the filtered binary (decimal) value will be placed
Parameter DL05 Range
Filter Frequency Timer ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ T T0-177
Filter Frequency Time (0.01 sec) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-9999
Raw Data (Binary) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Filter Divisor (1-100) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K1-100
Filtered Value (Binary) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
FILTERB Example
In the following example, the FILTERB instruction is used to filter a binary value that is in
V2000. Timer(T1) is set to 0.5 sec, the rate at which the filter calculation will be performed.
The filter constant is set to 3. A larger value will increase the smoothing effect of the filter. A
value of 1 results with no filtering. The filtered value will be placed in V2100.
SP1
HILOAL Parameters
• Monitoring Value (BCD): specifies the V-memory
location of the BCD value to be monitored
• High-High Limit: V-memory location or constant specifies the high-high alarm limit
• High-High Alarm: On when the high-high limit is reached
• High Limit: V-memory location or constant specifies the high alarm limit
• High Alarm: On when the high limit is reached
• Low Limit: V-memory location or constant specifies the low alarm limit
• Low Alarm: On when the low limit is reached
• Low-Low Limit: V-memory location or constant specifies the low-low alarm limit
• Low-Low Alarm: On when the low-low limit is reached
Parameter DL05 Range
Monitoring Value (BCD) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
High-High Limit ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V, K K0-9999; or see DL05 V-memory map - Data Words
High-High Alarm ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X, Y, C, GX,GY, B See DL05 V-memory map
High Limit ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V, K K0-9999; or see DL05 V-memory map - Data Words
High Alarm⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X, Y, C, GX,GY, B See DL05 V-memory map
Low Limit ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V, K K0-9999; or see DL05 V-memory map - Data Words
Low Alarm ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X, Y, C, GX,GY,B See DL05 V-memory map
Low-Low Limit ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V, K K0-9999; or see DL05 V-memory map - Data Words
Low-Low Alarm⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠X, Y, C, GX,GY, B See DL05 V-memory map
HILOAL Example
In the following example, the HILOAL instruction is used to monitor a BCD value that is in
V2000. If the value in V2000 meets/exceeds the high limit of K900, C101 will turn on. If the
value continues to increase to meet/exceed the high-high limit, C100 will turn on. Both bits
would be on in this case. The high and high-high limits and alarms can be set to the same value
if one “high” limit or alarm is desired to be used.
If the value in V2000 meets or falls below the low limit of K200, C102 will turn on. If the value
continues to decrease to meet or fall below the low-low limit of K100, C103 will turn on. Both
bits would be on in this case. The low and low-low limits and alarms can be set to the same
value if one “low” limit or alarm is desired to be used.
SP1
HILOALB Example
In the following example, the HILOALB instruction is used to monitor a binary value that is
in V2000. If the value in V2000 meets/exceeds the high limit of the binary value in V2011,
C101 will turn on. If the value continues to increase to meet/exceed the high-high limit value
in V2010, C100 will turn on. Both bits would be on in this case. The high and high-high
limits and alarms can be set to the same V-memory location/value if one “high” limit or alarm
is desired to be used.
If the value in V2000 meets or falls below the low limit of the binary value in V2012, C102 will
turn on. If the value continues to decrease to meet or fall below the low-low limit in V2013,
C103 will turn on. Both bits would be on in this case. The low and low-low limits and alarms
can be set to the same V-memory location/value if one “low” limit or alarm is desired to be
used.
SP1
OFFDTMR Parameters
• Timer Number: specifies the Timer(TMRF) number
which is used by the OFFDTMR instruction
• Off Delay Time (0.01sec): specifies how long the Output will
remain on once power flow to the Ibox is removed
• Output: specifies the output that will be delayed “turning off” by the Off Delay Time.
OFFDTMR Example
In the following example, the OFFDTMR instruction is used to delay the “turning off”of
output C20. Timer 2 (T2) is set to 5 seconds, the “off-delay” period.
When C100 turns on, C20 turns on and will remain on while C100 is on. When C100 turns
off, C20 will remain for the specified Off Delay Time (5s), and then turn off.
C100
5 sec 5 sec
C20
ONDTMR Parameters
• Timer Number: specifies the Timer(TMRF) number
which is used by the ONDTMR instruction
• On Delay Time (0.01sec): specifies how long the Output will
remain on once power flow to the Ibox is removed
• Output: specifies the output that will be delayed “turning on” by the On Delay Time.
ONDTMR Example
In the following example, the ONDTMR instruction is used to delay the “turning on” of
output C21. Timer 1 (T1) is set to 2 seconds, the “on-delay” period.
When C101 turns on, C21 is delayed turning on by 2 seconds. When C101 turns off, C21
turns off immediately.
C101
2 sec 2 sec
C21
ONESHOT Parameters
• Discrete Output: specifies the output
that will be on for one scan
ONESHOT Example
In the following example, the ONESHOT instruction is used to turn C100 on for one PLC
scan after C0 goes from an off to on transition. The input logic must produce an off to on
transition to execute the One Shot instruction.
C0
Scan time
C100
PONOFF Parameters
• Discrete Input: specifies the input
that will toggle the specified output
• Discrete Output: specifies the output
that will be “turned on/off” or toggled
• Internal State: specifies a work bit
that is used by the instruction
PONOFF Example
In the following example, the PONOFF instruction is used to control the on and off states of
the output C20 with a single input C10. When C10 is pressed once, C20 turns on. When C10
is pressed again, C20 turns off. C100 is an internal bit used by the instruction.
MOVEW Parameters
• From WORD: specifies the word that
will be moved to another location
• To WORD: specifies the location where
the “From WORD” will be move to
MOVEW Example
In the following example, the MOVEW instruction is used to move 16-bits of data from
V2000 to V3000 when C100 turns on.
MOVED Parameters
• From DWORD: specifies the double
word that will be moved to another
location
• To DWORD: specifies the location
where the “From DWORD” will be
moved to.
Parameter DL05 Range
From DWORD ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V,P,K K0-FFFFFFFF; See DL05 V-memory map - Data Words
To DWORD⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V,P See DL05 V-memory map - Data Words
MOVED Example
In the following example, the MOVED instruction is used to move 32-bits of data from V2000
and V2001 to V3000 and V3001 when C100 turns on.
MATHBCD Parameters
• WORD Result: specifies the location where the BCD result of the mathematical
expression will be placed (result must fit into 16 bit single V-memory location)
• Expression: specifies the mathematical expression to be executed and the result is stored
in specified WORD Result. Each V-memory location used in the expression must be in
BCD format.
MATHBCD Example
In the following example, the MATHBCD instruction is used to calculate the math expression
which multiplies the BCD value in V1200 by 1000 then divides by 4095 and loads the resulting
value in V2000.
MATHBIN Parameters
• WORD Result: specifies the location where the binary result of the mathematical
expression will be placed (result must fit into 16-bit single V-memory location)
• Expression: specifies the mathematical expression to be executed and the result is stored
in specified WORD Result. Each V-memory location used in the expression must be in
binary format.
MATHBIN Example
In the following example, the MATHBIN instruction is used to calculate the math expression
which multiplies the Binary value in V1200 by 1000 then divides by 4095 and loads the
resulting value in V2000.
SQUARE Parameters
• V
alue (WORD BCD): specifies the BCD
Word or constant that will be squared
• R
esult (DWORD BCD): specifies the
location where the squared DWORD
BCD value will be placed
Parameter DL05 Range
Value (WORD BCD) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V,P,K K0-9999 ; See DL05 V-memory map - Data Words
Result (DWORD BCD)⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
SQUARE Example
In the following example, the SQUARE instruction is used to square the 4-digit BCD value in
V2000 and store the 8-digit double word BCD result in V3000 and V3001
SQUAREB Parameters
• Value (WORD Binary): specifies the
binary Word or constant that will be
squared
• Result (DWORD Binary): specifies the
location where the squared DWORD
binary value will be placed
SQUAREB Example
In the following example, the SQUAREB instruction is used to square the single word Binary
value in V2000 and store the 8-digit double word Binary result in V3000 and V3001.
SUMBCD Parameters
• Start Address: specifies the starting address of a block of V-memory location values to be
added together (BCD)
• End Addr (inclusive): specifies the ending address of a block of V-memory location values
to be added together (BCD)
• Result (DWORD BCD): specifies the location where the sum of the block of V-memory
BCD values will be placed.
SUMBCD Example
In the following example, the SUMBCD instruction is used to total the sum of all BCD values
in words V2000 thru V2007 and store the resulting 8-digit double word BCD value in V3000
and V3001.
SUMBIN Parameters
• Start Address: specifies the starting address of a block of V-memory location values to be
added together (Binary)
• End Addr (inclusive): specifies the ending address of a block of V-memory location values
to be added together (Binary)
• Result (DWORD Binary): specifies the location where the sum of the block of V-memory
binary values will be placed
Parameter DL05 Range
Start Address ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
End Address (inclusive) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Result (DWORD Binary)⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
SUMBIN Example
In the following example, the SUMBIN instruction is used to total the sum of all Binary values
in words V2000 thru V2007 and store the resulting 8-digit double word Binary value in V3000
and V3001.
ECOM100 Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100 module in
the specified slot. All other ECxxxx IBoxes that need to reference this ECOM100 module
must reference this logical number
• Slot: specifies the option slot the module occupies
• Status: specifies a V-memory location that will be used by the instruction
• Workspace: specifies a V-memory location that will be used by the instruction
• M
sg Buffer: specifies the starting address of a 65 word buffer that will be used by the
module for configuration
ECOM100 Example
The ECOM100 Config IBox coordinates all of the interaction with other ECOM100 based
IBoxes (ECxxxx). You must have an ECOM100 Config IBox for each ECOM100 module in
your system. Configuration IBoxes must be at the top of your program and must execute every
scan.
This IBox defines ECOM100# K0 to be in slot 3. Any ECOM100 IBoxes that need to reference
this specific module (such as ECEMAIL, ECRX, ...) would enter K0 for their ECOM100#
parameter.
The Status register is for reporting any completion or error information to other ECOM100
IBoxes. This V-memory register must not be used anywhere else in the entire program.
The Workspace register is used to maintain state information about the ECOM100, along
with proper sharing and interlocking with the other ECOM100 IBoxes in the program. This
V-memory register must not be used anywhere else in the entire program.
The Message Buffer of 65 words (130 bytes) is a common pool of memory that is used by other
ECOM100 IBoxes (such as ECEMAIL). This way, you can have a bunch of ECEMAIL IBoxes,
but only need 1 common buffer for generating and sending each EMail. These V-memory
registers must not be used anywhere else in your entire program.
ECDHCPD Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100 module in
the specified slot. All other ECxxxx IBoxes that need to reference this ECOM100 module
must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
ECDHCPD Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, disable DHCP in the ECOM100. DHCP is the same protocol used
by PCs for using a DHCP Server to automatically assign the ECOM100’s IP Address, Gateway
Address, and Subnet Mask. Typically disabling DHCP is done by assigning a hard-coded
IP Address either in NetEdit or using one of the ECOM100 IP Setup IBoxes, but this IBox
allows you to disable DHCP in the ECOM100 using your ladder program. The ECDHCPD
is leading edge triggered, not power-flow driven (similar to a counter input leg). The command
to disable DHCP will be sent to the ECOM100 whenever the power flow into the IBox goes
from OFF to ON. If successful, turn on C100. If there is a failure, turn on C101. If it fails, you
can look at V2000 for the specific error code.
ECDHCPE Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, enable DHCP in the ECOM100. DHCP is the same protocol
used by PCs for using a DHCP Server to automatically assign the ECOM100’s IP Address,
Gateway Address, and Subnet Mask. Typically this is done using NetEdit, but this IBox
allows you to enable DHCP in the ECOM100 using your ladder program. The ECDHCPE is
leading edge triggered, not power-flow driven (similar to a counter input leg). The commands
to enable DHCP will be sent to the ECOM100 whenever the power flow into the IBox goes
from OFF to ON. The ECDHCPE does more than just set the bit to enable DHCP in the
ECOM100, but it then polls the ECOM100 once every second to see if the ECOM100 has
found a DHCP server and has a valid IP Address. Therefore, a timeout parameter is needed in
case the ECOM100 cannot find a DHCP server. If a timeout does occur, the Error bit will turn
on and the error code will be 1005 decimal. The Success bit will turn on only if the ECOM100
finds a DHCP Server and is assigned a valid IP Address. If successful, turn on C100. If there is
a failure, turn on C101. If it fails, you can look at V2000 for the specific error code.
ECDHCPQ Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• DHCP Enabled: specifies a bit that will turn on if the ECOM100’s DHCP is enabled or
remain off if disabled - after instruction query, be sure to check the state of the Success/
Error bit state along with DHCP Enabled bit state to confirm a successful module query
ECDHCPQ Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, read whether DHCP is enabled or disabled in the ECOM100
and store it in C5. DHCP is the same protocol used by PCs for using a DHCP Server to
automatically assign the ECOM100’s IP Address, Gateway Address, and Subnet Mask. The
ECDHCPQ is leading edge triggered, not power-flow driven (similar to a counter input leg).
The command to read (Query) whether DHCP is enabled or not will be sent to the ECOM100
whenever the power flow into the IBox goes from OFF to ON. If successful, turn on C100. If
there is a failure, turn on C101.
For the ECOM100 Send EMail IBox, the status codes below are specific to this IBox:
Normal Status 0 - 1
ECOM100 Send EMAIL IBOX Status Codes
0-1 Success - ECEMAIL completed successfully
1 Busy - ECEMAIL IBoxlogic sets the Error register to this
value when the ECEMAIL starts a new request
ECEMAIL Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: When a machine goes down, send an email to Joe in maintenance and to the VP over
production showing what machine is down along with the date/time stamp of when it went
down.
The ECEMAIL is leading edge triggered, not power-flow driven (similar to a counter input
leg). An email will be sent whenever the power flow into the IBox goes from OFF to ON. This
helps prevent self inflicted spamming.
If the EMail is sent, turn on C100. If there is a failure, turn on C101. If it fails, you can look
at V2000 for the SMTP error code or other possible error codes.
ECEMRDS Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
Parameter DL05 Range
ECOM100# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-255
Workspace ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Success ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error Code⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
ECEMRDS Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: Whenever an EStop is pushed, ensure that president of the company gets copies of all
EMails being sent.
The ECOM100 EMail Setup IBox allows you to set/change the SMTP EMail settings stored
in the ECOM100.
ECEMRDS Example
Rung 3: Once the EStop is pulled out, take the president off the cc: list by restoring the default
EMail setup in the ECOM100.
The ECEMRDS is leading edge triggered, not power-flow driven (similar to a counter input
leg). The ROM based EMail configuration stored in the ECOM100 will be copied over the
“working copy” whenever the power flow into the IBox goes from OFF to ON (the working
copy can be changed by using the ECEMSUP IBox).
If successful, turn on C102. If there is a failure, turn on C103. If it fails, you can look at V2001
for the specific error code.
ECEMSUP Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
• SMTP Server IP Addr: optional parameter that specifies the IP
Address of the SMTP Server on the ECOM100’s network
• Sender Name: optional parameter that specifies the sender name that
will appear in the “From:” field to those who receive the e-mail
• Sender EMail: optional parameter that specifies the sender EMail address
that will appear in the “From:” field to those who receive the e-mail
ECEMSUP Parameters
• P
ort Number: optional parameter that specifies the TCP/IP Port Number to send SMTP
requests; usually this does not to be configured (see your network administrator for
information on this setting)
• T
imeout (sec): optional parameter that specifies the number of seconds to wait for the
SMTP Server to send the EMail to all the recipients
• C
c: optional parameter that specifies a list of “carbon copy” Email addresses to send all
EMails to.
Parameter DL05 Range
ECOM100# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-255
Workspace ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Success ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error Code⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
ECEMSUP Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
ECEMSUP Example
Rung 2: Whenever an EStop is pushed, ensure that president of the company gets copies
of all EMails being sent.The ECOM100 EMail Setup IBox allows you to set/change the
SMTP EMail settings stored in the ECOM100. The ECEMSUP is leading edge triggered,
not power-flow driven (similar to a counter input leg). At power-up, the ROM based EMail
configuration stored in the ECOM100 is copied to a RAM based “working copy”. You can
change this working copy by using the ECEMSUP IBox. To restore the original ROM based
configuration, use the Restore Default EMail Setup ECEMRDS IBox.
If successful, turn on C100. If there is a failure, turn on C101. If it fails, you can look at V2000
ECIPSUP Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module.V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, configure all of the TCP/IP parameters in the ECOM100:
IP Address: 192.168. 12.100
Subnet Mask: 255.255. 0. 0
Gateway Address: 192.168. 0. 1
The ECIPSUP is leading edge triggered, not power-flow driven (similar to a counter input leg).
The command to write the TCP/IP configuration parameters will be sent to the ECOM100
whenever the power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101. If it fails, you can look at V2000
for the specific error code.
ECRDDES Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100 module in
the specified slot. All other ECxxxx IBoxes that need to reference this ECOM100 module
must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Description: specifies the starting buffer location where the ECOM100’s Module Name
will be placed
• N
um Char: specifies the number of characters (bytes) to read from the ECOM100’s
Description field
ECRDDES Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module.V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, read the Module Description of the ECOM100 and store it in
V3000 thru V3007 (16 characters). This text can be displayed by an HMI.
The ECRDDES is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to read the module description will be sent to the ECOM100 whenever
the power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101.
ECRDGWA Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Gateway IP Addr: specifies the starting address where the ECOM100’s
Gateway Address will be placed in 4 consecutive V-memory locations
ECRDGWA Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, read the Gateway Address of the ECOM100 and store it in V3000
thru V3003 (4 decimal numbers). The ECOM100’s Gateway Address could be displayed by
an HMI.
The ECRDGWA is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to read the Gateway Address will be sent to the ECOM100 whenever the
power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101.
ECRDIP Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• IP Address: specifies the starting address where the ECOM100’s IP
Address will be placed in 4 consecutive V-memory locations
ECRDIP Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, read the IP Address of the ECOM100 and store it in V3000 thru
V3003 (4 decimal numbers). The ECOM100’s IP Address could be displayed by an HMI.
The ECRDIP is leading edge triggered, not power-flow driven (similar to a counter input leg).
The command to read the IP Address will be sent to the ECOM100 whenever the power flow
into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101.
ECRDMID Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Module ID: specifies the location where the ECOM100’s
Module ID (decimal) will be placed
Parameter DL05 Range
ECOM100# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-255
Workspace ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Success ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Module ID⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
ECRDMID Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module.V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, read the Module ID of the ECOM100 and store it in V2000.
The ECRDMID is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to read the module ID will be sent to the ECOM100 whenever the power
flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101.
ECRDNAM Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• M
odule Name: specifies the starting buffer location where
the ECOM100’s Module Name will be placed
• Num Chars: specifies the number of characters (bytes)
to read from the ECOM100’s Name field
ECRDNAM Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, read the Module Name of the ECOM100 and store it in V3000 thru
V3003 (8 characters). This text can be displayed by an HMI.
The ECRDNAM is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to read the module name will be sent to the ECOM100 whenever the
power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101.
ECRDSNM Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Subnet Mask: specifies the starting address where the ECOM100’s
Subnet Mask will be placed in 4 consecutive V-memory locations
ECRDSNM Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, read the Subnet Mask of the ECOM100 and store it in V3000 thru
V3003 (4 decimal numbers). The ECOM100’s Subnet Mask could be displayed by an HMI.
The ECRDSNM is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to read the Subnet Mask will be sent to the ECOM100 whenever the
power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101.
ECWRDES Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
• Description: specifies the Description that will be written to the module
ECWRDES Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, set the Module Description of the ECOM100. Typically this is done
using NetEdit, but this IBox allows you to configure the module description in the ECOM100
using your ladder program.
The EWRDES is leading edge triggered, not power-flow driven (similar to a counter input leg).
The command to write the module description will be sent to the ECOM100 whenever the
power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101. If it fails, you can look at V2000
for the specific error code.
ECWRGWA Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
• Gateway Address: specifies the Gateway IP Address that will be written to the module
ECWRGWA Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, assign the Gateway Address of the ECOM100 to 192.168.0.1
The ECWRGWA is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to write the Gateway Address will be sent to the ECOM100 whenever the
power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101. If it fails, you can look at V2000
for the specific error code.
To configure all of the ECOM100 TCP/IP parameters in one IBox, see the ECOM100 IP
Setup (ECIPSUP) IBox.
ECWRIP Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
• IP Address: specifies the IP Address that will be written to the module
ECWRIP Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, assign the IP Address of the ECOM100 to 192.168.12.100
The ECWRIP is leading edge triggered, not power-flow driven (similar to a counter input leg).
The command to write the IP Address will be sent to the ECOM100 whenever the power flow
into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101. If it fails, you can look at V2000
for the specific error code.
To configure all of the ECOM100 TCP/IP parameters in one IBox, see the ECOM100 IP
Setup (ECIPSUP) IBox.
ECWRMID Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
• Module ID: specifies the Module ID that will be written to the module
ECWRMID Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, set the Module ID of the ECOM100. Typically this is done using
NetEdit, but this IBox allows you to configure the module ID of the ECOM100 using your
ladder program.
The EWRMID is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to write the module ID will be sent to the ECOM100 whenever the power
flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101. If it fails, you can look at V2000
for the specific error code.
ECWRNAM Parameters
• E
COM100#: this is a logical number associated with this specific ECOM100 module in
the specified slot. All other ECxxxx IBoxes that need to reference this ECOM100 module
must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
• Module Name: specifies the Name that will be written to the module
ECWRNAM Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, set the Module Name of the ECOM100. Typically this is done using
NetEdit, but this IBox allows you to configure the module name of the ECOM100 using your
ladder program.
The EWRNAM is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to write the module name will be sent to the ECOM100 whenever the
power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101. If it fails, you can look at V2000
for the specific error code.
ECWRSNM Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
• Error Code: specifies the location where the Error Code will be written
• Subnet Mask: specifies the Subnet Mask that will be written to the module
ECWRSNM Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
Rung 2: On the 2nd scan, assign the Subnet Mask of the ECOM100 to 255.255.0.0
The ECWRSNM is leading edge triggered, not power-flow driven (similar to a counter input
leg). The command to write the Subnet Mask will be sent to the ECOM100 whenever the
power flow into the IBox goes from OFF to ON.
If successful, turn on C100. If there is a failure, turn on C101. If it fails, you can look at V2000
for the specific error code.
To configure all of the ECOM100 TCP/IP parameters in one IBox, see the ECOM100 IP
Setup (ECIPSUP) IBox.
ECRX Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Slave ID: specifies the slave ECOM(100) PLC that
will be targeted by the ECRX instruction
• From Slave Element (Src): specifies the slave address of the data to be read
• Number of Bytes: specifies the number of bytes to read from the slave ECOM(100) PLC
• To Master Element (Dest): specifies the location where the slave
data will be placed in the master ECOM100 PLC
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
Parameter DL05 Range
ECOM100# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-255
Workspace ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Slave ID ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-90
From Slave Element (Src) ⸠⸠⸠⸠ X,Y,C,S,T,CT,GX,GY,V,P See DL05 V-memory map
Number of Bytes ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K1-128
To Master Element (Dest) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Success ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
ECRX Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
ECWX Parameters
• ECOM100#: this is a logical number associated with this specific ECOM100
module in the specified slot. All other ECxxxx IBoxes that need to reference
this ECOM100 module must reference this logical number
• Workspace: specifies a V-memory location that will be used by the instruction
• Slave ID: specifies the slave ECOM(100) PLC that will
be targeted by the ECWX instruction
• From Master Element (Src): specifies the location in the master
ECOM100 PLC where the data will be sourced from
• Number of Bytes: specifies the number of bytes to write to the slave ECOM(100) PLC
• To Slave Element (Dest): specifies the slave address the data will be written to
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
Parameter DL05 Range
ECOM100# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-255
Workspace ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Slave ID ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-90
From Master Element (Src) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Number of Bytes ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K1-128
To Slave Element (Dest) ⸠⸠⸠⸠⸠⸠X,Y,C,S,T,CT,GX,GY,V,P See DL05 V-memory map
Success ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
ECWX Example
Rung 1: The ECOM100 Config IBox is responsible for coordination/interlocking of all
ECOM100 type IBoxes for one specific ECOM100 module. Tag the ECOM100 in slot 1 as
ECOM100# K0. All other ECxxxx IBoxes refer to this module # as K0. If you need to move
the module in the base to a different slot, then you only need to change this one IBox. V400 is
used as a global result status register for the other ECxxxx IBoxes using this specific ECOM100
module. V401 is used to coordinate/interlock the logic in all of the other ECxxxx IBoxes using
this specific ECOM100 module. V402-V502 is a common 130 byte buffer available for use by
the other ECxxxx IBoxes using this specific ECOM100 module.
ECWX Example
Rung 2: Using ECOM100# K0, read X0-X7 from Slave K7 and write them to slave K5 as fast
as possible. Store them in this local PLC in C200-C207, and write them to C300-C307 in
slave K5.
Both the ECRX and ECWX work with the ECOM100 Config IBox to simplify all networking
by handling all of the interlocks and proper resource sharing. They also provide very simplified
error reporting. You no longer need to worry about any SP “busy bits” or “error bits”, or what
slot number a module is in, or have any counters or shift registers or any other interlocks for
resource management.
In this example, SP1 (always ON) is driving both the ECRX and ECWX IBoxes in the same
rung. On the scan that the Network Read completes, the Network Write will start that same
scan. As soon as the Network Write completes, any pending operations below it in the program
would get a turn. If there are no pending ECOM100 IBoxes below the ECWX, then the very
next scan the ECRX would start its request again.
Using the ECRX and ECWX for all of your ECOM100 network reads and writes is the fastest
the PLC can do networking. For local Serial Ports, DCM modules, or the original ECOM
modules, use the NETCFG and NETRX/NETWX IBoxes.
NETCFG Parameters
• Network#: specifies a unique # for each ECOM(100) or DCM network to use
• CPU Port or Slot: specifies the CPU port number or
slot number of DCM/ECOM(100) used
• Workspace: specifies a V-memory location that will be used by the instruction
NETCFG Example
The Network Configuration IBox coordinates all of the interaction with other Network
IBoxes (NETRX/NETWX). You must have a Network Configuration IBox for each serial
port network, DCM module network, or original ECOM module network in your system.
Configuration IBoxes must be at the top of your program and must execute every scan.
This IBox defines Network# K0 to be for the local CPU serial port #2 (KF2). For local CPU
serial ports or DCM/ECOM modules, use the same value you would use in the most significant
byte of the first LD instruction in a normal RX/WX rung to reference the port or module. Any
NETRX or NETWX IBoxes that need to reference this specific network would enter K0 for
their Network# parameter.
The Workspace register is used to maintain state information about the port or module, along
with proper sharing and interlocking with the other NETRX and NETWX IBoxes in the
program. This V-memory register must not be used anywhere else in the entire program.
NETRX Parameters
• Network#: specifies the (CPU port’s, DCM’s, ECOM’s)
Network # defined by the NETCFG instruction
• Workspace: specifies a V-memory location that will be used by the instruction
• Slave ID: specifies the slave PLC that will be targeted by the NETRX instruction
• From Slave Element (Src): specifies the slave address of the data to be read
• Number of Bytes: specifies the number of bytes to read from the slave device
• To Master Element (Dest): specifies the location where the
slave data will be placed in the master PLC
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
Parameter DL05 Range
Network# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-255
Workspace ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Slave ID ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-90
From Slave Element (Src) ⸠⸠⸠⸠ X,Y,C,S,T,CT,GX,GY,V,P See DL05 V-memory map
Number of Bytes ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K1-128
To Master Element (Dest) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Success ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
NETRX Example
Rung 1: The Network Configuration IBox coordinates all of the interaction with other
Network IBoxes (NETRX/NETWX). You must have a Network Configuration IBox for
each serial port network, DCM module network, or original ECOM module network in your
system. Configuration IBoxes must be at the top of your program and must execute every scan.
This IBox defines Network# K0 to be for the local CPU serial port #2 (KF2). For local CPU
serial ports or DCM/ECOM modules, use the same value you would use in the most significant
byte of the first LD instruction in a normal RX/WX rung to reference the port or module. Any
NETRX or NETWX IBoxes that need to reference this specific network would enter K0 for
their Network# parameter.
The Workspace register is used to maintain state information about the port or module, along
with proper sharing and interlocking with the other NETRX and NETWX IBoxes in the
program. This V-memory register must not be used anywhere else in the entire program.
NETWX Parameters
• Network#: specifies the (CPU port’s, DCM’s, ECOM’s)
Network # defined by the NETCFG instruction
• Workspace: specifies a V-memory location that will be used by the instruction
• Slave ID: specifies the slave PLC that will be targeted by the NETWX instruction
• From Master Element (Src): specifies the location in the
master PLC where the data will be sourced from
• Number of Bytes: specifies the number of bytes to write to the slave PLC
• To Slave Element (Dest): specifies the slave address the data will be written to
• Success: specifies a bit that will turn on once the request is completed successfully
• Error: specifies a bit that will turn on if the instruction is not successfully completed
Parameter DL05 Range
Network# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-255
Workspace ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Slave ID ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K0-90
From Master Element (Src) ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V See DL05 V-memory map - Data Words
Number of Bytes ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K K1-128
To Slave Element (Dest) ⸠⸠⸠⸠⸠⸠X,Y,C,S,T,CT,GX,GY,V,P See DL05 V-memory map
Success ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
Error ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B See DL05 V-memory map
NETWX Example
Rung 1: The Network Configuration IBox coordinates all of the interaction with other
Network IBoxes (NETRX/NETWX). You must have a Network Configuration IBox for
each serial port network, DCM module network, or original ECOM module network in your
system. Configuration IBoxes must be at the top of your program and must execute every scan.
This IBox defines Network# K0 to be for the local CPU serial port #2 (KF2). For local CPU
serial ports or DCM/ECOM modules, use the same value you would use in the most significant
byte of the first LD instruction in a normal RX/WX rung to reference the port or module. Any
NETRX or NETWX IBoxes that need to reference this specific network would enter K0 for
their Network# parameter.
The Workspace register is used to maintain state information about the port or module, along
with proper sharing and interlocking with the other NETRX and NETWX IBoxes in the
program. This V-memory register must not be used anywhere else in the entire program.
NETWX Example
Rung 2: Using Network# K0, read X0-X7 from Slave K7 and write them to slave K5 as fast as
possible. Store them in this local PLC in C200-C207, and write them to C300-C307 in slave
K5.
Both the NETRX and NETWX work with the Network Config IBox to simplify all networking
by handling all of the interlocks and proper resource sharing. They also provide very simplified
error reporting. You no longer need to worry about any SP “busy bits” or “error bits”, or what
port number or slot number a module is in, or have any counters or shift registers or any other
interlocks for resource management.
In this example, SP1 (always ON) is driving both the NETRX and NETWX IBoxes in the
same rung. On the scan that the Network Read completes, the Network Write will start that
same scan. As soon as the Network Write completes, any pending operations below it in the
program would get a turn. If there are no pending NETRX or NETWX IBoxes below this
IBox, then the very next scan the NETRX would start its request again.
Using the NETRX and NETWX for all of your serial port, DCM, or original ECOM network
reads and writes is the fastest the PLC can do networking. For ECOM100 modules, use the
ECOM100 and ECRX/ECWX IBoxes.
CTRIO Parameters
• CTRIO#: specifies a specific CTRIO module based on a user defined number
• Slot: specifies the single PLC option slot the CTRIO module occupies
• Workspace: specifies a V-memory location that will be used by the instruction
• CTRIO Location: specifies where the module is located (local base only for DL05)
• Input: This needs to be set to the same V-memory register as is specified in
CTRIO Workbench as ‘Starting V address for inputs’ for this unique CTRIO.
• Output: This needs to be set to the same V-memory register as is specified in
CTRIO Workbench as ‘Starting V address for outputs’ for this unique CTRIO.
CTRIO Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
CTRAPT Parameters
• CTRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config)
• Output#: specifies a CTRIO output to be used by the instruction
• Entry Type: specifies the Entry Type to be added to the end of a Preset Table
• Pulse Time: specifies a pulse time for the Pulse On and Pulse Off Entry Types
• Preset Count: specifies an initial count value to begin at after Reset
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTRADPT Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
Rung 2: This rung is a sample method for enabling the CTRADPT command. A C-bit is used
to allow the programmer to control the command from Data View for testing purposes.
Turning on C0 will cause the CTRADPT instruction to add a new preset to the preset table for
output #0 on the CTRIO in slot 2. The new preset will be a command to RESET (entry type
K1=reset), pulse time is left at zero as the reset type does not use this, and the count at which
it will reset will be 20.
Operating procedure for this example code is to load the CTRADPT_ex1.cwb file to your
CTRIO, then enter the code shown here, change to RUN mode, enable output #0 by turning
on C2 in dataview, turn encoder on CTRIO to value above 10 and output #0 light will come
on and stay on for all counts past 10. Now reset the counter with C1, enable C0 to execute
CTRADPT command to add a reset for output #0 at a count of 20, turn on C2 to enable
output #0, then turn encoder to value of 10+ (output #0 should turn on) and then continue on
to count of 20+ (output #0 should turn off).
Rung 4: This rung allows the operator to enable output #0 from the ladder code.
CTRCLRT Parameters
• CTRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config)
• Output#: specifies a CTRIO output to be used by the instruction
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTRCLRT Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
Rung 2: This rung is a sample method for enabling the CTRCLRT command. A C-bit is used
to allow the programmer to control the command from Data View for testing purposes.
Turning on C0 will cause the CTRCLRT instruction to clear the preset table for output #0 on
the CTRIO in slot 2.
Operating procedure for this example code is to load the CTRCLRT_ex1.cwb file to your
CTRIO, then enter the code shown here, change to RUN mode, enable output #0 by turning
on C2 in Data View, turn encoder on CTRIO to value above 10 and output #0 light will come
on and stay on until a count of 20 is reached, where it will turn off. Now reset the counter with
C1, enable C0 to execute CTRCLRT command to clear the preset table, turn on C2 to enable
output #0, then turn encoder to value of 10+ (output #0 should NOT turn on).
CTRCLRT Example
Rung 3: This rung allows the programmer to reset the counter from the ladder logic.
Rung 4: This rung allows the operator to enable output #0 from the ladder code.
CTREDPT Parameters
• CTRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config Ibox)
• Output#: specifies a CTRIO output to be used by the instruction
• Table#: specifies the Table number of which an Entry is to be edited
• Entry#: specifies the Entry location in the Preset Table to be edited
• Entry Type: specifies the Entry Type to add during the edit
• Pulse Time: specifies a pulse time for the Pulse On and Pulse Off Entry Types
• Preset Count: specifies an initial count value to begin at after Reset
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTREDPT Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
CTREDPT Example
Rung 3: This rung allows the programmer to reset the counter from the ladder logic.
Rung 4: This rung allows the operator to enable output #0 from the ladder code.
CTREDRL Parameters
• CTRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config Ibox)
• Output#: specifies a CTRIO output to be used by the instruction
• Table#: specifies the Table number of which an Entry is to be edited
• Entry#: specifies the Entry location in the Preset Table to be edited
• Entry Type: specifies the Entry Type to add during the edit
• Pulse Time: specifies a pulse time for the Pulse On and Pulse Off Entry Types
• Preset Count: specifies an initial count value to begin at after Reset
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTREDRL Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
CTREDRL Example
Rung 3: This rung allows the programmer to reset the counter from the ladder logic.
Rung 4: This rung allows the operator to enable output #0 from the ladder code.
CTRINPT Parameters
• CTRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config Ibox)
• Output#: specifies a CTRIO output to be used by the instruction
• Entry Type: specifies the Entry Type to add during the edit
• Pulse Time: specifies a pulse time for the Pulse On and Pulse Off Entry Types
• Preset Count: specifies an initial count value to begin at after Reset
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTRINPT Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
CTRINPT Example
Rung 3: This rung allows the programmer to reset the counter from the ladder logic.
Rung 4: This rung allows the operator to enable output #0 from the ladder code.
B
C
D
Parameter
CTRIO# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K
1 DL05 Range
K0-255
Output# ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ K
Entry Type ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V,K 2 K0-3
K0-5; See DL05 V-memory map - Data Words
Pulse Time ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V,K K0-65535; See DL05 V-memory map - Data Words
Preset Count ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠V,K
Workspace ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ V
3
K0-2147434528; See DL05 V-memory map
See DL05 V-memory map - Data Words
Success ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B
Error ⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠⸠ X,Y,C,GX,GY,B 4 See DL05 V-memory map
See DL05 V-memory map
CTRINTR Example 5
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The 6
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
7
8
9
10
11
(Example continued on next page) 12
13
14
A
B
C
D
CTRINTR Example
Rung 3: This rung allows the programmer to reset the counter from the ladder logic.
Rung 4: This rung allows the operator to enable output #0 from the ladder code.
CTRLDPR Parameters
• CTRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config)
• Output#: specifies a CTRIO output to be used by the instruction
• File#: specifies a CTRIO profile File number to be loaded
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTRLDPR Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
Rung 2: This CTRIO Load Profile IBox will load File #1 into the working memory of Output
0 in CTRIO #1. This example program requires that you load CTRLDPR_IBox.cwb into your
Hx-CTRIO(2) module.
CTRRDER Parameters
• CTRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config)
• Workspace: specifies a V-memory location that will be used by the instruction
• Error Code: specifies the location where the Error Code will be written
CTRRDER Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
Rung 2: This CTRIO Read Error Code IBox will read the Extended Error information from
CTRIO #1. This example program requires that you load CTRRDER_IBox.cwb into your
Hx-CTRIO(2) module.
CTRRTLM Parameters
• C
TRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config Ibox)
• Output#: specifies a CTRIO output to be used by the instruction
• Frequency: specifies the output pulse rate (H0-CTRIO:
20Hz - 25kHz / H0-CTRIO2: 20Hz - 250kHz)
• Limit: the CTRIO’s Input(s) must be configured as Limit(s) for this function to operate
• Duty Cycle: specifies the % of on time versus off time. This is a hex
number. Default of 0 is 50%, also entering 50 will yield 50%. 50%
duty cycle is defined as on half the time and off half the time
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTRRTLM Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
Rung 2: This CTRIO Run To Limit Mode IBox sets up Output #0 in CTRIO #1 to output
pulses at a Frequency of 1000 Hz until Llimit #0 comes on. This example program requires
that you load CTRRTLM_IBox.cwb into your Hx-CTRIO(2) module.
CTRRTPM Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
Rung 2: This CTRIO Run To Position Mode IBox sets up Output #0 in CTRIO #1 to
output pulses at a Frequency of 1000Hz, use the ‘Greater than Ch1/Fn1’ comparison operator,
until the input position of 1500 is reached. This example program requires that you load
CTRRTPM_IBox.cwb into your Hx-CTRIO(2) module.
Rung 3: If the Run To Position Mode parameters are OK, set the Direction Bit and Enable
the output.
CTRVELO Parameters
• CTRIO#: specifies a specific CTRIO module based on a user defined number (see
CTRIO Config Ibox)
• Output#: specifies a CTRIO output to be used by the instruction
• Frequency: specifies the output pulse rate (H0-CTRIO: 20Hz - 25kHz / H0-CTRIO2:
20Hz–250kHz)
• Duty Cycle: specifies the % of on time versus off time. This is a hex number. Default of
0 is 50%, also entering 50 will yield 50%. 50% duty cycle is defined as on half the time
and off half the time
• Step Count: This DWORD values specifies the number of pulses to output. A Step
Count value of -1 (or 0xFFFFFFFF) causes the CTRIO to output pulses continuously.
Negative Step Count values must be V-Memory references.
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTRVELO Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
Rung 2: This CTRIO Velocity Mode IBox sets up Output #0 in CTRIO #1 to output 10,000
pulses at a Frequency of 1000Hz. This example program requires that you load CTRVELO_
IBox.cwb into your Hx-CTRIO(2) module.
CTRVELO Example
Rung 3: If the Velocity Mode parameters are OK, set the Direction Bit and Enable the output.
CTRWFTR Parameters
• CTRIO#: specifies a specific CTRIO module based on a
user defined number (see CTRIO Config Ibox)
• Output#: specifies a CTRIO output to be used by the instruction
• Workspace: specifies a V-memory location that will be used by the instruction
• Success: specifies a bit that will turn on once the instruction has successfully completed
• Error: specifies a bit that will turn on if the instruction does not complete successfully
CTRWFTR Example
Rung 1: This sets up the CTRIO card in slot 2 of the local base. Each CTRIO in the system
will need a separate CTRIO I-box before any CTRxxxx I-boxes can be used for them. The
CTRIO has been configured to use V2000 through V2025 for its input data, and V2030
through V2061 for its output data.
Rung 2: This CTRIO Edit Preset Table Entry IBox will change Entry 0 in Table #2 to be a
RESET at Count 3456. This example program requires that you load CTRWFTR_IBox.cwb
into your Hx-CTRIO(2) module.