Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
0% found this document useful (0 votes)
67 views

Programming Manual II Fx1s

Copyright
© Attribution Non-Commercial (BY-NC)
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
67 views

Programming Manual II Fx1s

Copyright
© Attribution Non-Commercial (BY-NC)
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 120

PROGRAMMING MANUAL II

THE FX SERIES OF PROGRAMMABLE CONTROLLER (FX1S, FX1N, FX2N, FX2NC)

FX Series Programmable Controllers

FX Series Programmable Controllers

Programming Manual
Manual number : JY992D88101 Manual revision : D Date : April 2003

Foreword This manual contains text, diagrams and explanations which will guide the reader in the correct programming and operation of the PLC. Before attempting to install or use the PLC this manual should be read and understood. If in doubt at any stage of the installation of the PLC always consult a professional electrical engineer who is qualified and trained to the local and national standards which apply to the installation site. If in doubt about the operation or use of the PLC please consult the nearest Mitsubishi Electric distributor. This manual is subject to change without notice.

FX Series Programmable Controllers

ii

FX Series Programmable Controllers

FAX BACK Mitsubishi has a world wide reputation for its efforts in continually developing and pushing back the frontiers of industrial automation. What is sometimes overlooked by the user is the care and attention to detail that is taken with the documentation. However, to continue this process of improvement, the comments of the Mitsubishi users are always welcomed. This page has been designed for you, the reader, to fill in your comments and fax them back to us. We look forward to hearing from you. Fax numbers: Mitsubishi Electric.... America Australia Germany Spain United Kingdom (01) 847-478-2253 (02) 638-7072 (0 21 02) 4 86-1 12 (34) 93-589-1579 (01707) 278-695 Your name: ................................................... ..................................................................... Your company: ............................................. ..................................................................... Your location:................................................ .....................................................................

Please tick the box of your choice What condition did the manual arrive in?

!Good

!Minor damage !No !Unfriendly !Not too bad

!Unusable

Will you be using a folder to store the manual? !Yes What do you think to the manual presentation?!Tidy Are the explanations understandable?

!Yes

!Unusable

Which explanation was most difficult to understand: .................................................................. .................................................................................................................................................... Are there any diagrams which are not clear? What do you think to the manual layout?

!Yes !Good

!No !Not too bad !Unhelpful

If so,which: .................................................................................................................................. If there one thing you would like to see improved, what is it? ..................................................... .................................................................................................................................................... .................................................................................................................................................... Could you find the information you required easily using the index and/or the contents, if possible please identify your experience: ................................................................................... .................................................................................................................................................... .................................................................................................................................................... .................................................................................................................................................... .................................................................................................................................................... Do you have any comments in general about the Mitsubishi manuals? ..................................... .................................................................................................................................................... .................................................................................................................................................... .................................................................................................................................................... .................................................................................................................................................... Thank you for taking the time to fill out this questionnaire. We hope you found both the product and this manual easy to use.

iii

FX Series Programmable Controllers

iv

FX Series Programmable Controllers

Guidelines for the Safety of the User and Protection of the Programmable Controller (PLC)
This manual provides information for the use of the FX family of PLCs. The manual has been written to be used by trained and competent personnel. The definition of such a person or persons is as follows; a) Any engineer who is responsible for the planning, design and construction of automatic equipment using the product associated with this manual should be of a competent nature, trained and qualified to the local and national standards required to fulfill that role. These engineers should be fully aware of all aspects of safety with regards to automated equipment. b) Any commissioning or service engineer must be of a competent nature, trained and qualified to the local and national standards required to fulfill that job. These engineers should also be trained in the use and maintenance of the completed product. This includes being completely familiar with all associated documentation for the said product. All maintenance should be carried out in accordance with established safety practices. c) All operators of the completed equipment (see Note) should be trained to use this product in a safe manner in compliance to established safety practices. The operators should also be familiar with documentation which is associated with the operation of the completed equipment. Note : Note: the term completed equipment refers to a third party constructed device which contains or uses the product associated with this manual. Notes on the Symbols Used in this Manual At various times throughout this manual certain symbols will be used to highlight points of information which are intended to ensure the users personal safety and protect the integrity of equipment. Whenever any of the following symbols are encountered its associated note must be read and understood. Each of the symbols used will now be listed with a brief description of its meaning. Hardware Warnings 1) Indicates that the identified danger WILL cause physical and property damage.

2) Indicates that the identified danger could POSSIBLY cause physical and property damage. 3) Indicates a point of further interest or further explanation. Software Warnings 4) Indicates special care must be taken when using this element of software.

5) Indicates a special point which the user of the associate software element should be aware of. 6) Indicates a point of interest or further explanation.

FX Series Programmable Controllers

Under no circumstances will Mitsubishi Electric be liable responsible for any consequential damage that may arise as a result of the installation or use of this equipment. All examples and diagrams shown in this manual are intended only as an aid to understanding the text, not to guarantee operation. Mitsubishi Electric will accept no responsibility for actual use of the product based on these illustrative examples. Please contact a Mitsubishi Electric distributor for more information concerning applications in life critical situations or high reliability.

vi

FX Series Programmable controllers

1. Introduction............................................................................................1-1
1.1 1.2 1.3 1.4 Overview.............................................................................................................. 1-1 What is a Programmable Controller? .................................................................. 1-2 What do You Need to Program a PLC? .............................................................. 1-2 Special considerations for programming equipment ........................................... 1-3

1.4.1 Current Generation CPU all versions ....................................................................... 1-3

1.5 Associated Manuals ............................................................................................ 1-4

2. Basic Program Instructions ...................................................................2-1


2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 2.10 2.11 2.12 2.13 2.14 2.15 2.16 What is a Program? ............................................................................................. 2-1 Outline of Basic Devices Used in Programming .................................................. 2-1 How to Read Ladder Logic .................................................................................. 2-2 Load, Load Inverse .............................................................................................. 2-3 Out ....................................................................................................................... 2-4 And, And Inverse ................................................................................................. 2-6 Or, Or Inverse ...................................................................................................... 2-7 Load Pulse, Load Trailing Pulse .......................................................................... 2-8 And Pulse, And Trailing Pulse ............................................................................. 2-9 Or Pulse, Or Trailing Pulse ................................................................................ 2-10 Or Block ............................................................................................................. 2-11 And Block .......................................................................................................... 2-12 MPS, MRD and MPP ......................................................................................... 2-13 Master Control and Reset.................................................................................. 2-15 Set and Reset .................................................................................................... 2-17 Timer, Counter (Out & Reset)............................................................................ 2-18

2.5.1 Timer and Counter Variations ................................................................................... 2-4 2.5.2 Double Coil Designation ............................................................................................ 2-5

2.16.1 Basic Timers, Retentive Timers And Counters........................................................ 2-18 2.16.2 Normal 32 bit Counters ........................................................................................... 2-19 2.16.3 High Speed Counters .............................................................................................. 2-19

2.17 2.18 2.19 2.20

Leading and Trailing Pulse ................................................................................ 2-20 Inverse ............................................................................................................... 2-21 No Operation ..................................................................................................... 2-22 End .................................................................................................................... 2-23

vii

3. STL Programming .................................................................................3-1


3.1 What is STL, SFC And IEC1131 Part 3? ............................................................. 3-1 3.2 How STL Operates .............................................................................................. 3-2
3.2.1 Each step is a program ............................................................................................. 3-2

3.3 How To Start And End An STL Program ............................................................. 3-3


3.3.1 Embedded STL programs ......................................................................................... 3-3 3.3.2 Activating new states................................................................................................. 3-3 3.3.3 Terminating an STL Program .................................................................................... 3-4

3.4 Moving Between STL Steps ................................................................................ 3-5


3.4.1 Using SET to drive an STL coil ................................................................................. 3-5 3.4.2 Using OUT to drive an STL coil ................................................................................. 3-6

3.5 Rules and Techniques For STL programs........................................................... 3-7


3.5.1 Basic Notes On The Behavior Of STL programs....................................................... 3-7 3.5.2 Single Signal Step Control ........................................................................................ 3-9

3.6 3.7 3.8 3.9 3.10 3.11

Restrictions Of Some Instructions When Used With STL.................................. 3-10 Using STL To Select The Most Appropriate Program ....................................... 3-11 Using STL To Activate Multiple FlowsSimultaneously....................................... 3-12 General Rules For Successful STL Branching .................................................. 3-14 General Precautions When UsingFX-PCS/AT-EE Software ............................. 3-15 Programming Examples .................................................................................... 3-16

3.11.1 A Simple STL Flow .................................................................................................. 3-16 3.11.2 A Selective Branch/ First State Merge Example Program....................................... 3-18

3.12 Advanced STL Use............................................................................................ 3-20

4. Devices in Detail....................................................................................4-1
4.1 Inputs ................................................................................................................... 4-1 4.2 Outputs ................................................................................................................ 4-2 4.3 Auxiliary Relays ................................................................................................... 4-3
4.3.1 4.3.2 4.3.3 4.3.4 4.4.1 4.4.2 4.4.3 4.4.4 General Stable State Auxiliary Relays ...................................................................... 4-3 Battery Backed/ Latched Auxiliary Relays................................................................. 4-4 Special Diagnostic Auxiliary Relays .......................................................................... 4-5 Special Single Operation Pulse Relays ..................................................................... 4-5 General Stable State - State Relays ......................................................................... 4-6 Battery Backed/ Latched State Relays ...................................................................... 4-7 STL Step Relays ....................................................................................................... 4-8 Annunciator Flags ..................................................................................................... 4-9

4.4 State Relays ........................................................................................................ 4-6

4.5 Pointers ............................................................................................................. 4-10 4.6 Interrupt Pointers ............................................................................................... 4-11


4.6.1 4.6.2 4.6.3 4.6.4 Input Interrupts ........................................................................................................ 4-12 Timer Interrupts ....................................................................................................... 4-12 Disabling Individual Interrupts ................................................................................. 4-13 Counter Interrupts ................................................................................................... 4-13

4.7 Constant K ......................................................................................................... 4-14 4.8 Constant H......................................................................................................... 4-14 4.9 Timers................................................................................................................ 4-15
4.9.1 4.9.2 4.9.3 4.9.4 4.9.5 General timer operation........................................................................................... 4-16 Selectable Timers.................................................................................................... 4-16 Retentive Timers ..................................................................................................... 4-17 Timers Used in Interrupt and CALL Subroutines ................................................... 4-18 Timer Accuracy ....................................................................................................... 4-18

4.10 Counters ............................................................................................................ 4-19


4.10.1 General/ Latched 16bit UP Counters ...................................................................... 4-20 4.10.2 General/ Latched 32bit Bi-directional Counters....................................................... 4-21

viii

4.11 High Speed Counters ........................................................................................ 4-22


4.11.1 4.11.2 4.11.3 4.11.4 4.11.5 4.11.6 4.12.1 4.12.2 4.12.3 4.12.4 4.12.5 Basic High Speed Counter Operation ..................................................................... 4-23 Availability of High Speed Counters ....................................................................... 4-24 1 Phase Counters - User Start and Reset (C235 - C240) ....................................... 4-26 1 Phase Counters - Assigned Start and Reset (C241 to C245) .............................. 4-27 2 Phase Bi-directional Counters (C246 to C250) .................................................... 4-28 A/B Phase Counters (C252 to C255) ...................................................................... 4-29 General Use Registers ............................................................................................ 4-31 Battery Backed/ Latched Registers ......................................................................... 4-32 Special Diagnostic Registers................................................................................... 4-32 File Registers .......................................................................................................... 4-33 Externally Adjusted Registers ................................................................................. 4-34

4.12 Data Registers ................................................................................................... 4-30

4.13 Index Registers.................................................................................................. 4-35


4.13.1 Modifying a Constant............................................................................................... 4-36 4.13.2 Misuse of the Modifiers ........................................................................................... 4-36 4.13.3 Using Multiple Index Registers ................................................................................ 4-36

4.14 Bits, Words, BCD and Hexadecimal .................................................................. 4-37


4.14.1 4.14.2 4.14.3 4.14.4 Bit Devices, Individual and Grouped ....................................................................... 4-37 Word Devices .......................................................................................................... 4-39 Interpreting Word Data ............................................................................................ 4-39 Twos Compliment ................................................................................................... 4-42

4.15 Floating Point And Scientific Notation ............................................................... 4-43


4.15.1 Scientific Notation.................................................................................................... 4-44 4.15.2 Floating Point Format .............................................................................................. 4-45 4.15.3 Summary Of The Scientific Notation and Floating Point Numbers.......................... 4-46

5. Applied Instructions ...............................................................................5-1


5.1 Program Flow-Functions 00 to 09 ....................................................................... 5-4
5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7 5.2.1 5.2.2 5.2.3 5.2.4 5.2.5 5.2.6 5.2.7 5.2.8 5.2.9 5.2.10 CJ (FNC 00) .............................................................................................................. 5-5 CALL (FNC 01).......................................................................................................... 5-7 SRET (FNC 02) ......................................................................................................... 5-9 IRET, EI, DI(FNC 03, 04, 05) .................................................................................. 5-10 FEND (FNC 06) ....................................................................................................... 5-12 WDT (FNC 07) ........................................................................................................ 5-13 FOR, NEXT(FNC 08, 09) ........................................................................................ 5-14 CMP (FNC 10)......................................................................................................... 5-18 ZCP (FNC 11) ......................................................................................................... 5-19 MOV (FNC 12) ........................................................................................................ 5-20 SMOV (FNC 13) ...................................................................................................... 5-21 CML (FNC 14) ......................................................................................................... 5-22 BMOV (FNC 15) ..................................................................................................... 5-23 FMOV (FNC 16) ...................................................................................................... 5-24 XCH (FNC 17) ......................................................................................................... 5-25 BCD (FNC18) .......................................................................................................... 5-26 BIN (FNC 19)........................................................................................................... 5-27

5.2 Move And Compare - Functions 10 to 19 .......................................................... 5-17

ix

5.3 Arithmetic And Logical Operations -Functions 20 to 29 .................................... 5-29


5.3.1 5.3.2 5.3.3 5.3.4 5.3.5 5.3.6 5.3.7 5.3.8 5.3.9 5.3.10 5.4.1 5.4.2 5.4.3 5.4.4 5.4.5 5.4.6 5.4.7 5.4.8 5.4.9 5.4.10 5.5.1 5.5.2 5.5.3 5.5.4 5.5.5 5.5.6 5.5.7 5.5.8 5.5.9 5.5.10 5.6.1 5.6.2 5.6.3 5.6.4 5.6.5 5.6.6 5.6.7 5.6.8 5.6.9 5.6.10 5.7.1 5.7.2 5.7.3 5.7.4 5.7.5 5.7.6 5.7.7 5.7.8 5.7.9 5.7.10 ADD (FNC 20) ......................................................................................................... 5-30 SUB (FNC 21) ........................................................................................................ 5-31 MUL (FNC 22) ......................................................................................................... 5-32 DIV (FNC 23)........................................................................................................... 5-33 INC (FNC 24) ......................................................................................................... 5-34 DEC (FNC 24) ........................................................................................................ 5-35 WAND (FNC 26)...................................................................................................... 5-36 WOR (FNC 27) ........................................................................................................ 5-37 WXOR (FNC 28) ..................................................................................................... 5-38 NEG (FNC 29) ........................................................................................................ 5-39 ROR (FNC 30)......................................................................................................... 5-43 ROL (FNC 31) ......................................................................................................... 5-44 RCR (FNC 32) ......................................................................................................... 5-45 RCL (FNC 33) ......................................................................................................... 5-46 SFTR (FNC 34) ....................................................................................................... 5-47 SFTL (FNC 35) ........................................................................................................ 5-48 WSFR (FNC 36) ...................................................................................................... 5-49 WSFL (FNC 37)....................................................................................................... 5-50 SFWR (FNC 38) ...................................................................................................... 5-51 SFRD (FNC 39) ....................................................................................................... 5-52 ZRST (FNC 40) ....................................................................................................... 5-55 DECO (FNC 41) ...................................................................................................... 5-56 ENCO (FNC 42) ...................................................................................................... 5-57 SUM (FNC 43)......................................................................................................... 5-58 BON (FNC 44) ......................................................................................................... 5-59 MEAN (FNC 45) ...................................................................................................... 5-60 ANS (FNC 46) ......................................................................................................... 5-61 ANR (FNC 47) ......................................................................................................... 5-62 SQR (FNC 48) ......................................................................................................... 5-63 FLT (FNC 49) .......................................................................................................... 5-64 REF (FNC 50) ......................................................................................................... 5-68 REFF (FNC 51) ....................................................................................................... 5-69 MTR (FNC 52) ......................................................................................................... 5-70 HSCS (FNC 53)....................................................................................................... 5-72 HSCR (FNC 54) ...................................................................................................... 5-74 HSZ (FNC 55) ......................................................................................................... 5-75 SPD (FNC 56) ......................................................................................................... 5-78 PLSY (FNC 57) ....................................................................................................... 5-79 PWM (FNC 58) ........................................................................................................ 5-80 PLSR (FNC 59) ....................................................................................................... 5-81 IST (FNC 60) ........................................................................................................... 5-85 SER (FNC 61) ......................................................................................................... 5-87 ABSD (FNC 62) ....................................................................................................... 5-88 INCD (FNC 63) ........................................................................................................ 5-89 TTMR (FNC 64)....................................................................................................... 5-90 STMR (FNC 65) ...................................................................................................... 5-91 ALT (FNC 66) .......................................................................................................... 5-92 RAMP (FNC 67) ...................................................................................................... 5-93 ROTC (FNC 68) ...................................................................................................... 5-95 SORT (FNC 69)....................................................................................................... 5-97

5.4 Rotation And Shift - Functions 30 to 39 ............................................................. 5-42

5.5 Data Operation - Functions 40 to 49 ................................................................. 5-54

5.6 High Speed Processing - Functions 50 to 59 .................................................... 5-67

5.7 Handy Instructions - Functions 60 to 69 ............................................................ 5-84

5.8 External FX I/O Devices - Functions 70 to 79 ................................................. 5-100


5.8.1 5.8.2 5.8.3 5.8.4 5.8.5 5.8.6 5.8.7 5.8.8 5.8.9 5.8.10 5.9.1 5.9.2 5.9.3 5.9.4 5.9.5 5.9.6 5.9.7 5.9.8 TKY (FNC 70)........................................................................................................ 5-101 HKY (FNC 71) ....................................................................................................... 5-102 DSW (FNC 72) ...................................................................................................... 5-104 SEGD (FNC 73) .................................................................................................... 5-106 SEGL (FNC 74) ..................................................................................................... 5-107 ARWS (FNC 75) .................................................................................................... 5-109 ASC (FNC 76) ....................................................................................................... 5-110 PR (FNC 77).......................................................................................................... 5-111 FROM (FNC 78) .................................................................................................... 5-112 TO (FNC 79).......................................................................................................... 5-114 RS (FNC 80).......................................................................................................... 5-118 RUN (FNC 81) ....................................................................................................... 5-119 ASCI (FNC 82) ...................................................................................................... 5-121 HEX (FNC 83) ....................................................................................................... 5-122 CCD (FNC 84) ....................................................................................................... 5-123 VRRD (FNC 85) .................................................................................................... 5-124 VRSD (FNC 86)..................................................................................................... 5-125 PID (FNC 88)......................................................................................................... 5-126

5.9 External FX Serial Devices - Functions 80 to 89 ............................................. 5-117

5.10 Floating Point 1 & 2 - Functions 110 to 129 .................................................... 5-134


5.10.1 ECMP (FNC 110) .................................................................................................. 5-135 5.10.2 EZCP (FNC 111) ................................................................................................... 5-136 5.10.3 EBCD (FNC 118)................................................................................................... 5-137 5.10.4 EBIN (FNC 119) .................................................................................................... 5-138 5.10.5 EADD (FNC 120)................................................................................................... 5-139 5.10.6 EAUB (FNC 121) ................................................................................................... 5-140 5.10.7 EMUL (FNC 122)................................................................................................... 5-141 5.10.8 EDIV (FNC 123) .................................................................................................... 5-142 5.10.9 ESQR (FNC 127) .................................................................................................. 5-143 5.10.10INT (FNC 129) ...................................................................................................... 5-144

5.11 Trigonometry - FNC 130 to FNC 139 .............................................................. 5-146


5.11.1 SIN (FNC 130)....................................................................................................... 5-147 5.11.2 COS (FNC 131) ..................................................................................................... 5-148 5.11.3 TAN (FNC 132) ..................................................................................................... 5-149

5.12 Data Operations 2 - FNC 140 to FNC 149 ...................................................... 5-151


5.12.1 SWAP (FNC 147) .................................................................................................. 5-152

5.13 Positioning Control - FNC 150 to FNC 159 ..................................................... 5-155


5.13.1 Cautions when using Positioning Instructions ....................................................... 5-156 5.13.2 Pulse train settings ................................................................................................ 5-157 5.13.3 Devices related to positioning ............................................................................... 5-158 5.13.4 Servo Wiring Example ........................................................................................... 5-159 5.13.5 Example Program.................................................................................................. 5-160 5.13.6 ABS (FNC 155) ..................................................................................................... 5-164 5.13.7 ZRN (FNC 156) ..................................................................................................... 5-165 5.13.8 PLSV(FNC157) ..................................................................................................... 5-167 5.13.9 DRVI (FNC 158) .................................................................................................... 5-168 5.13.10DRVA(FNC 159) ................................................................................................... 5-170

5.14 Real Time Clock Control - FNC 160 to FNC 169............................................. 5-174
5.14.1 5.14.2 5.14.3 5.14.4 5.14.5 5.14.6 5.14.7 TCMP (FNC 160) .................................................................................................. 5-175 TZCP (FNC 161) ................................................................................................... 5-176 TADD (FNC 162) ................................................................................................... 5-177 TSUB (FNC 163) ................................................................................................... 5-178 TRD (FNC 166) ..................................................................................................... 5-179 TWR (FNC 167) .................................................................................................... 5-180 Hour (FNC 169) ..................................................................................................... 5-181

xi

5.15 Gray Codes - FNC 170 to FNC 179 ................................................................ 5-184


5.15.1 5.15.2 5.15.3 5.15.4 GRY (FNC 170) ..................................................................................................... 5-185 GBIN (FNC 171) .................................................................................................... 5-185 RD3A (FNC 176) ................................................................................................... 5-187 WR3A (FNC 177) .................................................................................................. 5-188

5.16 Additional Functions - FNC 180 to FNC 189 ................................................... 5-190


5.16.1 EXTR (FNC 180) ................................................................................................... 5-191

5.17 Inline Comparisons - FNC 220 to FNC 249 ..................................................... 5-217


5.17.1 LD compare (FNC 224 to 230) .............................................................................. 5-218 5.17.2 AND compare (FNC 232 to 238) ........................................................................... 5-219 5.17.3 OR compare (FNC 240 to 246) ............................................................................. 5-220

6. Diagnostic Devices ................................................................................6-1


6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 6.10 6.11 6.12 6.13 6.14 6.15 6.16 6.17 6.18 Device Lists ......................................................................................................... 6-2 PLC Status (M8000 to M8009 and D8000 to D8009) .......................................... 6-7 Clock Devices (M8010 to M8019 and D8010 to D8019) .................................... 6-8 Operation Flags (M8020 to M8029 and D8020 to D8029) .................................. 6-9 PLC Operation Mode (M8030 to M8039 and D8030 to D8039) ....................... 6-10 Step Ladder (STL) Flags (M8040 to M8049 and D8040 to D8049) .................. 6-11 Interrupt Control Flags (M8050 to M8059 and D8050 to D8059) .................... 6-12 Error Detection Devices (M8060 to M8069 and D8060 to D6069) ................... 6-13 Link and Special Operation Devices (M8070 to M8099 and D8070 to D8099) 6-15 Miscellaneous Devices (M8100 to M8119 and D8100 to D8119) ..................... 6-16 Communication Adapter Devices, i.e. 232ADP, 485ADP (M8120 to M8129 and D8120 to D8129) ............................................................6-16 High Speed Zone Compare Table Comparison Flags (M8130 to M8148 and D8130 to D8148) .......................................................... 6-17 Miscellaneous Devices (M8160 to M8199) ....................................................... 6-19 Miscellaneous devices (D8158 to D8164) and Index Registers (D8182 to D8199) .....................................................................6-20 N:N Network Related Flags and Data Registers ............................................... 6-21 Up/Down Counter Control (M8200 to M8234 and D8219 to D8234) ............... 6-22 High Speed Counter Control (M8235 to M8255 and D8235 to D8255) ............ 6-22 Error Code Tables ............................................................................................. 6-23

7. Execution Times And Instructional Hierarchy7-1


7.1 7.2 7.3 7.4 7.5 7.6 Basic Instructions ................................................................................................ 7-1 Applied Instructions ............................................................................................ 7-3 Hierarchical RelationshipsOf Basic Program Instructions ................................. 7-11 Batch Processing............................................................................................... 7-13 Summary of Device Memory Allocations ........................................................... 7-13 Limits Of Instruction Usage ............................................................................... 7-15

7.6.1 Instructions Which Can Only Be Used Once In The Main Program Area ............... 7-15 7.6.2 Instructions Which Are Not Suitable For Use With 110V AC Input Units7-15

8. PLC Device Tables................................................................................8-1


8.1 Performance Specification Of The FX1S ............................................................ 8-1 8.2 Performance Specification Of The FX1N ............................................................ 8-2 8.3 Performance Specification Of The FX2N and the FX2NC PLCs ........................ 8-4

xii

9. Assigning System Devices ....................................................................9-1


9.1 Addressing Extension Modules ........................................................................... 9-1 9.2 Real Time Clock Function ................................................................................... 9-2
9.2.1 Setting the real time clock ......................................................................................... 9-2

9.3 Analog Expansion Boards ................................................................................... 9-4


9.3.1 FX1N-1DA-BD ........................................................................................................... 9-4 9.3.2 FX1N-2AD-BD ......................................................................................................... 9-11

10.Points Of Technique...........................................................................10-1
10.1 Advanced Programming Points ......................................................................... 10-1 10.2 Users of DC Powered FX2N Units .................................................................... 10-1 10.3 Using The Forced RUN/STOP Flags................................................................. 10-2
10.3.1 A RUN/STOP push button configuration ................................................................. 10-2 10.3.2 Remote RUN/STOP control .................................................................................... 10-3

10.4 10.5 10.6 10.7 10.8 10.9

Constant Scan Mode ......................................................................................... 10-4 Alternating ON/OFF States................................................................................ 10-4 Using Battery Backed Devices For Maximum Advantage ................................. 10-5 Indexing Through MultipleDisplay Data Values ................................................. 10-5 Reading And Manipulating Thumbwheel Data .................................................. 10-6 Measuring a High Speed Pulse Input ................................................................ 10-6

10.9.1 A 1 msec timer pulse measurement ........................................................................ 10-6 10.9.2 A 0.1 msec timer pulse measurement ..................................................................... 10-7

10.10Using The Execution Complete Flag, M8029 ................................................... 10-7 10.11Creating a User Defined MTR Instruction ......................................................... 10-8 10.12An Example SystemApplication Using STL And IST Program Control ............. 10-8 10.13Using The PWM Instruction For Motor Control ............................................... 10-15 10.14Communication Format................................................................................... 10-18
10.14.1Specification of the communication parameters: .................................................. 10-18 10.14.2Header and Terminator Characters ...................................................................... 10-19 10.14.3Timing diagrams for communications: .................................................................. 10-20 10.14.48 bit or 16 bit communications. ............................................................................. 10-23

10.15PID Programming Techniques ........................................................................ 10-24


10.15.1Keeping MV within a set range ............................................................................. 10-24 10.15.2Manual/Automatic change over ............................................................................ 10-24 10.15.3Using the PID alarm signals ................................................................................. 10-25 10.15.4Other tips for PID programming............................................................................ 10-25

10.16Additional PID functions .................................................................................. 10-26


10.16.1Output Value range control (S3+1 b5).................................................................. 10-26

10.17Pre-tuning operation ....................................................................................... 10-27


10.17.1Variable Constants ............................................................................................... 10-27

10.18Example Autotuning Program ......................................................................... 10-28 10.19Using the FX1N-5DM Display module. ........................................................... 10-29
10.19.1Outline of functions. .............................................................................................. 10-29 10.19.2Control devices for 5DM ....................................................................................... 10-30 10.19.3Display screen protect function............................................................................. 10-30 10.19.4Specified device monitor....................................................................................... 10-31 10.19.5Specified device edit............................................................................................. 10-32 10.19.6Automatic Backlight OFF ...................................................................................... 10-33 10.19.7Error display enable / disable ............................................................................... 10-33

11. Index..................................................................................................11-1
11.1 Index .................................................................................................................. 11-1 11.2 ASCII Character Codes ..................................................................................... 11-9 11.3 Applied Instruction List .................................................................................... 11-10
xiii

xiv

FX Series Programmable Controllers

Introduction 1

1 2 3 4 5 6 7 8 9 10 11

Introduction Basic Program Instructions STL Programming Devices in Detail Applied Instructions Diagnostic Devices Instruction Execution Times PLC Device Tables Assigning System Devices Points of Technique Index

FX Series Programmable Controllers

Introduction 1

Chapter Contents 1. Introduction............................................................................................1-1


1.1 1.2 1.3 1.4 1.5 Overview.............................................................................................................. 1-1 What is a ProgrammableController? ................................................................... 1-2 What do You Need to Program a PC? ................................................................ 1-2 Curent Generation CPUs, All versions ............................................................... 1-3 Associated Manuals ............................................................................................ 1-4

Introduction 1
FX1S
FX1N FX2N FX2NC

1.
1.1

Introduction
Overview
1) Scope of this manual This manual gives details on all aspects of operation and programming for FX1S , FX1N, FX2N and FX2NC programmable controllers (PLCs). For all information relating to the PLC hardware and installation, refer to the appropriate manual supplied with the unit. 2) How to use this manual This manual covers all the functions of the highest specification Programmable (Logic) Controller (PLC). For this reason, the following indicator is included in relevant section titles to show which PLCs that section applies to;
FX1S
FX1N FX2N FX2NC

Shaded boxes indicate the applicable PLC type

FX1S FX1N FX2N

- All FX1S PLCs - All FX1N PLCs - All FX2N PLCs

FX2NC - All FX2NC PLCs


FX1S FX1N FX2N FX2NC

If an indicator box is half shaded, as shown to the left, this means that not all the functions described in the current section apply to that PLC. The text explains in further detail or makes an independent reference. If there are no indicator boxes then assume the section applies to all PLC types unless otherwise stated. 3) FX family This is a generic term which is often used to describe all Programmable Controllers without identifying individual types or model names. 4) CPU version numbers and programming support As Mitsubishi upgrades each model different versions have different capabilities. - Please refer to section 1.4 for details about peripheral support for each model.

1-1

Introduction 1

1.2

What is a Programmable Controller?

FX1S

FX1N

FX2N

FX2NC

A Programmable Logic Controller (PLC or programmable controller) is a device that a user can program to perform a series or sequence of events. These events are triggered by stimuli (usually called inputs) received at the PLC or through delayed actions such as time delays or counted occurrences. Once an event triggers, it actuates in the outside world by switching ON or OFF electronic control gear or the physical actuation of devices. A programmable controller will continually loop through its internal user defined program waiting for inputs and giving outputs at the programmed specific times. Note on terminology: The term programmable controller is a generic word used to bring all the elements making the control system under one descriptive name. Sometimes engineers use the term Programmable Logic Controller, PLC or programmable controller to describe the same control system. The construction of a programmable controller can be broken down into component parts. The element where the program is loaded, stored and processed is often known as the Main Processing Unit or MPU. Other terms commonly heard to describe this device are base unit, controller and CPU. The term CPU is a little misleading as todays more advanced products may contain local CPU devices. A Main CPU (or more correctly a Main Processing Unit) controls these local CPUs through a communication network or bus.

1.3

What do You Need to Program a PLC?

FX1S

FX1N

FX2N

FX2NC

A variety of tools are available to program the Mitsubishi FX family of PLCs. Each of these tools can use and access the instructions and devices listed in this manual for the identified PLC.

FX1S FX1N FX2N FX2NC


Opto-isolated RS232/ RS422 interface

HPP FX-10P-E FX-20P-E Personal computer Melsec MEDOC Melsec Medoc Plus SW1PC-FXGPEE FX-PCS-WIN-E

1-2

Introduction 1

1.4
1.4.1

Special considerations for programming equipment


Current Generation CPU all versions

FX1S

FX1N FX2N FX2NC

The introduction of the current CPU provides the FX user with many new devices and instructions. To use the full features of the current range of FX units the user must upgrade older software and hardware programming tools. However, because of the downward compatibility of the current range, it is not necessary to upgrade existing programming tools up to the equivalent functionality of last generation FX CPU ver 3.30 units.
Peripherals Table Description Hand held programmer (HHP) HHP cassette Model Number FX-10P-E FX-20P-MFXA-E FX-10DU-E FX-20DU-E FX-25DU-E FX-30DU-E FX-40DU-E(S) Data access units/ GOT units FX-40DU-TK-ES FX-50DU-TK(S)-E F930GOT-BWD F94*GOT-SWD(LWD)-E F94*GOT Handy F940WGOT System software version with full support from V 3.00 from V 3.00 from V 4.00 Supports up to FX devices only from V 2.00 from V 3.00 Supports up to FX devices only from V 3.00 from V 2.10 All versions All versions All versions All versions

1-3

Introduction 1

1.5

Associated Manuals
Manual name FX Base Unit Hardware FX1S Hardware manual FX1N Hardware manual FX2N Hardware manual FX2NC Hardware manual FX Programming FX0, FX0S, FX0N, FX, FX2C, FX2N, FX2NC Programming manual FX1S, FX1N, FX2N, FX2NC Programming manual II FX Peripherals FX-10P-E Operation manual FX-20P-E Operation manual FX-10P, 20P-E Supplementary manual FX-PCS-WIN-E Software manual FX Special Function Blocks FX0N-3A Users guide FX-4AD Users guide FX-2AD-PT Users guide FX-4AD-TC Users guide FX-2DA Users guide FX2N-2AD Users manual FX-4DA Users guide FX2N-4AD Users guide FX2N-4AD-TC Users guide FX2N-4AD-PT Users guide FX2N-4DA Users guide FX2N-2DA Users manual FX2N-2LC Users guide FX2N-2LC Users manual FX-485PC-IF Hardware manual FX/FX0N-485ADP Users guide FX-232ADP Users guide FX0N-232ADP Users guide FX2N-232BD Users guide FX2N-422BD Users guide FX2N-485BD Hardware manual FX2N-232IF Hardware manual FX Communication Users manual FX2N-CCL Users manual FX2N-16LNK-M Users manual FX0N-32NT-DP Users manual FX2N-32DP-IF Hardware manual FX2N-32DP-IF Users manual FX2N-32ASI-M Users manual JY992D49001 JY992D52601 JY992D55701 JY992D55901 JY992D52801 JY992D74701 JY992D61001 JY992D65201 JY992D65501 JY992D65601 JY992D65901 JY992D74901 JY992D85601 JY992D85801 JY992D81801 JY992D53201 JY992D48801 JY992D51301 JY992D66001 JY992D66101 JY992D73401 JY992D73501 JY992D69901 JY992D71801 JY992D73701 JY992D61401 JY992D77101 JY992D79401 JY992D76901 JY992D33401 JY992D19101 JY992D66901 JY992D66501 JY992D48301 JY992D88101 JY992D83901 JY992D88201 JY992D66301 JY992D76401 Number

1-4

Introduction 1

Manual name FX DU, GOT and DM units FX-5DM Users manual FX-10DM Users manual FX Positioning FX-1HC Users guide FX2N/FX-1PG-E Users manual E-20P-E Operation manual FX2N-1HC Users guide FX2N-1RM-E-SET Users manual FX2N-10GM Users guide FX2N-20GM Users guide FX2N-10/20GM Hardware/Programming manual FX-PCS-VPS/WIN-E Software manual

Number JY992D84901 JY992D86401 JY992D53001 JY992D65301 JY992D44901 JY992D65401 JY992D71101 JY992D77701 JY992D77601 JY992D77801 JY992D86801

1-5

Introduction 1

Memo

1-6

FX Series Programmable Controllers

Basic Program Instructions 2

1 2 3 4 5 6 7 8 9 10 11

Introduction Basic Program Instructions STL Programming Devices in Detail Applied Instructions Diagnostic Devices Instruction Execution Times PLC Device Tables Assigning System Devices Points of Technique Index

FX Series Programmable Controllers

Basic Program Instructions 2

Chapter Contents 2. Basic Program Instructions ...................................................................2-1


2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 2.10 2.11 2.12 2.13 2.14 2.15 2.16 What is a Program? ............................................................................................. 2-1 Outline of Basic Devices Used in Programming .................................................. 2-1 How to Read Ladder Logic .................................................................................. 2-2 Load, Load Inverse .............................................................................................. 2-3 Out ....................................................................................................................... 2-4 And, And Inverse ................................................................................................. 2-6 Or, Or Inverse ...................................................................................................... 2-7 Load Pulse, Load Trailing Pulse .......................................................................... 2-8 And Pulse, And Trailing Pulse ............................................................................. 2-9 Or Pulse, Or Trailing Pulse ................................................................................ 2-10 Or Block ............................................................................................................. 2-11 And Block .......................................................................................................... 2-12 MPS, MRD and MPP ......................................................................................... 2-13 Master Control and Reset.................................................................................. 2-15 Set and Reset .................................................................................................... 2-17 Timer, Counter(Out & Reset)............................................................................. 2-18

2.5.1 Timer and Counter Variations ................................................................................... 2-4 2.5.2 Double Coil Designation ............................................................................................ 2-5

2.16.1 Basic Timers, Retentive Timers And Counters........................................................ 2-18 2.16.2 Normal 32 bit Counters ........................................................................................... 2-19 2.16.3 High Speed Counters .............................................................................................. 2-19

2.17 2.18 2.19 2.20

Leading and Trailing Pulse ................................................................................ 2-20 Inverse ............................................................................................................... 2-21 No Operation ..................................................................................................... 2-22 End .................................................................................................................... 2-23

FX Series Programmable Controllers

Basic Program Instructions 2

2.
2.1

Basic Program Instructions


What is a Program?
A program is a connected series of instructions written in a language that the PLC can understand. There are three forms of program format; instruction, ladder and SFC/STL. Not all programming tools can work in all programming forms. Generally hand held programming panels only work with instruction format while most graphic programming tools will work with both instruction and ladder format. Specialist programming software will also allow SFC style programming.

LD OUT AND SET LD OUT

X10 Y7 M38 S5 X21 T01 K40

Instruction format

Ladder Format

SFC Format

2.2

Outline of Basic Devices Used in Programming


There are six basic programming devices. Each device has its own unique use. To enable quick and easy identification each device is assigned a single reference letter; - X: This is used to identify all direct, physical inputs to the PLC. - Y: This is used to identify all direct, physical outputs from the PLC. - T: This is used to identify a timing device which is contained within the PLC. - C: This is used to identify a counting device which is contained within the PLC. - M and S: These are used as internal operation flags within the PLC. All of the devices mentioned above are known as bit devices. This is a descriptive title telling the user that these devices only have two states; ON or OFF, 1 or 0.

Detailed device information:


Chapter 4 contains this information in detail. However, the above is all that is required for the rest of this chapter.

2-1

FX Series Programmable Controllers

Basic Program Instructions 2

2.3

How to Read Ladder Logic


Ladder logic is very closely associated to basic relay logic. There are both contacts and coils that can be loaded and driven in different configurations. However, the basic principle remains the same. A coil drives direct outputs of the PLC (ex. a Y device) or drives internal timers, counters or flags (ex. T, C, M and S devices). Each coil has associated contacts. These contacts are available in both normally open (NO) and normally closed (NC) configurations. The term normal(ly) refers to the status of the contacts when the coil is not energized. Using a relay analogy, when the coil is OFF, a NO contact would have no current flow, that is, a load being supplied through a NO contact would not operate. However, a NC contact would allow current to flow, hence the connected load would be active. Activating the coil reverses the contact status, that is, the current would flow in a NO contact and a NC contact would inhibit the flow. Physical inputs to the PLC (X devices) have no programmable coil. These devices may only be used in a contact format (NO and NC types are available). Example: Because of the close relay association, ladder logic programs can be read as current flowing from the left vertical line to the right vertical line. This current must pass through a series of contact representations such as X0 and X1 in order to switch the output coil Y0 ON. Therefore, in the example shown, switching X0 ON causes the output Y0 to also switch ON. If however, the limit switch X1 is activates, the output Y0 turns OFF. This is because the connection between the left and the right vertical lines breaks so there is no current flow.
Motor Toggle switch X0 I N P U T Programmable Controller Y0 PC Program X0 X1 Y0 O U T P U T

X1 Limit switch

COM (Y0)

AC Power Supply

DC Power Supply

2-2

FX Series Programmable Controllers

Basic Program Instructions 2

2.4

Load, Load Inverse


Mnemonic Function Initial logical operation contact type NO (normally open) Initial logical operation contact type NC (normally closed) Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

LD (LoaD)

X, Y, M, S, T, C

LDI (LoaD Inverse)

X, Y, M, S, T, C

Program example:

X0 Y0 X1 M100 LDI K T0 Y1 T0 K19

0 1 2 3 4 7 8

LD OUT LDI OUT OUT SP LD OUT

X 0 Y 0 X 1 M 100 T 0 K 19 T 0 Y 1

When using hand held programmers, the space key needs to be pressed to enable the constant to be entered.

Basic points to remember: - Connect the LD and LDI instructions directly to the left hand bus bar. - Or use LD and LDI instructions to define a new block of program when using the ORB and ANB instructions (see later sections).

The OUT instruction:


For details of the OUT instruction (including basic timer and counter variations) please see over the following page.

2-3

FX Series Programmable Controllers

Basic Program Instructions 2

2.5

Out
Mnemonic Function Final logical operation type coil drive Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps Y, M:1 S, special M coils: 2 T:3 C (16 bit): 3 C (32 bit): 5

OUT (OUT)

Y, M, S, T, C

Basic points to remember: - Connect the OUT instruction directly to the right hand bus bar. - It is not possible to use the OUT instruction to drive X type input devices. - It is possible to connect multiple OUT instructions in parallel (for example see the previous page; M100/T0 configuration)

2.5.1

Timer and Counter Variations When configuring the OUT instruction for use as either a timer (T) or counter (C) a constant must also be entered. The constant is identified by the letter K (for example see previous page; T0 K19). In the case of a timer, the constant K holds the duration data for the timer to operate, i.e. if a 100 msec timer has a constant of K100 it will be (1005 100 msec) 10 seconds before the timer coil activates. With counters, the constant identifies how many times the counter must be pulsed or triggered before the counter coil activates. For example, a counter with a constant of 8 must be triggered 8 times before the counter coil finally energizes. The following table identifies some basic parameter data for various timers and counters;
Timer/Counter 1 msec Timer 10 msec Timer 100 msec Timer 16 bit Counter 32 bit Counter 1 to 32,767 -2,147,483,648 to 2,147,483,647 1 to 32,767 Setting constant K Actual setting 0.001 to 32.767 sec 0.01 to 327.67 sec 0.1 to 3276.7 sec 1 to 32,767 -2,147,483,648 to 2,147,483,647 5 3 Program steps

2-4

FX Series Programmable Controllers

Basic Program Instructions 2

2.5.2

Double Coil Designation

1. X1 Y3 Y3 2. X2 Y3 Y4

Double or dual coiling is not a recommended practice. Using multiple output coils of the same device can cause the program operation to become unreliable. The example program shown opposite identifies a double coil situation; there are two Y3 outputs. The following sequence of events will occur when inputs X1 = ON and X2 = OFF; 1.The first Y3 tuns ON because X1 is ON. The contacts associated with Y3 also energize when the coil of output Y3 energizes. Hence, output Y4 turns ON. 2.The last and most important line in this program looks at the status of input X2.

If this is NOT ON then the second Y3 coil does NOT activate. Therefore the status of the Y3 coil updates to reflect this new situation, i.e. it turns OFF. The final outputs are then Y3 = OFF and Y4 = ON.

Use of dual coils:


Always check programs for incidents of dual coiling. If there are dual coils the program will not operate as expected - possibly resulting in physical damage.

The last coil effect:


In a dual coil designation, the coil operation designated last is the effective coil. That is, it is the status of the previous coil that dictates the behavior at the current point in the program. Input durations:
1 t secs 2 3

4 5

The ON or OFF duration of the PLC inputs must be longer than the operation cycle time of the PLC. Taking a 10 msec (standard input filter) response delay into account, the ON/OFF duration must be longer than 20 msec if the operation cycle (scan time) is 10 msec. Therefore, in this example, input pulses of more than 25Hz (1sec/(20msec ON + 20msec OFF)) cannot be sensed. There are applied instructions provided to handle such high speed input requests.

: Input ON state NOT recognized : Input ON state recognized : Input OFF state NOT recognized : 1 program processing : Input processing : Output processing : A full program scan/operation cycle

2-5

FX Series Programmable Controllers

Basic Program Instructions 2

2.6

And, And Inverse


Mnemonic Function Serial connection of NO (normally open) contacts Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

AND (AND)

X, Y, M, S, T, C

ANI (AND Inverse)

Serial connection of NC (normally closed) contacts

X, Y, M, S, T, C

Program example:

AND X2 X0 Y3 Y3 X3 M101 ANI T1 Y4 AND 0 1 2 3 4 5 6 7 LD AND OUT LD ANI OUT AND OUT X 2 X 0 Y 3 Y 3 X 3 M 101 T 1 Y 4

Basic points to remember: - Use the AND and ANI instructions for serial connection of contacts. As many contacts as required can be connected in series (see following point headed Peripheral limitations). - The output processing to a coil, through a contact, after writing the initial OUT instruction is called a follow-on output (for an example see the program above; OUT Y4). Followon outputs are permitted repeatedly as long as the output order is correct.

Peripheral limitations:
The PLC has no limit to the number of contacts connected in series or in parallel. However, some programming panels, screens and printers will not be able to display or print the program if it exceeds the limit of the hardware. It is preferable for each line or rung of ladder program to contain up to a maximum of 10 contacts and 1 coil. Also, keep the number of follow-on outputs to a maximum of 24.

2-6

FX Series Programmable Controllers

Basic Program Instructions 2

2.7

Or, Or Inverse
Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

OR (OR)

Parallel connection of NO (normally open) contacts Parallel connection of NC (normally closed) contacts

X, Y, M, S, T, C

ORI (OR Inverse)

X, Y, M, S, T, C

Program example:

X4 Y5 X6 OR M102 ORI Y5 M103 M110 X7 X10 M103

0 1 2 3 4 5 6 7 8 9

LD OR ORI OUT LDI AND OR ANI OR OUT

X X M Y Y X M X M M

4 6 102 5 5 7 103 10 110 103

Basic points to remember: - Use the OR and ORI instructions for parallel connection of contacts. To connect a block that contains more than one contact connected in series to another circuit block in parallel, use an ORB instruction. - Connect one side of the OR/ORI instruction to the left hand bus bar.

Peripheral limitations:
The PLC has no limit to the number of contacts connected in series or in parallel. However, some programming panels, screens and printers will not be able to display or print the program if it exceeds the limit of the hardware. It is preferable for each line or rung of ladder program to contain up to a maximum of 10 contacts and 1 coil. Also keep number of follow-on outputs to a maximum of 24.

2-7

FX Series Programmable Controllers

Basic Program Instructions 2

2.8

Load Pulse, Load Trailing Pulse


Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

LDP (LoaDPulse)

Initial logical operation Rising edge pulse Initial logical operation Falling / trailing edge pulse

X, Y, M, S, T, C

LDF (LoaD Falling pulse)

X, Y, M, S, T, C

Program example:
LDP X0

M100

X1 LDF X0 Y0

0 2 3 4 6

LDP OR OUT LDF OUT

X 0 X 1 M 100 X 0 Y 0

Basic points to remember: - Connect the LDP and LDF instructions directly to the left hand bus bar. - Or use LDP and LDF instructions to define a new block of program when using the ORB and ANB instructions (see later sections). - LDP is active for one program scan after the associated device switches from OFF to ON. - LDF is active for one program scan after the associated device switches from ON to OFF.

Single Operation flags M2800 to M3071:


The pulse operation instructions, when used with auxiliary relays M2800 to M3071, only activate the first instruction encountered in the program scan, after the point in the program where the device changes. Any other pulse operation instructions will remain inactive. This is useful for use in STL programs (see chapter 3) to perform single step operation using a single device. Any other instructions (LD, AND, OR, etc.) will operate as expected. For more details please see page 4-5.

2-8

FX Series Programmable Controllers

Basic Program Instructions 2

2.9

And Pulse, And Trailing Pulse


Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

ANP (ANd Pulse) ANF (ANd Falling pulse)

Serial connection of Rising edge pulse Serial connection of Falling / trailing edge pulse

X, Y, M, S, T, C

X, Y, M, S, T, C

Program example:

ANP M40 T10 M100 0 1 2 4 5 6 8 LD OR ANP OUT LDF ANF OUT M 40 X 1 T 10 M 100 X 0 C 0 Y 4

X1 ANF X0 C0 Y4

Basic points to remember: - Use the ANDP and ANDF instructions for the serial connection of pulse contacts. - Usage is the same as for AND and ANI; see earlier. - ANP is active for one program scan after the associated device switches from OFF to ON. - ANF is active for one program scan after the associated device switches from ON to OFF.

Single operation flags M2800 to M3071:


When used with flags M2800 to M3071 only the first instruction will activate. For details see page 2-8

2-9

FX Series Programmable Controllers

Basic Program Instructions 2

2.10

Or Pulse, Or Trailing Pulse


Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

ORP (OR Pulse)

Parallel connection of Rising edge pulse Parallel connection of Falling / trailing edge pulse

X, Y, M, S, T, C

ORF (OR Falling pulse)

X, Y, M, S, T, C

Program example:

M40 X1 ORP X0 Y7 M24 X1 ORF


Basic points to remember:

SET M50

Y4

0 1 3 4 5 6 7 9 10

LD ORP SET LD AND LD ORF ORB OUT

M X M X M Y X Y

40 1 50 0 24 7 1 4

- Use the ORP and ORF instructions for the parallel connection of pulse contacts. - Usage is the same as for OR and ORI; see earlier. - ORP is active for one program scan after the associated device switches from OFF to ON. - ORF is active for one program scan after the associated device switches from ON to OFF.

Single operation flags M2800 to M3071:


When used with flags M2800 to M3071 only the first instruction will activate. For details see page 2-8

2-10

FX Series Programmable Controllers

Basic Program Instructions 2

2.11

Or Block
Mnemonic Function Parallel connection of multiple contact circuits Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

ORB (OR Block)

N/A

Program example:
Recommended sequential programming method X0 X2 X1 Y6 X3 ORB X4 X5 ORB 0 1 2 3 4 5 6 7 8 LD AND LD AND ORB LDI AND ORB OUT X X X X 0 1 2 3 Non-preferred batch programming method 0 1 2 3 4 5 6 7 8 LD AND LD AND LDI AND ORB ORB OUT X X X X X X 0 1 2 3 4 5

X 4 X 5 Y 6

Y 6

Basic points to remember: - An ORB instruction is an independent instruction and is not associated with any device number. - Use the ORB instruction to connect multi-contact circuits (usually serial circuit blocks) to the preceding circuit in parallel. Serial circuit blocks are those in which more than one contact connects in series or the ANB instruction is used. - To declare the starting point of the circuit block use a LD or LDI instruction. After completing the serial circuit block, connect it to the preceding block in parallel using the ORB instruction.

Batch processing limitations:


When using ORB instructions in a batch, use no more than 8 LD and LDI instructions in the definition of the program blocks (to be connected in parallel). Ignoring this will result in a program error (see the right most program listing).

Sequential processing limitations:


There are no limitations to the number of parallel circuits when using an ORB instruction in the sequential processing configuration (see the left most program listing).

2-11

FX Series Programmable Controllers

Basic Program Instructions 2

2.12

And Block
Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

ANB (ANd Block)

Serial connection of multiple parallel circuits

N/A

Program example:

ANB X0 X1 X2 X4 X6

LD X3 Y7 X5 ORB

Recommended sequential programming method 0 1 2 3 4 5 6 7 8 9 10 LD OR LD AND LDI AND ORB OR ANB OR OUT X X X X X X X X Y 0 1 2 3 4 5 6 3 7

X3

Basic points to remember: - An ANB instruction is an independent instruction and is not associated with any device number - Use the ANB instruction to connect multi-contact circuits (usually parallel circuit blocks) to the preceding circuit in series. Parallel circuit blocks are those in which more than one contact connects in parallel or the ORB instruction is used. - To declare the starting point of the circuit block, use a LD or LDI instruction. After completing the parallel circuit block, connect it to the preceding block in series using the ANB instruction.

Batch processing limitations:


When using ANB instructions in a batch, use no more than 8 LD and LDI instructions in the definition of the program blocks (to be connected in parallel). Ignoring this will result in a program error (see ORB explanation for example).

Sequential processing limitations:


It is possible to use as many ANB instructions as necessary to connect a number of parallel circuit blocks to the preceding block in series (see the program listing).

2-12

FX Series Programmable Controllers

Basic Program Instructions 2

2.13

MPS, MRD and MPP


Mnemonic Function Stores the current result of the internal PLC operations Reads the current result of the internal PLC operations Pops (recalls and removes) the currently stored result Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

MPS (Point Store)

N/A
MPS

MRD (Read)

N/A
MRD

MPP (PoP)

N/A
MPP

Basic points to remember: - Use these instructions to connect output coils to the left hand side of a contact. Without these instructions connections can only be made to the right hand side of the last contact. - MPS stores the connection point of the ladder circuit so that further coil branches can recall the value later. - MRD recalls or reads the previously stored connection point data and forces the next contact to connect to it. - MPP pops (recalls and removes) the stored connection point. First, it connects the next contact, then it removes the point from the temporary storage area. - For every MPS instruction there MUST be a corresponding MPP instruction. - The last contact or coil circuit must connect to an MPP instruction. - At any programming step, the number of active MPS-MPP pairs must be no greater than 11.

MPS, MRD and MPP usage:


When writing a program in ladder format, programming tools automatically add all MPS, MRD and MPP instructions at the program conversion stage. If the generated instruction program is viewed, the MPS, MRD and MPP instructions are present. When writing a program in instruction format, it is entirely down to the user to enter all relevant MPS, MRD and MPP instructions as required.

2-13

FX Series Programmable Controllers

Basic Program Instructions 2

Multiple program examples:

X0

X1 Y0 X2 0 1 2 3 4 5 6 7 8 9 10 11 LD MPS LD OR ANB OUT MRD LD AND LD AND ORB X 0 X 1 X 2 Y 0 X X X X 3 4 5 6 12 13 14 15 16 17 18 19 20 ANB OUT MPP AND OUT LD OR ANB OUT Y 1

MPS X3 X5 MRD X7 Y2 X10 MPP X11 Y3 X4 Y1 X6

X 7 Y 2 X 10 X 11 Y 3

X0

X1
MPS MPP

X2 Y0 X3 Y1 X5 Y2 X6

MPS X4

MPP MPS MPP

Y3

0 1 2 3 4 5 6 7 8

LD MPS AND MPS AND OUT MPP AND OUT

X 0 X 1 X 2 Y 0 X 3 Y 1

9 10 11 12 13 14 15 16

MPP AND MPS AND OUT MPP AND OUT

X X Y X Y

4 5 2 6 3

X0 X1 X2 X3 X4 Y0 MPS Y1 Y2 Y3 Y4 MPP 0 1 2 3 4 5 6 7 8 LD MPS AND MPS AND MPS AND MPS AND X 0 X 1 X 2 X 3 X 4 9 10 11 12 13 14 15 16 17 OUT MPP OUT MPP OUT MPP OUT MPP OUT Y Y Y Y Y 0 1 2 3 4

2-14

FX Series Programmable Controllers

Basic Program Instructions 2

2.14

Master Control and Reset


Mnemonic Function Denotes the start of a master control block Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

MC (Master Control) MCR (Master Control Reset)

MC N

Y, M (no special M coils allowed) N denotes the nest level (N0 to N7) N denotes the nest level (N0 to N7) to be reset.

Denotes the end of a master control block

MCR N

Program example:

X0 MC N0 M100 X1 Y0 X2 Y1 N0 M100 0 1 4 5 6 7 8 LD MC SP LD OUT LD OUT MCR X 0 N 0 M 100 X 1 Y 0 X 2 Y 1 N 0

MCR N0

Note: SP - space key N - nest level of MC (N0 to N7)

Basic points to remember: - After the execution of an MC instruction, the bus line (LD, LDI point) shifts to a point after the MC instruction. An MCR instruction returns this to the original bus line. - The MC instruction also includes a nest level pointer N. Nest levels are from the range N0 to N7 (8 points). The top nest level is 0 and the deepest is 7. - The MCR instruction resets each nest level. When a nest level is reset, it also resets ALL deeper nest levels. For example, MCR N5 resets nest levels 5 to 7. - When input X0=ON, all instructions between the MC and the MCR instruction execute. - When input X0=OFF, none of the instruction between the MC and MCR instruction execute; this resets all devices except for retentive timers, counters and devices driven by SET/RST instructions. - The MC instruction can be used as many times as necessary, by changing the device number Y and M. Using the same device number twice is processed as a double coil (see section 2.5.2). Nest levels can be duplicated but when the nest level resets, ALL occurrences of that level reset and not just the one specified in the local MC.

2-15

FX Series Programmable Controllers

Basic Program Instructions 2

Nested MC program example:

A
N0

X0 MC M100 X1 Y0 N0 M100
Level N0: Bus line (B) active when X0 is ON.

B
X2 MC N1 M101 X3 Y1 N1 M101
Level N1: Bus line (C) active when both X0 and X2 are ON.

C
X4 MC N2 M102 X5 Y2 N2 M102
Level N2: Bus line (D) active when X0,X2 and X4 are ON.

D
MCR N2 X6 Y3
Level N1: MCRN2 executes and restores bus line (C). If the MCR had reset N0 then the original bus bar (A) would now be active as all master controls below nest level 0 would reset. Level N0: MCRN1 executes and restores bus line (B).

C
MCR N1 X7 Y4

B
MCR N0 X10
Initial state: MCR N0 executes and restores the initial bus line (A). Output Y5 turns ON/OFF according to the ON/OFF state of X10, regardless of the ON/OFF status of inputs X0, X2 or X4.

Y5

2-16

FX Series Programmable Controllers

Basic Program Instructions 2

2.15

Set and Reset


Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

SET (SET)

Sets a bit device permanently ON Resets a bit device permanently OFF

SET

Y, M, S Y, M, S, D, V, Z (see section 2.16 for timers and counters T,C)

Y,M:1 S, special M coils:2 D, special D registers, V and Z:3

RST (ReSeT)

RST

Program example:

X0 SET X1 RST X2 SET X3 RST X4 SET X5 RST X6 RST


Basic points to remember: - Turning ON X0 causes Y0 to turn ON. Y0 remains ON even after X0 turns OFF. - Turning ON X1 causes Y0 to turn OFF. Y0 remains OFF even after X1 turns OFF. - SET and RST instructions can be used for the same device as many times as necessary. However, the last instruction activated determines the current status.

Y0 Y0 M0 M0 S0 S0 D0

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

LD SET LD RST LD SET LD RST LD SET LD RST LD RST

X Y X Y X M X M X S X S X D

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

X0 X1 Y0

- It is also possible to use the RST instruction to reset the contents of data devices such as data registers, index registers etc. The effect is similar to moving K0 into the data device.

Resetting timers and counters:


Please see next page.

2-17

FX Series Programmable Controllers

Basic Program Instructions 2

2.16

Timer, Counter (Out & Reset)


Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

OUT (OUT)

Driving timer or counter coils Resets timer and counter, coils contacts and current values

T, C T, C (see section 2.15 for other resetable devices)

32 bit counters:5 Others: 3

RST (ReSeT)

RST

T, C:2

Program example:

X0 RST T246 X1 T246 K1234 T246 Y0 X2 M8200 X3 RST C200 X4 C200 D0 C200 Y1

2.16.1Basic Timers, Retentive Timers And Counters These devices can all be reset at any time by driving the RST instruction (with the number of the device to be reset). On resetting, all active contacts, coils and current value registers are reset for the selected device. In the example, T246, a 1msec retentive timer, is activate while X1 is ON. When the current value of T246 reaches the preset K value, i.e. 1234, the timer coil for T246 will be activated. This drives the NO contact ON. Hence, Y0 is switched ON. Turning ON X0 will reset timer T246 in the manner described previously. Because the T246 contacts are reset, the output Y0 will be turned OFF.

Retentive timers:
For more information on retentive timers please see page 4-17.

2-18

FX Series Programmable Controllers

Basic Program Instructions 2

2.16.2

Normal 32 bit Counters The 32 bit counter C200 counts (up-count, down-count) according to the ON/OFF state of M8200. In the example program shown on the previous page C200 is being used to count the number of OFF ~ ON cycles of input X4. The output contact is set or reset depending on the direction of the count, upon reaching a value equal (in this example) to the contents of data registers D1,D0 (32 bit setting data is required for a 32 bit counter). The output contact is reset and the current value of the counter is reset to 0 when input X3 is turned ON.

32 bit counters:
For more information on 32 bit counters please see page 4-21. 2.16.3 High Speed Counters High speed counters have selectable count directions. The directions are selected by driving the appropriate special auxiliary M coil. The example shown to the right works in the following manner; when X10 is ON, counting down takes place. When X10 is OFF counting up takes place. In the example the output contacts of counter C and its associated current count values are reset to 0 when X11 is turned ON. When X12 is turned ON the driven counter is enabled. This means it will be able to start counting its assigned input signal (this will not be X12 - high speed counters are assigned special input signals, please see page 4-22). .

X10 M8 X11 RST C

X12 C K/D C Y2

Availability of devices:
Not all devices identified here are available on all programmable controllers. Ranges of active devices may vary from PLC to PLC. Please check the specific availability of these devices on the selected PLC before use. For more information on high speed counters please see page 4-22. For PLC device ranges please see chapter 8.

2-19

FX Series Programmable Controllers

Basic Program Instructions 2

2.17

Leading and Trailing Pulse


Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

PLS (PuLSe)

Rising edge pulse

PLS

Y, M (no special M coils allowed) Y, M (no special M coils allowed)

PLF Falling / trailing (PuLse Falling) edge pulse

PLF

Program example:

X0 PLS M0 SET X1 PLF M1 RST Y0 M1 Y0 M0

0 1 3 4 5 6 8 9

LD PLS LD SET LD PLF LD RST

X M M Y X M M Y

0 0 0 0 1 1 1 0

Basic points to remember: - When a PLS instruction is executed, object devices Y and M operate for one operation cycle after the drive input signal has turned ON. - When a PLF instruction is executed, object devices Y and M operate for one operation cycle after the drive input signal has turned OFF.

X0 X1 M0 M1 Y0 t msec

- When the PLC status is changed from RUN to STOP and back to RUN with the input signals still ON, PLS M0 is operated again. However, if an M coil which is battery backed (latched) was used instead of M0 it would not re-activate. For the battery backed device to be re-pulsed, its driving input (ex. X0) must be switched OFF during the RUN/STOP/RUN sequence before it will be pulsed once more.

2-20

FX Series Programmable Controllers

Basic Program Instructions 2

2.18

Inverse
Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

INV (Inverse)

Invert the current result of the internal PLC operations

N/A

Program example:

X0 PLS M0 SET X1 PLF M1 RST Y0 M1 Y0 M0

0 1 3 4 5 6 8 9

LD PLS LD SET LD PLF LD RST

X M M Y X M M Y

0 0 0 0 1 1 1 0

Basic points to remember: - The INV instruction is used to change (invert) the logical state of the current ladder network at the inserted position. - Usage is the same as for AND and ANI; see earlier.

Usages for INV


Use the invert instruction to quickly change the logic of a complex circuit. It is also useful as an inverse operation for the pulse contact instructions LDP, LDF, ANP, etc.

2-21

FX Series Programmable Controllers

Basic Program Instructions 2

2.19

No Operation
Mnemonic Function Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

NOP No operation or (No Operation) null step Basic points to remember:

N/A

N/A

- Writing NOP instructions in the middle of a program minimizes step number changes when changing or editing a program. - It is possible to change the operation of a circuit by replacing programmed instructions with NOP instructions. - Changing a LD, LDI, ANB or an ORB instruction with a NOP instruction will change the circuit considerably; quite possibly resulting in an error being generated. - After the program all clear operation is executed, all of the instructions currently in the program are over written with NOPs.

2-22

FX Series Programmable Controllers

Basic Program Instructions 2

2.20

End
Mnemonic Function Forces the current program scan to end Format

FX1S

FX1N

FX2N

FX2NC

Devices

Program steps

END (END)

END

N/A

Basic points to remember: - Placing an END instruction in a program forces that program to end the current scan and carry out the updating processes for both inputs and outputs. - Inserting END instructions in the middle of the program helps program debugging as the section after the END instruction is disabled and isolated from the area that is being checked. Remember to delete the END instructions from the blocks which have already been checked. - When the END instruction is processed the PLCs watchdog timer is automatically refreshed.

A program scan:
A program scan is a single processing of the loaded program from start to finish, This includes updating all inputs, outputs and watchdog timers. The time period for one such process to occur is called the scan time. This will be dependent upon program length and complexity. Immediately the current scan is completed the next scan begins. The whole process is a continuous cycle. Updating of inputs takes place at the beginning of each scan while all outputs are updated at the end of the scan.

2-23

FX Series Programmable Controllers

Basic Program Instructions 2

MEMO

2-24

FX Series Programmable Controllers

STL Programming 3

1 2 3 4 5 6 7 8 9 10 11

Introduction Basic Program Instructions STL Programming Devices in Detail Applied Instructions Diagnostic Devices Instruction Execution Times PLC Device Tables Assigning System Devices Points of Technique Index

FX Series Programmable Controllers

STL Programming 3

Chapter Contents 3. STL Programming .................................................................................3-1


3.1 What is STL, SFC And IEC1131 Part 3? ............................................................. 3-1 3.2 How STL Operates .............................................................................................. 3-2
3.2.1 Each step is a program ............................................................................................. 3-2

3.3 How To Start And End An STL Program ............................................................. 3-3


3.3.1 Embedded STL programs ......................................................................................... 3-3 3.3.2 Activating new states................................................................................................. 3-3 3.3.3 Terminating an STL Program .................................................................................... 3-4

3.4 Moving Between STL Steps ................................................................................ 3-5


3.4.1 Using SET to drive an STL coil ................................................................................. 3-5 3.4.2 Using OUT to drive an STL coil ................................................................................. 3-6

3.5 Rules and Techniques For STL programs........................................................... 3-7


3.5.1 Basic Notes On The Behavior Of STL programs....................................................... 3-7 3.5.2 Single Signal Step Control ........................................................................................ 3-9

3.6 3.7 3.8 3.9 3.10 3.11

Restrictions Of Some Instructions When Used With STL.................................. 3-10 Using STL To Select The Most Appropriate Program ....................................... 3-11 Using STL To Activate Multiple Flows Simultaneously...................................... 3-12 General Rules For Successful STL Branching .................................................. 3-14 General Precautions When Using The FX-PCS/AT-EE Software ..................... 3-15 Programming Examples .................................................................................... 3-16

3.11.1 A Simple STL Flow .................................................................................................. 3-16 3.11.2 A Selective Branch/ First State Merge Example Program....................................... 3-18

3.12 Advanced STL Use............................................................................................ 3-20

FX Series Programmable Controllers

STL Programming 3

3.

STL Programming

FX1S

FX1N

FX2N

FX2NC

This chapter differs from the rest of the contents in this manual as it has been written with a training aspect in mind. STL/SFC programming, although having been available for many years, is still misunderstood and misrepresented. We at Mitsubishi would like to take this opportunity to try to correct this oversight as we see STL/SFC programming becoming as important as ladder style programming.

3.1

What is STL, SFC And IEC1131 Part 3?


The following explanation is very brief but is designed to quickly outline the differences and similarities between STL, SFC and IEC1131 part 3. In recent years Sequential Function Chart (or SFC) style programming (including other similar styles such as Grafcet and Funktionplan) have become very popular through out Europe and have prompted the creation of IEC1131 part 3. The IEC1131 SFC standard has been designed to become an interchangeable programming language. The idea being that a program written to IEC1131 SFC standards on one manufacturers PLC can be easily transferred (converted) for use on a second manufacturers PLC. STL programming is one of the basic programming instructions included in all FX PLC family members. The abbreviation STL actually means STep Ladder programming. STL programming is a very simple concept to understand yet can provide the user with one of the most powerful programming techniques possible. The key to STL lies in its ability to allow the programmer to create an operational program which flows and works in almost exactly the same manner as SFC. This is not a coincidence as this programming technique has been developed deliberately to achieve an easy to program and monitor system. One of the key differences to Mitsubishis STL programming system is that it can be entered into a PLC in 3 formats. These are: ) Instruction - a word/mnemonic entry system ) Ladder - a graphical program construction method using a relay logic symbols ) SFC - a flow chart style of STL program entry (similar to SFC) Examples of these programming methods can be seen on page 2-1.

General note:
IEC1131-3: 03.1993 Programmable controllers; part 3: programming languages. The above standard is technically identical to the Euro-Norm EN61131-3: 07.1993

3-1

FX Series Programmable Controllers

STL Programming 3

3.2

How STL Operates


As previously mentioned, STL is a system which allows the user to write a program which functions in much the same way as a flow chart, this can be seen in the diagram opposite. STL derives its strength by organizing a larger program into smaller more manageable parts. Each of these parts can be referred to as either a state or a step. To help identify the states, each is given a unique identification number. These numbers are taken from the state relay devices (see page 4-6 for more details).

M8002 S0 X0 X1 S 22 X0 X1 S 26

T0

X15

S 27 T7

3.2.1

Each step is a program Each state is completely isolated from all other states within the whole program. A good way to envisage this, is that each state is a separate program and the user puts each of those programs together in the order that they require to perform their task. Immediately this means that states can be reused many times and in different orders. This saves on programming time AND cuts down on the number of programming errors encountered. A Look Inside an STL On initial inspection the STL program looks as if it is a rather basic flow diagram. But to find out what is really happening the STL state needs to be put under a microscope so to speak. When a single state is examined in more detail, the sub-program can be viewed. With the exception of the STL instruction, it will be immediately seen that the STL sub-program looks just like ordinary programming. The STL instruction is shown as a fat normally open contact. All programming after an STL instruction is only active when the associated state coil is active. The transition condition is also written using standard programming. This idea re-enforces the concept that STL is really a method of sequencing a series of events or as mentioned earlier of joining lots of sm aller programs together.
STL S 22 T0 Y22 K20 T0 SET S 27

2
S 22 T0

1 2

3-2

FX Series Programmable Controllers

STL Programming 3

Combined SFC Ladder representation Sometimes STL programs will be written in hard copy as a combination of both flow diagram and internal sub-program. (example shown below). Identification of contact states Please note the following convention is used: Normally Open contact l Normally Closed contact Common alternatives are a and b identifiers for Normally Open, Normally Closed states or often a line drawn over the top of the Normally Closed contact name is used, e.g. X000.
M8002 S0 X0 X1 S 22
Y22 Y20

X0 X1 S 26
Y26

T0

T0 K20 X15

S 27 T7

Y27 T7 K20

3.3

How To Start And End An STL Program


Before any complex programming can be undertaken the basics of how to start and more importantly how to finish an STL program need to be examined.

3.3.1

Embedded STL programs An STL style program does not have to entirely replace a standard ladder logic program. In fact it might be very difficult to do so. Instead small or even large section of STL program can be entered at any point in a p r o g r a m . O n c e t h e S T L ta s k h a s b e e n completed the program must go back to processing standard program instructions until the next STL program block. Therefore, iden tifying the s ta rt a nd en d of a n ST L program is very important.
LD OUT LD SET STL OUT LDI OUT RET LD OUT RST X000 Y004 X002 S009 S009 Y010 X003 Y006 X005 Y007 M080 Normal Ladder Program

Embedded STL Program

3.3.2

Activating new states Once an STL step has been selected, how is it used and how is the program driven? This is not so difficult, if it is considered that for an STL step to be active its associated state coil must be ON. Hence, to start an STL sequence all that has to be done is to drive the relevant state ON. There are many different methods to drive a state, for example the initial state coils could be pulsed, SET or just included in an OUT instruction. However, within Mitsubishis STL programming language an STL coil which is SET has a different meaning than one that is included in an OUT instruction.
STL Y22 S 22 T0 SET S 27 STL S 27 K20 T0

Note: For normal STL operation it is recommended that the states are selected using the SET instruction. To activate an STL step its state coil is SET ON.

3-3

FX Series Programmable Controllers

STL Programming 3

Initial Steps For an STL program which is to be activated on the initial power up of the PLC, a trigger similar to that shown opposite could be used, i.e. using M8002 to drive the setting of the initial state. The STL step started in this manner is often referred to as the initial step. Similarly, the step activated first for any STL sequence is also called the initial step.
M8002 SET S005 STL S005 X001 Y000 X000 Y011 X012 Y014 X013

3.3.3

Terminating an STL Program Once an STL program has been started the programmable controllers CPU will process all following instructions as being part of that STL program. This means that when a second program scan is started the normal instructions at the beginning of the program are considered to be within the STL program. This is obviously incorrect and the CPU will proceed to identify a programming error and disable the programmable controllers operation. This scenario may seem a little strange but it does make sense when it is considered that the STL program must return control to the ladder program after STL operation is complete. This means the last step in an STL program needs to be identified in some way. Returning to Standard Ladder This is achieved by placing a RET or RETurn instruction as the last instruction in the last STL step of an STL program block. This instruction then returns programming control to the ladder sequence.
M8002 SET S005 STL S005 X001 Y000 X000 Y011 X012 Y014 X013 RET

Note: The RET instruction can be used to separate STL programs into sections, with standard ladder between each STL program. For display of STL in SFC style format the RET instruction is used to indicate the end of a complete STL program.

3-4

FX Series Programmable Controllers

STL Programming 3

3.4

Moving Between STL Steps


To activate an STL step the user must first drive the state coil. Setting the coil has already been identified as a way to start an STL program, i.e. drive an initial state. It was also noted that using an OUT statement to driving a state coil has a different meaning to the SET instruction. These difference will now be explained:

3.4.1

Using SET to drive an STL coil SET is used to drive an STL state coil to make the step active. Once the current STL step activates a second following step, the source STL coil is reset. Hence, although SET is used to activate a state the resetting is automatic. However, if an STL state is driven by a series of standard ladder logic instructions, X000 S040 S020 i .e . n o t a p r e c e d i n g S T L s ta t e , t h e n standard programming rules apply. S020 S030 In the example shown opposite S20 is not reset even after S30 or S21 have been SET S021 driven. In addition, if S20 is turned OFF, S 3 0 w ill a ls o st o p o pe r a tin g . T h is is RST S022 because S20 has not been used as an STL state. The first instruction involving the status of S20 is a standard LoaD instruction and NOT an STL instruction. Note: If a user wishes to forcibly reset an STL step, using the RST or ZRST (FNC 40) instructions would perform this task.
X000 ZRST S21 S28

SET is used to drive an immediately following STL step which typically will have a larger STL state number than the current step. SET is used to drive STL states which occur within the enclosed STL program flow, i.e. SET is not used to activate a state which appears in an unconnected, second STL flow diagram.

3-5

FX Series Programmable Controllers

STL Programming 3

3.4.2

Using OUT to drive an STL coil This has the same operational features as using SET. However, there is one major function which SET is not used. This is to make what is termed distant jumps. OUT is used for loops and jumps If a user wishes to jump back up a program, i.e. go back to a state which has already been processed, the OUT instruction would be used with the appropriate STL state number. Alternatively the user may wish to make a large jump forwards skipping a whole section of STL programmed states.
Partial repeat S0 S 20 OUT S 21 S 22 OUT S 22 S 23 S 23 S 21 S0 S 20 Program jump

Out is used for distant jumps If a step in one STL program flow was required to trigger a step in a second, separate STL program flow the OUT instruction would be used.
STL flow 1 S0 S 20 S 21 OUT S 42 S 22 S 23 S 43 S 44 STL flow 2 S1 S 40 S 41

Note: Although it is possible to use SET for jumps and loops use of OUT is needed for display of STL in SFC like structured format.

3-6

FX Series Programmable Controllers

STL Programming 3

3.5

Rules and Techniques For STL programs


It can be seen that there are a lot of advantages to using STL style programming but there are a few points a user must be aware of when writing the STL sub-programs. These are highlighted in this section.

3.5.1

Basic Notes On The Behavior Of STL programs When an STL state becomes active its program is processed until the next step is triggered. The contents of the program can contain all of the programming items and features of a standard ladder program, i.e. LoaD, AND OR, OUT, ReSeT etc., as well as applied instructions. When writing the sub-program of an STL state, the first vertical bus bar after the STL instruction can be considered in a similar manner as the left hand bus bar of a standard ladder program. Each STL step makes its own bus bar. This means that a user, cannot use an MPS instruction directly after the STL instruction (see ), i.e. There needs to be at least a single contact before the MPS instruction. Note: Using out coils and even applied instructions immediately after an STL instruction is permitted.
1
STL S005 X001 Y000 X000 Y011 X012 Y014 X013 RET

In normal programming using dual coils is not an acceptable technique. However repetition of a coil in separate STL program blocks is allowed. This is because the user can take advantage of the STLs unique feature of isolating all STL steps except the active STL steps. This means in practice that there will be no conflict between dual coils. The example opposite shows M111 used twice in a single STL flow. Caution: The same coil should NOT be programmed in steps that will be active at the same time as this will result in the same problem as other dual coils.

S 30

M111

S 31

M112

S 32

M111

3-7

FX Series Programmable Controllers

STL Programming 3

When an STL step transfers control to the next STL step there is a period (one scan) while both steps are active. This can cause problems with dual coils; particularly timers. If timers are dual coiled care must be taken to ensure that the timer operation is completed during the active STL step. If the same timer is used in consecutive steps then it is possible that the timer coil is never deactivated and the contacts of the timer will not be reset leading to incorrect timer operation. The example opposite identifies an unacceptable use of timer T001. When control passes from S30 to S31 T001 is not reset because its coil is still ON in the new step.

K20 S 30 T001 S 31 T001 T001

K50 S 32 T001

Note: As a step towards ensuring the correct operation of the dual timers they should not be used in consecutive STL steps. Following this simple rule will ensure each timer will be reset correctly before its next operation.

As already mentioned, during the transfer between steps, the current and the selected steps will be simultaneously active for one program scan. This could be thought of as a hand over or handshaking period. This means that if a user has two outputs contained in consecutive steps which must NOT be active simultaneously they must be interlocked. A good example of this would be the drive signals to select a motors rotation direction. In the example Y11 and Y10 are shown interlocked with each other.

Y10 S 30 Y11

Y11 S 31 Y10

3-8

FX Series Programmable Controllers

STL Programming 3

3.5.2

Single Signal Step Control Transferring between active STL steps can be controlled by a single signal. There are two methods the user can program to achieve this result. Method 1 - Using locking devices
FX1S
FX1N FX2N FX2NC

In this example it is necessary to program separate locking devices, and the controlling signal must only pulse ON. This is to prevent the STL programs from running through. The example shown below identifies the general program required for this method. - S30 is activated when M0 is first pulsed ON. - The operation of M1 prevents the sequence from continuing because although M0 is ON, the transfer requirements, need M0 to be ON and M1 to be OFF. - After one scan the pulsed M0 and the lock device M1 are reset. - On the next pulse of M0 the STL step will transfer program control from S31 to the next step in a similar manner. This time using M2 as t h e lo c k d e v i c e b e c a u s e d u a l c o i ls in successive steps is not allowed.

M0 S 30 M0 M1 S 31 M0 M2 PLS M2 PLS M1

- The reason for the use of the lock devices M1 and M2 is because of the handshaking period when both states involved in the transfer of program control are ON for 1 program scan. Without the locks it would be possible to immediately skip through all of the STL states in one go! Method 2 - Special Single Pulse Flags
FX1S
FX1N FX2N FX2NC

Using the pulse contacts (LDP, LDF, ANP, etc.) and a special range of M devices (M2800 to M3071) the same result as method 1 can be achieved. The special feature of these devices prevents run through of the states, as only the first occurrence of the LDP instruction will activate. The example program below shows the necessary instructions. - Assume S50 is already active. - When X01 activates M2800, this in turn activates the LDP M2800 instruction in S50 and the flow moves on to step S51. - The LDP M2800 instruction in the transition part of S51 does not execute because this is the second occurrence of M2800 in a pulse contact. - When X01 next activates M2800, the LDP instruction in S51 is the first occurrence because S50 is now inactive. Thus, control passes to the next step in the same manner.

LAD0

X001 M2800 M2800

M2800

Do not use the step control device in a pulse contact within the main programbody.

S 50
M2800

M2800 M2800

SET SET

S51 Snn

S 51
M2800

3-9

FX Series Programmable Controllers

STL Programming 3

3.6

Restrictions Of Some Instructions When Used With STL


Although STL can operate with most basic and applied instructions there are a few exceptions. As a general rule STL and MC-MCR programming formats should not be combined. Other instruction restrictions are listed in the table below.
Basic Instructions Operational State LD, LDI, AND, ANI, OR,ORI, NOP, OUT, SET, RST, PLS,PLF "
SET S** STL

ANB, ORB, MPS,MRD, MPP

MC, MCR

Initial and general states

STL

"

Branching and merging states

Output processing

SET S**

"

"

Transfer processing

STL

STL SET S**

STL

"

Restrictions on using applied instructions Most applied instructions can be used within STL programs. Attention must be paid to the way STL isolates each non-active step. It is recommended that when applied instructions are used their operation is completed before the active STL step transfers to the next step. Other restrictions are as follows: - FOR - NEXT structures can not contain STL program blocks. - Subroutines and interrupts can not contain STL program blocks. - STL program blocks can not be written after an FEND instruction. - FOR - NEXT instructions are allowed within an STL program with a nesting of up to 4 levels. For more details please see the operational compatibility listed in the two tables on pages 7-12,7-13.

Using jump operations with STL


Although it is possible to use the program jump operations (CJ instruction) within STL program flows, this causes additional and often unnecessary program flow complications. To ensure easy maintenance and quick error finding it is recommended that users do not write jump instructions into their STL programs.

3-10

FX Series Programmable Controllers

STL Programming 3

3.7

Using STL To Select The Most Appropriate Program

FX1S

FX1N

FX2N

FX2NC

So far STL has been considered as a simple flow charting programming language. One of STLs exceptional features is the ability to create programs which can have several operating modes. For example certain machines require a selection of manual and automatic modes, other machines may need the ability to select the operation or manufacturing processes required to produce products A, B, C, or D. STL achieves this by allowing multiple program branches to originate from one STL state. Each branch is then programmed as an individual operating mode, and because each operating mode should act individually, i.e. there should be no other modes active; the selection of the program branch must be mutually exclusive. This type of program construction is called Selective Branch Programming. An example instruction program can be seen below, (this is the sub-program for STL state S20 only) notice how each branch is SET by a different contact.

S 20

Y0

X0 S 21

X1 S 31

X2 S 41

STL OUT LD SET LD SET LD SET

S Y X S X S X S

20 0 0 21 1 31 2 41

A programming construction to split the program flow between different branches is very useful but it would be more useful if it could be used with a method to rejoin a set of individual branches.

S 29 X10

Y10

S 39 X11

Y11

S 49 X12

Y12

S 50

STL OUT LD SET STL OUT LD SET STL OUT LD SET

S Y X S S Y X S S Y X S

29 10 10 50 39 11 11 50 49 12 12 50

This type of STL program construction is called a First State Merge simply because the first state (in the example S29, S39 or S49) to complete its operation will cause the merging state (S50) to be activated. It should be noticed how each of the final STL states on the different program branches call the same joining STL state.

3-11

FX Series Programmable Controllers

STL Programming 3

Limits on the number of branches


Please see page 3-14 for general notes on programming STL branches.

Notes on using the FX-PCS/AT-EE software


Please see page 3-15 for precautions when using the FX-PCS-AT/EE software.

3.8

Using STL To Activate Multiple Flows Simultaneously

FX1S

FX1N

FX2N

FX2NC

In the previous branching technique, it was seen how a single flow could be selected from a group. The following methods describe how a group of individual flows can be activated simultaneously. Applications could include vending machines which have to perform several tasks at once, e.g. boiling water, adding different taste ingredients (coffee, tea, milk, sugar) etc. In the example below when state S20 is active and X0 is then switched ON, states S21, S31 and S41 are ALL SET ON as the next states. Hence, three separate, individual, branch flows are set in motion from a single branch point. This programming technique is often called a Parallel Branch. To aid a quick visual distinction, parallel branches are marked with horizontal, parallel lines.

S 20 X0

Y0

STL OUT LD SET SET SET S 41

S Y X S S S

20 0 0 21 31 41

S 21

S 31

3-12

FX Series Programmable Controllers

STL Programming 3

When a group of branch flows are activated, the user will often either; a) Race each flow against its counter parts. The flow which completes fastest would then activate a joining function (First State Merge described in the previous section) OR b) The STL flow will not continue until ALL branch flows have completed there tasks. This is called a Multiple State Merge. An explanation of Multiple State Merge now follows below. In the example below, states S29, S39 and S49 must all be active. If the instruction list is viewed it can be seen that each of the states has its own operating/processing instructions but that also additional STL instructions have been linked together (in a similar concept as the basic AND instruction). Before state S50 can be activated the trigger conditions must also be active, in this example these are X10, X11 and X12. Once all states and input conditions are made the merging or joining state can be SET ON. As is the general case, all of the states used in the setting procedure are reset automatically.

S 29 X10 X11 X12 S 50

Y10

S 39

Y11

S 49

Y12

STL S 29 OUT Y 10 STL S 39 OUT Y 11 STL S 49 OUT Y 12 STL STL STL LD AND AND SET S S S X X X S 29 39 49 10 11 12 50

Because more than one state is being simultaneously joined with further states (some times described as a parallel merge), a set of horizontal parallel lines are used to aid a quick visual recognition.

Limits on the number of branches


Please see page 3-14 for general notes on programming STL branches.

Notes on using the FX-PCS/AT-EE software


Please see page 3-15 for precautions when using the FX-PCS-AT/EE software.

3-13

FX Series Programmable Controllers

STL Programming 3

3.9

General Rules For Successful STL Branching


For each branch point 8 further branches may be programmed. There are no limits to the number of states contained in a single STL flow. Hence, the possibility exists for a single initial state to branch to 8 branch flows which in turn could each branch to a further 8 branch flows etc. If the programmable controllers program is read/written using instruction or ladder formats the above rules are acceptable. However, users of the FX-PCS/AT-EE programming package who are utilizing the STL programming feature are constrained by further restrictions to enable automatic STL program conversions (please see page 3-15 for more details). When using branches, different types of branching /merging cannot be mixed at the same branch point. The item marked with a S are transfer condition which are not permitted.

The following branch configurations/modifications are recommended:


S 20 X0 X1 S 30 X2 X0 X3 S 50 X4 S 60 S 50 S 60 S 40 S 50 S 40 S 50 S 40 S 20 S 30 S 40 X0 S 20 X1 X0 X1 X2 S 30 S 20 S 30

Rewrite as
S 20 X0 X1 S 30 X2 X0 S 100 Dummy state
(S100) (S100)

Rewrite as
S 20 S 30 S 40 X0 S 20 X1 X0 S 102 Dummy state
(S102) (S103) (S103)

S 40

S 30

S 20

S 30

S 101 Dummy state


(S101)

S 103

Dummy state

X3 S 50

X4 S 60 S 50 S 60 S 40 S 50

X1 S 40

X2 S 50

In Instruction format...
STL LD SET STL LD SET STL LD SET STL LD AND SET LD AND SET S X S S X S S X S S S X S S X S 20 0 100 30 1 100 40 2 100 100 100 3 50 100 4 60 STL STL STL LD SET STL LD SET SET

In Instruction format...
S 20 S 30 S 40 X 0 S 101 S 101 S 101 S 50 S 60 STL LD SET STL LD SET STL LD SET SET S X S S X S S S S S 20 0 102 30 1 102 102 102 40 50 STL STL LD SET STL LD AND SET LD AND SET S S X S S S X S S X S 20 30 0 103 103 103 1 40 103 2 50

3-14

FX Series Programmable Controllers

STL Programming 3

Further recommended program changes:


S 20 S 20

Rewrite as...
X0 X1 S 21 X2 S 22 X3 X7 S 29 X6 X5 S 24 X4 S 23 X10 X11 S 25 X12 S 26 X13 X17 X14 S 27 X15 S 28 X16 X3 X7 S 29 X2 S 22 X6 X7 X0 X1 S 21 X5 S 24 X0 X4 S 23 X10 X11 S 25 X12 S 26 X13 X17 X10 X14 S 27 X15 S 28 X16 X17

Program violation!
Rewrite as...
X0 S 21 X2 S 22 X6 S 29 X3 S 24 X7 S 23 X4 S 26 S 20 X1 S 25 S 27 X5 S 28

STL LD SET SET LD SET SET

S X S S X S S

20 0 21 23 1 25 27

STL STL LD SET STL STL LD SET

S S X S S S X S

22 24 6 29 26 28 7 29

3.10

General Precautions When Using FX-PCS/AT-EE Software

FX1S

FX1N

FX2N

FX2NC

This software has the ability to program in SFC flow diagrams. As part of this ability it can read and convert existing STL programs back into SFC flows even if they were never originally programmed using the FX-PCS/AT-EE software. As an aid to allowing this automatic SFC flow generation the following rules and points should be noted: 1) When an STL flow is started it should be initialized with one of the state devices from the range S0 to S9. 2) Branch selection or merging should always be written sequentially moving from left to right. This was demonstrated on page 3-11, i.e. on the selective branch S21 was specified before S31 which was specified before S41. The merge states were programmed in a similar manner, S29 proceeded S39 which proceeded S49. 3) The total number of branches which can be programmed with the STL programming mode are limited to a maximum of 16 circuits for an STL flow. Each branch point is limited to a maximum of 8 branching flows. This means two branch points both of 8 branch flows would equal the restriction. These restrictions are to ensure that the user can always view the STL flow diagram on the computer running the FX-PCS-AT/ EE software and that when it is needed, the STL program flow can be printed out clearly.
3-15

FX Series Programmable Controllers

STL Programming 3

3.11
3.11.1

Programming Examples
A Simple STL Flow

FX1S

FX1N

FX2N

FX2NC

Loading hopper

Y12 Start button X0

Y10

Y11 Ore truck Y13

X2 Ore dischange point

X1

This simple example is an excerpt from a semi-automatic loading-unloading ore truck program. This example program has a built in, initialization routine which occurs only when the PLC is powered from OFF to ON. This is achieved by using the special auxiliary relay M8002. This activates a Zone ReSeT (ZRST is applied instruction 40) instruction which ensures all of the operational STL states within the program are reset. The program example opposite shows an M8002/ZRST example.
M8002 ZRST S21 S25

The push button X0 acts as a start button and a mode selection button. The STL state S0 is initialized with the ZRST instruction. The system waits until inputs X0 and X2 are given and Y 13 is not active. In the scenario this means the ore truck is positioned at the ore discharge point, i.e. above the position sensor X2. The ore truck is not currently discharging its load, i.e. the signal to open the trucks unloading doors (Y13) is not active and the start button (X0) has been given. Once all of the points have been met the program steps on to state S21. On this state the ore cart is moved (Y10) and positioned (X1) at the loading hopper. If the start button (X0) is pressed during this stage the ore cart will be set into a repeat mode (M2 is reset) where the ore truck is immediately returned to the loading hopper after discharging its current load. This repeat mode must be selected on every return to the loading station. Once at the loading point the program steps onto state S22. This state opens the hoppers doors (Y11) and fills the truck with ore. After a timed duration, state S23 is activated and the truck returns (Y12) to the discharge point (X2).

3-16

FX Series Programmable Controllers

STL Programming 3

Once at the discharge point the truck opens its bottom doors (Y13). After a timed duration in which the truck empties its contents, the program checks to see if the repeat mode was selected on the last cycle, i.e. M2 is reset. If M2 was reset (in state S21) the program jumps to step S21 and the ore truck is returned for immediate refilling. If M2 is not reset, i.e. it is active, the program cycles back to STL state S0 where the ore truck will wait until the start push button is given. This is a simple program and is by no means complete but it identifies the way a series of tasks have been mapped to an STL flow.
M8002 SET S 0 ZRST S 21 S 25 STL X0 X2 Y13 Y10 X0 S 22 T1 S 23 X2 S 24 T2 M2 S 25 M2 SET M2 Y13 T2 K50 STL S 23 M2 STL S 24 T2 T2 LD M8002 SET S 0 ZRST 40 S 21 S 25 STL S 0 LD X 0 AND X 2 ANI Y 13 SET S 21 STL S 21 OUT Y 10 LD X 0 RST M 2 LD SET STL OUT OUT K LD SET STL OUT LD SET STL OUT X S S Y T T S S Y X S S Y 1 22 22 11 1 70 1 23 23 12 2 24 24 13 OUT K LD ANI SET LD AND OUT STL SET LD OUT RET END T 2 50 T 2 M 2 S 25 T 2 M 2 S 0 S 25 M 2 M 2 S 21 STL S 25 M2 S 21 RET END M2 SET S 25 M2 S0 SET M 2 Y12 X2 SET S 24 Y13 K50 T2 T1 SET S 23 RST M2 Y11 T1 Y12 K70 STL S 22 S0 STL S 21 X0 RST M 2 X1 SET S 22 Y11 K70 T1 S 21 X1 SET S 21 Y10

S0 X0 X2 Y13

Identification of normally closed contacts


This example has used the line convention to identify normally closed contacts, for further variations and different methods used to perform this task please see the information note page 3-3.

3-17

FX Series Programmable Controllers

STL Programming 3

3.11.2

A Selective Branch/ First State Merge Example Program The following example depicts an automatic sorting robot. The robot sorts two sizes of ball bearings from a mixed source pool into individual storage buckets containing only one type of ball bearing.

X12 Y3

Y7 X1 X3 X4 X5

Y4

Y2 Y0

X2

Y1

X0

The sequence of physical events (from initial power On) are: 1) The pickup arm is moved to its zero-point when the start button (X12) is pressed. When the pickup arm reaches the zero-point the zero-point lamp (Y7) is lit. 2) The pickup arm is lowered (Y0) until a ball is collected (Y1). If the lower limit switch (X2) is made a small ball bearing has been collected; consequently no lower limit switch signal means a large ball bearing has been collected. Note, a proximity switch (X0) within the source pool identifies the availability of ball bearings. 3) Depending on the collected ball, the pickup arm retracts (output Y2 is operated until X3 is received) and moves to the right (Y3) where it will stop at the limit switch (X4 or X5) indicating the container required for storage. 4) The program continues by lowering the pickup arm (Y0) until the lower limit switch (X2) is reached. 5) The collected ball being is released (Y1 is reset). 6) The pickup arm is retracted (Y2) once more. 7) The pickup arm is traversed back (Y4) to the zero-point (X1).

Points to note
The Selective Branch is used to choose the delivery program for either small ball bearings or large ball bearings. Once the destination has been reached (i.e. step S24 or S27 has been executed) the two independent program flows are rejoined at step S30. The example program shown works on a single cycle, i.e. every time a ball is to be retrieved the start button (X12) must be pressed to initiate the cycle.

3-18

FX Series Programmable Controllers

STL Programming 3

Full STL flow diagram/program.

S0 X12 Y7 S 21 Start Zero-point arrival Y0 T0

This example uses the dot notation to identify normally open and normally closed contacts. Normally open contacts Normally closed contacts Lower pickup arm K20

T0 X2 S 22 T1 S 23 X3 Lower limit = small ball SET Y1 Collect ball T1 Y2 K10 Raise pickup arm

T0 X2 S 25 T1 S 26 X3 Lower limit = large ball SET Y1 Collect ball K10 T1 Y2 Raise pickup arm

Upper limit reached X4 S 24 Y3 Move to small ball bucket

Upper limit reached X5 S 27 Y3 Move to large ball bucket

X4 S 30 X2 S 31 T2 S 32 X3

X5

Y0 Lower limit reached

Lower pickup arm

RST Y1 Release ball T2 Y2 K10 Raise pickup arm

Upper limit reached X1 S 33 Y4 Return to zero-point Zero-point reached

X1

3-19

FX Series Programmable Controllers

STL Programming 3

3.12

Advanced STL Use


STL programming can be enhanced by using the Initial State Applied Instruction. This instruction has a mnemonic abbreviation of IST and a special function number of 60. When the IST instruction is used an automatic assignment of state relays, special auxiliary relays (M coils) is made. The IST instruction provides the user with a pre-formatted way of creating a multi-mode program. The modes available are: a) Automatic: - Single step - Single cycle - Continuous b) Manual: - Operator controlled - Zero return More details on this instruction can be found on page 5-85.

3-20

FX Series Programmable Controllers

Devices in Detail 4

1 2 3 4 5 6 7 8 9 10 11

Introduction Basic Program Instructions STL Programming Devices in Detail Applied Instructions Diagnostic Devices Instruction Execution Times PLC Device Tables Assigning System Devices Points of Technique Index

FX Series Programmable Controllers

Devices in Detail 4

Chapter Contents 4. Devices in Detail....................................................................................4-1


4.1 Inputs ................................................................................................................... 4-1 4.2 Outputs ................................................................................................................ 4-2 4.3 Auxiliary Relays ................................................................................................... 4-3
4.3.1 4.3.2 4.3.3 4.3.4 4.4.1 4.4.2 4.4.3 4.4.4 General Stable State Auxiliary Relays ...................................................................... 4-3 Battery Backed/ Latched Auxiliary Relays................................................................. 4-4 Special Diagnostic Auxiliary Relays .......................................................................... 4-5 Special Single Operation Pulse Relays ..................................................................... 4-5 General Stable State - State Relays ......................................................................... 4-6 Battery Backed/ Latched State Relays ...................................................................... 4-7 STL Step Relays ....................................................................................................... 4-8 Annunciator Flags ..................................................................................................... 4-9

4.4 State Relays ........................................................................................................ 4-6

4.5 Pointers ............................................................................................................. 4-10 4.6 Interrupt Pointers ............................................................................................... 4-11


4.6.1 4.6.2 4.6.3 4.6.4 Input Interrupts ........................................................................................................ 4-12 Timer Interrupts ....................................................................................................... 4-12 Disabling Individual Interrupts ................................................................................. 4-13 Counter Interrupts ................................................................................................... 4-13

4.7 Constant K ......................................................................................................... 4-14 4.8 Constant H......................................................................................................... 4-14 4.9 Timers................................................................................................................ 4-15
4.9.1 4.9.2 4.9.3 4.9.4 4.9.5 General timer operation........................................................................................... 4-16 Selectable Timers.................................................................................................... 4-16 Retentive Timers ..................................................................................................... 4-17 Timers Used in Interrupt and CALL Subroutines ................................................... 4-18 Timer Accuracy ....................................................................................................... 4-18

4.10 Counters ............................................................................................................ 4-19


4.10.1 General/ Latched 16bit UP Counters ...................................................................... 4-20 4.10.2 General/ Latched 32bit Bi-directional Counters....................................................... 4-21

4.11 High Speed Counters ........................................................................................ 4-22


4.11.1 4.11.2 4.11.3 4.11.4 4.11.5 4.11.6 4.12.1 4.12.2 4.12.3 4.12.4 4.12.5 Basic High Speed Counter Operation ..................................................................... 4-23 Availability of High Speed Counters ....................................................................... 4-24 1 Phase Counters - User Start and Reset (C235 - C240) ....................................... 4-26 1 Phase Counters - Assigned Start and Reset (C246 to C250) .............................. 4-27 2 Phase Bi-directional Counters (C246 to C250) .................................................... 4-28 A/B Phase Counters (C252 to C255) ...................................................................... 4-29 General Use Registers ............................................................................................ 4-31 Battery Backed/ Latched Registers ......................................................................... 4-32 Special Diagnostic Registers................................................................................... 4-32 File Registers .......................................................................................................... 4-33 Externally Adjusted Registers ................................................................................. 4-34

4.12 Data Registers ................................................................................................... 4-30

4.13 Index Registers.................................................................................................. 4-35


4.13.1 Modifying a Constant............................................................................................... 4-36 4.13.2 Misuse of the Modifiers ........................................................................................... 4-36 4.13.3 Using Multiple Index Registers ................................................................................ 4-36

4.14 Bits, Words, BCD and Hexadecimal .................................................................. 4-37


4.14.1 4.14.2 4.14.3 4.14.4 Bit Devices, Individual and Grouped ....................................................................... 4-37 Word Devices .......................................................................................................... 4-39 Interpreting Word Data ............................................................................................ 4-39 Twos Compliment ................................................................................................... 4-42

4.15 Floating Point And Scientific Notation ............................................................... 4-43


4.15.1 Scientific Notation.................................................................................................... 4-44 4.15.2 Floating Point Format .............................................................................................. 4-45 4.15.3 Summary Of The Scientific Notation and Floating Point Numbers.......................... 4-46

FX Series Programmable Controllers

Devices in Detail 4

4.
4.1

Devices in Detail
Inputs
Device Mnemonic: X

FX1S

FX1N

FX2N

FX2NC

Purpose: Representation of physical inputs to the programmable controller (PLC) Alias: I/P Inp (X) Input Input contact Available forms: NO () and NC () contacts only (see example device usage for references) Devices numbered in: Octal, i.e. X0 to X7, X10 to X17 Further uses: None Example device usage:

X0

X1 Y10

Available devices:
Please see the information point on page 4-2, Outputs. Alternatively refer to the relevant tables for the selected PLC in chapter 8.

Configuration details:
Please see chapter 9

4-1

FX Series Programmable Controllers

Devices in Detail 4

4.2

Outputs
Device Mnemonic: Y

FX1S

FX1N

FX2N

FX2NC

Purpose: Representation of physical outputs from the programmable controller Alias: O/P Otp Out (Y) Output (Y) Output (coil/ relay/ contact) Available forms: NO () and NC contacts and output coils () (see example device usage for references) Devices numbered in: Octal, i.e. Y0 to Y7, Y10 to Y17 Further uses: None Example device usage:

X0 Y10

X1 Y10

2 1

Available devices:
PLC FX1S FX1N FX2N FX2NC Maximum number of inputs 16 128 256 (addressable in software) Maximum number of outputs 14 128 256 (addressable in software) Absolute total available I/O 30 128 256 (Total addressed in software/hardware)

Please note, these are all the absolute maximums which are available. The values are subject to variations caused by unit selection. For configuration details please see chapter 9. For more information about the device availability for individual PLCs, please see chapter 8.

4-2

FX Series Programmable Controllers

Devices in Detail 4

4.3

Auxiliary Relays
Device Mnemonic: M Purpose: Internal programmable controller status flag Alias: Auxiliary (coil/ relay/ contact/ flag) M (coil/ relay/ contact /flag) M (bit) device

FX1S

FX1N

FX2N

FX2NC

Available forms: NO () and NC contacts and output coils () (see example device usage for references) Devices numbered in: Decimal, i.e. M0 to M9, M10 to M19 Further uses: General stable state auxiliary relays - see page 4-3 Battery backed/ latched auxiliary relays - see page 4-4 Special diagnostic auxiliary relays - see page 4-5 Example device usage:

X0 M507

X1 M507

2 1
4.3.1 General Stable State Auxiliary Relays A number of auxiliary relays are used in the PLC. The coils of these relays are driven by device contacts in the PLC in the same manner that the output relays are driven in the program. All auxiliary relays have a number of electronic NO and NC contacts which can be used by the PLC as required. Note that these contacts cannot directly drive an external load. Only output relays can be used to do this.

Available devices:
PLC General auxiliary relays Battery backed/ latched relays Total available FX1S 384 (M0 - 383) 128 (M384 - 511) 512 FX1N 384 (M0 - 383) 1152 (M384 1535) 1536 FX2N 500 (M0 - 499) 2572 (M500 3071) 3072 FX2NC 500 (M0 - 499) 2572 (M500 3071) 3072

For more information about device availability for individual PLCs, please see chapter 8.

4-3

FX Series Programmable Controllers

Devices in Detail 4

4.3.2

Battery Backed/ Latched Auxiliary Relays There are a number of battery backed or latched relays whose status is retained in battery backed or EEPROM memory. If a power failure should occur all output and general purpose relays are switched off. When operation is resumed the previous status of these relays is restored. The circuit shown on page 4-3 is an example of a self retaining circuit. Relay M507 is activated when X0 is turned ON. If X0 is turned OFF after the activation of M507, the ON status of M507 is self retained, i.e. the NO contact M507 drives the coil M507. However, M507 is reset (turned OFF) when the input X1 is turned ON, i.e. the NC contact is broken. A SET and RST (reset) instruction can be used to retain the status of a relay being activated momentarily.

X0 SET M507 X1 RST M507

External loads:
Auxiliary relays are provided with countless number of NO contact points and NC contact points. These are freely available for use through out a PLC program. These contacts cannot be used to directly drive external loads. All external loads should be driven through the use of direct (Y) outputs.

4-4

FX Series Programmable Controllers

Devices in Detail 4

4.3.3

Special Diagnostic Auxiliary Relays A PLC has a number of special auxiliary relays. These relays all have specific functions and are classified into the following two types. a) Using contacts of special auxiliary relays - Coils are driven automatically by the PLC. Only the contacts of these coils may be used by a user defined program. Examples: M8000: RUN monitor (ON during run) M8002: Initial pulse (Turned ON momentarily when PLC starts) M8012: 100 msec clock pulse b) Driving coils of special auxiliary relays - A PLC executes a predetermined specific operation when these coils are driven by the user. Examples: M8033: All output statuses are retained when PLC operation is stopped M8034: All outputs are disabled M8039: The PLC operates under constant scan mode

Available devices:
Not all PLCs share the same range, quantity or operational meaning of diagnostic auxiliary relays. Please check the availability and function before using any device. PLC specific diagnostic ranges and meanings are available in chapter 6.
FX1S
FX1N FX2N FX2NC

4.3.4

Special Single Operation Pulse Relays

When used with the pulse contacts LDP, LDF, etc., M devices in the range M2800 to M3072 have a special meaning. With these devices, only the next pulse contact instruction after the device coil is activated.
M0 to M2799
M0

M2800 to M3072
M2800

SET

M50
M0

SET

M50
M2800

1 LDP 2 LDP 3 LDP 4 LD

X0 M0 M0 M0

5 LDP 6 LDP 7 LDP 8 LD

X0 M2800 M2800 M2800

SET SET SET

M51 M52 M53

SET SET SET

M51 M52 M53

Turning ON X0 causes M0 to turn ON. Contacts , and are pulse contacts and activate for 1 scan. Contact is a normal LD contact and activates while M0 is ON.

Turning ON X0 causes M2800 to turn ON. Contact is a pulse contact and activates for 1 scan. Contacts and are pulse contacts of the same M device as contact . Contact has already operated, so contact and do not operate. Contact is a normal LD contact and activates while M2800 is ON.
4-5

FX Series Programmable Controllers

Devices in Detail 4

4.4

State Relays
Device Mnemonic: S Purpose: Internal programmable controller status flag Alias: State (coil/ relay/ contact/ flag) S (coil/ relay/ contact /flag) STL step (coil/ relay/ contact /flag) Annunciator flag

FX1S

FX1N

FX2N

FX2NC

Available forms: NO () and NC contacts and output coils () (see example device usage for references) Devices numbered in: Decimal, i.e. S0 to S9, S10 to S19 Further uses: General stable state - state relays - see page 4-6 Battery backed/ latched state relays - see page 4-7 STL step relays - see page 4-8 Annunciator flags - see page 4-9 Example device usage:

X0 S20

X1 S20

2 1
4.4.1 General Stable State - State Relays A number of state relays are used in the PLC. The coils of these relays are driven by device contacts in the PLC in the same manner that the output relays are driven in the program. All state relays have a number of electronic NO and NC contacts which can be used by the PLC as required. Note that these contacts cannot directly drive an external load. Only output relays can be used to do this.

Available devices:
Please see the information point on page 4-7 Battery backed/ latched state relays, or see the relevant tables for the selected PLC in chapter 8.

4-6

FX Series Programmable Controllers

Devices in Detail 4

4.4.2

Battery Backed/ Latched State Relays There are a number of battery backed or latched relays whose status is retained in battery backed or EEPROM memory. If a power failure should occur all output and general purpose relays are switched off. When operation is resumed the previous status of these relays is restored.

Available devices:
PLC General state relays Battery backed/ latched relays Total available FX1S N/A 128 (S0 - 127) 128 FX1N N/A 1000 (S0 - 999) 1000 FX2N 500 (S0 - 499) 500 (S500 - 999) 1000 FX2NC

For more information about device availability for individual PLCs, see chapter 8.

External loads:
State relays are provided with countless number of NO contact points and NC contact points, and are freely available for use through out a PLC program. These contacts cannot be used to directly drive external loads. All external loads should be driven through the use of direct (ex. Y) outputs.

4-7

FX Series Programmable Controllers

Devices in Detail 4

4.4.3

STL Step Relays St a t e s ( S ) a r e v e r y i m p o r t a n t d e v i c e s w h e n programming step by step process control. They are used in combination with the basic instruction STL. When all STL style programming is used certain states have a pre-defined operation. The step identified as in the figure opposite is called an initial state. All other state steps are then used to build up the full STL function plan. It should be remembered that even though remaining state steps are used in an STL format, they still retain their general or latched operation status. The range of available devices is as specified in the information point of the previous section.
1 X0

S2

S20
X1

Y0

S21
X2

Y1

S22
X3

Y2

Assigned states:
When the applied instruction IST (Initial STate function 60) is used, the following state devices are automatically assigned operations which cannot be changed directly by a users program: S0 S1 S2 S10 to S19 : Manual operation initial state : Zero return initial state : Automatic operation initial state : Allocated for the creation of the zero return program sequence

Monitoring STL programs:


To monitor the dynamic-active states within an STL program, special auxiliary relay M8047 must be driven ON.

STL/SFC programming:
For more information on STL/SFC style programming, please see chapter 3.

IST instruction:
For more information on the IST instruction please FNC 60 in Chapter 5.

4-8

FX Series Programmable Controllers

Devices in Detail 4

4.4.4

Annunciator Flags

FX1S

FX1N

FX2N

FX2NC

Some state flags can be used as outputs for external diagnosis (called annunciation) when certain applied instructions are used. These instructions are; ANS function 46: Annunciator Set - see page 5-61 ANR function 47: Annunciator Reset - see page 5-61 When the annunciator function is used the controlled state flags are in the range S900 to S999 (100 points). By programming an external diagnosis circuit as shown below, and monitoring special data register D8049, the lowest activated state from the annunciator range will be displayed. Each of the states can be assigned to signify an error or fault condition. As a fault occurs the associated state is driven ON. If more than one fault occurs simultaneously, the lowest fault number will be displayed. When the active fault is cleared the next lowest fault will then be processed. This means that for a correctly prioritized diagnostic system the most dangerous or damaging faults should activate the lowest state flags, from the annunciator range. All state flags used for the annunciator function fall in the range of battery backed/ latched state registers. Monitoring is enabled by driving special auxiliary relay M8049 ON. State S900 is activated if input X0 is not driven within one second after the output Y0 has been turned ON. State S901 is activated when both inputs X1 and X2 are OFF for more than two seconds. If the cycle time of the controlled machine is less than ten seconds, and input X3 stays ON, state S902 will be set ON if X4 is not activated within this machine cycle time. If any state from S900 to S999 is activated, i.e. ON, special auxiliary relay M8048 is activated to turn on failure indicator output Y10. The states activated by the users error / failure diagnosis detection program, are turned OFF by activating input X5. Each time X5 is activated, the active annunciator states are reset in ascending order of state numbers.

M8000 M8049 Y0 X0 FNC46 ANS T0 K10 S900 FNC46 ANS T1 K20 S901 FNC46 ANS T2 K100 S902

X1

X2

X3

X4

M8048 Y10 X5 FNC47 ANR (P)

4-9

FX Series Programmable Controllers

Devices in Detail 4

4.5

Pointers
Device Mnemonic: P Purpose: Program flow control Alias: Pointer Program Pointer P

FX1S

FX1N

FX2N

FX2NC

Available forms: Label: appears on the left of the left hand bus bar when the program is viewed in ladder mode. Devices numbered in: Decimal, i.e. P0 to P9, P10 to P19 Further uses: Can be used with conditional jump statements (CJ function 00) - see page 5-5 and item on the example device usage diagram. Can be used with call statements - see page 5-7 and item on the example device usage diagram Example device usage:

X20 X20 CJ P0 2 1 P0 P1 FEND CALL P1

SRET

Available devices:
FX1S PLCs have 64 pointers; available from the range of P0 to P63. FX1N, FX2N and FX2NC PLCs have 128 pointers; available from the range of P0 to P127.

Jumping to the end of the program:


When using conditional jump instructions (CJ, function 00) the program end can be jumped to automatically by using the pointer P63 within the CJ instruction. Labelling the END instruction with P63 is not required.

Device availability:
For more information about device availability for individual PLCs, please see chapter 8.

4-10

FX Series Programmable Controllers

Devices in Detail 4

4.6

Interrupt Pointers
Device Mnemonic: I Purpose: Interrupt program marker Alias: Interrupt High speed interrupt I

FX1S

FX1N

FX2N

FX2NC

Available forms: Label: appears on the left of the left hand bus bar when the program is viewed in ladder mode (see in the example device usage diagram). Devices numbered in: Special numbering system based on interrupt device used and input triggering method Further uses: Input interrupts - see page 4-12 Timer interrupts - see page 4-12 Disabling interrupts - see page 4-13 Counter interrupts - see page 4-13 Example device usage:

FEND I101

1 IRET END

Additional applied instructions:


Interrupts are made up of an interrupt device, an interrupt pointer and various usage of three, dedicated interrupt applied instructions; - IRET function 03: interrupt return - EI function 04: enable interrupt - DI function 05: disable interrupt

Nested levels:
While an interrupt is processing all other interrupts are disabled. To achieve nested interrupts the EI-DI instruction must be programmed within an interrupt routine. Interrupts can be nested for two levels.

Pointer position:
Interrupt pointers may only be used after an FEND instruction (first end instruction, function 06).

4-11

FX Series Programmable Controllers

Devices in Detail 4

4.6.1

Input Interrupts Identification of interrupt pointer number: I q 0 q 0: interrupt triggered on trailing/ falling edge of input signal 1: interrupt triggered on leading/ rising edge of input signal Input number; each input number can only be used once. FX1S has 4 points (0 to 3 which map to X0 to X3) Other units have 6 points (0 to 5 which map to X0 to X5) Example: I001 The sequence programmed after the label (indicated by the I001 pointer) is executed on the leading or rising edge of the input signal X0. The program sequence returns from the interruption program when an IRET instruction is encountered.

Rules of use:
The following points must be followed for an interrupt to operate; - Interrupt pointers cannot have the same number in the 100s position, i.e. I100 and I101 are not allowed. - The input used for the interrupt device must not coincide with inputs already allocated for use by other high speed instructions within the user program.

4.6.2

Timer Interrupts Identification of interrupt pointer number: I q q q

FX1S

FX1N

FX2N

FX2NC

10 to 99 msec: the interrupt is repeatedly triggered at intervals of the specified time. Timer interrupt number 3 points (6 to 8) Example: I610 The sequence programmed after the label (indicated by the I610 pointer) is executed at intervals of 10msec. The program sequence returns from the interruption program when an IRET instruction is encountered.

Rules of use:
The following points must be followed for an interrupt to operate; - Interrupt pointers cannot have the same number in the 100s position, i.e. I610 and I650 are not allowed.

4-12

FX Series Programmable Controllers

Devices in Detail 4

4.6.3

Disabling Individual Interrupts Individual interrupt devices can be temporarily or permanently disabled by driving an associated special auxiliary relay. The relevant coils are identified in the tables of devices in chapter 6. However for all PLC types the head address is M8050, this will disable interrupt I0oo.

Driving special auxiliary relays:


Never drive a special auxiliary coil without first checking its use. Not all PLCs assign the same use to the same auxiliary coils.

Disabling high speed counter interrupts


These interrupts can only be disabled as a single group by driving M8059 ON. Further details about counter interrupts can be found in the following section.

4.6.4

Counter Interrupts Identification of interrupt pointer number: I 0 q 0

FX1S

FX1N FX2N FX2NC

Counter interrupt number 6 points (1 to 6). Counter interrupts can be entered as the output devices for High Speed Counter Set (HSCS, FNC 53). To disable the Counter Interrupts Special Auxiliary Relay M8059 must be set ON. Example:

M8000 DHSCS K100 C255 I030

The sequence programmed after the label (indicated by the I030 pointer) is executed once t h e v a lu e o f H i g h S p e e d C o u n te r C 2 5 5 reac hes/equa ls th e prese t limit of K 100 identified in the example HSCS.

Additional notes:
Please see the following pages for more details on the HSSC applied instruction. - High Speed Counter Set, HSCS FNC 53.

4-13

FX Series Programmable Controllers

Devices in Detail 4

4.7

Constant K
Device Mnemonic: K Purpose: Identification of constant decimal values Alias: Constant K (value/ constant) K

FX1S

FX1N

FX2N

FX2NC

Available forms: Numeric data value, when used for 16bit data, values can be selected from the range -32,768 to +32,767 For 32bit data, values from the range -2,147,483,648 to + 2,147,483,647 can be used. Devices numbered in: N/A. This device is a method of local instruction data entry. There is no limit to the number of times it can be used. Further uses: K values can be used with timers, counters and applied instructions Example device usage: N/A

4.8

Constant H
Device Mnemonic: H Purpose: Identification of constant hexadecimal values Alias: Constant H (value/ constant) Hex (value/ constant) H

FX1S

FX1N

FX2N

FX2NC

Available forms: Alpha-numeric data value, i.e. 0 to 9 and A to F (base 16). When used for 16bit data, values can be selected from the range 0 to FFFF. For 32bit data, values from the range 0 to FFFFFFFF can be used. Devices numbered in: N/A. This device is a method of local instruction data entry. There is no limit to the number of times it can be used. Further uses: Hex values can be used with applied instructions Example device usage: N/A

4-14

FX Series Programmable Controllers

Devices in Detail 4

4.9

Timers
Device Mnemonic: T Purpose: Timed durations Alias: Timer(s) T

FX1S

FX1N

FX2N

FX2NC

Available forms: A driven coil sets internal PLC contacts (NO and NC contacts available). Various timer resolutions are possible, from 1 to 100 msec, but availability and quantity vary from PLC to PLC. The following variations are also available:Selectable timer resolutions - see page 4-16 Retentive timers - see page 4-17 Timers used in interrupt and CALL subroutines - see page 4-18 Devices numbered in: Decimal, i.e T0 to T9, T10 to T19. Further uses: None Example device usage:

X0 T20 K123

Available devices:
Timer Resolution 100 msec 10 msec 1 msec Retentive 1 msec Retentive 100 msec FX1S 63 (T0 - 62) \ 31 (T32 - 62) 1 (T63) N/A N/A FX1N FX2N 200 (T0 - 199) 46 (T200 - 245) N/A 4 (T246 - 249) 6 (T250 - 255) FX2NC

Selectable timers taken from the main range of 100 msec timers, see page 4-16.

Timer accuracy:
See page 4-18.

4-15

FX Series Programmable Controllers

Devices in Detail 4

4.9.1

General timer operation Timers operate by counting clock pulses (1, 10 and 100 msec). The timer output contact is activated when the count data reaches the value set by the constant K. The overall duration or elapsed time, for a timers operation cycle, is calculated by multiplying the present value by the timer resolution, i.e. A 10 msec timer with a present value of 567 has actually been operating for: 567 10 msec 567 0.01 sec = 5.67 seconds Timers can either be set directly by using the constant K to specify the maximum duration or indirectly by using the data stored in a data register (ex. D). For the indirect setting, data registers which are battery backed/ latched are usually used; this ensures no loss of data during power down situations. If however, the voltage of the battery used to perform the battery backed service, reduces excessively, timer malfunctions may occur.

4.9.2

Selectable Timers

FX1S

FX1N

FX2N

FX2NC

On certain programmable controllers, driving a special auxiliary coil redefines approximately half of the 100 msec timers as 10 msec resolution timers. The following PLCs and timers are subject to this type of selection. - For FX1S, driving M8028 ON, timers T32 to 62 (31 points) are changed to 10 msec resolution.

Driving special auxiliary coils:


Please check the definition of special auxiliary coils before using them. Not all PLCs associate the same action to the same device.

4-16

FX Series Programmable Controllers

Devices in Detail 4

4.9.3

Retentive Timers

FX1S

FX1N

FX2N

FX2NC

A retentive timer has the ability to retain the currently reached present value even after the drive contact has been removed. This means that when the drive contact is re-established a retentive timer will continue from where it last reached. Because the retentive timer is not reset when the drive contact is removed, a forced reset must be used. The following diagram shows this in a graphical format.

Non-retentive timer operation X0 T20 K123 T20 Y0

Retentive timer operation X1 T250 K345 T250 Y1 X2 RST T250

1.23 s X0 Present value X1

t1

t2

t1 + t2 = 34.5s

Present value

Y0

Y1 X2

Using timers in interrupt or CALL subroutines:


Please see page 4-18.

Available devices:
Please see the information table on page 4-15.

4-17

FX Series Programmable Controllers

Devices in Detail 4

4.9.4

Timers Used in Interrupt and CALL Subroutines

FX1S

FX1N

FX2N

FX2NC

If timers T192 to T199 and T246 to T249 are used in a CALL subroutine or an interruption routine, the timing action is updated at the point when an END instruction is executed. The output contact is activated when a coil instruction or an END instruction is processed once the timers current value has reached the preset (maximum duration) value. Timers other than those specified above cannot function correctly within the specified circumstances. When an interrupt timer (1 msec resolution) is used in an interrupt routine or within a CALL subroutine, the output contact is activated when the first coil instruction of that timer is executed after the timer has reached its preset (maximum duration) value. 4.9.5 Timer Accuracy Timer accuracy can be affected by the program configuration. That is to say, if a timer contact is used before its associated coil, then the timer accuracy is reduced. The following formulas give maximum and minimum errors for certain situations. However, an average expected error would be approximately; 1.5 The program scan time Condition 1: The timer contact appears after the timer coil.

X10 T0 T0 Y10

Maximum timing error: 2 Scan time + The input filter time Minimum timing error: Input filter time - The timer resolution Condition 2: The timer contact appears before the timer coil.

T0 Y10 X10 T0

Maximum timing error: 3 Scan time + The input filter time Minimum timing error: Input filter time- The timer resolution

Internal timer accuracy:


The actual accuracy of the timing elements within the PLC hardware is; 10 pulses per million pulses. This means that if a 100 msec timer is used to time a single day, at the end of that day the timer will be within 0.8 seconds of the true 24 hours or 86,400 seconds. The timer would have processed approximately 864,000; 100 msec pulses.

4-18

FX Series Programmable Controllers

Devices in Detail 4

4.10

Counters
Device Mnemonic: C Purpose: Event driven delays Alias: Counter(s) C

FX1S

FX1N

FX2N

FX2NC

Available forms: A driven coil sets internal PLC contacts (NO and NC contacts available). Various counter resolutions are possible including; General/latched 16bit up counters - see page 4-20 General/latched 32bit bi-directional counters - see page 4-21 (The availability and use of all these counters is PLC specific - please check availability before use) Devices numbered in: Decimal, i.e C0 to C9, C10 to C19 Further uses: None Example device usage:

X1 C12 K345 X2 RST C12

Available devices:
Counter Resolution General 16bit up counter Latched 16bit up counter General 32bit bi-directional counter Latched 32bit bi-directional counter FX1S FX1N FX2N FX2NC

16 (C0 - 15) 16 (C16 - 31) N/A N/A

16 (C0 - 15) 184 (C16 - 199)

100 (C0 - 99) 100 (C100 - 199) 20 (C200 - 219) 15 (C220 - 234)

High speed counters:


For high speed counters please see page 4-22.

Setting ranges for counters:


16bit and 32bit up counters:1 to +32,767 32bit bi-directional counters: -2,147,483,648 to +2,147,483,647

4-19

FX Series Programmable Controllers

Devices in Detail 4

4.10.1

General/ Latched 16bit UP Counters The current value of the counter increases each time coil C0 is turned ON by X11. The output contact is activated when the coil is turned ON for the tenth time (see diagram). After this, the counter data remains unchanged when X11 is turned ON. The counter current value is reset to 0 (zero) when the RST instruction is executed by turning ON X10 in the example. The output contact Y0 is also reset at the same time. Counters can be set directly using constant K or indirectly by using data stored in a data register (ex. D). In an indirect setting, the d es ig n a ti o n o f D 10 f o r e x am pl e , w h ic h contains the value 123 has the same effect as a setting of K123. If a value greater than the counter setting is written to a current value register, the counter counts up when the next input is turned ON. This is true for all types of counters. Generally, the count input frequency should be around several cycles per second.
X10 RST C0 X11

C0
C0 K10 Y0

X10 X11
8 9 10

Y0

Battery backed/latched counters:


Counters which are battery backed/ latched are able to retain their status information, even after the PLC has been powered down. This means on re-powering up, the latched counters can immediately resume from where they were at the time of the original PLC power down.

Available devices:
Please see the information table on page 4-19.

4-20

FX Series Programmable Controllers

Devices in Detail 4

4.10.2

General/ Latched 32bit Bi-directional Counters

FX1S

FX1N

FX2N

FX2NC

The counter shown in the example below, activates when its coil is driven, i.e. the C200 coil is driven. On every occasion the input X14 is turned from OFF to ON the current value or current count of C200 is incremented.

X12 Up counting

Up counting Down counting

X13

X14 X12 M8200

Counters present value


0

X13
2 3 4 5 4

RST C200
3 2 1

X14
0 -1 -2 0

C200 C200 K-5 Y1

-3

Y1 turned ON

If output is already

-4

-5

-6

-7

-8

-7

-6

-5

-4

-3

The output coil of C200 is set ON when the current value increases from -6 to -5. However, if the counters value decreases from -5 to -6 the counter coil will reset. The counters current value increases or decreases independently of the output contact state (ON/OFF). Yet, if a counter counts beyond +2,147,483,647 the current value will automatically change to -2,147,483,648. Similarly, counting below -2,147,483,648 will result in the current value changing to +2,147,483,647. This type of counting technique is typical for ring counters. The current value of the active counter can be rest to "0" (zero) by forcibly resetting the counter coil; in the example program by switching the input X13 ON which drives the RST instruction. The counting direction is designated with special auxiliary relays M8200 to M8234.

Battery backed/ latched counters:


Counters which are battery backed/ latched are able to retain their status information, even after the PLC has been powered down. This means on re-powering up, the latched counters can immediately resume from where they were at the time of the original PLC power down.

Available devices:
Please see the information table on page 4-19.

Selecting the counting direction:


If M8PPP for CPPP is turned ON, the counter will be a down counter. Conversely, the counter is an up counter when M8PPP is OFF.

4-21

FX Series Programmable Controllers

Devices in Detail 4

4.11

High Speed Counters


Device Mnemonic: C Purpose: High speed event driven delays Alias: Counter (s) C High speed counter (s) Phase counters

FX1S

FX1N

FX2N

FX2NC

Available forms: A driven coil sets internal PLC contacts (NO and NC contacts available). There are various types of high speed counter available but the quantity and function vary from PLC to PLC. Please check the following sections for device availability; FX1S and FX1N - see page 4-24 FX2N and FX2NC - see page 4-25 The following sections refer to counter types; 1 phase bi-directional counters (user start and reset) - see page 4-29 1 phase counters bi-directional (assigned start and reset) - see page 4-30 1 phase two input bi-directional counters - see page 4-31 A/B phase counters - see page 4-32 Devices numbered in: Decimal, i.e C235 to C255 Further uses: None Example device usage: For examples on each of the available forms please see the relevant sections.

Basic high speed counter operation:


For information on basic high speed counters please see page 4-23.

4-22

FX Series Programmable Controllers

Devices in Detail 4

4.11.1

Basic High Speed Counter Operation Although counters C235 to C255 (21 points) are all high speed counters, they share the same range of high speed inputs. Therefore, if an input is already being used by a high speed counter, it cannot be used for any other high speed counters or for any other purpose, i.e as an interrupt input. The selection of high speed counters are not free, they are directly dependent on the type of counter required and which inputs are available. Available counter types; a) 1 phase bi-directional with user start/reset: C235 to C240 b) 1 phase bi-directional with assigned start/reset: C241 to C245 c) 1 phase two input bi-directional: C246 to C250 d) A/B phase type: C251 to C255 Please note ALL of these counters are 32bit devices. High speed counters operate by the principle of interrupts. This means they are event triggered and independent of cycle time. The coil of the selected counter should be driven continuously to indicate that this counter and its associated inputs are reserved and that other high speed processes must not coincide with them. Example: When X20 is ON, high speed counter C235 is selected. The counter C235 corresponds to count input X0. X20 is NOT the counted signal. This is the continuous drive mentioned earlier. X0 does not have to be included in the program. The input assignment is hardware related and cannot be changed by the user.

X20 X20 C235 K4789 C236 D4

When X20 is OFF, coil C235 is turned OFF and coil C236 is turned ON. Counter C236 has an assigned input of X1, again the input X20 is NOT the counted input. The assignment of counters and input devices is dependent upon the PLC selected. This is explained in the relevant, later sections.

Driving high speed counter coils:


The counted inputs are NOT used to drive the high speed counter coils. X0 This is because the counter coils C235 need to be continuously driven ON K4789 X1 to reserve the associated high speed C236 inputs. D4 Therefore, a normal non-high speed drive contact should be used to drive the high speed counter coil. Ideally the special auxiliary contact M8000 should be used. However, this is not compulsory.

4-23

FX Series Programmable Controllers

Devices in Detail 4

4.11.2

Availability of High Speed Counters The following device table outlines the range of available high speed counters.
I N P U T 1 Phase counter user start/reset C235 C236 U/D U/D U/D U/D U/D C237 C238 C239 C240 1 Phase counter assigned start/reset C241 C242 C243 C244 C245

FX1S

FX1N

FX2N

FX2NC

2 Phase counter bi-directional C246 C247 C248 C249 C250

A/B Phase counter C251 C252 C253 C254 C255

X0 U/D X1 X2 X3 X4 X5 X6 X7

U/D R U/D R U/D R

U/D R U/D R

U D

U D R U D R

U D R U D R S S

A B

A B R A B R

A B R A B R S S

S S

Key:

C235

U - up counter input D - down counter input R - reset counter (input) S - start counter (input) A - A phase counter input B - B phase counter input - Counter is backed up/latched

Input assignment:
X6 and X7 are also high speed inputs, but function only as start signals. They cannot be used as the counted inputs for high speed counters. Different types of counters can be used at the same time but their inputs must not coincide. For example, if counter C247 is used, then the following counters and instructions cannot be used; C235, C236, C237, C241, C242, C244, C245, C246, C249, C251, C252, C254, I0oo, I1oo, I2oo.

Counter Speeds:
General counting frequencies: - Single phase and bi-directional counters; up to 10 kHz. - A/B phase counters; up to 5 kHz. - Maximum total counting frequency (A/B phase counter count twice) FX1S & FX1N 60kHz, FX2N & FX2NC 20kHZ. For FX2N & FX2NC Inputs X0 and X1 are equipped with special hardware that allows higher speed counting as follows: - Single phase or bi-directional counting (depending on unit) with C235, C236 or C246; up to 60 kHz. - Two phase counting with C251; up to 30 kHz.

4-24

FX Series Programmable Controllers

Devices in Detail 4

If any high speed comparison instructions (FNCs 53, 54, 55) are used, X0 and X1 must resort to software counting. In this case, please see the table below:
Unit FX2N & FX2NC FX1S & FX1N Function Number 53 or 54 55 53 or 54 Max. Combined Signal Frequency 11 kHz 5.5 kHz 30 kHz

Calculating the maximum combined counting speed on FX1S:


This is calculated as follows:(2 phase counter speed x number of counted edges) : (the sum of the speeds of the active 1 phase counters).

4-25

FX Series Programmable Controllers

Devices in Detail 4

4.11.3

1 Phase Counters - User Start and Reset (C235 - C240) These counters only use one input each. When direction flag M8235 is ON, counter C235 counts down. When it is OFF, C235 counts up. When X11 is ON, C235 resets to 0 (zero). All contacts of the counter C235 are also reset. When X12 is ON, C235 is selected. From the previous counter tables, the corresponding counted input for C235 is X0. C235 therefore counts the number of times X0 switches from OFF to ON.

X10 M8235 X11 RST C235 X12 C235 K1234

Device specification:
All of these counters are 32bit up/down ring counters. Their counting and contact operations are the same as normal 32bit up/down counters described on page 4-21. When the counters current value reaches its maximum or setting value, the counters associated contacts are set and held when the counter is counting upwards. However, when the counter is counting downwards the contacts are reset.

Setting range:
-2,147,483,648 to +2,147,483,647

Direction setting:
The counting direction for 1 phase counters is dependent on their corresponding flag M8PPP; where PPP is the number of the corresponding counter, (C235 to C240). When M8PPP is ON the counter counts down, When M8PPP is OFF the counter counts up.

Using the SPD instruction:


Care should be taken when using the SPD applied instruction (FNC 56). This instruction has both high speed counter and interrupt characteristics, therefore input devices X0 through X5 may be used as the source device for the SPD instruction. In common with all high speed processes the selected source device of the SPD instruction must not coincide with any other high speed function which is operating, i.e. high speed counters or interrupts using the same input. When the SPD instruction is used it is considered by the system to be a 1 phase high speed counter. This should be taken into account when summing the maximum combined input signal frequencies - see the previous section.

4-26

FX Series Programmable Controllers

Devices in Detail 4

4.11.4

1 Phase Counters - Assigned Start and Reset (C241 to C245) These counters have one countable input and 1 reset input each. Counters C244 and C245 also have a start input. X13 M8245 When the direction flag M8245 is ON, C245 counts down. When it is OFF C245 will count X14 up. RST C245 When X14 is ON, C245 resets in the same X15 manner as normal internal 32bit counters, but C245 C245 can also be reset by input X3. This is D0 assigned automatically when counter C245 is used (see previous counter tables). Counter C245 also has an external start contact, again automatically assigned. This is actually input X7. Once again this data can be found on the previous counter tables. When X7 is ON, C245 starts counting, conversely when X7 is OFF C245 stops counting. The input X15 selects and reserves the assigned inputs for the selected counter, i.e. in this case C245. The reason why these counters use assigned start (X7) and reset (X3) inputs is because they are not affected by the cycle (scan) time of the program. This means their operation is immediate and direct. In this example C245 actual counts the number of OFF to ON events of input X2. Note: Because C245 is a 32bit counter, its setting data, specified here by a data register also has to be of a 32bit format. This means that data registers D1 and D0 are used as a pair to provide the 32bit data format required.

Device specification:
All of these counters are 32bit up/down ring counters. Their counting and contact operations are the same as normal 32bit up/down counters described on page 4-21. When the counters current value reaches its maximum or setting value, the counters associated contacts are set and held when the counter is counting upwards. However, when the counter is counting downwards the contacts are reset.

Setting range:
-2,147,483,648 to +2,147,483,647

Direction setting:
The counting direction for 1 phase counters is dependent on their corresponding flag M8PPP; where PPP is the number of the corresponding counter, (C241 to C245). - When M8PPP is ON the counter counts down. - When M8PPP is OFF the counter counts up.

4-27

FX Series Programmable Controllers

Devices in Detail 4

4.11.5

2 Phase Bi-directional Counters (C246 to C250) These counters have one input for counting up and one input for counting down. Certain counters also have reset and start inputs as well. When X10 is ON, C246 resets in the same way as standard 32bit counters. Counter C246 uses inputs; X0 to count up and X1 to count down For any counting to take place the drive input X11 must be ON to set and reserve the assigned inputs for the attached counter, i.e. C246. Note: X0 moving from OFF to ON will increment C246 by one X1 moving from ON to OFF will decrement C246 by one Bi-directional counter C250 can be seen to have X5 as its reset input and X7 as its start X13 input. Therefore, a reset operation can be C250 made externally without the need for the RST K1234 C250 instruction. X13 must be ON to select C250. But start input X7 must be ON to allow C250 to actually count. If X7 goes OFF counting ceases. Counter C250 uses input X3 to count up and input X4 to count down.

X10 RST C246 X11 C246 D2

Device size:
All of these counters have 32bit operation.

Setting range:
-2,147,483,648 to +2,147,483,647

Direction setting:
The counting direction for 1 phase counters is dependent on their corresponding flag M8PPP; where PPP is the number of the corresponding counter, (C241 to C245). - When M8PPP is ON the counter counts down, - When M8PPP is OFF the counter counts up.

4-28

FX Series Programmable Controllers

Devices in Detail 4

4.11.6

A/B Phase Counters (C252 to C255) With these counters only the input identified in the previous high speed counter tables can be used for counting. The counting performed by these devices is independent of the program cycle (scan) time. Depending on the counter used, start, reset and other associated inputs are automatically allocated. The A phase, B phase input signal not only provide the counted signals but their relationship to each other will also dictate the counted direction. While the wave form of the A phase is in the ON state and... the B phase moves from OFF to ON the counter will be counting up. However, if... the B phase moves from ON to OFF the counter will be in a down configuration. One count is registered after both A and B phase inputs have been given and released in the correct order.

Up-count A-phase

B-phase Down-count A-phase

B-phase

C251 counts the ON/OFF events of input X0 (the A phase input) and input X1 (the B phase input) while X11 is ON. C255 starts counting immediately when X7 is turned ON while X13 is ON. The counting inputs are X3 (A phase) and X4 (B phase). C255 is reset when X5 is turned ON. It can also be reset with X12 in the sequence.

X10 RST C251 X11 X12 X13 C255 D0 C251 K1234 RST C255

Device specification:
A maximum of 2 points - 2 phase, 32bit, up/down counters can be used. The operation of the output contact in relation to the counted data is the same as standard 32bit counters described in section 4.11.

Setting range:
-2,147,483,648 to +2,147,483,647

Direction setting:
Check the corresponding special relay M8PPP to determine if the counter is counting up or down.

4-29

FX Series Programmable Controllers

Devices in Detail 4

4.12

Data Registers
Device Mnemonic: D

FX1S

FX1N

FX2N

FX2NC

Purpose: A storage device capable of storing numeric data or 16/32bit patterns Alias: Data (register/ device/ word) D (register) D Word Available forms: General use registers - see page 4-34 Battery backed/latched registers - see page 4-35 Special diagnostic registers - see page 4-35 File registers - see page 4-36 RAM file registers - see page 4-36 Externally adjusted registers - see page 4-37 Devices numbered in: Decimal, i.e. D0 to D9, D10 to D19 Further uses: Can be used in the indirect setting of counters and timers Example device usage: None

Available devices:
FX1S General use registers Latched registers Diagnostic registers File registers R Adjustable registers F 128 (D0 - 127) 128 (D128 - 255) FX1N 128 (D0 - 127) 7872 (D128 - 7999) FX2N 200 (D0 - 199) 7800 (D200 - 7999) FX2NC 200 (D0 - 199) 7800 (D200 - 7999)

256 256 256 256 (D8000 - 8255) (D8000 - 8255) (D8000 - 8255) (D8000 - 8255) N/A 7000 7000 7000 (D1000 - 7999) (D1000 - 7999) (D1000 - 7999) N/A N/A

2 2 (D8030 - 8031) (D8030 - 8031)

R - These devices are allocated by the user at the expense of available program steps. On FX2N and FX2NC these devices are a subset of the latched registers. F - These devices are also included under the count for diagnostic registers.

4-30

FX Series Programmable Controllers

Devices in Detail 4

4.12.1

General Use Registers Data registers, as the name suggests, store data. The stored data can be interpreted as a numerical value or as a series of bits, being either ON or OFF. A single data register contains 16bits or one word. However, two consecutive data registers can be used to form a 32bit device more commonly known as a double word. If the contents of the data register is being considered numerically then the Most Significant Bit (MSB) is used to indicate if the data has a positive or negative bias. As bit devices can only be ON or OFF, 1 or 0 the MSB convention used is, 0 is equal to a positive number and 1 is equal to a negative number.

D0 1 2 D1 0: 1:

MSB - Most Significant Bit D0

0: 1:

MSB - Most Significant Bit

The diagram above shows both single and double register configurations. In the diagram, at point , it should be noted that the lower register D0 no longer has a Most Significant Bit. This is because it is now being considered as part of a 32bit-double word. The MSB will always be found in the higher 16 bits, i.e. in this case D1. When specifying a 32 bit data register within a program instruction, the lower device is always used e.g. if the above example was to be written as a 32bit instructional operand it would be identified as D0. The second register, D1, would automatically be associated. Once the data is written to a general data register, it remains unchanged until it is overwritten. When the PLC is turned from RUN to STOP all of the general data registers have their current contents overwritten with a 0 (zero).

Data retention:
Data can be retained in the general use registers when the PLC is switched from RUN to STOP if special auxiliary relay M8033 is ON.

Data register updates:


Writing a new data value to a data register will result in the data register being updated with the new data value at the end of the current program scan.

4-31

FX Series Programmable Controllers

Devices in Detail 4

4.12.2

Battery Backed/ Latched Registers Once data is written to a battery backed register, it remains unchanged until it is overwritten. When the PLCs status is changed from RUN to STOP, the data in these registers is retained. The range of devices that are battery backed can be changed by adjusting the parameters of the PLC. For details of how to do this please refer to the appropriate programming tools manual.

Using the FX2-40AW/AP:


When using an FX with either the FX2-40AW or the FX2-40AP a proportion of the latched data registers are automatically assigned for communications use by the FX2-40AW/AP module. Communication between Master and Slave 100 points M800 to M899 10 points D490 to D499 Communication between Slave and Master 100 points M900 to M999 10 points D500 to D509

4.12.3

Special Diagnostic Registers Special registers are used to control or monitor various modes or devices inside the PLC. Data written in these registers are set to the default values when the power supply to the PLC is turned ON. - Note: When the power is turned ON, all registers are first cleared to 0 (zero) and then the default values are automatically written to the appropriate registers by the system software. For example, the watchdog timer data is written to D8000 by the system software. To change the setting, the user must write the required value over what is currently stored in D8000. Data stored in the special diagnostic registers will remain unchanged when the PLC is switched from STOP mode into RUN.

Use of diagnostic registers:


On no account should unidentified devices be used. If a device is used, it should only be for the purpose identified in this manual. Please see chapter 6 for tables containing data and descriptions of the available devices for each PLC.

4-32

FX Series Programmable Controllers

Devices in Detail 4

4.12.4

File Registers Program memory registers

FX1S

FX1N

FX2N

FX2NC

File registers can be secured in the program memory (EEPROM or EPROM) in units of 500 points. These registers can be accessed with a peripheral device. While the PLC is operating, data in the file registers can be read to the general-use/ battery backed/ latched registers by using the BMOV instruction. File registers are actually setup in the parameter area of the PLC. For every block of 500 file registers allocated and equivalent block of 500 program steps are lost. Note: The device range for file registers in the FX1N, FX2N and FX2NC overlaps with the latched data registers. The allocation of these devices as file registers ensures that the data is kept with the program.

Writing to file registers:


FX1S file register data can only be changed by a personal computer running the appropriate software. For details of how to carry out the changes please reference the relevant operation manual for guidance. FX1N, FX2N and FX2NC file register data can also be changed by the PLC program using the BMOV instruction.

Special caution when using FX1S:


No file registers can be modified during RUN.

Available devices:
Please refer to chapters 6 and 8, where further details of the available devices can be found.

4-33

FX Series Programmable Controllers

Devices in Detail 4

4.12.5

Externally Adjusted Registers The FX1S and FX1N have built in setting po ts w h ich a re us e d t o a d jus t t he Setting pot co n te n ts of ce r ta in d e d ic a te d da ta registers. The contents of these registers of an FX1S can range from 0 to 255. This is a built in feature and requires no additional setup or programming. RUN The FX 2N and FX 2NC do not have this feature, however, an additional special function unit is available which provides STOP the same function. The unit required is the FX 2N -8AV-BD. For use, this unit requires the applied instructions VRRD function 85 (Volume Read) and VRSC function 86 (Volume Scale).
FX1S Number of setting pots FX1N FX2N FX2NC 2 points, plus 8 points: Supplied by using 8 points: Supplied by using the the additional special function additional special function board board FX2N-8AV-BD FX2N-8AV-BD 1: D8030 2: D8031 Additional 8 points selected by the user when applied instructions VRRD and VRSC are used. Selected by the user when applied instructions VRRD and VRSC are used.

Number of controlled data registers

Uses:
This facility is often used to vary timer settings, but it can be used in any application where a data register is normally found, i.e. setting counters, supplying raw data, even selection operations could be carried out using this option.

4-34

FX Series Programmable Controllers

Devices in Detail 4

4.13

Index Registers
Device Mnemonic: V,Z Purpose: To modify a specified device by stating an offset. Alias: (V/ Z) Register Index (register/ addressing/ modifier) Offset(s) (register/ addressing/ modifier) Indices Modifier Available forms: For 16bit data V or Z (2 devices) For 32bit data V and Z combined (1 device - Z is specified) Operation is similar to data registers.

FX1S

FX1N

FX2N

FX2NC

16 Bit V

16 Bit Z

32 Bit V Z

Devices numbers:

16 devices V0 - V7 and Z0 - Z7

Further uses: Can be used to modify the following devices under certain conditions; X, Y, M, S, P, T, C, D, K, H, KnX, KnY, KnM, KnS Example device usage: The program shown right transfers data from D5V to D10Z. If the data contained in register V is equal to 8 and the data in register Z is equal to 14, then: V=8 D5V D5 +8 =13 D13 Z = 14 D10Z D10 + 14 = 24 D24 Hence, the actual devices used after the modifiers V and Z have been taken into account are; D13 and D24 and not D5 and D10 respectively.

Use of Modifiers with Applied Instruction Parameters:


All applied instruction parameters should be regarded as being able to use index registers to modify the operand except where stated otherwise.

4-35

FX Series Programmable Controllers

Devices in Detail 4

4.13.1

Modifying a Constant Constants can be modified just as easily as data registers or bit devices. If, for example, the constant K20 was actually written K20V the final result would equal: K20 + the contents of V Example: K If V = 3276 then K20V V 20 (3276) 3296

4.13.2

Misuse of the Modifiers Modifying Kn devices when Kn forms part of a device description such as KnY is not possible, i.e. while the following use of modifiers is permitted; K3Z K1M10V Y20Z Statements of the form: K4ZY30 are not acceptable. Modifiers cannot be used for parameters entered into any of the 20 basic instructions, i.e. LD, AND, OR etc.

4.13.3

Using Multiple Index Registers T h e u s e o f m u lt i p l e in d e x r e g i s t e r s i s sometimes necessary in larger programs or programs which handle large quantities of data. There is no problem from the PLC s point of view in using both V and Z registers many times through out a program. The point to be aware of is that it is sometimes confusing for the user or a maintenance person reading such programs, as it is not always clear what the current value of V or Z is. Example: V = 10 (K10) Z = 20 (K20) D5V = D15 (D5 + V = D5 + 10 = D15) D15Z = D35 (D15 + Z = D15 + 20 = D35) D40Z = D60 (D40 + Z = D40 + 20 = D60)

X0 MOV K10 X1 MOV K20 X2 ADD D 5V D 15Z D40Z M8000 MOV X3 DADD D 0 D 2 D 4Z K0 V Z V

Both V and Z registers are initially set to K10 and K20 respectively. The contents of D15 is added to that of D35 and store in D60. V is then reset to 0 (zero) and both V and Z are used in the double word addition (DADD). The contents of D1, D0 are then added to D3, D2 and then finally stored in D25, D24.

4-36

FX Series Programmable Controllers

Devices in Detail 4

4.14

Bits, Words, BCD and Hexadecimal

FX1S

FX1N

FX2N

FX2NC

The following section details general topics relating to good device understanding. The section is split into several smaller parts with each covering one topic or small group of topics. Some of the covered topics are; Bit devices, individual and grouped Word devices Interpreting word data Twos compliment - see page 4-40 - see page 4-42 - see page 4-42 - see page 4-45

Available devices:
For PLC specific available devices please see chapter 8.

4.14.1

Bit Devices, Individual and Grouped Devices such as X, Y, M and S are bit devices. Bit devices are bi-stable, this means there are only two states, ON and OFF or 1 and 0. Bit devices can be grouped together to form bigger representations of data, for example 8 consecutive bit devices are some-times referred to as a byte. Further more, 16 consecutive bit devices are referred to as a word and 32 consecutive bit devices are a double word. The PLC identifies groups of bit devices which should be regarded as a single entity by looking for a range marker followed by a head address. This is of the form KnP where P represents the head address of the bit devices to be used. The Kn portion of the statement identifies the range of devices enclosed. n can be a number from the range 0 to 8. Each n digit actual represents 4 bit devices, i.e K1 = 4 bit devices and K8 = 32 bit devices. Hence all groups of bit devices are divisible by 4. The diagram and example on the following page explain this idea further........

4-37

FX Series Programmable Controllers

Devices in Detail 4

Assigning grouped bit devices: As already explained, bit devices can be grouped into 4 bit units. The n in KnM0 defines the number of groups of 4 bits to be combined for data operation. K1 to K4 are allowed for 16bit data operations but K1 to K8 are valid for 32bit operations. K2M0, for example identifies 2 groups of 4 bits; M0 to M3 and M4 to M7, giving a total of 8 bit devices or 1 byte. The diagram below identifies more examples of KnP use.
X37 X36 X35 X34 X33 X32 X31 X30 X16 X15 X14 X13 X12 X11 X10 X7 X6 X5 X4 X3 X2 X1 X0

0 1 0 0 0 1 0

0 0 1 1 0 1 0 0 1 1 0 1 1 0 K1X6 K3X0 K8X0 K1X0

K1X0 K1X6 K3X0 K8X0

: : : :

X0 to X3 4 bit devices with a head address of X0 X6 to X11 4 bit devices with a head address of X6 X0 to X13 12 bit devices with a head address of X0 X0 to X37 32 bit devices with a head address of X0

Moving grouped bit devices:


If a data move involves taking source data and moving it into a destination which is smaller than the original source, then the overflowing source data is ignored. For example; If K3M20 is moved to K1M0 then only M20 to M23 or K1M20 is actually moved. The remaining data K2M24 or M24 to M31 is ignored.

Assigning I/O:
Any value taken from the available range of devices can be used for the head address marker of a bit device group. However, it is recommended to use a 0 (zero) in the lowest digit place of X and Y devices (X0, X10, X20.....etc). For M and S devices, use of a multiple of 8 is the most device efficient. However, because the use of such numbers may lead to confusion in assigning device numbers, it recommended to use a multiple of 10. This will allow good correlation to X and Y devices.

4-38

FX Series Programmable Controllers

Devices in Detail 4

4.14.2

Word Devices Word devices such as T, C, D, V and Z can store data about a particular event or action within the PLC. For the most part these devices are 16 bit registers. However, certain variations do have 32 bit capabilities, as can pairs of consecutive data registers or combined V and Z registers. It may seem strange to quote the size of a word device in bits. This is not so strange when it is considered that the bit is the smallest unit of data within the PLC. So by identifying every thing in bit format a common denomination is being used, hence comparison etc is much easier. Additional consequences of this bit interpretation is that the actual data can be interpreted differently. The physical pattern of the active bits may be the important feature or perhaps the numerical interpretation of the bit pattern may be the key to the program. It all comes down to how the information is read.

4.14.3

Interpreting Word Data As word data can be read in many ways the significance of certain parts of the word data can change. PLCs can read the word data as: - A pure bit pattern - A decimal number - A hexadecimal number - Or as a BCD (Binary Coded Decimal) number The following examples will show how the same piece of data can become many different things depending wholly on the way the information is read or interpreted. a) Considering a bit pattern The following bit pattern means nothing - it is simply 16 devices which have two states. Some of the devices are randomly set to one of the states. However, if the header notation (base 2) is added to the 16 bit data the sum, decimal, total of the active bits can be calculated, e.g.,

1 0 0 1 1 1 1 0 0 1 1 1 0 1 0 1

MSB 214 213 212 211 210 29 28 27 26 25 24 23 22 21 20 1 0 0 1 1 1 1 0 0 1 1 1 0 1 0 1


Decimal value = Decimal value = (20 x 1) + (22 x 1) + (24 x 1) + (25 x 1) +(25 x 1) + (29 x 1) + (210 x 1) + (211 x 1) + (212 x 1) 7797

This is in fact incorrect! There is one bit device which has been shaded in. If its header notation is studied carefully it will be noted that it says MSB. This is the Most Significant Bit. This single bit device will determine if the data will be interpreted as a positive or negative number. In this example the MSB is equal to 1. This means the data is negative. The answer however, is not -7797.

4-39

FX Series Programmable Controllers

Devices in Detail 4

The reason this is not -7797 is because a negative value is calculated using two s compliment (described later) but can quickly be calculated in the following manner: Because this is a negative number, a base is set as -32768. This is the smallest number available with 16bit data. To this the positive sum of the active bits is added, i.e. -32768 + 7797. The correct answer is therefore -24971. Remember this is now a decimal representation of the original 16 bit - bit pattern. If the original pattern was re-assessed as a hexadecimal number the answer would be different. b) A hexadecimal view Taking the same original bit pattern used in point a) and now adding a hexadecimal notation instead of the binary (base 2) notation the bit patterns new meaning becomes:
1 0 0 1 1 1 1 0 0 1 1 1 0 1 0 1

8 1

4 0

2 0

1 1

8 1

4 1

2 1

1 0

8 0

4 1

2 1

1 1

8 0

4 1

2 0

1 1

Hexadecimal value = ((1 x 8) + (1 x 1)), ((1 x 8) + (1 x 4) + (1 x 2)), ((1 x 4) + (1 x 2) + (1 x 1)), ((1 x 4) + (1 x 1)) Hexadecimal value = 9E75 Two things become immediately obvious after a hexadecimal conversion. The first is that there is sign bit as hexadecimal numbers are always positive. The second is there is an "E" appearing in the calculated data. This is actually acceptable as hexadecimal counts from 0 to 15. But as there are only ten digits (0 to 9), substitutes need to be found for the remaining base 16 numbers, i.e. 10, 11, 12, 13, 14 and 15. The first six characters from the alphabet are used as the replacement indices, e.g. A to F respectively. As a result of base 16 counting, 4 binary bits are required to represent one base 16 or hexadecimal number. Hence, a 16 bit data word will have a 4 digit hexadecimal code. There is actually a forth interpretation for this bit sequence. This is a BCD or Binary Coded Decimal reading. The following section converts the original bit pattern into a BCD format.

4-40

FX Series Programmable Controllers

Devices in Detail 4

c) ABCD conversion Using the original bit pattern as a base but adding the following BCD headers allows the conversion of the binary data into a BCD format.
1 0 0 1 1 1 1 0 0 1 1 1 0 1 0 1

8 1

4 0

2 0

1 1

8 1

4 1

2 1

1 0

8 0

4 1

2 1

1 1

8 0

4 1

2 0

1 1

Binary Coded Decimal value= ERROR!!!!! It will be noticed that this will produce an ERROR. The conversion will not be correct. This is because BCD numbers can only have values from 0 to 9, but the second block of 4 bit devices from the left would have a value of 14. Hence, the error. The conversion process is very similar to that of hexadecimal except for the mentioned limit on values of 0 to 9. If the other blocks were converted just as an example the following values would be found; Extreme Left Hand Block= ((1 8) + (1 1)) = 9 Second Right Hand Block= ((1 4) + (1 2) + (1 1)) = 7 Extreme Right Hand Block= ((1 4) + (1 1)) = 5 BCD data is read from left to right as a normal number would be read. Therefore, in this example the 9 would actually represent 9000. The second right hand block is actually 70 not 7. The units are provided by the extreme right hand block, i.e. 5. The hundreds 100s would have been provided by the second left hand block (which is in error). It is also important to note that there is no sign with BCD converted data. The maximum number allowable for a single data word is 9999 and the minimum is 0000. Word Data Summary In each of the previous cases the original bit pattern had a further meaning. To recap the three new readings and the original bit pattern,

Decimal Hexadecimal BCD

: : :

-24971 9E75 Error (9?75)

Each meaning is radically different from the next yet they are all different ways of describing the same thing. They are in fact all equal to each other!

4-41

FX Series Programmable Controllers

Devices in Detail 4

4.14.4

Twos Compliment Programmable controllers, computers etc, use a format called 2 s compliment. This is a mathematical procedure which is more suited to the micro processors operational hardware requirements. It is used to represent negative numbers and to perform subtraction operations. The procedure is very simple, in the following example 15 - 7 is going to be solved: Step1: Find the binary values (this example uses 8 bits) 15 = 00001111 7 = 00000111 Step2: Find the inversion of the value to be subtracted. Procedure: invert all 1s to 0s and all 0s to 1s. 7 = 00000111 Inverted 7 = 11111000 Step3: Add 1 to the inverted number. Procedure: add 1 to the right hand most bit. Remember this is binary addition hence, when a value of 2 is obtained 1 is moved in to the next left hand position and the remainder is set to 0 (zero); Inverted7 Additional1 Answer 11111000 00000001 11111001

This result is actually the same as the negative value for 7 i.e. -7. Step4: Add the answer to the number the subtraction is being made from (i.e. 15). Procedure: Remember 1+1 = 0 carry 1 in base 2 (binary). Original value15 00001111 11111001 Answer found in step3 Solution (1) 00001000 The (1) is a carried 1 and is ignored as this example is only dealing with 8 bits. Step 5: Convert the answer back. 00001000 = 8 The answer is positive because the MSB (the most left hand bit) is a 0 (zero). If a quick mental check is made of the problem it is indeed found that 15-7 = 8. In fact no subtraction has taken place. Each of the steps has either converted some data or performed an addition. Yet the answer is correct 15 - 7 is 8. This example calculation was based on 8 bit numbers but it will work equally well on any other quantity of bits.

4-42

FX Series Programmable Controllers

Devices in Detail 4

4.15

Floating Point And Scientific Notation

FX1S

FX1N

FX2N

FX2NC

PLCs can use many different systems and methods to store data. The most common have already been discussed in previous sections e.g. BCD, Binary, Decimal, Hex. These are what is known as integer formats or whole number formats. As the titles suggest these formats use only whole numbers with no representation of fractional parts. However, there are two further formats which are becoming increasingly important and they are: a) Floating point and b) Scientific notation Both of these formats are in fact closely related. They both lend themselves to creating very large or very small numbers which can describe both whole and fractional components.

General note:
Sometimes the words Format, Mode and Notation are interchanged when descriptions of these numerical processes are made. However, all of these words are providing the same descriptive value and as such users should be aware of their existence.

Some useful constants


2 /4 2 The speed of light Gravity, g e 3.141 5 100 6.283 5 100 7.853 5 10-1 9.869 5 100 2.997 5 108 m/s 9.807 5 100 m/s2 2.718 5 100 -1.8297 5 102 C 0.00 5 100 C 1.00 5 10-2 C 1.00 5 102 C

Fixed points: Boiling point of liquid oxygen Melting point of ice Triple point of water Boiling point of water

4-43

FX Series Programmable Controllers

Devices in Detail 4

4.15.1

Scientific Notation This format could be called the step between the integer formats and the full floating point formats. In basic terms Scientific Notation use two devices to store information about a number or value. One device contains a data string of the actual characters in the number (called the mantissa), while the second device contains information about the number of decimal places used in the number (called the exponent). Hence, Scientific Notation can accommodate values greater/smaller than the normal 32 bit limits, i.e. -2,147,483,648 to 2,147,483,647 where Scientific Notation limits are; Maximums 9999 5 1035 -9999 5 1035 Minimums 9999 5 10-41 -9999 5 10-41

Scientific Notation can be obtained by using the BCD, or EBCD in FX2N, instruction (FNC 18 or FNC 118) with the float flag M8023 set ON. In this situation floating point format numbers are converted by the BCD instruction into Scientific Notation - see page 5-22 for details. When using the FX2N the INT instruction (FNC 129) can be used. Scientific Notation can be converted back to floating point format by using the BIN instruction (FNC 19) with the float flag M8023 set ON - see page 5-22 for details. The following points should be remembered about the use of Scientific Notation within appropriate FX units; The mantissa and exponent are stored in consecutive data registers. Each part is made up of 16 bits and can be assigned a positive or negative value indicated by the value of the most significant bit (MSB, or bit 15 of the data register) for each number.

EXPONENT Data Register D+1


b15 b0 b15

MANTISSA Data Register D


b0

The mantissa is stored as the first 4 significant figures without any rounding of the number, i.e. a floating point number of value 2.34567 5 103 would be stored as a mantissa of 2345 at data register D and an exponent of 0 (zero) at data register D+1. The range of available mantissa values is 0, 1000 to 9999 and -1000 to -9999. The range of available exponent values is +35 through to -41. Scientific format cannot be used directly in calculations, but it does provide an ideal method of displaying the data on a monitoring interface.

Sign bit (MSB) 1= Negative 0 = Positive

Sign bit (MSB) 1= Negative 0= Positive

4-44

FX Series Programmable Controllers

Devices in Detail 4

4.15.2

Floating Point Format Floating point format extends the abilities and ranges provided by Scientific Notation with the ability to represent fractional portions of whole numbers, for example; Performing and displaying the calculation of 22 divided by 7 would yield the following results: a) Normal FX operation using decimal (integers) numbers would equal 3 remainder 1 b) In floating point it would equal 3.14285 (approximately) c) In Scientific format this calculation would be equal to 3142 5 10 -3 So it can be seen that a greater degree of accuracy is provided by floating point numbers, i.e. through the use of larger numerical ranges and the availability of more calculable digits. Hence, calculations using floating point data have some significant advantages. Decimal data can be converted in to floating point by using the FLT, float instruction (FNC 49). When this same instruction is used with the float fag M8023 set ON, floating point numbers can be converted back to decimal. see page 5-49 for more details. The following points should be remembered about the use of Floating Point within appropriate FX units; Floating point numbers, no matter what numerical value, will always occupy two consecutive data registers (or 32 bits). Floating point values cannot be directly monitored, as they are stored in a special format recommended by the I.E.E.E (Institute of Electrical and Electronic Engineers) for personal and micro computer applications. Floating point numbers have both mantissa and exponents (see Scientific Notation for an explanation of these terms). In the case of floating point exponents, only 8 bits are used. Additionally there is a single sign bit for the mantissa. The remaining bits of the 32 bit value, i.e. 23 bits, are used to describe the mantissa value.
FX Data Register Contruction b15 Data register 'D+1' (16 bits) b0 b15 Exponet (8 bits) Sign bit Data register 'D' (16 bits) b0

Mantissa (23 bits) Floating Point Format

Valid ranges for floating point numbers as used in FX Main Processing Units:
Description Sign Exponent (bit pattern) 11111110 00000001 00000000 Mantissa (bit pattern) Remark

Normal Float 0 or 1

11111111111111111111111 Largest number +/- 3.403 51038 11111111111111111111110 Accuracy: 7 significant figures 00000000000000000000001 Smallest number +/- 1.175 510-38 00000000000000000000000 00000000000000000000000 All digits are 0 (zero)

Zero

0 or 1

4-45

FX Series Programmable Controllers

Devices in Detail 4

4.15.3

Summary Of The Scientific Notation and Floating Point Numbers The instruction needed to convert between each number format are shown below in a diagrammatically format for quick and easy reference.

View as either integer of hexadecimal Perform all mathematical operations as normal (M8023 OFF)

Use to view the mantissa and exponent of a floating point number as integer values

Integers (16 or 32 bit) (Data registers)

Perform all mathematical operations using the special floating point instructions using double word format (DEADD, DESUB, DEMUL, DEDIV, DESQR, etc.)

Scientific Notation (2 16 bit)

FLT

(FNC

49)

EB

CD

(F

NC

11

8)
(F NC 11

9)

INT (

EB

IN

FNC

129)

Floating Point Numbers (1 32 bit)

4-46

You might also like