# MACHINE CONTROLLER CP-9200SH PROGRAMMING MANUAL This Programming Manual provides descriptions on the programming language which is essential for preparing the software for the Machine Controller CP-9200SH. In this manual, "CP-717" refers to Control Pack CP-717, which is one of the peripheral devices. Listed below are other documents relevant to the CP-9200SH. Please refer to these materials also. #### ■ Relevant Documents | Document No. | Name of Document | | | | |---------------|--------------------------------------------------------------------------|--|--|--| | SIE-C873-16.4 | SIE-C873-16.4 FDS System Installation Manual | | | | | SIE-C877-17.4 | Control Pack CP-717 Operation Manual (Vol.1) | | | | | SIE-C877-17.5 | Control Pack CP-717 Operation Manual (Vol.2) | | | | | TOE-C877-17.7 | TOE-C877-17.7 Control Pack CP-717 Instructions | | | | | CHE-C879-40 | CP-9200SH Brochure | | | | | KAE-C879-40 | CP-9200SH Catalog | | | | | SIE-879-40.1 | SIE-879-40.1 Machine Controller CP-9200SH User's Manual | | | | | SIE-879-40.2 | SIE-879-40.2 Machine Controller CP-9200SH Servo Controller User's Manual | | | | ## **TABLE OF CONTENTS** | 1 | INT:<br>1.1 | RODUCTION TO PROGRAMMING ———————————————————————————————————— | = 1-1 | |---|-------------|-------------------------------------------------------------------------|---------------| | 2 | нтв | | = 2-1 | | | 2.1 | | - <i>4</i> -1 | | | 2.2 | | | | | ۵.2 | 2.2.1 Execution Control of Parent Drawings 2-3 | | | | | 2.2.2 Scheduling of the Execution of Scan Process Drawings 2-3 | | | | 2.3 | | | | | 2.0 | 2.3.1 Execution of Drawings 2-4 | | | | | 2.3.2 Execution of Process of Drawings 2-5 | | | | 2.4 | | | | | 4.7 | 2.4.1 Function Definition 2-6 | | | | | 2.4.2 User Function Preparation Procedure 2-7 | | | 3 | REC | GISTER MANAGEMENT METHOD | = 3.1 | | Ū | 3.1 | | - 0-1 | | | | Data Types 3-3 | | | | 3.3 | | | | | 0.0 | 3.3.1 DWG Registers 3-5 | | | | | 3.3.2 Function Registers 3-6 | | | | | 3.3.3 CPU Internal Registers 3-6 | | | | | 3.3.4 Subscripts i and j 3.7 | | | | | (1) When a Subscript is Attached to Bit Type Data 3-7 | | | | | (2) When a Subscript is Attached to Integer Type Data 3-7 | | | | | (3) When a Subscript is Attached to Double-Length Integer Type Data 3-7 | | | | | (4) When a Subscript is Attached to Real Number Type Data 3-7 | | | | | (5) Example of Program Using a Subscript 3-7 | | | | | 3.3.5 Function I/O and Function Registers 3-8 | | | | | 3.3.6 Programs and Register Referencing Ranges 3-9 | | | | 3.4 | | | | | | 3.4.1 Symbol Management in the DWG's 3-10 | | | | | 3.4.2 Symbol Management in the Functions 3-10 | | | | 3.5 | Upward Linking of Symbols and Automatic Number Allocation 3-11 | | | | 0.0 | 3.5.1 Upward Linking of Symbols 3-11 | | | | | 3.5.2 Automatic Register Number Allocation 3-11 | | | | | | | | 4 | | SIC INSTRUCTIONS — | = 4-1 | | | | Instruction with [] 4-3 | | | | 4.2 | Program Control Instructions 4-4 | | | | | 4.2.1 Child Drawing Referencing Instruction (SEE) 4-4 | | | | | 4.2.2 FOR Structure Statement 4-5 | | | | | 4.2.3 WHILE Structure Statement 4.6 | | | | | 4.2.4 IF Structure Statement 4-8 | | | | | (1) IF Structure Statement - 1 4-8 | | | | | (2) IF Structure Statement - 2 4-9 | | | | | 4.2.5 Function Referencing Instruction (FSTART) 4-10 | | | | | 4.2.6 Function Input Instruction (FIN) 4-11 | | | | | 4.2.7 Function Output Instruction (FOUT) 4-12 | | | | | 4.2.8 Comment Instruction (COMMENT) 4-14 | | | | 4.6 | 4.2.9 Expansion Program Execution Instruction (XCALL) 4-16 | | | | 4.3 | Direct I/O Instructions 4-17 | | | | | 4.3.1 Continuous Execution Type Direct Input Instruction (INS) 4-17 | | | | | 4.3.2 Continuous Execution Type Direct Output Instruction (OUTS) 4-19 | | ``` Sequence Circuit Instructions 4-20 4.4 NO Contact Instruction (----------------) 4-20 4.4.1 NC Contact Instruction (—//—) 4-21 Coil Instruction (—0—) 4-21 4.4.2 4.4.3 Set Coil / Reset Coil Instruction (-[S]+, -[R]+) Rising Pulse Instruction (-]- ) 4-23 4-22 4.4.4 4.4.5 Falling Pulse Instruction ( -f-) 4-24 4.4.6 On-delay Timer Instruction: Unit of measurement=0.01 seconds (-{T } ) 4-25 (-{T} ) 4-27 4.4.7 4.4.8 Off-delay Timer Instruction: Unit of measurement=0.01 seconds } ) 4-29 $ ) 4-31 On-delay Timer Instruction: Unit of measurement=1 seconds 4.4.9 Off-delay Timer Instruction: Unit of measurement=1 seconds 4.4.10 Logical Operation Instructions 4-34 4.5 AND Instruction 4 - 34 4.5.1 4.5.2 OR Instruction 4-35 4.5.3 XOR Instruction 4-35 4.6 Numerical Operation Instructions 4-36 Integer Type Entry Instruction ( ├ ) 4-36 4.6.1 Real Number Type Entry Instruction ( | ) 4.6.2 4.6.3 Storage Instruction ( ) 4-38 Addition Instruction ( + ) 4-39 Subtraction Instruction ( - ) 4-40 4.6.4 4.6.5 Extended Addition Instruction ( ++ ) 4-41 4.6.6 Extended Subtraction Instruction ( -- ) 4-42 Multiplication Instruction ( × ) 4-43 4.6.7 4.6.8 Division Instruction ( ÷ ) 4-44 4.6.9 4.6.10 MOD Instruction 4-45 REM Instruction 4.6.11 4-45 INC Instruction 4-46 4.6.12 DEC Instruction 4-47 4.6.13 Time Add Instruction (TMADD) 4-48 4.6.14 Time Subtraction Instruction (TMSUB) 4.6.15 4-49 4-50 Time Spend Instruction (SPEND) 4.6.16 4.7 Numerical Conversion Instructions 4-52 4.7.1 INV Instruction 4-52 COM Instruction 4-53 4.7.2 ABS Instruction 4.7.3 4-53 BIN Instruction 4.7.4 4-54 BCD Instruction 4-54 4.7.5 PARITY Instruction 4-55 4.7.6 ASCII Instruction 4-55 4.7.7 4.7.8 BINASC Instruction ASCBIN Instruction 4-57 4.7.9 Number Comparison Instructions 4.8 4-58 Comparison Instructions 4.8.1 4-58 Range Check Instruction (RCHK) 4-60 4.8.2 4.9 Data Operation Instructions 4-62 ROTL Instruction and ROTR Instruction 4-62 4.9.1 4.9.2 MOVB Instruction 4-63 4.9.3 MOVW Instruction 4.65 XCHG Instruction 4-66 4.9.4 SETW Instruction 4-67 4.9.5 BEXTD Instruction 4-68 4.9.6 BPRESS Instruction 4-69 4.9.7 BSRCH Instruction 4-70 4.9.8 4.9.9 SORT Instruction 4-71 SHFTL Instruction and SHFTR Instruction 4-72 4.9.10 COPYW Instruction 4-73 4.9.11 4.9.12 BSWAP Instruction 4-74 ``` | | 4.10 | Basic F | unction Instructions 4-75 | | |---|-------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | | | 4.10.1 | SQRT Instruction 4-75 | | | | | 4.10.2 | SIN Instruction 4-76 | | | | | 4.10.3 | COS Instruction 4.77 | | | | | 4.10.4 | TAN Instruction 4-78 | | | | | 4.10.5 | ASIN Instruction 4-78 | | | | | 4.10.6 | ACOS Instruction 4-78 | | | | | 4.10.7 | ATAN Instruction 4-79 | | | | | 4.10.7 | | | | | | | | | | | | 4.10.9 | LN Instruction 4-80 | | | | 4 1 1 | | LOG Instruction 4-80 | | | | 4.11 | | structions 4-81 | | | | | 4.11.1 | DZA Instruction 4-81 | | | | | 4.11.2 | DZB Instruction 4-82 | | | | | 4.11.3 | LIMIT Instruction 4-84 | | | | | 4.11.4 | PI Instruction 4-86 | | | | | 4.11.5 | PD Instruction 4-88 | | | | | 4.11.6 | PID Instruction 4-90 | | | | • | 4.11.7 | LAG Instruction 4-93 | | | | | 4.11.8 | LLAG Instruction 4-94 | | | | | 4.11.9 | FGN Instruction 4-96 | | | | | 4.11.10 | IFGN Instruction 4-98 | | | | | 4.11.11 | LAU Instruction 4-100 | | | | | 4.11.12 | SLAU Instruction 4-103 | | | | | 4.11.13 | PWM Instruction 4-107 | | | | 4.12 | Table D | ata Operation Instructions 4-108 | | | | | 4.12.1 | Block Read Instruction (TBLBR) 4-108 | | | | | 4.12.2 | Block Write Instruction (TBLBW) 4-109 | | | | | 4.12.3 | Row Search Instruction: Vertical Direction (TBLSRL) 4-110 | | | | | 4.12.4 | Column Search Instruction: Horizontal Direction (TBLSRC) 4-111 | | | | | 4.12.5 | Block Clear Instruction (TBLCL) 4-112 | | | | | 4.12.6 | Inter Table Block Transfer Instruction (TBLMV) 4-113 | | | | | 4.12.7 | Cue Table Read Instruction (QTBLR, QTBLRI) 4-114 | | | | | 4.12.8 | Cue Table Write Instruction (QTBLW, QTBLWI) 4-115 | | | | | 4.12.9 | Cue Pointer Clear Instruction (QTBLCL) 4-116 | | | | | | ( <b>4,2232</b> ) | | | 5 | SFC | PROGRA | AMMING ==================================== | = 5-1 | | | 5.1 | | ration of an SFC Program 5-2 | 0 1 | | | 5.2 | - | on of SFC 5-2 | | | | 5.3 | | stem Operation Registers 5-3 | | | | 5.4 | | wchart 5-4 | | | | 5.5 | | ion Box 5-5 | | | | 5.6 | | tput Definition Time Chart 5-6 | | | | 5.7 | | me Designation Method 5-7 | | | | 5.8 | | Out System Step Nos. 5-7 | | | | 5.9 | | ions upon Preparation of an SFC Program 5-8 | | | | 0.0 | 5.9.1 | Restrictions concerning Branching and Converging Connections 5-9 | | | | | 5.9.2 | Restriction concerning Branching and Converging Connections 5-9 | | | | | 0.0.2 | ~ · ~ · | | | | | 5.9.3 | The second of th | | | | | 5.9.4 | | | | | | ບ.ສ.4 | Restrictions concerning Subroutines 5-13 | | | | | | (1) Restrictions concerning Nesting (Depth of Macro) 5-14 | | | | | | (2) Restrictions concerning Jumping 5-15 | | | | | | (3) Restrictions concerning Branching 5-16 | | | | | | | | | | | F 0 F | (4) Restrictions concerning the Timer Transition Condition Instruction | 5-17 | | | | 5.9.5 | | 5-17 | | | 6 | TAB | BLE FORMAT PROGRAMMING | 6-1 | |---|----|---------|-----------------------------------------------------------------|-----| | | | 6.1 | Types of Table Format Programs 6-2 | | | | | 6.2 | Execution of Table Format Programs 6-3 | | | | | 6.3 | Constant Table (M Register) 6-4 | | | | | | 6.3.1 Outline of the Constant Table (M Register) 6-4 | | | | | | 6.3.2 Preparing the Constant Table (M Register) 6-5 | | | | | | (1) Defining the Constant Table (M Register) 6-5 | | | | | | (2) Inputs into the Constant Table (M Register) 6-5 | | | | | 6.4 | Constant Table (# Register) 6-6 | | | | | | 6.4.1 Outline of the Constant Table (# Register) 6-6 | | | | | | 6.4.2 Preparing the Constant Table (# Register) 6-7 | | | | | | (1) Defining the Constant Table (# Register) 6-7 | | | | | | (2) Inputs into the Constant Table (# Register) 6-7 | | | | | 6.5 | I/O Conversion Table 6-8 | | | | | 0.0 | 6.5.1 Outline of the I/O Conversion Table 6-8 | | | | | | 6.5.2 Preparing the I/O Conversion Table 6-9 | | | | | | (1) Scale Conversion Function 6-9 | | | | | | (2) Bit Signal Conversion Table 6-10 | | | | | 6.6 | Interlock Table 6-12 | | | | | | 6.6.1 Outline of the Interlock Table 6-12 | | | | | | 6.6.2 Preparing the Interlock Table 6-13 | | | | | 6.7 | Part Composition Table 6-14 | | | | | | 6.7.1 Outline of the Part Composition Table 6-14 | | | | | | 6.7.2 Preparing the Part Composition Table 6-15 | | | | | | 6.7.3 Preparing the Function Program for Parts 6-16 | | | | | 6.8 | Constant Table (C Register) 6-17 | | | | | | 6.8.1 Outline of the Constant Table (C Register) 6-17 | | | | | | 6.8.2 Preparing the Constant Table (C Register) 6-18 | | | | | | (1) Defining the Constant Table (C Register) 6-18 | | | | | | (2) Inputs into the Constant Table (C Register) 6-18 | | | _ | СШ | A D.TTD | ADD CYCMON DITAICMICAIC | _ | | 7 | ST | | ARD SYSTEM FUNCTIONS 7- | ·1 | | | | 7.1 | Data Trace Read Function (DTRC-RD) 7-2 | | | | | | 7.1.1 Readout of Data 7-3 | | | | | | 7.1.2 Configuration of the Read Data 7-4 | | | | | | (1) Data Configuration 7-4 | | | | | | (2) Record Length 7-4 | | | | | 7.0 | (3) Number of Records 7-4 | | | | | 7.2 | Trace Function (TRACE) 7-5 | | | | | 7.3 | Failure Trace Read Function (FTRC-RD) 7-6 | | | | | | 7.3.1 Data Readout (Failure Occurrence Data) 7-7 | | | | | | 7.3.2 Readout Data Configuration (Failure Occurrence Data) 7-7 | | | | | | (1) Data Configuration 7-7 | | | | | | (2) Record Configuration 7-7 | | | | | | (3) Structure of Register Designation No. (2 words) 7-7 | | | | | | (4) Number of Records 7-7 | | | | | | 7.3.3 Data Readout (Failure Restoration Data) 7-8 | | | | | | 7.3.4 Readout Data Configuration (Failure Restoration Data) 7-8 | | | | | | (1) Data Configuration 7-8 | | | | | | (2) Record Configuration 7-8 | | | | | - 4 | (3) Number of Records 7-8 | | | | | 7.4 | Inverter Trace Read Function (ITRC-RD) 7-9 | - | | | | | 7.4.1 Readout of Inverter Trace Data 7-10 | | | | | | 7.4.2 Readout Data Configuration 7-10 | | | | | | (1) Data Configuration 7-10 | | | | | | (2) Record Length 7-10 | | | | | | (3) Number of Records 7-10 | | 7.5.2 Method of Writing to an EEPROM 7-13 (1) WRITE ENTER Command (2) Program Example 7-14 7.6 Inverter Constant Read Function (ICNS-RD) 7-16 7.7 CP-213 Initial Data Setting Function (ISET-213) 7.8 Send Message Function (MSG-SND) 7-19 7.8.1 Parameters 7-20 (1) Process Result (PARAM00) (2) Status (PARM01) 7-21 (3) Called Station # (PARAM02) (4) Function Code (PARAM04) (5) Data Address (PARAM05) (6) Data Size (PARAM06) 7-23 (7) Called CPU # (PARAM07) 7 - 24(8) Coil Offset (PARAM08) 7 - 24(9) Input Relay Offset (PARAM09) (10) Input Register Offset (PARAM10) 7-24 (11) Holding Register Offset (PARAM11) 7-24 (12) For System Use (PARAM12) 7-24 (13) Relationship between the Data Address, Size and Offset (14) When Transmission Protocol is set to Non-procedural **7.8.2** Inputs 7-25(1) EXECUTE (Send Message Execution Command) 7-25 (2) ABORT (Send Message Forced Interruption Command) 7-25 (3) DEV-TYP (Transmission Device Type) 7-25 (4) PRO-TYP (Transmission Protocol) 7-25(5) CIR-NO (Circuit No.) 7-25 (6) CH-NO (Channel No.) 7-25 (7) PARAM (Set Data Head Address) 7-257.8.3 Outputs 7-26 (1) BUSY (In Process) 7-26 (2) COMPLETE (Completion of Process) 7-26 (3) ERROR (Occurrence of Error) 7-26 7.8.4 Limitations Arising from Other Companies' Communications Protocols with the CP-217IF (1) When Making a Dedicated Protocol Connection Link with the MELSEC computer 7-27 (2) When Making an OMRON Upward Linking Mode (SYSWAY) Connection 7.8.5 Program Example 7-28 Receive Message Function (MSG-RCV) 7-29 7.9 7.9.1 Parameters 7-30 (1) Process Result (PARAM00) (2) Status (PARAM01) 7-31 (3) Calling Station # (PARAM02) 7-31 (4) Function Code (PARAM04) 7-31 (5) Data Address (PARAM05) 7-31 (6) Data Size (PARAM06) 7-31 (7) Calling CPU # (PARAM07) 7-31 (8) Coil Offset (PARAM08) 7-31 (9) Input Relay Offset (PARAM09) 7-31 (10) Input Register Offset (PARAM 10) 7-32 (11) Holding Register Offset (PARAM11) 7-32 (12) Write-in Range LO (PARAM12), Write-in Range HI (PARAM13) (13) For System Use (PARAM14) 7-32 (14) When Non-procedural is set for Transmission Protocol 7-32 Inverter Constant Write Function (ICNS-WR) 7.5.1 Configuration of the Write-in Data 7.12 | 7.9.2 Inputs 7-32 | | |------------------------------------------------------------------|-----| | (1) EXECUTE (Receive Message Execution Command) 7-32 | | | (2) ABORT (Receive Message Forced Interruption Command) 7-32 | | | (3) DEV-TYP (Transmission Device Type) 7-32 | | | (4) PRO-TYP (Transmission Protocol) 7-33 | | | (5) CIR-NO (Circuit No.) 7-33 | | | (6) CH-NO (Channel No.) 7-33 | | | (7) PARAM (Set Data Head Address) 7-33 | | | 7.9.3 Outputs 7-33 | | | (1) BUSY (In Process) 7-33 | | | (2) COMPLETE (Completion of Process) 7-33 | | | (3) ERROR (Occurrence of Error) 7-33 | | | 7.9.4 Limitations Arising from Other Companies' | | | Communications Protocols with the CP-217IF 7-34 | | | (1) When Making a Dedicated Protocol | | | Connection Link with the MELSEC Computer 7-34 | | | (2) When Making an OMRON Upward Linking Mode (SYSWAY) Connection | 7-3 | | 7.9.5 'Program Example 7-35 | | | 7.10 Counter Function (COUNTER) 7-36 | | | 7.11 First-in First-out Function (FINFOUT) 7-37 | | | | | | Appendix ———————————————————————————————————— | A-1 | | A Types of Instruction Words A-2 | | | B List of Instructions A-3 | | | C Differences on Programming between CP-9200H and CP-9200SH A-16 | | # 1 INTRODUCTION TO PROGRAMMING # 1.1 Programming Languages CP-9200SH support the programming languages shown in Table 1.1. User programs can be prepared using the programming language that is optimal for the application. For details, refer to the Control Pack CP-9200SH User's Manual (SIE-C879-40.1). Table 1.1 Programming Languages that can be Used | Programming Language | Characteristics | | |-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Ladder program | <ul> <li>Programs are prepared using relay circuit instructions and text type instructions (control instructions, numerical operation instructions, etc.)</li> <li>Sequential processes, numerical operation processes, data processes, and various other programs can be written.</li> </ul> | | | Table format program | <ul> <li>Programs for specific applications are prepared in FIF (fill in form) with the use of tables.</li> <li>Tables, such as the constant data setting table, interlock table, and part composition table, are available.</li> </ul> | | | SFC (sequential function chart) program | <ul> <li>Sequential programs are prepared in flowchart form by the use of steps and transition conditions.</li> <li>Sequences, such as automatic operation flows, can be written readily.</li> </ul> | | # 2 HIERARCHICAL STRUCTURE OF THE DRAWING SYSTEM AND PROGRAMS User programs are managed in units of drawings, which are identified by the drawing No. (DWG No.). These drawings serve as the basis of user programs. There are parent drawings, child drawings, grandchild drawings, and operation error processing drawings. Besides drawings, there are also functions, which can be referenced freely from each drawing. #### **Parent Drawings** The parent drawing is executed automatically by the system program when the "Condition of Execution" of Table 2.1 is established. #### **Child Drawings** Child drawings are executed upon being referenced from the parent drawing by the SEE Instruction. #### **Grandchild Drawings** Grandchild drawings are executed upon being referenced from a child drawing by the SEE Instruction. #### **Operation Error Processing Drawing** This is executed automatically by the system program upon occurrence of operation error. #### **Functions** Functions are executed upon being referenced from the parent, child, or grandchild drawing by the FSTART Instruction. ## 2.1 Types and Priority Levels of Parent Drawings Parent drawings are classified by the first character of the drawing (A, I, H, L) according to the purpose of the process. The priority levels and execution conditions of drawings are defined as shown in Table 2.1. For details, refer to the Control Pack CP-9200SH User's Manual (SIE-C879-40.1). **Table 2.1 Types and Priority Levels of Parent Drawings** | Type of<br>Parent<br>Drawing | Role of<br>Drawing | Priority<br>Level | Condition of Execution | Number of<br>Drawings<br>(Note) | |------------------------------|----------------------------|-------------------|----------------------------------------------------------------------------|---------------------------------| | DWG. A | Starting process | , 1 | Turning on the power (Executed once when the power is turned on.) | 64 | | DWG. I | Interruption process | 2 | Start of interruption (Executed upon rising of interruption input signal.) | 64 | | DWG. H | High-speed<br>scan process | · 3 | Start of fixed cycle (Executed on each high-speed scan time.) | 100 | | DWG. L | Low-speed<br>scan process | 4 | Start of fixed cycle (Executed on each low-speed scan time.) | 100 | (Note): The details of the number of drawings is as follows. Parent drawing : 1 (□) Operation error processing drawing: 1 (□00) Child drawings : n-2 (□01 to 99) A maximum total of n-2 child Grand child drawings : (□△△ .01 to 99) and grandchild drawings. (A, L: 62, H, L: 98) <sup>\*</sup> n: the maximum number of drawings that can be used. ☐: first character of the drawing (A, I, H, L) △△: child drawing number #### 2.2 Execution Control of Parent Drawings #### 2.2.1 Execution Control of Parent Drawings Each drawing is executed based on its priority level as shown in Fig. 2.1. Fig. 2.1 Execution Control of Parent Drawings #### 2.2.2 Scheduling of the Execution of Scan Process Drawings The scan process drawings are not executed simultaneously but are scheduled based on priority levels as shown in Fig. 2.2 and are executed on the schedule. <sup>\*:</sup> For executing internal processes (self-diagnosis, etc.) of the system. Fig. 2.2 Scheduling of the Execution of Scan Process Drawings #### 2.3 Hierarchical Structure of Drawings The drawings are arranged in the manner: parent drawing - child drawing - grandchild drawing. However, a parent drawing cannot reference a child drawing of a different type and a child drawing cannot reference a grandchild drawing of a different type. The child drawing is referenced from the parent drawing, and from that child drawing the grandchild drawing is referenced. This structure is always followed, and is called the hierarchical structure of drawings. #### 2.3.1 Execution of Drawings The user prepares each processing program with a parent drawing - child drawing - grandchild drawing hierarchy as shown in Fig. 2.3. (Note) Substitute A, I, H, or L in X. Fig. 2.3 Hierarchical Structure of DWG's The parent drawing is executed automatically by the system, since from Table 2.1 of 2.1 "Types and priority of parent drawings," criteria for execution are determined separately for each type. In other words, the parent drawing is automatically called (called up and executed) by the system. Thus, the customer can execute any child or grandchild drawing by programming a DWG reference instruction (SEE instruction) in the parent or child drawings. Functions listed in 2.2 may be referenced from all drawings. Furthermore, a function can be referenced by a function. If a operation error occurs, operation error processing drawings corresponding to each screen will be started. #### 2.3.2 Execution Process of Drawings The execution process of the drawings arranged in a hierarchy is carried out in a manner whereby lower-ranking drawings are referenced by upper-ranking drawings. Taking an example of DWG. A, the hierarchical structure of DWGs (drawings) is shown in Fig. 2.4. Start up when system program execution conditions are satisfied Fig. 2.4 Drawing Execution Process #### 2.4 Functions Functions can be freely referenced from any drawing. Functions can even be referenced simultaneously from drawings of different types and different hierarchies. Further, functions can also reference other functions. The following benefits can be obtained by using functions. · It become easy to arrange a program into parts. · The program can be prepared and maintained easily. A function is composed of the function definition, which determines the number and types of data that are input into and output from a function, and the main body (program), which depicts the processes that are to be executed according to the inputs and outputs. Functions can be classified into standard system functions, which are made available by the system, and user functions, which are defined by the user. #### Standard System Functions The user can freely use a function that has been predefined by the system, but is not permitted to modify the contents of that function. In other words, the user cannot freely create definitions (program). Refer to Chapter 7 "Standard System Functions" for more information on system functions. #### **User Functions** These are functions that are defined (programmed) freely by the user. The user prepares the function definition and the main body (program) of the function. See 2.4.2 "User Function Preparation Procedures" concerning the preparation methods. #### 2.4.1 Function Definition Functions are defined by the user at the time of user function preparation using the graphic expression form for functions shown in Fig. 2.5. (Note): The names of the function, the inputs, and the outputs are respectively expressed in 8 or less alphanumeric characters. Fig. 2.5 Graphic Expression of a Function #### 2.4.2 **User Function Preparation Procedure** Fig. 2.6 shows the procedure for preparing user functions, which can be defined freely by the user. Use the FOUT Instruction to prepare the program for output data. \*: If a system function is to be used, prepare the program upon referring to the description on I/O definition in Chapter 7 "STANDARD SYSTEM FUNCTIONS". Since the I/O specifications, the function definition, and the main body of the function program are already provided by the system in the case of system functions, these do not have to be defined or prepared. Fig. 2.6 User Function Preparation Procedure For more details on operating the CP-717, refer to the Control Pack CP-717 Operation Manual (SIE-C877-17.4, -17.5). # REGISTER MANAGEMENT METHOD Various types of registers are introduced according to application and the register attributes and designation methods are described in this chapter. ## 3.1 Register Designation Method As shown in Table 3.1, registers may be designated by direct register No. designation or by symbolic designation. These two types of register designation methods may be used together in the user programs. When symbolic designation is to be used, the relationship between the symbol and the register No. must be defined in the symbol table described later. Refer to the Control Pack CP-9200SH User's Manual (SIE-C879-40.1) for details. **Table 3.1 Register Designation Methods** | Type of<br>Designation | Designation Method | |------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Direct register<br>No. designation | Bit type register designation : MB00100A□ Integer type register designation : MW00100□ Double-length integer type register designation : ML00100□ Real number type register designation : MF00100□ Address type register designation : MA00100□ □: In the case of subscript designation, the subscript i or j is attached after the register No. | | Symbolic<br>designation | Bit type register designation : RESET1-A. Integer type register designation : STIME-H. Double-length integer type register designation : POS-REF. Real number type register designation : IN-DEF. Address type register designation : PID-DATA. An alphanumeric expression of 8 characters or less. : In the case of subscript designation, a "." and then the subscript, i or j, are attached after the alphanumeric expression of the symbol with 8 characters or less. | #### 3.2 **Data Types** There are five data types; the bit type, the integer type, the double-length integer type, the real number type, and the address type. These are used according to the purpose. Address type data may be used only for pointer designation. Refer to the Control Pack CP-9200SH User's Manual (SIE-C879-40.1) for the corresponding device for details. **Table 3.2 Data Types** | Type | Data Type | Numerical Range | Remarks | |------|------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | В | Bit | ON,OFF | Used for relay circuits. | | w | Integer | -32768 to +32767<br>(8000H) (7FFFH) | Used for numerical operations. Values in () are used in the case of logic operations. Ordinarily used in a series of instruction groups that begin with an integer type entry instruction (—). It can also be used in a series of instruction groups that begin with a real number type entry instruction (—). | | L | Double-<br>length<br>integer | -2147483648 to +2147483647<br>(80000000H) (7FFFFFFH) | Used for numerical operations. Values in () are used in the case of logic operations. Ordinarily used in a series of instruction groups that begin with an integer type entry instruction (├─). It can also be used in a series of instruction groups that begin with a real number type entry instruction (├─). | | F | Real<br>number | ±(1.175E -38 to 3.402E<br>+38),0 | Used for numerical operations. May only be used in a series that begins with a real number type entry instruction (├─). Please keep in mind that it cannot be used in a series of instruction groups that begin with an integer type entry instruction (├─). | | A | Address | 0 to 32767 | Used only for pointer designation. | Fig. 3.1 Pointer Designation In Fig. 3.1, MA00100 signifies the memory address nn of MW00100. By handing MA00100 to a function, the register domain below MW00100 may be used for internal processes of the function. Such use of an address as an argument of a function is referred to as "pointer designation". In this way, the register domain below MW00100 can be freely used for bits, integers, double-length integers, or real numbers. # 3.3 Type of Registers ### 3.3.1 DWG Registers The 7 types of register shown in Table 3.3 can be used in each DWG. Refer to the Control Pack CP-9200SH User's Manual (SIE-C879-40.1) for details. Table 3.3 DWG Registers | Туре | Name | Designation<br>Method | Description | Characteristic | | |------|----------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--| | S | System<br>register | SB, SW, SL,<br>SFnnnnn<br>(SAnnnnn) | Registers made available by the system.<br>The register No. nnnnn is a decimal expression.<br>Upon system start-up, SW00000-SW00049 are all<br>cleared to 0. | · | | | М | Data<br>regoster | MB, MW,<br>ML,<br>MFnnnnn<br>(MAnnnnn) | Registers used in common among DWG's. Used for I/F between DWG's, etc. The register number nnnnn is a decimal expression. | | | | I | Input<br>register | IB, IW, IL,<br>IFhhhh<br>(IAhhhh) | Register that is used for interface with I/O module and communication module. The register number hhhh is a hexadecimal expression. The register number is assigned on the module configuration definition screen. The register numbers C000 and later are used for interface with motion modules such as SVA modules. For details, refer to the instruction manual of each module. | Used in<br>common by<br>DWG's | | | O | Output<br>register | OB, OW, OL,<br>OFhhhh<br>(OAhhhh) | Register that is used for interface with I/O module and communication module. The register number hhhh is a hexadecimal expression. The register number is assigned on the module configuration definition screen. The register numbers C000 and later are used for interface with motion modules such as SVA modules. For details, refer to the instruction manual of each module. | | | | С | Constant<br>register | CB, CW, CL,<br>CFnnnnn<br>(CAnnnnn) | Register that can only be referenced by a program. The register number nnnn is a decimal expression. | | | | # | # register | #B, #W, #L,<br>#Fnnnnn<br>(#Annnnn) | Registers that can only be referenced in a program. Can only referenced the corresponding DWG. The actual application range is specified by the user with the CP-717. The register number nnnnn is a decimal expression. | Unique to<br>each DWG | | | D | D register | DB, DW, DL,<br>DFnnnnn<br>(DAnnnnn) | Internal registers unique to each DWG. Can only referenced the corresponding DWG. The actual application range is specified by the user with the CP- 717. The register number nnnnn is a decimal expression. | OROH D WO | | #### 3.3.2 Function Registers The 11 types of registers shown in Table 3.4 can be used in each function. Refer to the Control Pack CP-9200SH User's Manual (SIE-C879-40.1) for details. **Table 3.4 Function Registers** | Туре | Name | Designation Method | Description | Characteristic | |------|---------------------------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------| | Х | Function<br>input<br>register | XB,XW,XL,XFnnnn | Input into a function Bit input :XB000000 to XB00000F Integer input :XW00001 to XW00016 Double-length integer input: XL00001 to XL00015 The register number nnnnn is a decimal expression. | | | Y | Function<br>output<br>register | YB,YW,YL,YFnnnn | Outputs from a function Bit output :YB000000 to YB00000F Integer output :YW00001 to YW00016 Double-length integer output: YL00001 to YL00015 The register number nnnnn is a decimal expression. | | | Z | Register<br>inside<br>function | ZB,ZW,ZL,ZFnnnn | Internal registers unique to each function. Can be used for internal processes of the function. The register number nnnnn is a decimal expression. | | | A | Register<br>outside<br>function | AB,AW,AL,AFnnnn | External registers that use the address input value as the base address. For linking with (S, M, I, O, #, DAnnnn). The register number nnnnn is a decimal expression. | Unique to<br>each function | | # | # Register | #B,#W,#L,#Fnnnn<br>(#Annnnn) | Register that can only be referenced by a program. Can reference only the corresponding function. The actual application range is specified by the user with the CP-717. The register number nnnnn is a decimal expression. | | | D | D register | DB,DW,DL,DFnnnn<br>(DAnnnn) | Characteristic internal register for each function. Can reference only the corresponding function. The actual application range is specified by the user with the CP-717. The register number nunnn is a decimal expression. | , | | | System<br>register | SB,SW,SL,SFnnnnn<br>(SAnnnnn) | | | | М | Data<br>register | MB,MW,ML,MFnnnnn<br>(MAnnnnn) | Same as the DWG registers. | | | | Input<br>register | IB,IW,IL,IFhhhh<br>(IAhhhh) | (Since these registers are used in common by both DWG's and functions, be careful of their use when the same function is referenced from DWG's of different priority levels.) | Used in<br>common by<br>DWG's | | 11 1 | Output<br>register | OB,OW,OL,OFhhhh<br>(OAhhhh) | 200 do di unidicino priority 164618.) | D#/G\$ | | | Constant<br>register | CB,CW,CL,CFnnnn<br>(CAnnnn) | ;<br>; | | (Note) SA, MA, IA, OA, DA, #A, and CA may also be used inside a function. ### 3.3.3 CPU Internal Registers The registers shown in Table 3.5 are provided inside the CPU. These are used for carrying out user program processes. **Table 3.5 CPU Internal Registers** | Register | Usage | | | | | |-------------------------------------------------------------------------------|--------------------------------|--|--|--|--| | A register Used as a register for logic, integer, and double-leng operations. | | | | | | | F register Used as a register for real number operations. | | | | | | | B register | | | | | | | I register | Used as an index register (I). | | | | | | J register | | | | | | #### 3.3.4 Subscripts i and j Two types of registers, i and j, are used exclusively for modifying a relay number or register number. i and j have the same function. These subscripts are explained below with an example for each register data type. #### (1) When a Subscript is Attached to Bit Type Data This will be equivalent to adding the value of i or j to the relay number. For example if I=2, MB000000i will be the same as MB000002. If J=27, MB000000j will be the same as MB000001B. #### (2) When a Subscript is Attached to Integer Type Data This will be equivalent to adding the value of i or j to the register number. For example, if I=3, MW00010i will be the same as MW00013. If J=30, MW00001j will be the same as MW00031. | - 00030 | ⇒J | $\stackrel{\text{equivalent}}{\Longleftrightarrow}$ | ⊢MW00031 | · · · · · · · · · · · · · · · · · · · | |-----------|----|-----------------------------------------------------|----------|---------------------------------------| | ⊢MW00001j | | | | | #### (3) When a Subscript is Attached to Double-Length Integer Type Data This will be equivalent to adding the value of i or j to the register number. For example, if I=1, ML00000i will be the same as ML00001. ML00000j will be as follows when J=0 and J=1. Be careful. #### (4) When a Subscript is Attached to Real Number Type Data This will be equivalent to adding the value of i or j to the register number. For example, if I=1, MF00000i will be the same as MF00001. MF00000j will be as follows when J=0 and J=1. Be careful #### (5) Example of Program Using a Subscript The program shown in Fig. 3.2 is one in which the total for 100 registers from MW00100 to MW00199 is set in MW00200 by the use of subscript j. Fig. 3.2 Example of Program Using a Subscript #### 3.3.5 Function VO and Function Registers The inputs and outputs in a function referencing process correspond to the function registers as shown in Table 3.6. Refer to the Control Pack CP-9200SH User's Manual (SIE-C879-40.1) for details. Table 3.6 Correspondence between Function I/O's and Function Registers | Function I/O | Function Register | |---------------------|-----------------------------------------------------------------------| | Bit input | The bit number increases continuously from XB000000 in the order | | , | of bit input. (XB000000, XB000001, XB000002,, XB00000F) | | Integer, double- | The register number increases continuously from XW00001, XL00001, | | length integer, and | and XF00001 in the order of the integer-double-length integer-real | | real number inputs | number input. | | | (XW00001, XW00002, XW00003, , XW00016) | | | (XL00001, XL00003, XL00005,, XL00015) | | | (XF00001, XF00003, XF00005,, XF00015) | | Address input | The address input value corresponds to register No. 0 of the external | | | register. (Input value = MA00100 : MW00100 = AW00000, MW00101 | | | = AW00001) | | Bit output | The bit number increases continuously from XB000000 in the order | | | of bit output. (YB000000, YB000001, YB000002,, YB00000F) | | Integer, double- | The register number increases continuously from YW00001, YL00001, | | length integer, and | and YF00001 in the order of the integer, double-length integer, and | | real number | real number output, respectively. | | outputs | (YW00001, YW00002, YW00003,, YW00016) | | • | (YL00001, YL00003, YL00005,, YL00015) | | | (YF00001, YF00003, YF00005,, YF00015) | Fig. 3.3 Function Program In the function program shown in Fig. 3.3, if " $\vdash$ AW00000 + AW00001 $\Rightarrow$ AW000002" is written in the program inside the function, the operation: <sup>&</sup>quot; $\vdash$ MW01000 + MW01001 $\Rightarrow$ MW01002" is executed. #### 3.3.6 Programs and Register Referencing Ranges - ①: The registers that can be used in common by the DWG's may be referenced from any drawing or function. - ②: Registers that are unique to each drawing can only be referenced within that drawing. - ③: Registers that are unique to each function can only be referenced within that function. - ④: The registers that can be used in common by the DWG's and the registers that are unique to each drawing may be referenced from a function by the use of the function external registers. #### 3.4 Symbol Management #### 3.4.1 Symbol Management in the DWG's All symbols used in the DWG are managed by the DWG symbol table shown in Fig. 3.7. Both registration of symbols on the symbol table and designation of register numbers can be performed on the symbol definition screen of the CP-717. Further, registration, deletion, and modification of symbols as well as designation or modification of register numbers can be done any time while a program is being prepared. A maximum of 200 symbols can be registered for a single drawing. Refer to the Control Pack CP-717 Operation Manual (SIE-C877-17.4, -17.5) for the method of defining DWG symbol tables. #### When an unregistered symbol is used during program preparation... Since only the symbol will be registered automatically in the DWG symbol table, the designation of the register number will become necessary after the program is prepared. | • | • | I able 5.7 | Dira 3y | IIIDOI TADIE | |-----|--------------|------------|---------|--------------------------------------------------| | No. | Register No. | Symbol | Size * | Remarks | | 0 | IB00000 | STARTPBL | 1 | The register number is a hexadecimal expression. | | 1 | OB00000 | STARTCOM | 1 | The register number is a hexadecimal expression. | | 2 | MW00000 | SPDMAS | 1 | | | 3 | MB000010 | WORK-DB | 16 | | | 4 | MW00010 | PIDDATA | 10 | · | | 5 | MW00020 | LAUIN | 1 | | | 6 | MW00021 | LAUOUT | 1 | | | : | | | | | | N | , | | | 1 | Table 3.7 DWG Symbol Table For example, if data is referenced as PIDDATA i and i takes on values in the range 0 to 9, define the size as 10. ### 3.4.2 Symbol Management in the Functions The symbols used in the functions are all managed with the symbol table, shown in Table 3.8. The registration, deletion, and modification of a symbol and the designation and modification of a register number are carried out in the same manner as in the DWG's. | | | | | · · · · · · · · · · · · · · · · · · · | |-----|--------------|----------|--------|---------------------------------------| | No. | Register No. | Symbol | Size * | Remarks | | 0 | XB000000 | EXECOM | 1 | | | 1 | XW00001 | INPUT | 1 | | | 2 | AW00001 | P-GAIN | 1 | | | 3 | AB00000F | ERROR | 1 | | | 4 | YB000000 | PIDEXE | 1 | | | 5 | YW00001 | PIDOUT | 1 | | | 6 | ZB000000 | WORKCOIL | 4 | - | | 7 | ZW00001 | WORK1 | 1 | | | 8 | ZW00002 | WORK2 | 1 | | | | | | | | | . N | 7 | | | | **Table 3.8 Function Symbol Table** For example, if data is referenced as PIDDATA.i and i takes on values in the range 0 to 9, define the size as 10. <sup>\*:</sup> If a program is prepared using such data configurations as arrays, index process data, etc., define the sizes used in the respective data configurations. <sup>\*:</sup> If a program is prepared using such data configurations as arrays, index process data, etc., define the sizes used in the respective data configurations. ## 3.5 Upward Linking of Symbols and Automatic Number Allocation #### 3.5.1 Upward Linking of Symbols The upward linking of symbols refers to the defining of symbols so that symbol names defined in drawings of different hierarchical rank can be used to reference the same register number. Ordinarily, a symbol that is defined for a certain DWG or function becomes unique to that DWG or function program and cannot be referenced by other DWG's or functions. However, by using the upward linking function for symbols, a symbol defined in a parent drawing may be referenced by a child drawing as long as the drawings are process drawings of the same type. The upward linking of a symbol is set at the Symbol Definition screen of the CP-717. Refer to the Control Pack CP-717 Operation Manual (SIE-C877-17.4, -17.5) for details concerning the setting method. Table 3.9 Linkable Symbols and Symbol Table for Linking | Symbol Table | Parent<br>drawing | Child<br>drawing | Grandchild<br>drawing | |---------------------------------|-------------------|------------------|-----------------------| | Symbols of a parent drawing | × | × | × | | Symbols of a child drawing | 0 | × | × | | Symbols of a grandchild drawing | 0 | 0 | × | | Symbols inside a function | × | × | × | O: Linkable ×: Not linkable #### 3.5.2 Automatic Register Number Allocation Automatic register number allocation refers to the setting of the head register number and the automatic allocation of register numbers to symbols for which register numbers have not been assigned. Setting automatic allocation of register numbers can be performed on the symbol definition screen of the CP-717. Refer to the Control Pack CP-717 Operation Manual (SIE-C877-17.4, -17.5) for detailed procedures for setting them. **Table 3.10 Automatic Register Number Assignment** | DWG Symbol Table | | Automatic Number<br>Allocation | Function Symbol Table | Automatic Number<br>Allocation | | |------------------|-----|--------------------------------|----------------------------|--------------------------------|---| | System register | S | 0 | System register | S | 0 | | Input regiter | I | 0 | Input register | I | 0 | | Output register | 0 | 0 | Output register | 0 | 0 | | Data register | M | 0 | Data register | M | 0 | | # register | · # | 0 | # register | # | 0 | | C register | С | 0 | C register | C | 0 | | D register | D | 0 | D register | D | 0 | | | _ | _ | Function input register | X | × | | | _ | | Function output register | Y | × | | | | <del>-</del> | Function internal register | Z | 0 | | | _ | _ | Function external register | Α | × | O: Automatic number allocation possible $\times$ : Automatic number allocation impossible # **4 BASIC INSTRUCTIONS** All of the instructions that can be used with CP-9200SH are described in detail in this chapter. #### **Arrangement of This Chapter** In this chapter, the description of each instruction is arranged in the following manner. [Format] Description of the operands and the form of the operands of the instruction. [Description] Description of the functions of the instruction. [Operation of the Register] Shows the storage status of the CPU internal registers. The registers shown in Table 4.1 are provided inside the CPU. These are used to perform user program processes. | A | F | В | I | J | |---|---|---|---|---| | 0 | 0 | × | 0 | 0 | ○: stored ×: not stored : indeterminate (Stored or not stored depending on the case.) A: A register, F: F register, B: B register, I: I register, J: J register **Table 4.1 CPU Internal Registers** | Register | Usage | |------------|------------------------------------------------------------------------------| | A register | Used as a register for logic, integer, and double-length integer operations. | | F register | Used as a register for real number operations. | | B register | Used for relay circuit operations | | I register | Used as an index register (I). | | J register | Used as an index register (J). | [Example(s)] Describes an example or examples of a simple program that uses the instruction. Instruction with [] #### 4.1 Instruction with [] [Format] [Instruction] [Description] A instruction with [] enables conditional execution according to the value of the immediately preceding B register. The instruction within [] is only executed when the value of the B register is ON. [] can only be used for 1 instruction. A plurality of instructions cannot be enclosed in a single []. If [] is to be used for a plurality of instructions, attach [] to each instruction. #### [Operation of the Register] When the B register is OFF: | Α | F | В | I | J | |---|---|---|---|---| | 0 | Ö | 0 | 0 | 0 | O: stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) When the B register is ON: | Α | F | В | I | J | |---|---|---|---|---| | * | * | * | * | * | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) #### [Example(s)] Example 1 #### \$ equivalent #### Example 2 #### 1 equivalent <sup>\*:</sup> In accordance with the instruction within []. #### 4.2 **Program Control Instructions** #### 4.2.1 **Child Drawing Referencing Instruction (SEE)** [Format] SEE < Child drawing No. or grand-child drawing No. > [Description]. The SEE instruction is used when referencing a child drawing from a parent drawing or when referencing a grandchild drawing from a child drawing. Referencing cannot be performed between drawings which differ in type. For example, "SEE H01" cannot be written inside DWG.L. #### [Operation of the Register] | • | Α | F | В | I | J | <ul><li>: stored ×: not stored</li><li>: indeterminate</li></ul> | |---|---|----|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | * | * | * | * | * | (Stored or not stored depending on the case.) | | | | ٠. | · | | • | (Elected of Tool Property as Personal State of S | #### [Example(s)] FOR Structure Statement #### 4.2.2 FOR Structure Statement [Format] FOR V = A to B by C Instruction sequence (processing program) FEND [Description] The instruction sequence surrounded by the FOR instruction and the corresponding FEND instruction is repeated by the designated number of times $\{N = (B - A + 1)/C\}$ . The variable V starts from initial value A and is incremented by C on each repeated execution. The instruction sequence is ended when V>B. The following registers may be used for V, A, B, and C. - V: Any registers of the integer type, any register of the integer type with subscript, and any subscript register (I, J). - A, B, C: Any registers of the integer type, any register of the integer type with subscript, any constant or any subscript register (I, J). (B>A>0, C>0) To the next instruction Fig. 4.1 Execution Control by the FOR Structure Statement #### **Depth of Structure Statements (Nesting)** The FOR, WHILE, and IF structure statements may contain other structure statements within themselves. This is called "nesting". A FOR, WHILE, or IF structure statement can each be nested up to 8 times. The maximum depth of a nested structure using FOR, WHILE, and IF statements is thus restricted to 24 nests. ### [Operation of the Register] | Α | F | В | I | J | <ul><li>: stored × : not stored</li><li>: indeterminate</li></ul> | |---|---|---|---|---|-------------------------------------------------------------------| | * | * | * | * | * | (Stored or not stored depending on the case.) | [Example(s)] The total for 100 registers, from MW00100 to MW00199, is stored in MW00200. #### 4.2.3 WHILE Structure Statement [Format] WHILE Instruction sequence 1 (judgment of repetition condition) ON/OFF Instruction sequence 2 (processing program) WEND [Description] The instruction sequence 2, between WHILE and WEND is executed repeatedly as long as the conditions defined by instruction sequence 1 and the ON (or OFF) instruction are satisfied. When the conditions are no longer satisfied, instruction sequence 2 is not executed and the program proceeds with the instruction next to WEND. As shown in Fig. 4.2, the condition for execution of instruction sequence 2 is determined by the condition of the B register immediately preceding the ON (or OFF) instruction (ie. the results of instruction sequence 1). If, for example, the condition for execution is found to be not satisfied as a result of the first execution of instruction sequence 1, the program proceeds with the instruction next to WEND without executing the instruction sequence (a) WHILE-ON-WEND Structure Statement (b) WHILE-OFF-WEND Structure Statement Fig. 4.2 Control of Execution by the WHILE Structure Statement #### **Depth of Structure Statements (Nesting)** The FOR, WHILE, and IF structure statements may contain other structure statements within themselves. This is called "nesting". A FOR, WHILE, or IF structure statement can each be nested up to 8 times. The maximum depth of a nested structure using FOR, WHILE, and IF statements is thus restricted to 24 nests. #### NOTE Write the program so that the condition part (instruction sequence 1) of the WEND structure statement will definitely be unsatisfied at some point. If the repetition is continued endlessly and the program cannot proceed out of the WHILE structure statement, the watchdog timer will be activated and the CPU will stop. #### [Operation of the Register] | Α | F | В | ·I | J | U: 8 | |---|---|---|----|---|------| | * | * | * | * | * | (Sto | O: stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) WHILE Structure Statement [Example(s)] The total for 100 registers, from MW00100 to MW00199, is stored in MW00200. #### NOTE #### 4.2.4 IF Structure Statement The IF structure statement can take one of two formats depending on whether or not an exclusive condition exists. Although the two formats are described separately below, there are no essential differences between these two. #### (1) IF Structure Statement - 1 IFON/IFOFF [Format] Instruction sequence (processing program) #### [Description] #### When the IFON Instruction is Used The instruction sequence between IFON and IEND will be executed if the current value of the B register is ON and will not be executed if the current value of the B register is OFF. #### When the IFOFF Instruction is Used The instruction sequence between IFON and IEND will be executed if the current value of the B register is OFF and will not be executed if the current value of the B register is ON. The process flows are shown in Fig. 4.3. Structure Statement Structure Statement Fig. 4.3 Execution Control by the IF Structure Statement (1) [Operation of the Register] | Α | F | В | I | J | ○: stored ×: not stored | |---|------------|---|---|---|-----------------------------------------------------------------| | * | ; <b>*</b> | * | * | * | * : indeterminate (Stored or not stored depending on the case.) | | | | | | | (Stored or not stored depending on the case.) | [Example(s)] If MB000108 is ON, the contents of MW00021 are set to 0. ### (2) IF Structure Statement - 2 [Format] IFON/IFOFF Instruction sequence - 1 ELSE Instruction sequence - 2 IEND #### [Description] #### When the IFON Instruction is Used: If the current value of the B register is ON, only instruction sequence 1 will be executed and instruction sequence 2 will not be executed. If the current value of the B register is OFF, only instruction sequence 2 will be executed and instruction sequence 1 will not be executed. #### When the IFOFF Instruction is Used: If the current value of the B register is OFF, only instruction sequence 1 will be executed and instruction sequence 2 will not be executed. If the current value of the B register is ON, only instruction sequence 2 will be executed and instruction sequence 1 will not be executed. The process flows are shown in Fig. 4.4. #### (a) IFON-ELSE-IEND Structure Statement #### (b) IFOFF-ELSE-IEND Structure Statement Fig. 4.4 Execution Control by the IF Structure Statement (2) # Depth of Structure Statements (Nesting) The FOR, WHILE, and IF structure statements may contain other structure statements within themselves. This is called "nesting." A FOR, WHILE, or IF structure statement can each be nested up to 8 times. The maximum depth of a nested structure using FOR, WHILE, and IF statements is thus restricted to 24 nests. ### [Operation of the Register] | - | Α | F | В | I | J | O: stored ×: not stored | |---|---|---|---|---|---|-----------------------------------------------------------------| | | * | * | * | * | * | * : indeterminate (Stored or not stored depending on the case.) | | | | | | | | (Diored or not stored depending on the case.) | ### [Example(s)] The contents of MW00011 are set to 0 if MW00010 contains a positive number and to 1 if MW00010 contains a negative number. Function Referencing Instruction (FSTART) #### NOTE Place an N.O. contact instruction )if an IFON (or IFOFF) instruction is to be used after a coil instruction. #### 4.2.5 **Function Referencing Instruction (FSTART)** [Format] **FSTART** [Description] The FSTART instruction is used to reference an user function or a system function from a parent drawing, child drawing, or user function. The function definition of the referenced user function must be prepared in advance. System functions do not have to be defined by the user since they are already defined by the system. ### [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | * | * | * | * | * | O: stored ×: not stored : indeterminate (Stored or not stored depending on the case.) #### [Additional Note] When "FSTART Enter" " is input at the CP-717, the graphic display of the functions is displayed and the input of the function name is prompted. The "FSTART" instruction itself will not be displayed on the screen. Refer to the Control Pack CP-717 Operation Manual (SIE-C877-17.4, -17.5) for details on the input method. Function Input Instruction (FIN) #### 4.2.6 Function Input Instruction (FIN) [Format] FIN [Description] The FIN instruction is used to store input data into a function input register. The forms of data input into a function register are shown in Table 4.2. **Table 4.2 Function Input Data Forms** | Input Data Form | Input Designation* | Description | |--------------------|--------------------|------------------------------------------------------------------------------------| | | | Designates the output to be of a bit type. | | Bit input | B-VAL | Usually, the ⊢ instruction or the ⊢/ instruction is used to reference | | Die mpae | D-AVE | the function. | | | | The bit data become the input to the function. | | | | Designates the input to be of an integer type. | | | I-VAL | Usually, the instruction is used to reference the function. | | | I-VAL | The contents (integer data) of the register number designated with the | | | | instruction become the input to the function. | | Integer type input | | Designates the input to be the contents of an integer type register. The | | | | number of the integer type register is designated when referencing the | | | I-REG | function. The — instruction is not necessary. | | | | The contents (integer data) of the register with the designated number | | | | become the input to the function. | | | | Designates the input to be of a double-length integer type. | | | L-VAL | Usually, the - instruction is used to reference the function. | | • | | The contents (double-length integer data) of the register with the number | | | | designated with the - instruction become the input to the function. | | Double-length | | Designates the input to be the contents of a double-length integer type | | integer type input | | register. | | | 1 750 | The number of the double-length integer type register is designated when | | | L-REG | referencing the function. The - instruction is not necessary. The contents | | | | (double-length integer data) of the register with the designated number | | | | become the input to the function. | | | | Designates the input to be of a real number type. | | | F-VAL | Usually, the ⊨ instruction is used to reference the function. | | | L-AWP | The contents (real number data) of the register with the number designated | | | | with the - instruction become the input to the function. | | Real number type | | Designates the input to be the contents of a real number type register. The | | input | | number of the real number type register is designated when referencing the | | | F-REG | function. The - instruction is not necessary. The contents (real number | | | | data) of the register with the designated number become the input to the | | | | function. | | Address innut | | Hands over the address of the designated register (an arbitrary integer | | Address input | | register) to the function. Only 1 input is allowed in the case of a user function. | <sup>\*:</sup> Indicates the input designation at the CP-717. ### [Operation of the Register] | ļ | Α | F | В | Ι | J | ○: stored ×: not stored | |---|---|---|---|---|---|-----------------------------------------------------------------| | | 0 | 0 | 0 | 0 | 0 | * : indeterminate (Stored or not stored depending on the case.) | ### [Additional Note] The graphic display of function inputs is displayed when "FIN Enter" is input at the CP-717 after designating the data. The "FIN" instruction itself will not be displayed on the screen. Refer to the Control Pack CP-717 Operation Manual (SIE-C877-17.4, -17.5) for details on the input method. #### NOTE It is recommended that I-REG, L-REG, or F-REG be used if the I/O data are not of a bit type. #### 4.2.7 **Function Output Instruction (FOUT)** [Format] FOUT . [Description] The FOUT instruction is used to take out the contents of a function output register as output data of the function. The forms of data output from a function are shown in Table 4.3. **Table 4.3 Function Output Data Forms** | Output Data Form | Output Designation* | Description | |----------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit output | B-VAL | Designates the output to be of a bit type. Usually, the —O— instruction is used to reference the function. The output data (bit data) are stored in the register with the number designated with the —O— instruction. | | Integer type output | I-VAL | Designates the output to be of a Integer type. Usually, the ⇒ instruction is used reference the function. The output data (integer data) are stored in the register with the number designated with the ⇒ instruction. | | moeger type daspus | I-REG | Designates the output to be the contents of an integer type register. The number of the integer type register is designated when referencing the function. The $\Rightarrow$ instruction is not necessary. The output data (integer data) are stored in the register with the designated number. | | Double-length integer | L-VAL | Designates the output to be of a double-length integer type. Usually, the ⇒ instruction is used to reference a function. The output data (double-length integer data) are stored in the register with the number designated with the ⇒ instruction. | | type output | L-REG | Designates the output to be the contents of a double-length integer type register. The number of the double-length integer type register is designated when referencing the function. The instruction is not necessary. The output data (double-length data) are stored in the register with the designated number. | | D. Januari, and a second | F-VAL | Designates the output to be of a real number type. Usually, the ⇒ instruction is used to reference a function. The output data (real number data) are stored in the register with the number designated with the ⇒ instruction. | | Real number type<br>output | F-REG | Designates the output to be the contents of a real number type register. The number of the real number type register is designated when referencing the function. The => instruction is not necessary. The output data (real number data) are stored in the register with the designated number. | <sup>\*:</sup> Indicates the output designation at the the CP-717. ### [Operation of the Register] | <u> </u> | Α | F | В | 1 | J | |----------|---|---|---|---|---| | B-VAL | 0 | 0 | X | 0 | 0 | | I -VAL | × | O | 0 | 0 | 0 | | I -REG | 0 | 0 | 0 | 0 | 0 | | L-VAL | × | Ò | 0 | 0 | 0 | | L-REG | 0 | 0 | 0 | 0 | 0 | | F-VAL | | X | 0 | Ó | 0 | | F.REG | | | | | | ○: stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) Function Output Instruction (FOUT) #### [Additional Note] The graphic display of function outputs is displayed when "FOUT Enter" is input at the CP-717 after designating the data. The "FOUT" instruction itself will not be displayed on the screen. Refer to the Control Pack CP-717 Operation Manual (SIE-C877-17.4, -17.5) for details. #### [Example(s)] Table 4.4 shows the function I/O data defined by function definition in the program example above. Table 4.4 Function I/O Data Forms | Input Data | Data Form | |------------|-----------| | INPUT-1 | B-VAL | | INPUT-2 | I - REG | | INPUT-3 | B-VAL | | INPUT-4 | L - REG | | Output Data | Data Form | |-------------|-----------| | OUTPUT-1 | B-VAL | | OUTPUT-2 | I - REG | | OUTPUT-3 | B-VAL | | OUTPUT-4 | L - REG | #### NOTE It is recommended that I-REG, L-REG, or F-REG be used if the I/O data are not of a bit type. Table 4.5 shows the correspondence relationships between the I/O data and the function I/O registers when the I/O data are referenced within the main body of the function. Table 4.5 VO Correspondence Relationships | Input Data | , - | ithin the Main<br>e Function | Output Data | | | |------------------------|----------------------------|------------------------------|------------------------|--|--| | Input Data | Function Input<br>Register | Function Output<br>Register | | | | | B register (=MB000000) | XB000000 | | | | | | IW0010 | XW00001 | | | | | | B Register (=MB000001) | XB000001 | | | | | | ML00011 | XL00002 | | | | | | MW00100 | AW00000 | | | | | | MW00101 | AW00001 | | , | | | | ML00102 | AW00002 | | | | | | MB001040 | AB000040 | | | | | | : | : | | | | | | | • | YB000000 | B Register (=OB00000) | | | | | | YW00001 | MW00200 | | | | | | YB000001 | B Register (=MB000021) | | | | | | YW00002 | ML00201 | | | #### 4.2.8 Comment Instruction (COMMENT) Comments can be written at any position in the DWG program or user function program. Alphanumeric characters may be used for comments. # [Format] [Description] "character string" The character string enclosed with "" is treated as a comment. Since this is merely a comment, it is not executed as an instruction. Be aware that it becomes the target of the number of steps in the user program. A character string of 12 characters will be equivalent to 1 step (1 basic instruction). #### [Operation of the Register] | A | F | В | Ι | J | : stored X: not stored : indeterminate | |---------|---|---|---|---|-----------------------------------------------| | $\circ$ | 0 | 0 | 0 | 0 | (Stored or not stored depending on the case.) | #### NOTE Do not prepare a program that there is a comment instruction in the middle of branching in a series of sequence instruction groups. DB000005 Correct 10000080 ### 4.2.9 Expansion Program Execution Instruction (XCALL) [Format] XCALL <type of expansion program> [Description] The XCALL instruction is used to execute an expansion program. Expansion programs refer to the table format programs. There are 4 types of table format programs as shown in Table 4.6. With the CP-9200SH, these expansion programs are converted into ladder programs for execution. A converted ladder program is executed with the XCALL instruction. Although a plurality of XCALL instructions may be used in one drawing, the same expansion program cannot be called more than once. **Table 4.6 Types of Expansion Programs** | Symbol | Program Type | |--------|-----------------------------| | MCTBL | Constant table (M register) | | IOTBL | I/O conversion table | | ILKTBL | Interlock table | | ASMTBL | Parts composition table | #### [Operation of the Register] | | A | $\overline{}$ F | В | ·I | J | |---|---|-----------------|---|----|---| | Ì | 0 | * | 0 | * | * | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) #### [Example(s)] #### 4.3 Direct I/O Instructions The direct I/O instructions are used to execute inputs and outputs in an user program independent of the system I/O (batch input/batch output). An input or output is carried out at the point of execution of the direct I/O instruction. The subsequent instruction is not executed until the I/O operation has been completed. #### 4.3.1 Continuous Execution Type Direct Input Instruction (INS) [Format] [Parameter/head address of the data table] INS Register address (except for #/C) Register address (except for #/C) with subscript [Description] The INS instruction conforming to previously set parameter table contents, continuously performs direct input to a single module. The only modules that can apply direct input are the LIO-01/2000IO. If no error at all occurs, B register is OFF. If an error occurred in even a single word, B register turns ON. During operation, interruption by the system is prohibited. Table 4.7 INS Instruction Parameter/Data Table | ADR | Туре | Symbol | Name | Specifications | Input<br>or<br>Output | |-----|------|--------|----------------------|-------------------------------------------------|-----------------------| | 0 | W | RSSEL | Module designation 1 | Designation of module for performing input | IN | | 1 | W | MDSEL | Module designation 2 | (The details are described (1) and (2) below.) | IN | | 2 | W | STS | Status | Status for each word output with bit response | OUT | | 3 | W | N | Number of words | Designation of number of continuous input words | IN | | 4 | W | ID1 | Input data 1 | Outputs the input data. | OUT | | ÷ | : | : | : | If there is an error, 0 is stored. | : | | N+3 | W | IDN | Input data N | | OUT | #### \* Method of RSSEL and MDSEL Settings (1) RSSEL Designates the rack/slot where the target module is mounted. Hexadecimal expression: xxyyH $\begin{array}{l} (01_{\rm H} \leq xx \leq 04_{\rm H}) \\ (00_{\rm H} \leq yy \leq 0D_{\rm H}) \end{array}$ xx = rack numberyy = slot number However, designate the mounting rack/slot as: LIO-01: Mounting rack/slot number on LIO-01 itself 2000IO: Mounting rack/slot number on 2000IOIF module connected to the target 2000IO rack (2) MDSEL For the LIO-01: Designate the input data offset for the internal LIO-01 module. For the 2000IO: Designates the rack number/slot number/input module type in the 2000IO rack of the target module. a: Input module type 0: Discrete input module 1: Register input module b: Rack number $(1 \le b \le 4)$ c: Slot number $(1 \le c \le 9)$ d: Data offset $(0 \le d \le 7)$ Designation of RSSEL and MDSEL in a system configuration shown below is explained in ex 1 to ex 6. ex ① LIO-01 (RACK1/SLOT9) First word is input RSSEL=0109H MDSEL=0 ex ② LIO-01 (RACK2/SLOT2) Second word is output RSSEL=0202H MDSEL=1 ex ③ B2501 (Discrete input) (RACK1/SLOT6) connected to 2000IOIF (RACK2/SLOT11) First word is input RSSEL=020BH MDSEL=0160H x 4 B2701 (Register input) (RACK2/SLOT5) connected to 2000IOIF (RACK2/SLOT11) Fourth word is input RSSEL=020BH MDSEL=1254H ex (5) B2500 (Discrete output) (RACK1/SLOT5) connected to 2000IOIF (RACK2/SLOT11) First word is input RSSEL=020BH MDSEL=0150H ex 6 B2700 (Register output) (RACK2/SLOT4) connected to 2000IOIF (RACK2/SLOT11) Seventh word is input RSSEL=020BH MDSEL=1247H depending on the case.) [Operation of the Register] | Α | F | В | I | J | : stored × : not stored | |---|---|---|---|---|---------------------------------------------------| | 0 | 0 | × | 0 | 0 | * : indeterminate<br>(Stored or not stored depend | [Example(s)] Data input from LIO mounted at rack 2, slot 4. | ├─ H0204<br>├─ 0<br>├─ 1 | | ⇒ MW00100<br>⇒ MW00101<br>⇒ MW00103 | |--------------------------|--|-------------------------------------| | INS MA00100 | | | <sup>\*</sup> Input data stored in MW00104. Continuous execution type direct output instruction (OUTS) ### 4.3.2 Continuous Execution Type Direct Output Instruction (OUTS) [Format] [Parameter/head address of the data table] OUTS [ Register address (except for #/C) Register address (except for #/C) with subscript [Description] The OUTS instruction conforming to previously set parameter table contents, continuously performs direct output to a single module. The only module that can apply direct output is the LIO-01/2000IO. If no error at all occurs, B register is OFF. If an error occurred in even a single word, B register turns ON. During operation, interruption by the system is prohibited. Table 4.8 OUTS Instruction Parameter/Data Table | ADR | Туре | Symbol | Name | Specifications | Input<br>or<br>Output | |-----|------|--------|----------------------|--------------------------------------------------|-----------------------| | 0 | W | RSSEL | Module designation 1 | Designation of module for performing output | IN | | 1 | W | MDSEL | Module designation 2 | (The details are described (1) and (2) below.) | IN | | 2 | W | STS | Status | Status for each word output with bit response | OUT | | 3 | W | N | Number of words | Designation of number of continuous output words | IN | | 4 | W | OD1 | Output data 1 | Setting output data | IN | | : | : | : | <b>:</b> | | : | | N+3 | W | ODN | Output data N | | IN | <sup>\*</sup> Method of setting RSSEL and MDSEL is the same as for INS. [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | 0 | 0 | × | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] Two words output to LIO-01 mounted at rack 3, slot 10. | ⊢ H030A | ⇒MW00200 | |------------------|-----------------------| | l ⊢ 0 | $\Rightarrow$ MW00201 | | $\vdash_2$ | ⇒MW00203 | | | | | Output data 1 | | | ├─ xxxxx | ⇒MW00204 | | Ontrod data 9 | | | Output data 2 | . 3 57770 0 0 0 7 | | <b>├</b> ─ ууууу | $\Rightarrow$ MW00205 | | OUTS MA00200 | | | 0018 MA00200 | | # 4.4 Sequence Circuit Instructions The circuit elements shown in Table 4.9 are used in combination to prepare sequence circuits. **Table 4.9 Sequence Circuit Elements** | No. | Sequence Circuit Element | Symbol | Remarks | |-----|-----------------------------|----------------|--------------------------------| | 1 | N.O. contact instruction | ⊣⊢ | Connection indication elements | | 2 | N.C. contact instruction | -14- | (1) Branching | | 3 | Coil | . — | (2) Parallel connection point | | 4 | Set coil | ⊬s⊬ | (3) Parallel connection | | 5 | Reset coil | -{ <b>8</b> }- | (b) Faranci connection | | 6 | Rising pulse | 1 | | | 7 | Falling pulse | -7 | 4 | | 8 | On-delay timer (10ms unit) | -{ | | | 9 | Off-delay timer (10ms unit) | -{ }- | | | 10 | On-delay timer (1s unit) | -{* }- | · . | | 11 | Off-delay timer (1s unit) | ન *}- | | ### 4.4.1 N.O. Contact Instruction ( $\neg \vdash$ ) [Format] Any bit type register Any bit type register with subscript [Description] The N.O. contact instruction sets the status of the B register to ON if the value of the referenced register is 1 (ON) and to OFF if the value of the referenced register is (OFF). [Operation of the Register] | Α | F | В | I | J | : stored ×: not stored | |---|---|---|---|---|-----------------------------------------------| | 0 | 0 | × | 0 | 0 | (Stored or not stored depending on the case.) | Example(s)] When MB000100 becomes ON, MB000101 becomes ON. N.C. Contact Instruction (-Coil Instruction ( #### N.C. Contact Instruction ( $\dashv$ / $\vdash$ ) .4.2 [Format] Any bit type register Any bit type register with subscript [Description] The N.C. contact instruction sets the status of the B register to OFF if the value of the referenced register is 1 (ON) and to ON if the value of the referenced register is 0 (OFF). [Operation of the Register] | I | A | F | В | I | J | |---|---|---|---|---|---| | I | 0 | 0 | × | 0 | 0 | : stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] When MB000100 becomes ON, MB000101 becomes OFF. # Coil Instruction ( → ) [Format] Any bit type register (except for # and C registers) Any bit type register with subscript (except for # and C registers) [Description] The coil instruction sets the status of the referenced register to 1 (ON) if the status of the immediately preceding B register is ON and to 0 (OFF) if the status of the immediately preceding B register is OFF. [Operation of the Register] ○: stored ×: not stored : indeterminate (Stored or not stored depending on the case.) When MB000100 becomes ON, MB000101 becomes ON. [Example(s)] ### 4.4.4 Set Coil / Reset Coil linstruction (-[S]+/-[R]+) [Format] Set Coil Any bit type register (except for # and C registers) Any bit type register with subscript (except for # and C registers) [S] Reset Any bit type register (except for # and C registers) Any bit type register with subscript (except for # and C registers) [R] [R] [Description] The set coil instruction turns the output ON when execution conditions are satisfied and maintains that ON status. Conversely, the reset coil instruction turns the output OFF when execution conditions are satisfied, and maintains that OFF status. #### [Operation of the Register] | Α | F | В | I | J | : stored X: not stored | |----|----|---|---|---|--------------------------------------------------------------------| | ,0 | .0 | × | 0 | 0 | * : indeterminate<br>(Stored or not stored depending on the case.) | #### [Example(s)] . <Example 1> Case where the same output destination is designated multiple times. The above example acts as in the graph below. - (1) When OB00000 is OFF, with the "set coil" instruction, OB00000 turns ON. - (2) When OB00000 is ON, with the "reset coil" instruction, OB00000turns | Set coil / Reset | coil instructions (-{SH/-{RH) | | | | | |----------------------------|-------------------------------|--|--|--|--| | Rising Pulse Instruction ( | | | | | | <Example 2> When all execution conditions are ON. This part of the program is processed assuming OB00000 is ON. OB00000 is processed as OFF. OB00000 is processed as ON. During operation processing, the contents of the output are rewritten with each step. In the above case, OB00000 is ultimately ON. # [Format] 1.4.5 Any bit type register (except for # and C registers) Any bit type register with subscript (except for # and C registers) [Description] With the rising pulse instruction, when the status of the immediately preceding B register changes from OFF to ON, the status of the B register turns ON and stays ON during one scan. The designated register is used for storage of the previous value of the B register. [Operation of the Register] | Α | F | В | Ι | J | ○: stored ×: not stored | |---|---|---|---|---|----------------------------------------------------------------| | 0 | 0 | × | 0 | 0 | *: indeterminate (Stored or not stored depending on the case.) | [Example(s)] When IB00001 turns ON from OFF, MB000101 turns ON and stays ON during 1 scan. MB000100 is used to store the previous value of IB00001. Table 4.10 Register Status with Rising Pulse Instruction | | Input | Result | | |-----------|-----------------------------|------------------|----------| | | MB000100 | MB000100 | | | . IB00001 | (Previous value of IB00001) | (IB00001 stored) | MB000101 | | OFF | OFF | OFF | OFF | | OFF | ON | OFF | OFF | | 3 ON: | of CITE | • ON | 0N:- | | ON | ON | ON | OFF | #### NOTE In the above example, the instruction is used not for rise detection of MB000100 be is used for rise detection of IB00001. MB000100 is used only for storing the previous value of IB00001. Please be careful not to make a mistake. #### [Format] Any bit type register (except for # and C registers) Any bit type register with subscript (except for # and C registers) [Description] With the falling pulse instruction, when the status of the immediately preceding B register changes from ON to OFF, the status of the B register turns ON and stays ON during 1 scan. The designated register is used for storage of the previous value of the B register. [Operation of the Register] | 1 | Α | F | В | _ I | J | : stored X: not stored | |---|---|---|---|-----|---|------------------------| | i | Ō | 0 | X | 0 | 0 | *: indeterminate | (Stored or not stored depending on the case.) [Example(s)] When IB00001 turns OFF, MB000101 turns ON and stays ON during 1 scan. MB000100 is used to store the previous value of IB00001. | Falling Pulse Instruction ( | |------------------------------------------------------------------------| | On-delay Timer Instruction: unit of measurement=0.01 seconds ( -(' )-) | Table 4.11 Register Status with Falling Pulse Instruction | | Input | Result | | |---------|-----------------------------|------------------|----------| | | MB000100 | MB000100 | | | IB00001 | (Previous value of IB00001) | (IB00001 stored) | MB000101 | | OFF | OFF | OFF | OFF | | OFF | ON | OFF | ON · | | ON | OFF | ON | OFF | | ON | ON | ON | OFF | #### NOTE In the above example, the instruction is used not for fall detection of MB000100 but is used for fall detection of IB00001. MB000100 is used only for storing the previous value of IB00001. Please be careful not to make a mistake. ### On-delay Timer Instruction: unit of measurement=0.01 seconds ( ⊣' ⊢ ) [Format] -['Set value Count value]- Set value : constant, any integer type register, or any integer type register with subscript (0 to 655.35sec: in 0.01sec unit) Count value: any integer type register (except for # and C registers), any integer type register with subscript (except for # and C registers) [Description] With the on-delay timer instruction, the time is counted while the status of the immediately preceding B register is ON. The status of the B register becomes ON when "Count value = Set value". The timer operation is stopped when the status of the immediately preceding B register becomes OFF in the middle of counting. When the B register turns ON again, the counting is started from the beginning (0.00s). A value equal to the actual counted time $\times$ 100 is stored in the count register. The on-delay timer instruction (-1') counts when the instruction is executed. Thus, exercise caution when using it in IF, WHILE, or FOR statement. #### (1) When used in IF structure statement. In the above example, when MB000000 is OFF, the instruction of timer ① is not executed, accordingly time is not counted. The time operation remains stopped. ### (2) When used in WHILE structure statement In the above example, since instruction sequence ① is executed 100 times ( $0 \le 99$ ), the timer ① is also executed 100 times. Thus, the time is counted for $10 \times 99$ scan time set value, so time is counted faster than real time. #### (3) When used in FOR structure statement In the above example, since instruction sequence ① is executed 100 times ( $0 \le 99$ ), the timer ① is also executed 100 times. Thus, the time is counted for $10 \times 99$ scan time set value, so time is counted faster than real time. ### [Operation of the Register] | Α | F | В | I | J | <pre>: stored × : not stored * : indeterminate</pre> | |---|---|---|---|---|------------------------------------------------------| | 0 | 0 | × | 0 | 0 | (Stored or not stored depending on the case.) | ### [Example(s)] #### NOTE MW00011 works as timer count register. Thus, it is essential that there is no overlap Set an unused register. Off-delay Timer Instruction: unit of measurement=0.01 seconds ( - 1 - ) ### Off-delay Timer Instruction: unit of measurement=0.01 seconds ( - 1 )- ) [Format] - Set value Count value'}- Set value : constant, any integer type register, or any integer type register with subscript (0 to 655.35sec: in 0.01sec unit) Count value: any integer type register (except for # and C registers), any integer type register with subscript (except for # and C registers) [Description] .4.8 With the off-delay timer instruction, the time is counted while the status of the immediately preceding B register is OFF. The status of the B register becomes OFF when "Count value = Set value". The timer operation is stopped when the status of the immediately preceding B register becomes ON in the middle of counting. When the B register turns OFF again, the counting is started from the beginning (0.00s). A value equal to the actual counted time X100 is stored in the count register. With the off-delay timer instruction, the time is counted when the instruction is executed. Therefore, pay attention when using the off-delay instruction in IF, WHILE, and FOR structure statement. #### (1) When used in IF structure statement In the above example, when MB000000 is OFF, the instruction of timer ① is not executed, time is not counted. The timer operation remains stopped. #### (2) When used in WHILE structune statement. In the above example, since instruction sequence ① is executed 100 times ( $0 \le I \le 99$ ), the timer ① is also executed 100 times. Thus, the time is counted for 100 $\times$ scan time set value, so time is counted faster than real time. #### (3) When used in FOR structure statement In the above example, since instruction sequence ① is executed 100 times ( $0 \le I \le 99$ ), the timer ① is also executed 100 times. Thus, the time is counted for 100 $\times$ scan time set value, so time is counted faster than real time. ### Off-delay Timer Instruction: unit of measurement=0.01 seconds ( + ') ### [Operation of the Register] | | • | - | | | | |---|---|-----|---|---|----------------------------------------------------------------| | Α | F | В | Ι | J | ○: stored ×: not stored | | 0 | 0 | . × | 0 | 0 | *: indeterminate (Stored or not stored depending on the case.) | | | | , | | | (Etoroa or not blorea acpending on the case.) | [Example(s)] #### NOTE In the above example, MW00011 functions as the count register of the timer. E sure to set an unused register for the count register so that an overlap will no occur. On-delay Timer Instruction: units of measurement=1 second (-{s}) ### On-delay Timer Instruction: unit of measurement=1 second ( ¬s → ) [Format] - Set value Count value - 4.9 Set value : constant, any integer type register, or any integer type register with subscript (0 to 65535sec: in 1sec unit) Count value: any integer type register (except for # and C registers), any integer type register with subscript (except for # and C registers) [Description] With the on-delay timer instruction, the time is counted while the status of the immediately preceding B register is ON. The status of the B register becomes ON when "Count value = Set value". The timer operation is stopped when the status of the immediately preceding B register becomes OFF in the middle of counting. When the B register turns ON again, the counting is started from the beginning (0s). A value equal to the actual counted time X1 is stored in the count register. With the off-delay timer instruction, the time is counted when the instruction is executed. Therefore, pay attention when using the on-day instruction in IF, WHILE, and FOR structure statement. #### (1) When used in IF structure statement In the above example, when MB000000 is OFF, the instruction of timer ① is not executed, time is not counted. The timer operation remains stopped. #### (2) When used in WHILE structure statement. In the above example, since instruction sequence ① is executed 100 times ( $0 \le I \le 99$ ), the timer ① is also executed 100 times. Thus, the time is counted for 100 $\times$ scan time set value, so time is counted faster than real time. #### (3) When used in FOR structure statement. In the above example, since instruction sequence ① is executed 100 times (0≦I ≦99), the timer ① is also executed 100 times. Thus, the time is counted for 100 × scan time set value, so time is counted faster than real time. 4-29 ### On-delay Timer Instruction: unit of measurement=1 second (-1s +) [Operation of the Register] | Ā | | F | В | I | J | |---|----------|---|---|---|---| | C | <u> </u> | 0 | × | 0 | 0 | : stored X: not stored \*: indeterminate (Stored or not stored depending on the case.) ### [Example(s)] #### NOTE In the above example, MW00011 functions as the count register of the timer. Be sure to set an unused register for the count register so that an overlap will not occur. Off-delay Timer Instruction: units of measurement=1 second ( + 5) ### .4.10 Off-delay Timer Instruction: unit of measurement=1 second ( - 1 5 ) ### [Format] - Set value Count value - Set value : constant, any integer type register, or any integer type register with subscript (0 to 65535sec: in 1sec unit) Count value: any integer type register (except for # and C registers), any integer type register with subscript (except for # and C registers) #### [Description] With the off-delay timer instruction, the time is counted while the status of the immediately preceding B register is OFF. The status of the B register becomes OFF when "Count value = Set value". The timer operation is stopped when the status of the immediately preceding B register becomes ON in the middle of counting. When the B register turns OFF again, the counting is started from the beginning (0s). A value equal to the actual counted time X1 is stored in the count register. With the on-delay timer instruction, the time is counted when the instruction is executed. Therefore, pay attention when using the on-delay instruction in IF, WHILE, and FOR structure statement. #### (1) When used in IF structure statement. In the above example, when MB000000 is OFF, the instruction of timer ① is not executed, time is not counted. The timer operation remains stopped. #### (2) When used in WHILE structure statement. In the above example, since instruction sequence ① is executed 100 times $(0 \le I \le 99)$ , the timer ① is also executed 100 times. Thus, the time is counted for 100 $\times$ scan time set value, so time is counted faster than real time. ### (3) When used in FOR structure statement In the above example, since instruction sequence ① is executed 100 times ( $0 \le I \le 99$ ), the timer ① is also executed 100 times. Thus, the time is counted for 100 $\times$ scan time set value, so time is counted faster than real time. ### Off-delay Timer Instruction: unit of measurement=1 second ( + s) ### [Operation of the Register] | Α | F | В | I | J | |----|---|---|---|---| | .0 | 0 | × | 0 | 0 | ○: stored ×: not stored : indeterminate (Stored or not stored depending on the case.) # [Example(s)] #### NOTE In the above example, MW00011 functions as the count register of the timer. Esure to set an unused register for the count register so that an overlap will no occur. ### **Examples of Relay Circuit Combinations** #### **Example of a Series Circuit** In the example below, relays are connected in series and their logical product is output to a coil. #### **Examples of Branched and Parallel Circuits** The branch indication element is used to branch the contents of the B register to several parts. The parallel connection indication element is used to determine the logical sum (OR) of a plurality of relays. In the examples below, relays are connected in series and in parallel and the result is output to a coil or to coils. (Example 1) Simple example of branching and parallel connection (Example 2) Example in which several branches and parallel connections are used #### **Example of a Sequence Circuit with Subscript** A relay number may be used with a subscript. In the example below, the logical product (AND) of relays MB000000 to MB00000F is determined and set in MB000010. # 4.5 Logical Operation Instructions The AND ( $\wedge$ ), OR ( $\vee$ ), and XOR ( $\oplus$ ) instructions are available as logical operation instructions. #### 4.5.1 AND Instruction [Format] Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Subscript register Constant [Description] The AND instruction outputs the logical product (AND) of the immediately preceding A register and the designated register to the A register. 1-bit Truth Table for the Logical Product (AND : $A \land B = C$ ) | Α | В | C | |-----|-----|---| | 0 | 0_ | 0 | | 0 | 1 | 0 | | : 1 | 0 | 0 | | , 1 | 1 - | 1 | [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | X | 0 | 0 | 0 | 0 | O: stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] The logical product of MW00100 and a constant is stored in MW00101. | ⊢ MW00100 | ↑ H 0 0FF | → MW00101 | |-----------|-----------|-----------| | (H1234) | (H 0 0FF) | (H0034) | | [ (H1234) | (HUUFF) | (110054) | | OR Instruction | | |-----------------|--| | XOR Instruction | | #### .5.2 OR Instruction [Format] Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Subscript register [Description] The OR instruction outputs the logical sum (OR) of the immediately preceding A register and the designated register to the A register. 1-bit Truth Table for the Logical Sum (OR: $A \lor B = C$ ) | Α | В | C | |---|---|---| | 0 | 0 | 0 | | 0 | 1 | 1 | | 1 | 0 | 1 | | 1 | 1 | 1 | Constant [Operation of the Register] | Α | F | В | Ι | J | |---|---|---|---|---| | × | 0 | 0 | 0 | 0 | O: stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] The logical sum of MW00100 and a constant is stored in MW00101. | ⊢MW00100 | | <b>⇒</b> MW00101 | |----------|----------|------------------| | (H1234) | (H00 FF) | (H12FF) | ### XOR Instruction [Format] 4.5.3 Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Subscript register Constant [Description] The XOR instruction outputs the exclusive logical sum (XOR) of the immediately preceding A register and the designated register to the A register. 1-bit Truth Table for the Exclusive Logical Sum (XOR: $A \oplus B = C$ ) | Α | В | C | |---|---|----| | 0 | 0 | 0 | | 0 | 1 | 1 | | 1 | 0 | 1_ | | 1 | 1 | 0 | [Operation of the Register] | | ` | | | | | |---|---|---|---|---|---| | İ | Α | F | В | I | J | | | × | 0 | 0 | 0 | 0 | O: stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] The exclusive logical sum of MW00100 and a constant is stored in MW00101. | ⊢MW00100 ⊕ H.0 0 FF | → MW00101 | |---------------------|-----------| | (H5555) (H.0 0 FF) | (H55AA) | # 4.6 Numerical Operation Instructions Data types include the integer type, the double-length integer type, and the real number type. Refer the Control Pack CP-9200SH User's Manual (SIE-C879-40.1) for details. ### 4.6.1 Integer Type Entry Instruction [Format] Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Subscript register Constant [Description] The integer type entry instruction enters data into the A register and starts an integ type operation. There on after, real number type data cannot be used until a real numb type entry instruction appears. [Operation of the Register] | Α | F | В | I | J | : stored X: not stored | |---|---|---|---|---|----------------------------------------------------------------| | × | 0 | 0 | 0 | 0 | *: indeterminate (Stored or not stored depending on the case.) | [Example(s)] The contents of MW00100 are entered in the A register. ⊢**MW00100** The contents of ML00100 are entered in the A register. ⊢ML00100 ML00100=66770 Lower 16 bits : MW00100 = 01234 = H04D2 Upper 16 bits : MW00101 = 00001 = H0001 ### Real Number Type Entry Instruction ( | ) [Format] .6.2 Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant [Description] The real number type entry instruction enters data into the F register and starts a real number type operation. The series of operations beginning with a real number type entry instruction can be programmed using integer, double-length integer, and real number type registers. When an integer or double-length integer type register is designated for a real number type entry instruction, the data is automatically converted to a real number type data upon execution. #### [Operation of the Register] | A | F | В | I | J | |---|---|---|---|---| | 0 | × | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored : indeterminate (Stored or not stored depending on the case.) #### [Example(s)] The content of DF00200 are entered in the F register. | ⊩DF00200 | | |----------|--| | | | | | | The integer type data in DW00100 are converted to real number type data and then stored in the F register. ``` ⊩ DW00100 ``` The double-length integer type data in DL00100 are converted to real number type data and then stored in the F register. #### **|⊢DL00100** | - DW00000<br>(00001) | ⇒ DF00010<br>(1.0E+00) | |-------------------------|---------------------------------| | ⊩ DL00001<br>(1234567) | <b>→ DF00012</b> (1.234567E+06) | | - DF00004<br>(-2.5E+00) | <b>⇒ DF00014</b> (-2.5E+00) | #### NOTE The following form of usage is not allowed. | <b>⊢</b> 12345 | <br>DF00200 | |----------------|-------------| | | | | Οι | T | | / : | $\overline{}$ | |---------|--------|--------|-----|---------------| | Storage | Instru | ection | ( ➡ | ) | # 4.6.3 | Storage Inst | ruction | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | [Format] | Any integer type register (except for # and C-registers) Any integer type register with subscript (except for # and C registers) Any double-length integer type register (except for # and C registers) Any double-length integer type register with subscript (except for # and C registers) Any real number type register (except for # and C registers) Any real number type register with subscript (except for # and C registers) Subscript register | | [Description] | The storage instruction stores the contents of the F register or the A register in the designated register. Whether the A register or the F register is selected is determined by the type of the immediately preceding entry instruction. In the contents of the A register are store in the Regis | | [Operation of | the Register] | | - | A F B I J C: stored X: not stored *: indeterminate (Stored or not stored depending on the case.) | | [Example(s)] | The contents of the A register are stored in MW00100. | | , | ⊢ 12345 | | | The contents of the A register are stored in ML00100. | | • | ⊢ 1234567 | | | The contents of the F register are stored in DF00100 as they are in the real number for | | | - 1.23456 | | | The contents of the F register are converted into integer form and then stored in DW0010 | | • | $ \vdash 1.234567 \qquad \Longrightarrow DW00100 $ $(00001)$ | | | The contents of the F register are converted into double-length integer form and stored in DL001 | | | ⊢ 123456.7 | | | NOTE (1) The following form of usage is not allowed. | | | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$ | | | #i | #### .6.4 Addition Instruction ( + ) [Format] Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant [Description] The addition instruction performs addition of integer type, double-length integer type, and real number type values. An overflow operation error will occur if the result of addition of integer type values is greater than 32767. An overflow operation error will occur if the result of addition of double-length integer type values is greater than 2147483647. #### [Operation of the Register] | A | F | В | I | J | |----|----|---|---|---| | *1 | *2 | 0 | 0 | 0 | : stored X: not stored : indeterminate (Stored or not stored depending on the case.) #### [Example(s)] Addition of integer type values | ⊢MW00100+12345 | ⇒ MW00101 | |-------------------|-----------| | (03000) | (15345) | | ⊢ ML00102+ML00104 | ⇒ ML00106 | | (100000) (200000) | (300000) | Addition of real number type values | - DF00200+1.23456 | ⇒ DF00202 | |---------------------------------------|------------------------------------| | (10.0) | (11.23456) | | - DF00204 + DW00206<br>(0.15) (00006) | $\Longrightarrow DF00208$ $(6.15)$ | | - DF00210+DL00212 | → DF00214 | | (3.51) (100000) | (100003.51) | ### NOTE In the case of double-length integer type values, an operation using addition and subtraction instructions (+, -, ++, --) will be a 32-bit operation. However, when an addition or subtraction instruction is used in a remainder correction operation (where a multiplication instruction (X) is the immediately preceding instruction and a division instruction ( \div ) is the immediately subsequent instruction), the operation will be a 64-bit operation. Remainder correction operation (y) = $$\frac{a \times b + c}{d}$$ <sup>\*1:</sup> Will not be stored if the operation starts with $a \models$ . Will be stored if the operation does not start with $a \models$ . <sup>\*2:</sup> Will not be stored if the operation starts with a |- . Will be stored if the operation does not start with a |- . ### 4.6.5 Subtraction Instruction ( - ) [Format] Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant [Description] The subtraction instruction performs subtraction of integer type, double-length integ type, and real number type values. An underflow operation error will occur if the subtraction result of integer type values is less than -32768. An underflow operation error will occur if the subtraction result of double-length integer type values is less than -2147483648. [Operation of the Register] | Α | F | В | I | J | |------|----|---|---|---| | . *1 | *2 | 0 | 0 | 0 | O: stored X: not stored \* : indeterminate (Stored or not stored depending on the case.) #### [Example(s)] Subtraction of integer type values | ⊢MW00100−12345<br>(03000) | $\longrightarrow MW00101 \\ (-09345)$ | |------------------------------------------|---------------------------------------| | ⊢ ML00102 − ML00104<br>(100000) (200000) | $\implies ML00106 \\ (-100000)$ | Subtraction of real number type values | - DF00200 1.23456 | → DF00202 | |---------------------|-------------| | (10.0) | (8.76544) | | - DF00204 - DW00206 | ⇒ DF00208 | | (0.15) (00006) | (-5.85) | | - DF00210 - DL00212 | ⇒ DF00214 | | (3.51) (100000) | (-99996.49) | #### NOTE In the case of double-length integer type values, an operation using addition are subtraction instructions (+, -, ++, -) will be a 32-bit operation. However, when a addition or subtraction instruction is used in a remainder correction operation (when a multiplication instruction $(\times)$ is the immediately preceding instruction and division instruction $(\div)$ is the immediately subsequent instruction), the operation will be a 64-bit operation. Remainder correction operation (y) = $$\frac{a \times b + c}{d}$$ $\vdash ML00400 \times ML00402 + ML00404 \div ML00406$ $\Longrightarrow ML00408$ MOD $\Longrightarrow ML00404$ <sup>\*1:</sup> Will not be stored if the operation starts with a |- . Will be stored if the operation does not start with a |- <sup>\*2:</sup> Will not be stored if the operation starts with a |- . Will be stored if the operation does not start with a |- ### Extended Addition Instruction (++) [Format] .6.6 ++ Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Subscript register Constant Cannot be used in a real number type operation begins with a real number type entry instruction ( |- ). [Description] The extended addition instruction performs addition of integer type values. An operation error will not occur even if the operation results in an overflow. Otherwise, the extended addition instruction is identical to the addition instruction in function. $: 0 \to 1 \cdots 32767 \to -32768 \cdots -1 \to 0$ Decimal numbers Integer type l Hexadecimal numbers : $0000 \rightarrow 0001 \cdots 7FFF \rightarrow 8000 \cdots FFFF \rightarrow 0000$ Double-length Decimal numbers $: 0 \rightarrow 1 \cdots 2147483647 \rightarrow -2147483648 \cdots -1 \rightarrow 0$ $\rightarrow$ 80000000···FFFFFFFF $\rightarrow$ 00000000 [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | × | 0 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored : indeterminate (Stored or not stored depending on the case.) [Example(s)] This instruction is used in cases where it is desirable that operation errors do not occur in the addition of integer type values. | ├-MW00100++00001 | <b>⇒</b> MW00101 | |------------------|------------------| | (32767) | (-32768) | #### NOTE In the case of double-length integer type values, an operation using addition and subtraction instructions (+, -, ++, --) will be a 32-bit operation. However, when an addition or subtraction instruction is used in a remainder correction operation (where a multiplication instruction (X) is the immediately preceding instruction and a division instruction (÷) is the immediately subsequent instruction), the operation will be a 64-bit operation. Remainder correction operation (y) = $\frac{a \times b + c}{a}$ $$\begin{array}{ccc} & a & b & c & d \\ \vdash ML00400 \times ML00402 + ML00404 \div ML00406 & & & & \\ MOD & & & & & \\ MOD & & & & & \\ \end{array}$$ #### 4.6.7 Extended Subtraction Instruction ( -- ) [Format] Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Subscript register Constant Cannot be used in a real number type operation begin with a real number type entry instruction ( | [Description] The extended subtraction instruction performs subtraction of integer type values. operation error will not occur even if the operation results in an underflow. Otherwise the extended subtraction instruction is identical to the subtraction instruction in function Integer type Decimal numbers : $0 \rightarrow 1 \cdots 32767 \rightarrow 32768 \cdots 1 \rightarrow 0$ Hexadecimal numbers : $0000 \rightarrow FFFF \cdots 8000 \rightarrow 7FFF \cdots 9001 \rightarrow 9000$ : 0 → -1···-2147483648 → -2147483647···1 − Double-length Decimal numbers $\rightarrow$ 7FFFFFFF···00000001 $\rightarrow$ 00000000 [Operation of the Register] | Α | F | В | I | J | |---|---|----|---|---| | × | 0 | 0. | 0 | 0 | $\supset$ : stored $\times$ : not stored : indeterminate (Stored or not stored depending on the case.) [Example(s)] This instruction is used in cases where it is desirable that operation errors do not occur in the subtraction of integer type values. | ⊢ | MW0010000001 | → MW00101 | | |---|--------------|-----------|--| | | (-32768) | (32767) | | #### NOTE In the case of double-length integer type values, an operation using addition ar subtraction instructions (+, -, ++, --) will be a 32-bit operation. However, when an addition or subtraction instruction is used in a remainde correction operation (where a multiplication instruction ( $\times$ ) is the immediate preceding instruction and a division instruction $(\div)$ is the immediately subsequent instruction), the operation will be a 64-bit operation. Remainder correction operation (y) = $\frac{a \times b + c}{a}$ → MW00400×ML00402+ML00404÷ML00406 ML00408 MOD ML00404 Multiplication Instruction ( × ) ### 4.6.8 Multiplication Instruction ( $\times$ ) [Format] × [ Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant [Description] The multiplication instruction performs multiplication of integer type, double-length integer type, and real number type values. In the case of the multiplication of integer or double-integer type values, $\times$ and $\div$ are used as a pair. However, if an integer type multiplication result is to be stored in a double-length integer type register, only $\times$ is used. #### [Operation of the Register] | Α | F | В | I | J | |----|----|---|---|---| | *1 | *2 | 0 | 0 | 0 | O: stored X: not stored \*: indeterminate (Stored or not stored depending on the case.) ### [Example(s)] Multiplication of integer type values | ⊢ MW00100×3÷10 | ⇒ MW00101 | | |--------------------|-----------|--| | (01234) | (00370) | | | ⊢MW00102×MW00103÷1 | → ML00104 | | | (00010) (10000) | (100000) | | ### Multiplication of double-length integer type values ``` ⊢ML00100×ML00102÷18000 ⇒ ML00104 (100000) (050000) ⊢ML00106×ML00108÷ML00110 ⇒ ML00112 (100000) (100000) (50000) ``` #### Multiplication of real number type values | - DF00200 × DF00100 | → DF00202 | |-------------------------------------|-----------------| | (10.0) (3.0) | (30.0) | | - DF00204×DW00206<br>(0.15) (00002) | ⇒ DF00208 (0.3) | | - DF00210×DL00212 | ⇒ DF00214 | | (0.15) (100000) | (15000.0) | #### NOTE With integer type and double-length integer type multiplication, $\times$ instruction can be used also independently. However, in this case, make a program so that the result is within 32 bits (-2147483648 to +2147483647). When the result is within 16 bits (-32768 to +32767), it can be stored in integer type register. When the result exceeds 16 bits, store it in double-length integer type register. | | | <del></del> | | | | |-----------|---|-------------|-------------------|-------------|--| | ⊢ MW00100 | × | 3 | <b></b> → | MW00101 | | | (01234) | | | | (03702) | | | ⊢ MW00102 | × | MW00103 | $\Longrightarrow$ | ML00104 | | | (00010) | | (10000) | | (100000) | | | ⊢ ML00200 | × | ML00202 | $\Longrightarrow$ | ML00204 | | | (100000) | | (009000) | | (900000000) | | <sup>\*1:</sup> Will not be stored if the operation starts with a |- . Will be stored if the operation does not start with a |- . <sup>\*2:</sup> Will not be stored if the operation starts with a |-. Will be stored if the operation does not start with a |-. ### 4.6.9 Division Instruction ( $\div$ ) [Format] Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant [Description] The division instruction performs division of integer type, double-length integer type and real number type values. Although $\times$ and $\div$ are usually used as a pair, $\div$ can a be used alone. Refer to the MOD instruction and the REM instruction concerning to remainder of a division operation. If the value of the designated register is 0, a division by-zero error will occur. An operation error will also occur if the result of integer, doublength integer, or real number type division in the F register falls outside the numeric range of the A register. #### [Operation of the Register] | A | F | В | I | J | : stored X: not stored | |----|----|---|---|---|-----------------------------------------------| | *1 | *2 | 0 | 0 | 0 | (Stored or not stored depending on the case.) | <sup>\*1:</sup> Will not be stored if the operation starts with a | . Will not be stored if the operation does not start with a | . ### [Example(s)] Division of integer type values | ⊢MW00100×1÷3 | ⇒ MW00101 | |---------------------|-----------| | (01234) | (00411) | | ├ MW00102 ÷ MW00103 | → MW00104 | | (01234) (00003) | (00411) | #### Division of double-length integer type values | ⊢ML00100×ML00102÷<br>(100000) (100000) | → ML00112<br>(200000) | |----------------------------------------|-----------------------| | ⊢ML00104÷ML00110<br>(1000000) (50000) | ⇒ ML00114<br>(000020) | #### Division of real number type values | - DF00200÷3.0 | ⇒ DF00202 | |-----------------------------------------|---------------------------------------| | (1237.5) | (412.5) | | - DF00200 ÷ DF00204<br>(1237.5) (3.0) | $\Longrightarrow DF00206$ $(412.5)$ | | - DF00200 ÷ DW00208<br>(1237.5) (00003) | $\Longrightarrow DF00210 \tag{412.5}$ | | - DF00212÷DL00214 | ⇒ DF00216 | | (100000.0) (40000) | (2.5) | <sup>\*2:</sup> Will not be stored if the operation starts with a |- . Will be stored if the operation does not start with a |-. | <br> | |-----------------| | MOD Instruction | | REM Instruction | #### 6.10 MOD Instruction [Format] MOD [Description] The MOD instruction outputs the remainder of an integer type or double-length integer type division to the A register. Execute the MOD instruction immediately after the division instruction or after the storage instruction ( $\Longrightarrow$ ). If the MOD instruction is not executed immediately after the division instruction, the remainder of an integer type or double-length integer division will not be guaranteed. [Operation of the Register] | A | F | В | I | J | |---|---|---|---|---| | × | 0 | 0 | 0 | 0 | ○: stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] The quotient of an integer type division is stored in MW00101 and the remainder is stored in MW00102. | ⊢MW00100 ×<br>(00010) | 1 | ÷ | 3 | → MW00101<br>(00003) | |-----------------------|---|---|---|----------------------| | MOD | | | | $\implies$ MW00102 | | | | | | (00001) | The quotient of a double-length integer type division is stored into ML00106 and the remainder is stored in ML00108. | ⊢ ML00100<br>(100000) | X | ML00102<br>(60000) | ÷ ML00104 (34567) | ⇒ ML00106<br>(173575) | |-----------------------|---|--------------------|-------------------|-----------------------| | MOD | | | | <b>→ ML00108</b> | | | | | • | (32975) | (Note): The quotient and remainder are generally determined together. It will thus be convenient to use the instructions in the above manner. # REM Instruction [Format] .6.11 REM Any real number type register Any real number type register with subscript Constant [Description] The REM instruction outputs the remainder of a real number type division to the F register. In this case, the remainder refers to the remainder obtained by repeatedly subtracting the variable value designated by the F register. That is, the output value Y of the REM instruction will be as follows when the F register value is A, the value of the designated variable is X, and the number of repeated subtractions is n: $$Y = A - (X \times n) \qquad (0 \le Y < X)$$ [Operation of the Register] | <br>, | <b>9</b> , | , | | | | |-------|------------|---|---|---|----------------------------------------------------------------| | Α | F | В | I | J | O: stored ×: not stored | | 0 | × | 0 | 0 | 0 | * : indeterminate (Stored or not stored depending on the case) | | | | | | | | [Example(s)] The remainder of the division of the real number variable MF00200 by the constant value, 1.5, is determined and stored in MF00202. | -MF00200 | REM | 1.5 | ⇒ MF00202 | |----------|-----|-----|-----------| | (4.0) | | | (1.0) | ### 4.6.12 INC Instruction [Format] INC Any integer type register (except for # and C registers) Any integer type register with subscript (except for # and C registers) Any double-length integer type register (except for # and C registers) Any double-length integer type register with subscript (except for # and C registers) C registers) Subscript register [Description] The INC instruction adds 1 to the designated integer or double-length integer ty register. In the case of an integer type register, an overflow operation error will no occur even if the addition result exceeds 32767. Likewise, an overflow operation error will not occur in the case of a double-length integer type register. Integer Type Decimal number $: 0 \to 1 \times 32767 \to -32768 \times -1 \to 0$ Hexadecimal number : $0000 \rightarrow 0001 \cdots 7FFF \rightarrow 8000 \cdots FFFF \rightarrow 0000$ Double-length Integer Type Decimal number $: 0 \to 1 \times 2147483647 \to -2147483648 \times -1 \to 0$ Hexadecimal number : $00000000 \rightarrow 00000001 \cdots 7FFFFFFF \rightarrow 80000000$ $\cdots$ FFFFFFFF $\rightarrow$ 00000000 [Operation of the Register]. | Α | F | В | I | J | |---|---|---|---|---| | 0 | 0 | 0 | 0 | 0 | O: stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] Integer type INC MW00100 Double-length integer type equivalent INC ML00100 #### NOTE The following form of usage is not allowed. INC #W00100 (# register) INC DF00200 (real number type register) **DEC** Instruction #### .6.13 DEC Instruction [Format] DEC Any integer type register (except for # and C registers) Any integer type register with subscript (except for # and C registers) Any double-length integer type register (except for # and C registers) Any double-length integer type register with subscript (except for # and C registers) Subscript register [Description] The DEC instruction subtracts 1 from the designated integer or double-length integer type register. In the case of an integer type register, an underflow operation error will not occur even if the subtraction result falls below -32768. Likewise, an underflow operation error will not occur in the case of a double-length integer type register. Integer Type Decimal number $: 0 \rightarrow -1 \cdots -32768 \rightarrow 32767 \cdots 1 \rightarrow 0$ Hexadecimal number: $0000 \rightarrow FFFF \cdots 8000 \rightarrow 7FFF \cdots 0001 \rightarrow 0000$ Double-length Integer Type Decimal number $: 0 \rightarrow -1 \cdots -2147483648 \rightarrow 2147483647 \cdots 1 \rightarrow 0$ Hexadecimal number: 00000000 → FFFFFFFFF......80000000 → 7FFFFFFF $\cdots \cdots 000000001 \rightarrow 000000000$ [Operation of the Register] | | Α | F | В | I | J | |---|---|---|---|---|---| | 1 | 0 | 0 | 0 | 0 | 0 | ○: stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] Integer type #### NOTE The following form of usage is not allowed. DEC #W00100 (# register) DEC DF00200 (real number type register) #### 4.6.14 Time Add Instruction (TMADD) [Format] [Time to be added] [Time to add] TMADD Any integer type register (except for # and C registers) Any integer type register with subscript (except for # and C registers) Any integer type register Any integer type register with subscript [Description] The TMADD instruction performs addition on two time data (seconds, minutes, hour The second parameter (time to add) is added to the first parameter (time to be added and the result is stored in the first parameter. It is essential that the formats parameters 1 and 2 should be as shown in Table 4.12. Table 4.12 Parameter Format | Register offset | Data contents | Data range (BCD) | |-----------------|---------------|-------------------------------| | . 0 | Hours/minutes | Upper byte (hours): 0 to 23, | | . : | | Lower byte (minutes): 0 to 59 | | 1 | Seconds | 0000 to 0059 | When the contents of the first parameter, second parameter, and operation result are the data ranges listed above, the operation is performed normally. After operation, the B register turns OFF. Conversely, if a parameter has data that exceeds the above range "9999H" is stored for the seconds of the parameter and the operation is stopped. The the B register turns ON. # [Operation of the Register] | Α | F | В . | I | J | |---|---|-----|---|---| | 0 | Ö | × | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored : indeterminate (Stored or not stored depending on the case.) [Example(s)] The time data in DW0000-DW0001 is added to the time data in MW00100-MW0010 | TMADD MW00100, DW0000 | DB000100 | |-----------------------|----------| | | | 8 hrs 40 min 32 sec + 1 hs 22 min 16 sec = 10 hrs 2 min 48 sec(DW00000) (DW00001) (MW00100) (MW00101) (MW00100) (MW00101) | | Before execution | After execution | |---------|------------------|-----------------| | MW00100 | 0840H | 1002H | | MW00101 | 0032H | 0048H | | DW00000 | 0122H | 0122H | | DW00001 | 0016H | · 0016H | Time Subtraction Instruction (TMSUB) # Time Subtraction Instruction (TMSUB) [Format] .6.15 [Time subtracted from] [Time subtracted] TMSUB [Any integer type register (except for # and C registers) Any integer type register with subscript (except for # and C registers) Any integer type register Any integer type register with subscript [Description] The TMSUB instruction makes subtraction between two time data (hour/min/sec). The second parameter (time subtracted) is subtracted from the first parameter (time subtracted from), and the result is stored in the first parameter. The formats of the first and second parameters must be as shown in Table 4.13. Table 4.13 Parameter Format | Register offset | Data contents | Data range (BCD) | | |-----------------|---------------|-------------------------------|--| | 0 | Hours/minutes | Upper byte (hours): 0 to 23, | | | | | Lower byte (minutes): 0 to 59 | | | 1 | Seconds | 0000-0059 | | When the contents of the first parameter, second parameter, and operation result are in the data ranges listed above, the operation is performed normally. After opreation, the B register turns OFF. Conversely, if a parmeter has data that exceeds the above range, "9999H" is stored for the seconds of the parameter and the operation is stopped. Then the B register turns ON. # [Operation of the Register] | A | F | В | I | J | |---|---|---|---|---| | 0 | 0 | × | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored : indeterminate (Stored or not stored depending on the case.) [Example(s)] The time data in DW0000-DW0001 is subtracted from the time data in MW00100-MW00101. | | | | DB000100 | |-------|----------|---------|-------------| | TMSUB | MW00100, | DW00000 | <del></del> | 1 hs 22 min 16 sec = 7 hrs 18 min 16 sec<u>8 hrs 40 min 32 sec</u> – (MW00100) (MW00101) (DW00000) (DW00001) (MW00100) (MW00101) | | Before execution | After execution | |---------|------------------|-----------------| | MW00100 | 0840H | 0718H | | MW00101 | 0032H | 0016H | | DW00000 | 0122H | 0122H | | DW00001 | 0016H | 0016H | #### 4.6.16 Time Spend Instruction (SPEND) [Format] [Time being subtracted from and result] [Time subtracted] SPEND[Any integer type register] (except for # and C registers) Any integer type register with subscript (except for # and C registers) Any integer type register. Any integer type register with subscript [Description] The SPEND instruction performs subtraction between two time data (Yr/Mo/Day/Hi Min/Sec), and computes the elapsed time. The second parameter (time subtracted) is subtracted from the first parameter (tim subtracted from), and the result is stored in the first parameter. The formats of the first and second parameters must be as shown in Tables 4.14 an 4.15. **Table 4.14 First Parameter Format** | | · · · · · · · · · · · · · · · · · · · | | , | |-----------------|---------------------------------------|-------------------------------|--------| | Register offset | Data contents | Data range (BCD) | I/O | | 0 | Year (BCD) | 0000 to 0099 | IN/OUT | | 1 | Month/Day (BCD) | Upper byte (month): 1 to 12, | IN/OUT | | , | - | Lower byte (day): 1 to 31 | | | 2 | Hours/minutes (BCD) | Upper byte (hours): 0 to 23, | IN/OUT | | | | Lower byte (minutes): 0 to 59 | | | 3 | Seconds (BCD) | 0000 to 0059 | IN/OUT | | , <b>4</b> | Total number of seconds | This is the number of records | OUT | | + + + | : | which is obtained by | | | | | converting Year/Month/Day/ | E | | 5 | • | Hour/Minute/Second, which is | | | | : | the results of operations, to | | | E | | seconds. (Double-length | 1 | | | • | integer) | | **Table 4.15 Second Parameter Format** | Register offset | Data contents | Data range (BCD) | I/O | |-----------------|---------------------|---------------------------------------------------------------|-----| | 0 | Year (BCD) | 0000 to 0099 | IN | | 1 | Month/Day (BCD) | Upper byte (month): 1 to 12,<br>Lower byte (day): 1 to 31 | IN | | , 2 | Hours/minutes (BCD) | Upper byte (hours): 0 to 23,<br>Lower byte (minutes): 0 to 59 | IN | | 3 | Seconds (BCD) | 0000 to 0059 | IN | When the contents of the first parameter, second parameter, and operation result are in the data ranges listed above, the operation is performed normally. After operation the B register turns OFF. Conversely, if a parameter has data that exceeds the above range, "9999H" is stored for the seconds of the parameter and the operation is stopped Then the B register turns ON. ## [Operation of the Register] | A F | | В | I | J | |-----|---|---|---|---| | 0 | 0 | × | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored : indeterminate (Stored or not stored depending on the case.) Time Spend Instruction (SPEND) [Example(s)] The time elapsed from the time data in MW00100 to MW00103 to the time data in DW000000 to DW000003 is stored to MW00100 to MW00105. | | | DB000100 | |-------|------------------|---------------| | SPEND | MW00100, DW00000 | <del></del> 0 | 98 yrs 5 mos 11 days 15 hrs 4 min 47 sec — 98 yrs 4 mos 2 days 8 hs 13 min 8 sec (MW00100) (MW00101) (MW00102) (MW00103) (DW00000) (DW00101) (DW00102) (DW00103) | | Before execution | After execution | |---------|------------------|-----------------| | MW00100 | H0098 | H0000 | | MW00101 | H0511 | H0039 | | MW00102 | H1504 | H0651 | | MW00103 | H0047 | H0039 | | MW00104 | | 3394299 | | MW00105 | <del>_</del> | (Decimal) | | DW00000 | H0098 | H0098 | | DW00001 | H0402 | H0402 | | DW00002 | H0813 | H0813 | | DW00003 | H0008 | H0008 | #### NOTE In the operation results, the year is counted as 365 days and a leap year is not taken into consideration. Also, the number of months is not counted. It is counted in days. # 4. 7 Numerical Conversion Instructions The 6 types of numerical conversion instructions shown in Table 4.16 are made available as instruction for changing the contents of the A register or the F register. These instructions use the contents of the A register or the F register as the input and leaves the operation result in the A register or F register. **Table 4.16 Numerical Conversion Instructions** | Numerical Conversion | | Operation | | | |-----------------------------|----------------------------|-----------|----------------|-----------------------------------------------------------------------------| | Instruction | Turkensus Double sembers | | Real<br>Number | Numerical Conversion Operation | | Sign inversion (INV) | . 0 | 0 | O | Inverts the sign of the contents of the A register or F register. | | Complement of 1 (COM) | , 0 | 0 | × | Determines the complement of 1 of the value in the A register. | | Absolute value (ABS) | 0 | 0 | 0. | Determines the absolute value of the value in the A register or F register. | | BIN conversion (BIN) | 0 | ,<br>O | × | Performs BIN conversion of the contents of the register. | | BCD conversion (BCD) | 0 | 0 | × | Performs BCD conversion of the contents of the A register. | | Parity conversion (PARITY) | ,0 | 0 | <b>×</b> | Counts the number of bits in the A register that are ON. | | ASCII conversion 1 (ASCII) | . 0 | × | × | Converts the designated character string to ASCII codes. | | ASCII conversion 2 (BINASC) | 0 | × | × | Converts the binary data in A register to ASCII codes. | | ASCII conversion 3 (ASCBIN) | 0 | × | × | Converts the ASCII codes to binary data and stores them in A register. | #### 4.7.1 INV Instruction [Format] INV [Description] Inverts the sign of the contents of the A register or F register. [Operation of the Register] | . A | F | В | I | J | : stored ×: not stored | |-----|----|---|---|---|----------------------------------------------------------------| | *1 | *2 | 0 | 0 | 0 | *: indeterminate (Stored or not stored depending on the case.) | <sup>\*1:</sup> Will not be stored if the operation starts with a | . Will be stored if the operation does not start with a | . [Example(s)] Integer type data (A register) | ⊢MW00100<br>(00100) | INV | MW00101<br>(-00100) | |---------------------|-----|---------------------| | (30100) | | ( 00100) | Double-length integer type data (A register) | ⊢ ML00100<br>(100000) | INV | $\longrightarrow \text{ML00102} \atop (-100000)$ | |-----------------------|-----|--------------------------------------------------| |-----------------------|-----|--------------------------------------------------| Real number type data (F register) | - DF00200<br>(1.0) | INV | ⇒ DF00202<br>(-1.0) | |--------------------|-----|---------------------| |--------------------|-----|---------------------| <sup>\*2:</sup> Will not be stored if the operation starts with a 📙 . Will be stored if the operation does not start with a 📙 . COM Instruction ABS Instruction # COM Instruction [Format] .7.2 COM [Description] Determines the complement of 1 of the value in the A register. [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | × | 0 | 0 | 0 | 0 | : stored × : not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] Integer type data (A register) Double-length integer type data (A register) #### 1.7.3 ABS Instruction [Format] ABS [Description] Determines the absolute value of the value in the A register or F register. [Operation of the Register] | 1 | Α | F | В | I | J | |---|----|----|---|---|---| | | *1 | *2 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) \*1 : Will not be stored if the operation starts with a 📙 . Will be stored if the operation does not start with a 📙 . \*2: Will not be stored if the operation starts with a |- . Will be stored if the operation does not start with a |- . [Example(s)] Integer type data (A register) | ⊢ MW00100<br>(-00100) | ABS | $\Rightarrow^{\mathbf{MW00101}}_{(00100)}$ | |-----------------------|-----|--------------------------------------------| Double-length integer type data (A register) | - ML00100 ABS | ⇒ ML00102<br>(100000) | |---------------|-----------------------| | (-100000) | (100000) | Real number type data (F register) | ⊩ DF00200 ABS<br>(-1.0) | $\Rightarrow^{\mathbf{DF00202}}_{(1.0)}$ | |-------------------------|------------------------------------------| |-------------------------|------------------------------------------| # 4.7.4 BIN Instruction [Format] BIN [Description] This instruction converts a numeral expressed in BCD in the A register into a bina number (BIN conversion). If the (4-digit) numeral expressed in BCD in the integer ty A register is abcd, the output value Y of the BIN instruction can be determined by t following formula: $$Y = (a \times 1000) + (b \times 100) + (c \times 10) + d$$ Although the above formula will be applied even if the numeral in the A register is r of a BCD expression (e.g. 123FH, etc.), a correct result will not be obtained in su cases. # [Operation of the Register] | _ | | | | | | |---|---|---|---|---|---| | | Α | F | В | I | J | | Ī | × | 0 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] Integer type data (A register) |--| Double-length integer type data (A register) | ⊢ ML00100 BIN | . ML00102 | |---------------|--------------| | (H12345678) | ⇒(D12345678) | | (1112010010) | (222323), | #### 4.7.5 BCD Instruction [Format] BCD [Description] This instruction converts a numeral expressed in binary in the A register into a BC expression (BCD conversion). If the (4-digit) decimal expression of the numeral in the integer type A register is 0abcd, the output value Y of the BCD instruction can be determined by the following formula: $$Y = (a \times 4096) + (b \times 256) + (c \times 16) + d$$ Although the above formula will be applied even if the numeral in the A register cann be expressed in BCD (e.g. a number over 9999, negative numbers, etc.), a correct result not be obtained in such cases. # [Operation of the Register] | | | | <del>,</del> - | | |---|---|---|----------------|---| | A | F | В | I | J | | Х | 0 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) #### [Example(s)] Integer type data (A register) | | | - | |---------------------------|-----------------------------------------------------|---| | ⊢ MW00100 BCD<br>(D01234) | $\Rightarrow^{\mathbf{MW00101}}_{\mathbf{(D1234)}}$ | • | Double-length integer type data (A register) | ⊢ ML00100 BCD | ⇒ML00102 | |---------------|---------------------------| | (D12345678) | $\Rightarrow$ (H12345678) | | PARITY Instruction | |--------------------| | ASCII Instructions | ## .7.6 PARITY Instruction [Format] PARITY [Description] This instruction is used to compute the number of binary expression bits that are ON (=1) in the A register. [Operation of the Register] | A | F | В | I | J | |---|---|---|---|---| | × | 0 | 0 | 0 | 0 | ○: stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] Integer type data (A register) Double-length integer type data (A register) #### ASCII Instruction [Format] .7.7 [Storage register number] [Text] | ASCII | Any integer type register (except for # and C registers) | |-------|------------------------------------------------------------------------| | | Any integer type register with subscript (except for # and C registers | " ASCII characters [Description] The ASCII instruction converts the specified character string in the instruction to ASCII codes, and stores them in the designated storage register. These are stored in the order: first character, lower byte of the first word, second character, upper byte of the first word. If the length of the character string is odd, the upper byte of the last word in the storage register is a 0. A maximum of 32 characters may be entered. ASCII VW □□□□□ ← "character string" [Operation of the Register] | Α | F | В | I | J | ○: stored ×: not stored *: indeterminate | |---|---|---|---|---|-----------------------------------------------| | 0 | 0 | 0 | 0 | 0 | (Stored or not stored depending on the case.) | [Example(s)] (1) The character string "ABCD" is stored in MW00100 to MW00101. | ASCI | I MW0 | 0100 "AB | CD" | | |------|--------|-----------|-----------|---------------| | | | Upper | Lower | | | MV | V00100 | 42H ('B') | 41H ('A') | MW00100=4241H | | MV | V00101 | 44H ('D') | 43H ('C') | MW00101=4443H | **ASCII Instruction** **BINASC Instructions** [Format] (2) The character string "ABCDEFG" is stored in MW00100 to MW00103. | $\overline{}$ | - | | | | | | | | |---------------|-------|---------------|-----------|---|---|--|--|--| | ١. | ACCTT | MW00100 | "ABCDEEC" | , | 1 | | | | | ١ ٠ | ADOH | TAT AA OO TOO | ABCDEFG | | | | | | | | | | | | | | | | | | Upper | Lower | . , | |---------|-----------|-----------|-----------------| | MW00100 | 42H ('B') | 41H ('A') | MW00100=4241H | | MW00101 | 44H ('D') | 43H ('C') | - MW00101=4443H | | MW00102 | 46H ('F') | 45H ('E') | MW00102=4645H | | MW00103 | 00H | 47H ('G') | MW00103=0047H | A "0" is entered in the extra byte. #### 4.7.8 BINASC Instruction [Format] [Storage register number] BINASC Any integer type register (except for # and C registers) Any integer type register with subscrip Any integer type register with subscript (except for # and C register) [Description] The BINASC instruction converts the 16-bit binary data stored in the A register to four digit hexadecimal ASCII code and stores it in the designated storage register (twoords). | | Upper byte | | Lower byte | | |---------------|-----------------|---|------------------|-----------------| | VW 00000 | Third digit (Y) | : | Fourth digit (X) | | | VW [][][][]+1 | First digit (W) | : | Second digit (Z) | V=S, I, O, M, I | [Operation of the Register] | | | 1 | | | O atomo | |---|----|---|---|---|-----------| | Α | F | B | I | J | │ | | 0 | O, | 0 | 0 | 0 | (Stored o | : stored × : not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] The "1234H" binary data stored in the A register is converted to a four digit hexadecim ASCII code and stored in MW00100 to MW00101. | | | · · · · · · · · · · · · · · · · · · · | | |--|--------|---------------------------------------|--| | | H1234 | | | | | BINASC | MW00100 | | | | | | | | | Upper byte | Lower byte | | |---------|-------------|------------|---------------| | MW00100 | 32H ('2') : | 31H ('1') | MW00100=3231H | | MW00101 | 34H ('4') | 33H ('3') | MW00101=3433H | ASCBIN Instruction # ASCBIN Instruction [Format] 7.9 [Storage register number] ASCBIN Any integer type register Any integer type register with subscript [Description] The ASCBIN instruction converts a numerical value expressed in a four digit hexadecimal ASCII code to 16-bit binary data. The converted result is stored in the A register. In the case of ASCBIN VW DDDDD (Conversion source register) Conversion source register A register | | Upper byte | Lower byte | | Upper | Lower | |------------|-----------------|------------------|-------------------|------------------------------------|-------| | VW 🗆 🗆 🗆 🗆 | Third digit (Y) | Fourth digit (X) | ] <del>&gt;</del> | XY | ZW | | VW 00000+1 | First digit (W) | Second digit (Z) | ] ' | | | | | | | . V=S I | $\mathbf{O} \mathbf{M} \mathbf{D}$ | | [Operation of the Register] | Α | F | В | 1 | J | |---|---|---|---|---| | X | 0 | 0 | 0 | 0 | O: stored ×: not stored : indeterminate (Stored or not stored depending on the case.) [Example(s)] The four-byte ASCII code stored in MW00100 to MW00101 is converted to two-byte binary data, and the result is stored in MW00200. | AS | CBIN | MW00100 | ⇒ MW00200 | |----|------|---------|-----------| Data to be converted A register | | Upper | Lower | | | Upper | Lower | |---------|-----------|-----------|---------------|---------|----------|-------| | MW00100 | 32H ('2') | 31H ('1') | $\rightarrow$ | MW00200 | 12H | 34H | | MW00101 | 34H ('4') | 33H ('3') | | | <u> </u> | | # 4.8 Numerical Comparison Instructions #### 4.8.1 Comparison Instructions There are 6 types of comparison instructions for comparing numerals and inspecting equivalen relationships. [Description] A comparison instruction stores the result of comparison of the immediately preceding A or F register and the designated register in the B register (ON when true). [Operation of the Register] | A | F | В | I | J | |---|---|---|---|---| | | 0 | × | 0 | 0 | ○: stored ×: not stored : indeterminate (Stored or not stored depending on the case.) [Example(s)] (1) If the value of MW00100 is not 100, the instructions from IFON and below a executed. (2) If you want to use the comparison result in a subsequent instruction, it is convenied to accept the comparison result with the coil. Unless the value of MW00100 is 10 MW00010A is set to ON. Comparison Instruction #### **NOTE** 1. Use the NO contact instruction if an IFON (IFOFF) or ON (OFF) instruction is to be used after receiving the comparison result with a coil. - 3. In the case of real number type data, since there is a minute precision difference in the data displayed on the CP-717, the execution result of a comparison instruction may not coincide with an apparent result. - 4. Do not use instructions other than coil instruction when receiving the comparison result with a coil. # 4.8.2 Range Check Instruction (RCHK) [Format] [Lower limit] Any integer type register Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant with subscript Any real number type register Any real number type register wit subscript [Upper limit] Any integer type register with subscrip Any double-length integer type registe Any double-length integer type registe Subscript register Constant [Description] The RCHK instruction examines the contents entered in the A register whether it is within the specified range or not. The result is output to the B register. The content of the A register are kept. ( ⊢ input value) Result RCHK [Lower limit], [Upper limit] - If the input value (A register) is greater than the lower limit and less than the upper limit, the result (B register) = ON. - \* In the cases other than the above, the result (B register) = OFF. [Operation of the Register] | 1 | A | F | В | I | J | |---|---|---|---|---|---| | | 0 | 0 | × | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] For integer type operation | ├ MW00100 | <del></del> | | |-------------|-------------|----------| | ` | | DB000000 | | RCHK -1000, | 1000 | <u> </u> | | Input (MW00100) | Output (DB000000) | |--------------------|-------------------| | -1000>MW00100 | OFF | | -1000≤MW00100≤1000 | ON | | MW00100>1000 | OFF | For double-length integer type operation | LOI double-length miceger | t type operation | |---------------------------|------------------| | - ML00100 | : | | · · | DB000000 | | RCHK -100000, | 100000 | | Input (ML00100) | Output (DB000000) | |------------------------|-------------------| | -100000>ML00100 | OFF | | -100000≤ML00100≤100000 | ON | | ML00100>100000 | OFF | # Range Check Instruction (RCHK) # For real number type operation | ├ DF00100 | | | |-------------|------|-------------| | | | DB000000 | | RCHK -10.5, | 10.5 | <del></del> | | Input (DF00100) | Output (DB000000) | |--------------------|-------------------| | -10.5>DF00100 | OFF | | —10.5≦DF00100≦10.5 | ON | | DF00100>10.5 | OFF | # 4.9 Data Operation Instructions #### 4.9.1 ROTL Instruction and ROTR Instruction [Description] The ROTL (or ROTR) instruction is used to perform rotation, in the left (or right) directi for the number of times designated, on the bit table designated by the head bit address and the bit width. Fig. 4.5 The ROTL Operation # [Operation of the Register] [Example(s)] (1) ROTL The data having MB00000A (bit A of MW00000) as the head address and bit width of 10 are rotated five times to the left. (2) ROTR The data having MB000000 (bit 0 of MW00000) as the head address and bit width of 10 are rotated once to the right. # MOVB Instruction .9.2 [Format] [Address of Transfer Source Bit] [Address of Transfer Destination Bit] [Number of Transfers] MOVB [Any bit type register] Any bit type register Any bit type register with subscript with subscript [Any bit type register] Any bit type register [Description] The MOVB instruction transfers the designated number of bit data, starting from the head of the transfer source bits, to the transfer destination, which starts from the address of the head transfer destination bit. The transfer is carried out 1 bit at a time in the direction in which the relay number increases. with subscript Although the bit table of the transfer source will be stored as long as the transfer source bits and transfer destination bits do not overlap, caution is needed when the bits do overlap. Transfer source Transfer destination | (a)<br>(b) | 7 | С | |------------|---|-------------------| | (b) | | d | | c | | е | | d · | | f | | е . | | g | | f | | (f)<br>(g)<br>(h) | | (h) | | (g) | | (h) | | (h) | When the transfer source and transfer destination overlap (1) Transfer source Transfer destination When the transfer source and transfer destination overlap (2) [Operation of the Register] | Α | F | В | I | J | : stored ×: not stored | |---|---|---|---|---|-----------------------------------------------| | 0 | 0 | 0 | 0 | 0 | (Stored or not stored depending on the case.) | # MOVB Instruction [Example(s)] The 10 bits of data starting from MB000000 (bit 0 of MW00000) are transferred MB000010 (bit 0 of MW00001). | MOVE | B MB000000 ⇒ MB000010 W=10 | |---------|-------------------------------| | | | | | ← Transfer range | | MW00000 | 1 0 0 1 1 0 1 1 0 0 1 0 0 0 1 | | • | | | MW00001 | 000000011110011010 | | | After transfer | | | $\leftarrow$ Transfer range | | MW00000 | | | | | | MW00001 | 00000110010001 | MOVW Instruction #### MOVW Instruction .9.3 [Description] The MOVW instruction transfers the designated number of words of data, starting from the head of the transfer source registers, to the transfer destination, which starts from the address of the head transfer destination register. The transfer process is carried out 1 word at a time in the direction in which the register number increases. Although the transfer source will be stored as long as the transfer source and the transfer destination do not overlap, caution is needed when these do overlap. When the transfer source and transfer destination overlap (1) When the transfer source and transfer destination overlap (2) #### [Operation of the Register] | Α | F | В | I | J | ○: stored ×: not stored<br>*: indeterminate | |---|---|---|---|---|-----------------------------------------------| | 0 | 0 | 0 | 0 | 0 | (Stored or not stored depending on the case.) | [Example(s)] The word data MW00000 to MW00009 are transferred to MW00100 to MW00109. #### 4.9.4 XCHG Instruction [Description] The XCHG instruction is used to exchange the contents of data table 1 and data table [Operation of the Register] | A | F | В | I | J | : stored : not stored : indeterminate | |---|---|-----|---|---|-----------------------------------------------| | 0 | 0 | . 0 | 0 | 0 | (Stored or not stored depending on the case.) | VCUC MXX00000 - [Example(s)] The contents of MW00000 to MW00009 are exchanged with those of MW00100 MW00109. - MW00100 W-00010 | · XC | HG MWU | 0000 ⇒ M | MOOTOO . | M=000T0 | | | | | |---------|---------------|----------|----------|----------|--------|---------|-----------|-------| | , | | | | 1 . | | | 1 | | | MW00000 | 1031H | MW00100 | 2050H | | MW0000 | 0 2050H | MW00100 | 1031F | | MW00001 | 1032H | MW00101 | 2051H | | MW0000 | 1 2051H | MW00101 | 1032F | | MW00002 | 1033H | MW00102 | 2052H | | MW0000 | 2 2052H | MW00102 | 1033F | | MW00003 | 1034H | MW00103 | 2053H | After | MW0000 | 3 2053H | . MW00103 | 1034H | | MW00004 | 1035 <b>H</b> | MW00104 | 2054H | transfer | MW0000 | 4 2054H | MW00104 | 1035E | | MW00005 | 1036H | MW00105 | 2055H | | MW0000 | 5 2055H | MW00105 | 1036H | | MW00006 | 1037H | MW00106 | 2056H | | MW0000 | 6 2056H | MW00106 | 1037H | | MW00007 | 1038H | MW00107 | 2057H | | MW0000 | 7 2057H | MW00107 | 1038H | | MW00008 | 1039H | MW00108 | 2058H | | MW0000 | 8 2058H | MW00108 | 1039H | | MW00009 | 1030H | MW00109 | 2059H | | MW0000 | 9 2059H | MW00109 | 1030H | | • | | ' | | | | | • | _ | SETW Instruction # SETW Instruction .9.5 [Format] [Transfer Destination Register No.] [Data to be Transferred] [Number of Transfers] Any integer type register W= Any integer type register SETW Any integer type register (except for # and C registers) Any integer type register Any integer type register Any integer type register with subscript (except for # and C with subscript with subscript Constant Constant registers) [Description] The SETW instruction stores the data designated as transfer data in all registers designated by the transfer destination register number and the number of transfers. The storage process is carried out by 1 word in the direction of increasing register number. [Operation of the Register] | Α | F | В | Ι | J | ○: stored ×: not stored *: indeterminate | |---|---|---|---|---|-----------------------------------------------| | 0 | 0 | 0 | 0 | 0 | (Stored or not stored depending on the case.) | [Example(s)] The contents of MW00100 to MW00119 are set to 0. #### 4.9.6 BEXTD Instruction [Description] The BEXTD instruction stores the byte sequence stored in the transfer source regist area byte by byte in the word sequence of the transfer destination register. The upp byte of the transfer destination register is "0." [Operation of the Register] | Α | F | В | I | J | ○: stored ×: not stored *: indeterminate | |---|---|-----|---|---|-----------------------------------------------| | × | 0 | · O | 0 | 0 | (Stored or not stored depending on the case.) | [Example(s)] The 5 bytes beginning with MW00100 are expanded into five words beginning with MW00200. BPRESS Instruction #### .9.7 BPRESS Instruction [Description] The BPRESS instruction stores the lower byte of the word sequence stored in the transfer source register area in the byte sequence of the transfer destination register area. The upper byte of the transfer source register is ignored. This is the reverse of the BEXTD instruction. [Operation of the Register] | Α | F | В | I | J | ○: stored ×: not stored | |---|---|---|---|---|-------------------------------------------------------------------| | 0 | 0 | 0 | 0 | 0 | *: indeterminate<br>(Stored or not stored depending on the case.) | [Example(s)] The 5 words beginning with MW00100 are compressed into five bytes beginning with MW00200. #### 4.9.8 BSRCH Instruction #### [Search result] [Format] [Range word number] [Search data] Head number of the search rangel Any integer type register Any integer type register with subscript Any integer type regist BSRCH Any integer type register Any integer type register Any integer type register (except for # and C Any integer type register with subscript registers) Any integer type registe with subscript (except f with subscript Any double-length integer Any double-length integer Constant type register Any double-length integer type register Any double-length integer # and C registers) type register with subscript type register Any real number type with subscript register Any real number type Any real number type register register with subscript Any real number type Constant register with subscript [Description] The BSRCH instruction uses a binary search method to search for the specified data in the specified search range. The search results (offset number of the search range head register number of matched data) are stored in the specified register. Before the execution of the BSRCH instruction, it is necessary that the data in the search range be sorted in ascending order. If this is not done, the result will not be correct. In addition, the result will not be correct if there are two or more identical data. If no matched data is found, "-1" is stored. [Operation of the Register] | A | | F | В | I | J | | |---|---------------|---|---|---|---|--| | 0 | $\overline{}$ | 0 | 0 | 0 | 0 | | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] Data matching with 01234 are searched for in registers MW00100 to MW00199, and the result is stored in register DW00000. BSRCH MW00100 W=100 D=01234 R=DW00000 SORT Instruction #### 9.9 **SORT Instruction** [Format] [Head number of the sort range] W=\[Any integer type register SORT Any integer type register (except for # and C registers) Any integer type register with subscript Any double-length integer type register (except for # and C registers) Any double-length integer type register with subscript Any real number type register (except for # and C registers) Any real number type register with subscript- Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register [Number of range registers] Any real number type register with subscript [Description] The SORT instruction arranges data in the specified register range in ascending order. [Operation of the Register] | I | _A | F | В | I | J | | |---|----|---|---|---|---|--| | | 0 | 0 | 0 | 0 | 0 | | O: stored ×: not stored : indeterminate (Stored or not stored depending on the case.) [Example(s)] The data in registers MW00100 to MW00199 are sorted in ascending order. | ſ | SORT | MW00100 | W=00020 | |---|------|---------|---------| | | | | | #### 4.9.10 SHFTL Instruction and SHFTR Instruction [Description] The SHIFTL (SHIFTR) instruction shifts to the left (right) by only the specified number of shifts the bit sequence specified by head bit address and bit width. As shown in Fig. 4.6, bit data that overflows the bit width is thrown away, and insufficient bits become 0. Fig. 4.6 The SHIFT Operation [Operation of the Register] | Α | F | В | Ī | J | : stored : not stored : indeterminate | |---|---|---|---|---|-----------------------------------------------| | 0 | 0 | 0 | 0 | 0 | (Stored or not stored depending on the case.) | [Example(s)] (1) SHFTL A ten-bit wide section of data with MB00000A (bit A of MW00000) as the head is shifted five bits to the left. 2) SHFTR A five-bit wide section of data with MB00005 (bit 5 of MW00000) as t head is shifted three bits to the right. # COPYW Instruction .9.11 [Description] The COPYW instruction transfers the specified number of word data to the head of the transfer destination register from the head of the transfer source register. The transfer operation copies the data in a block from the transfer source to the transfer destination. Even if there is overlap between the transfer source and the transfer destination, the full transfer data block is copied to the transfer destination. Transfer source Transfer destination When the transfer source and transfer destination overlap (1) Transfer source Transfer destination When the transfer source and transfer destination overlap (2) # [Operation of the Register] | Α | F | B | T | J | ○: stored ×: not stored | |---|---|---|---|---|------------------------------------------------------------------------------------------| | 0 | Ō | Ō | 0 | Ö | <ul> <li>indeterminate</li> <li>(Stored or not stored depending on the case.)</li> </ul> | [Examples(s)] The word data of MW00000 to MW00009 are transferred to MW00100 to MW00109. #### **BSWAP Instruction** 4.9.12 [Format] [Target register number] **BSWAP** Any bit type register (except for # and C registers) Any bit type register with subscript (except for # and C registers) The BSWAP instruction swaps the upper and lower bytes of the specified register. [Description] (Target register) In the case of BSWAP VW 0000 [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored : indeterminate (Stored or not stored depending on the case.) The upper and lower bytes of MW00100 to MW00102 are swapped. [Example(s)] > FOR I = 00000 to 00002 by 00001BSWAP MW00100 i **FEND** SQRT Instruction ## .10 Basic Function Instructions # SQRT Instruction [Format] .10.1 SQRT [Description] This instruction leaves the square root of integer type or real number type data as the operation result. The input unit and the output result will differ according to whether the data are of an integer type or a real number type. This instruction cannot be used for double-length integer type data. # **Integer Type Data** The operation result will differ slightly from the square root in mathematical terms. To be more precise, the operation result is expressed by the following formula: $32768 \times \text{sign}(A) \times \text{SQRT}(|A|/32768)$ sign (A): sign of register A |A|: absolute value of register A That is, the operation result will be equal to the mathematical square root multiplied by $128\sqrt{2}$ (approx. 181.02). When the input is a negative number, the square root of the absolute value is determined and the negative of this square root is left as the operation result in the A register. The maximum operation error of the output value is $\pm 2$ . #### **Real Number Type Data** The immediately preceding operation result (F register) is used as the input and the square root thereof is left in the F register. When the input is a negative number the square root of the absolute value is determined and the negative of this square root is left as the operation result in the A register. This instruction can be used inside a real number type operation. #### [Operation of the Register] Integer type data | _A | F | В | I | J | |----|---|---|---|---| | × | 0 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) Real number type data | Α | F | В | I | J | |---|---|---|---|---| | 0 | × | 0 | 0 | 0 | O: stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) #### [Example(s)] ] Integer type data When the input is a positive number | ⊢MW00100 SQR<br>(00064) | T | |-------------------------|---| |-------------------------|---| When the input is a negative number Real number type data When the input is a positive number | - DF00200 SQRT | ⇒ DF00202 | |----------------|-----------| | (64.0) | (8.0) | When the input is a negative number | (-8.0) | - DF00200<br>( - 64.0) | SQRT | $\Longrightarrow DF00202 $ ( -8.0) | |--------|------------------------|------|------------------------------------| |--------|------------------------|------|------------------------------------| #### 4.10.2 SIN Instruction [Format] SIN [Description] This instruction leaves the sine of integer type or real number type data as the operation result. The input unit and the output result will differ according to whether the data are of an integer type or a real number type. This instruction cannot be used for doub length integer type data. Integer Type Data This instruction can be used in the range $-327.68 \sim 327.67$ degrees. T immediately preceding operation result (A register) is used as the input (1 = 0.68) degrees) and the operation result is left in the A register. Upon output, the operation result is multiplied by 10000. If a number outside the range -327.68 to 327.67 is mistakenly entered, a correresult will not be obtained. For example, if 360.00 is entered, a result of -295. degrees is output. **Real Number Type Data** The immediately preceding operation result (F register) is used as the input (u = degrees) and the sine thereof is left in the F register. This instruction can used inside a real number type operation. # [Operation of the Register] Integer type data | 1 | A | F | В | I. | J | |---|---|---|---|----|---| | | × | 0 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) Real number type data | Α | F | В | I | J | |---|---|---|---|---| | 0 | × | 0 | 0 | 0 | O: stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) #### [Example(s)] Integer type data | Γ | | | | |------|----------|-----|--------------------| | - [: | ⊢MW00100 | SIN | $\implies$ MW00102 | | ŀ | (03000) | | (05000) | Input $\theta = 30$ degrees (MW00100 = $30 \times 100 = 3000$ ) Output SIN( $\theta$ ) = 0.50 (MW00102 = 0.50 × 10000 = 5000) Real number type data | - DF00200 SIN | ⇒ DF00202 | |---------------|-----------| | | | | (30.0) | (0.5) | COS Instruction #### .10.3 COS Instruction [Format] COS [Description] This instruction leaves the cosine of integer type or real number type data as the operation result. The input unit and the output result will differ according to whether the data are of an integer type or a real number type. This instruction cannot be used for double-length integer type data. #### **Integer Type Data** This instruction can be used in the range $-327.68 \sim 327.67$ degrees. The immediately preceding operation result (A register) is used as the input (1 = 0.01 degrees) and the operation result is left in the A register. Upon output, the operation result is multiplied by 10000. If a number outside the range -327.68 to 327.67 is mistakenly entered, a correct result will not be obtained. For example, if 360.00 is entered, a result of -295.36 degrees is output. ### Real Number Type Data The immediately preceding operation result (F register) is used as the input (unit = degrees) and the cosine thereof is left in the F register. This instruction can be used inside a real number type operation. #### [Operation of the Register] Integer type data | A | F | В | T | Į, | |---|---|---|---|----| | × | 0 | 0 | 0 | Ō | : stored × : not stored \* : indeterminate (Stored or not stored depending on the case.) ### Real number type data | į | A | F | В | Ι | J | |---|---|---|---|---|---| | I | 0 | × | 0 | 0 | 0 | ○: stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) #### [Example(s)] Integer type data | Q 71 | | | |---------------------|-----|----------------------| | ⊢MW00100<br>(06000) | cos | → MW00102<br>(05000) | Input $\theta = 60$ degrees (MW00100 = $60 \times 100 = 6000$ ) Output COS( $\theta$ ) = 0.50 (MW00102 = 0.50 $\times$ 10000 = 5000) # Real number type data | - DF00200<br>(60.0) | cos | ⇒ DF00202<br>(0.5) | |---------------------|-----|--------------------| | (00.0) | | (0.3) | | TAN Instruction | |------------------| | ASIN Instruction | | ACOS Instruction | #### 4.10.4 TAN Instruction [Format] TAN [Description] With the TAN instruction, the immediately preceding operation result (F register) used as the input (unit = degrees) and the tangent thereof is left in the F register. The instruction can be used inside a real number type operation. [Operation of the Register]. | A_ | F | В | I · | J | |----|---|---|-----|---| | 0 | × | 0 | 0 | 0 | : stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] The tangent of the input value ( $\theta = 45.0$ degrees) [TAN( $\theta$ ) = 1.0] is calculated. | ſ, | ⊩ DF00200<br>(45.0) | TAN | | - | ı | ⇒DF00202<br>(1.0) | |----|---------------------|-----|--|---|---|-------------------| | ı | <b>(</b> / | | | | | • / | ### 4.10.5 ASIN instruction [Format] **ASIN** [Description] With the ASIN instruction, the immediately preceding operation result (F register) used as the input (unit = degrees) and the arc sine thereof is left in the F register. The instruction can be used inside a real number type operation. [Operation of the Register] | ļ | Α | F | $\mathbf{B}_{-}$ | Ι | J | |---|---|---|------------------|---|---| | | 0 | × | Ó | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] The arc sine of the input value ( $\theta = 0.5$ ) [ASIN(0.5) = $\theta = 30.0$ degrees] is calculated #### 4.10.6 ACOS Instruction [Format] **ACOS** [Description] With the ACOS instruction, the immediately preceding operation result (F register) used as the input (unit = degrees) and the arc cosine thereof is left in the F register. This instruction can be used inside a real number type operation. [Operation of the Register] | Α | F | В | Ι | J | |---|---|---|---|---| | 0 | × | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] The arc cosine of the input value ( $\theta = 0.5$ ) [ACOS(0.5) = $\theta = 60.0$ degrees] is calculate | ⊩ DF00200<br>(0.5) | | | |--------------------|---|---------------------| | . ACOS | 1 | ⇒ DF00202<br>(60.0) | ATAN Instruction #### 10.7 ATAN Instruction [Format] ATAN Description This instruction leaves the arc tangent of integer type or real number type data as the operation result. The input unit and the output result will differ according to whether the data are of an integer type or a real number type. This instruction cannot be used for double-length integer type data. #### **Integer Type Data** This instruction can be used in the range -327.68 to 327.67. The immediately preceding operation result (A register) is used as the input (1 = 0.01) and the operation result is left in the A register. Upon output, the operation result is multiplied by 100 degrees. ### **Real Number Type Data** The immediately preceding operation result (F register) is used as the input and the arc tangent thereof (unit = degrees) is left in the F register. This instruction can be used inside a real number type operation. ## [Operation of the Register] Integer type data | Α | F | В | I | J | |---|---|---|---|---| | × | 0 | 0 | 0 | 0 | ○: stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) #### Real number type data | ĺ | Α | F | В | I | J | |---|---|---|---|---|---| | · | 0 | × | 0 | 0 | 0 | O: stored X: not stored \*: indeterminate (Stored or not stored depending on the case.) #### [Example(s)] Integer type data ``` ⊢ MW00100 (00100) ATAN ⇒ MW00102 (04500) ``` Input X = 1.00 (MW00100 = $1.00 \times 100 = 100$ ) Output $\theta = 45$ degrees (MW00102 = $45 \times 100 = 4500$ ) #### Real number type data EXP Instruction LN Instruction LOG Instruction ## 4.10.8 EXP Instruction [Format] EXP [Description] With the EXP instruction, the immediately preceding operation result (F register) used as the input (x) and the natural logarithmic base (e) to the power of the input value (e<sup>x</sup>) is left in the F register as the operation result. This instruction can be us only inside a real number type operation. [Operation of the Register] | A | F | В | I | J | |---|---|---|---|---| | 0 | × | 0 | 0 | 0 | ○: stored ×: not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] e = 2.7183 to the power of the input value (x = 1.0) is calculated. | - DF00200 | EXP | <b>⇒</b> DF00202 | |-----------|-----|------------------| | (1.0) | • | (2.7183) | # 4.10.9 LN Instruction [Format] LN [Description] With the LN instruction, the immediately preceding operation result (F register) used as the input (x) and the natural logarithm (Log-)thereof is left in the F register the operation result. This instruction can be used inside a real number type operation [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | 0 | × | 0 | 0 | 0 | ○: stored × : not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] Calculate the natural logarithm of the input value (x = 10.0) [Log<sub>e</sub>(x) = 2.3026]. | - DF00200 | LN | | ⇒ DF00202 | |-----------|------|---|-----------| | (10.0) | 2, • | 1 | (2.3026) | #### 4.10.10 LOG Instruction [Format] LOG [Description] With the LOG instruction, the immediately preceding operation result (F register) used as the input (x) and the common logarithm (log<sub>10</sub>) thereof is left in the F regist as the operation result. This instruction can be used inside a real number type operation [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | Ö | × | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] The common logarithm of the input value (x = 10.0) [Log<sub>10</sub>(x) = 1.0] is calculated. | (10.0) | |--------| |--------| **DZA** Instruction #### .11 DDC Instructions #### **DZA Instruction** [Format] 11.1 [Designated Dead Zone Value] DZA Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant [Description] The DZA instruction executes a dead zone operation on integer, double-length integer, or real number type data. Where X is the input value, D is the designated dead zone value, and Y is the output value, the following operation is performed: (a) $$Y = X(|X| \ge |D|)$$ (b) $$Y = 0 (|X| < |D|)$$ Fig. 4.7 Operation of the DZA Instruction [Operation of the Register] | | J | · | | | | |----|----|---|---|---|----------------------------------------------------------------| | Α | F | В | I | J | O: stored ×: not stored | | *1 | *2 | 0 | 0 | 0 | *: indeterminate (Stored or not stored depending on the case.) | | | • | | | | (Stored or not stored depending on the case.) | <sup>\*1:</sup> Will not be stored if the operation starts with a $\vdash$ . Will be stored if the operation does not start with a $\vdash$ . #### [Example(s)] Integer type operation #### Double-length integer type operation <sup>\*2:</sup> Will not be stored if the operation starts with a |-. Will be stored if the operation does not start with a |-. #### Real number type operation ## 4.11.2 DZB Instruction #### [Format] #### [Designated Dead Zone Value] DZB Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant [Description] The DZB instruction executes a dead zone operation on integer, double-length integer or real number type data. Where X is the input value, D is the designated dead zo value, and Y is the output value, the following operation is performed: (a) $$Y = X - |D| (|X| \ge |D|, X \ge 0)$$ (b) $$Y = X + |D| (|X| \ge |D|, X \le 0)$$ (c) $$Y = 0 (|X| < |D|)$$ Fig. 4.8 Operation of the DZB Instruction #### [Operation of the Register] | Α | ·F | В | I | J | : stored X: not stored *: indeterminate | |----|----|---|---|---|-----------------------------------------------| | *1 | *2 | 0 | 0 | 0 | (Stored or not stored depending on the case.) | DZB Instruction # [Example(s)] #### Integer type operation ## Double-length integer type operation ### Real number type operation #### 4.11.3 LIMIT instruction #### [Format] ## [Lower Limit] ## [Upper Limit] LIMIT Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register with subscript Any real number type register Any real number type register with subscript Subscript register Constant tumo rogistor Any integer type register Any integer type register with subscript Any double-length integer type register Any double-length integer type register wi subscript Any real number type register Any real number type register with subscript Subscript register Constant ## [Description] The LIMIT instruction executes an upper/lower limit operation on integer, double-leng integer, or real number type data. The following operation is performed: (a) $$Y = A (X < A)$$ (b) $$Y = X (A \leq X \leq B)$$ (c) $$Y = B (B < X)$$ Where X is the input value. A is the lower limit, B is the upper limit, and Y is the outp Fig. 4.9 Operation of the LIMIT Instruction #### [Operation of the Register] | Α | F | В | I | J | |----|----|---|---|---| | *1 | *2 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) ## [Example(s)] Integer type operation | <b>⊢</b> MW00100 | | | |------------------|----|-----------------------| | LIMIT -00100 001 | 00 | $\Rightarrow$ MW00102 | | Input (MW00100) | Output (MW0010) | | | |------------------|------------------------------------------------------|--|--| | -100>MW00100 | -00100 (under the lower limit) | | | | -100≤MW00100≤100 | Value of MW00100 (within the upper and lower limits) | | | | MW00100>100 | 00100 (above the upper limit) | | | #### ■ Double-length integer type operation | ⊢ ML00100 | | | |----------------|--------|-------------| | MILIOUTOU | | | | LIMIT -100000 | 100000 | ⇒ML00102 | | THAILI -100000 | 100000 | → WILLOUTUZ | | Input (ML00100) | Output (ML00102) | |------------------------|------------------------------------------------------| | -100000>ML00100 | -100000 (under the lower limit) | | -100000≤ML00100≤100000 | Value of ML00100 (within the upper and lower limits) | | ML00100>100000 | 100000 (above the upper limit) | <sup>\*1:</sup> Will not be stored if the operation starts with $a \vdash .$ Will be stored if the operation does not start with $a \vdash .$ \*2: Will not be stored if the operation starts with $a \models .$ Will be stored if the operation does not start with $a \models .$ LIMIT Instruction ## Real number type operation | ⊩ MF00200 | | | |--------------------|---|----------| | LIMIT -100.0 100.0 | : | ⇒MF00202 | | Input (MF00200) | Output (MF00202) | |----------------------|------------------------------------------------------| | -100.0>DF00100 | -100.0 (under the lower limit) | | -100.0≦DF00100≦100.0 | Value of MF00200 (within the upper and lower limits) | | DF00100>100.0 | 100.0 (above the upper limit) | ## PI Instruction #### 4.11.4 Pl Instruction [Format] [ Head Address of Parameter Table ] Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Description] PI The PI instruction executes a PI operation in accordance with the contents of a parameter table that is set in advance. The input (X) to the PI operation must be an integer type or real number type value. The configuration of the parameter table will differ according to whether the parameters are of an integer type or of a real number type. Double-length integer type parameters cannot be used (operations will be performed with each parameter being handled as an integer consisting of the lower 1 bits). Table 4.17 Table of Integer Type PI Instruction Parameters | ADR | Туре | Symbol | Name . | Specification | ľΟ | |-----|------|--------|-----------------------------|-------------------------------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | w | Kp | P gain | Gain of the P correction (a gain of 1 is set to 100) | IN | | 2 | W | Ki | Integration adjustment gain | Gain of the integration circuit input (a gain of 1 is set to 100) | IN | | 3 | W | Ti | Integration time | Integration time (ms) | IN | | 4 | W | IUL | Upper integration limit | Upper limit for the I correction value | IN | | 5 | W | ILL | Lower integration limit | Lower limit for the I correction value | IN | | 6 | W | UL | Upper PI limit | Upper limit for the P+I correction value | IN | | 7 | W | LL | Lower PI limit | Lower limit for the P+I correction value | IN | | 8 | W | DB | PI output dead band | Width of the dead band for the P+I correction value | IN | | 9 | W | Y | PI output | PI correction output (also output to the A register) | OUT | | 10 | W | Yi | I correction value | Storage of the I correction value | OUT | | 11 | w | IREM | I remainder | Storage of the I remainder | OUT | #### \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | ľО | |--------|--------|-------------------|-----------------------------------------|-----| | 0 | IRST | Integration reset | "ON" is input when integration is reset | IN | | 1 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 to F | | (Reserve) | Reserve relay for output | OUT | #### Table 4.18 Table of Real Type PI Instruction Parameters | Туре | Symbol | Name | Specification | I/O | | | | |------|-----------------------------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | | | | W | | (Reserve) | Reserve register | 1— | | | | | F | Кр | P gain | Gain of the P correction | IN | | | | | F | Ki | Integration adjustment gain | Gain of the integration circuit input | IN | | | | | F | Ti | Integration time | Integration time (s) | IN | | | | | F | IUL | Upper integration limit | Upper limit for the I correction value | IN | | | | | F | ILL | Lower integration limit | Lower limit for the I correction value | IN | | | | | F | UL | Upper PI limit | Upper limit for the P+I correction value | IN | | | | | F | LL | Lower PI limit | Lower limit for the P+I correction value | IN | | | | | F | DB | PI output dead band | Width of the dead band for the P+I correction value | IN | | | | | F | Y | PI output | PI correction output (also output to the A register) | OUT | | | | | F | Yi | I correction value | Storage of the I correction value | OUT | | | | | | W F F F F F F F F F F F F F F F F F F F | W RLY W — F Kp F Ki F Ti F IUL F UL F LL F DB F Y | W RLY Relay I/O W — (Reserve) F Kp P gain F Ki Integration adjustment gain F Ti Integration time F IUL Upper integration limit F UL Upper PI limit F UL Lower PI limit F DB PI output dead band F Y PI output | W RLY Relay I/O Relay input, relay output *1 W — (Reserve) Reserve register F Kp P gain Gain of the P correction F Ki Integration adjustment gain Gain of the integration circuit input F Ti Integration time Integration time (s) F IUL Upper integration limit Upper limit for the I correction value F ILL Lower integration limit Upper limit for the I correction value F UL Upper PI limit Upper limit for the P+I correction value F LL Lower PI limit Lower limit for the P+I correction value F DB PI output dead band Width of the dead band for the P+I correction value F PI output PI correction output (also output to the A register) | | | | #### \*1: Relay I/O Bit Assignment | L | BIT | BIT Symbol Name | | Specification | I/O | |---|--------|-----------------|-------------------|------------------------------------------|-----| | | 0 | IRST | Integration reset | "ON" is input when integration is reset. | IN | | | 1 to 7 | | (Reserve) | Reserve relay for input | IN | | | 8 to F | | (Reserve) | Reserve relay for output | OUT | PI Instruction Here, the PI operation is expressed as follows: $$\frac{\mathbf{Y}}{\mathbf{X}} = \mathbf{K}\mathbf{p} + \mathbf{K}\mathbf{i} \times \frac{1}{\mathbf{T}\mathbf{i} \times \mathbf{S}}$$ X: deviation input value Y: output value The following operation is performed within the PI instruction: $$Y = Kp \times X + \{(Ki \times X + IREM) / \frac{Ti}{Ts} + Yi\}$$ Yi': previous I output value Ts: scan time set value When the present P correction value and the I correction value are the same in sign (diverging), the I correction value is not renewed but is kept at the previous value. Oppositely, if the P and I correction values are opposite in sign (converging towards 0), the I correction value is renewed by the present value. When the integration reset (IRST) is "ON" Yi = 0 and IREM = 0 are output #### [Operation of the Register] | Α | F | В | I | J | ○: stored ×: not stored | |----|----|---|---|---|---------------------------------------------------------------| | *1 | *2 | 0 | 0 | 0 | *: indeterminate (Stored or not stored depending on the case) | <sup>\*1:</sup> Will not be stored if the operation starts with a $\vdash$ . Will be stored if the operation does not start with a $\vdash$ . #### [Example(s)] Integer type operation MW00100 to MW00111 are used for the parameter table. Real number type operation MF00200 to MF00220 are used for the parameter table. <sup>\*2:</sup> Will not be stored if the operation starts with a $\Vdash$ . Will be stored if the operation does not start with a $\Vdash$ . #### 4.11.5 PD Instruction [Format] [ Head Address of Parameter Table ] PD Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Description] The PD instruction executes a PD operation in accordance with the contents of a parameter table that is set in advance. The input (X) to the PD operation must be an integer type or real number type value. The configuration of the parameter table will differ according to whether the parameters are of an integer type or of a real number type. Double-length integer type parameters cannot be used (operations will be performed with each parameter being handled as an integer consisting of the lower 16 bits). Table 4.19 Table of Integer Type PD Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|--------|----------------------------------|-----------------------------------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | w | Kp | P gain | Gain of the P correction (a gain of 1 is set to 100) | IN | | 2 | W | Kd | D gain | Gain of the differentiation circuit input (a gain of 1 is set to 100) | IN | | 3 | W | Td1 | Divergence differentiation time | The differentiation time (ms) used in the case of diverging input. | IN | | 4 | W | Td2 | Convergence differentiation time | The differentiation time (ms) used in the case of converging input. | IN | | 5 | W | UL | Upper PD limit | Upper limit for the P+D correction value | IN | | 6 | w | LL | Lower PD limit | Lower limit for the P+D correction value | IN | | 7 | w | DB | PD output dead band | Width of the dead band for the P+D correction value | IN | | 8 | W | Y | PD output | PD correction output (also output to the A register) | OUT | | 9 | W | X | Input value storage | Storage of the present deviation input value | OUT | #### \*1: Relay I/O Bit Assignment | ſ | BIT | Symbol | Name | Specification | I/O | |---|--------|--------|-----------|--------------------------|-----| | Ī | 0 to 7 | | (Reserve) | Reserve relay for input | IN | | l | 8 to F | | (Reserve) | Reserve relay for output | OUT | ### Table 4.20 Table of Real Type PD Instruction Parameters | | The state of s | | | | | | | | | | |---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|----------------------------------|--------------------------------------------------------------------|--------|--|--|--|--| | | ADR | Type | Symbol | Name | Specification | I/O_ | | | | | | f | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | | | | | ſ | 1 | W | | (Reserve) | Reserve register | | | | | | | | 2 | F | Kp | P gain | Gain of the P correction | IN | | | | | | t | 4 | F | Kd | D gain | Gain of the differentiation circuit input | IN | | | | | | t | 6 | F | Td1 | Divergence differentiation time | The differentiation time (s) used in the case of diverging input. | IN | | | | | | ľ | 8 | F | Td2 | Convergence differentiation time | The differentiation time (s) used in the case of converging input. | IN | | | | | | t | 10 | F | UL | Upper PD limit | Upper limit for the P+D correction value | IN | | | | | | r | 12 | F | LL | Lower PD limit | Lower limit for the P+D correction value | IN | | | | | | ľ | 14 | F | DB | PD output dead band | Width of the dead band for the P+D correction value | IN · | | | | | | T | 16 | F | Y | PD output | PD correction output (also output to the A register) | OUT | | | | | | ı | 18 | F | X | Input value storage | Storage of the present deviation input value | OUT | | | | | ## \*1: Relay I/O Bit Assignment | - | BIT | Symbol | Name | Specification | I/O | |---|--------|--------|-----------|--------------------------|-----| | | 0 to 7 | | (Reserve) | Reserve relay for input | IN | | | 8 to F | | (Reserve) | Reserve relay for output | OUT | PD Instruction Here, the PD operation is expressed as follows: $$\frac{\mathbf{Y}}{\mathbf{Y}} = \mathbf{K}\mathbf{p} + \mathbf{K}\mathbf{d} \times \mathbf{T}\mathbf{d} \times \mathbf{S}$$ X: deviation input value Y: output value The following operation is performed within the PD instruction: $$Y = Kp \times X + Kd \times (X-X') \times \frac{Td}{Ts}$$ Xi': previous input value Ts: scan time set value When the change in deviation output (X-X') and the previous deviation input (X') are the same in sign (diverging) in the differentiation (D) operation The divergence differentiation time (Td1) is used as the differentiation time. When the change in deviation output (X-X') and the previous deviation input (X') are opposite in sign (converging) in the differentiation (D) operation The convergence differentiation time (Td2) is used as the differentiation time. #### [Operation of the Register] | Α | F | В | Ι | J | : stored ×: not stored | |----|----|---|---|---|------------------------------------------------------------| | *1 | *2 | 0 | 0 | 0 | *: indeterminate (Stored or not stored depending on the ca | <sup>\*1:</sup> Will not be stored if the operation starts with a |-. Will be stored if the operation does not start with a |-. #### [Example(s)] Integer type operation MW00100 to MW00109 are used for the parameter table. Real number type operation MF00200 to MF00218 are used for the parameter table. <sup>\*2:</sup> Will not be stored if the operation starts with a |-. Will be stored if the operation does not start with a |-. #### PID Instruction #### 4.11.6 PID Instruction [Format] [ Head Address of Parameter Table ] PID Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Description] The PID instruction executes a PID operation in accordance with the contents of a parameter table that is set in advance. The input (X) to the PID operation must be an integer type or real number type value. The configuration of the parameter table will differ according to whether the parameters are of an integer type or of a real number type. Double-length integer type parameters cannot be used (operations will be performed with each parameter being handled as an integer consisting of the lower 16 bits). Table 4.21 Table of Integer Type PID Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|--------|----------------------------------|-----------------------------------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output*1 | IN/OUT | | 1 | W | Kp | P gain | Gain of the P correction (a gain of 1 is set to 100) | IN | | 2 | W | Ki | I gain | Gain of the integration circuit input (a gain of 1 is set to 100) | IN | | 3 | W | Kd | D gain | Gain of the differentiation circuit input (a gain of 1 is set to 100) | IN | | 4 | W | Ti | Integration time | Integration time (ms) | IN | | 5 | W | Td1 | Divergence differentiation time | The differentiation time (ms) used in the case of diverging input. | IN | | 6 | W | Td2 | Convergence differentiation time | The differentiation time (ms) used in the case of converging input. | IN | | 7 | W | IUL | Upper integration limit | Upper limit for the I correction value | IN | | 8 | W | ILL | Lower integration limit | Lower limit for the I correction value | IN | | 9 | W | UL | Upper PID limit | Upper limit for the P+I+D correction value | IN | | 10 | W | LL | Lower PID limit | Lower limit for the P+I+D correction value | IN | | 11 | W | DB , | PID output dead band | Width of the dead band for the P+I+D correction value | IN | | 12 | W | Y | PID output | PID correction output (also output to the A register) | OUT | | 13 | W | Yi | I correction value | Storage of the I correction value | OUT | | 14 | W | IREM | I remainder | Storage of the I remainder | OUT | | 15 | W | X | Input value storage | Storage of the present deviation input value | OUT | #### \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | I/O | |--------|------------------|-------------------|------------------------------------------|-----| | 0 | IRST | Integration reset | "ON" is input when integration is reset. | IN | | 1 to 7 | 1 to 7 (Reserve) | | Reserve relay for input | IN | | 8 to F | <u> </u> | (Reserve) | Reserve relay for output | OUT | Table 4.22 Table of Real Type PID Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|----------|----------------------------------|--------------------------------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | W | <u> </u> | (Reserve) | Reserve register | | | 2 | F | Kp | P gain | Gain of the P correction | IN | | 4 | F | Ki | I gain | Gain of the integration circuit input | IN | | 6 | F | Kd | D gain | Gain of the differentiation circuit input | IN | | 8 | F | Ti | Integration time | Integration time (s) | IN | | 10 | F | Td1 | Divergence differentiation time | The differentiation time (s) used in the case of diverging input. | IN | | 12 | F | Td2 | Convergence differentiation time | The differentiation time (s) used in the case of converging input. | IN | | 14 | F | IUL | Upper integration limit | Upper limit for the I correction value | IN | | 16 | F | ILL | Lower integration limit | Lower limit for the I correction value | IN | | 18 | F | UL | Upper PID limit | Upper limit for the P+I+D correction value | IN | | 20 | F | LL | Lower PID limit | Lower limit for the P+I+D correction value | IN | | 22 | F | DB | PID output dead band | Width of the dead band for the P+I+D correction value | IN | | 24 | F | Y | PID output | PID correction output (also output to the A register) | OUT | | 26 | F | Yi | I correction value | Storage of the I correction value | OUT | | 28 | · F | X | Input value storage | Storage of the present deviation input value | OUT | \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | . I/O | |--------|--------|-------------------|------------------------------------------|-------| | 0 | IRST | Integration reset | "ON" is input when integration is reset. | IN | | 1 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 to F | | (Reserve) | Reserve relay for output | OUT | Here, the PID operation is expressed as follows: $$\frac{Y}{X} = Kp + Ki \times \frac{1}{Ti \times S} + Kd \times Td \times S$$ X: deviation input value Y: output value The following operation is performed within the PID instruction: $$Y = K_p \times X + \{(K_i \times X + IREM) / \frac{T_i}{T_s} + Y_i'\} + K_d \times (X-X') \times \frac{T_d}{T_s}$$ X': previous input value Yi': previous I output value Ts: scan time set value ## When the P+I+D correction value reaches the upper or lower PID limit (UL, LL) or the PID dead band (DB) When the present P correction value and the I correction value are the same in sign (diverging), the I correction value is not renewed but is kept at the previous value. Oppositely, if the P and I correction values are opposite in sign (converging towards 0), the I correction value is renewed with the present value. When the change in deviation output (X-X') and the previous deviation input (X') are the same in sign (diverging) in the differentiation (D) operation The divergence differentiation time (Td1) is used as the differentiation time. When the change in deviation output (X-X') and the previous deviation input (X') are opposite in sign (converging) in the differentiation (D) operation The convergence differentiation time (Td2) is used as the differentiation time. When the integration reset (IRST) is "ON" $Y_i = 0$ and IREM = 0 are output. ## [Operation of the Register] | Α | F | В | I | J | : stored | |----|----|---|---|---|------------| | *1 | *2 | 0 | 0 | 0 | * : indete | $\bigcirc$ : stored $\times$ : not stored (Stored or not stored depending on the case.) \*1: Will not be stored if the operation starts with a $\vdash$ . Will be stored if the operation does not start with a $\vdash$ . \*2: Will not be stored if the operation starts with a $\vdash$ . Will be stored if the operation does not start with a $\vdash$ . #### [Example(s)] Integer type operation MW00100 to MW00115 are used for the parameter table. #### Real number type operation MF00200 to MF00228 are used for the parameter table. LAG Instruction #### .11.7 LAG Instruction [Format] [ Head Address of Parameter Table ] LAG Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Description] The LAG instruction computes the first-order lag in accordance with the contents of a parameter table that is set in advance. The input (X) to the LAG operation must be an integer type or real number type value. The configuration of the parameter table will differ according to whether the parameters are of an integer type or of a real number type. Double-length integer type parameters cannot be used (operations will be performed with each parameter being handled as an integer consisting of the lower 16 bits). Table 4.23 Table of Integer Type LAG Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|--------|-------------------------------|--------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *S1 | IN/OUT | | 1 | W | T | First-order lag time constant | First-order lag time constant (ms) | IN | | 2 | W | Y | LAG output | LAG output (also output to the A register) | OUT | | 3 | W | REM | Remainder | Storage of remainder | OUT | \*1: Relay I/O Bit Assignment | 2. Ivolay 2 o Div I Digitalion | | | | | | | | | |--------------------------------|--------|-----------|----------------------------------|-----|--|--|--|--| | BIT | Symbol | Name | Specification | Ι/O | | | | | | 0 . | IRST | LAG reset | "ON" is input when LAG is reset. | IN | | | | | | 1 to 7 | | (Reserve) | Reserve relay for input | IN | | | | | | 8 to F | | (Reserve) | Reserve relay for output | OUT | | | | | Table 4.24 Table of Real Type LAG Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|--------|-------------------------------|--------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | W | | (Reserve) | Reserve register | | | 2 | F | T | First-order lag time constant | First-order lag time constant (s) | IN | | 4 | F | Y | LAG output | LAG output (also output to the F register) | OUT | \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | I/O | |--------|--------|-----------|----------------------------------|-----| | 0 | IRST | LAG reset | "ON" is input when LAG is reset. | IN | | 1 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 to F | | (Reserve) | Reserve relay for output | OUT | Here, the LAG operation is expressed as follows: $$\frac{Y}{X} = \frac{1}{1 + T \times S}$$ ; ie. $T \times (dY/dt) + Y = X$ The following operation is performed within the LAG instruction with dt=Ts and dY=Y-Y': $$Y = \frac{T \times Y + T_S \times X + REM}{T + T_S}$$ X : input value Y: output value Y': previous output value Ts: scan time set value Y=0 and REM=0 are output when the LAG reset (RST) is "ON". LAG Instruction [Operation of the Register] | Α | F | В | I | J | | |----|----|---|-----|---|--| | *1 | *2 | 0 | - 0 | 0 | | : stored ×: not stored \* : indeterminate (Stored or not stored depending on the case.) \*1: Will not be stored if the operation starts with a |-. Will be stored if the operation does not start with a |-. \*2. Will not be stored if the operation starts with a |-. Will be stored if the operation does not start with a |-. #### [Example(s)] Integer type operation MW00100 to MW00103 are used for the parameter table. Real number type operation MF00200 to MF00204 are used for the parameter table. #### 4.11.8 LLAG Instruction [Format] [ Head Address of Parameter Table ] LLAG Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Description] The LLAG instruction computes the phase lead/lag in accordance with the contents of parameter table that is set in advance. The input (X) to the LLAG operation must be a integer type or real number type value. The configuration of the parameter table widiffer according to whether the parameters are of an integer type or of a real number type. Double-length integer type parameters cannot be used (operations will be performed with each parameter being handled as an integer consisting of the lower 16 bits). Table 4.25 Table of Integer Type LLAG Instruction Parameters | ADR | Туре | Symbol | Name , | Specification | ΝO | |-----|------|------------|--------------------------|----------------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | W | T2 | Phase lead time constant | Phase lead time constant (ms) | IN | | 2 | W | <b>T</b> 1 | Phase lag time constant | Phase lag time constant (ms) | IN | | 3 - | W | Y | LLAG output | LLAG output (may also be output to the A register) | OUT | | 4 | W | REM | Remainder | Storage of remainder | OUT | | 5 | W | X | Input value storage | Storage of the input value | OUT | ## \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | ΛO | |--------|--------|------------|-----------------------------------|-----| | 0 | IRST | LLAG reset | "ON" is input when LLAG is reset. | IN | | 1 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 to F | T | (Reserve) | Reserve relay for output | OUT | Table 4.26 Table of Real Type LLAG Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|------------|--------------------------|----------------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | W | | (Reserve) | Reserve register | | | 2 | F | <b>T2</b> | Phase lead time constant | Phase lead time constant (s) | IN | | 4 | F | <b>T</b> 1 | Phase lag time constant | Phase lag time constant (s) | IN | | 6 | F | Y | LLAG output | LLAG output (may also be output to the F register) | OUT | | 8 | F | X | | Storage of the input value | OUT | \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | I/O | |--------|--------|------------|-----------------------------------|-----| | 0 | IRST | LLAG reset | "ON" is input when LLAG is reset. | IN | | 1 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 to F | | (Reserve) | Reserve relay for output | OUT | Here, the LLAG operation is expressed as follows: $$\frac{Y}{X} = \frac{1 + T2 \times S}{1 + T1 \times S}$$ ; ie. T1 × (dY/dt) + Y = T2 + (dX/dt) + X The following operation is performed within the LAG instruction with dt=Ts, dY=Y-Y', and dX=X-X': $$Y = \frac{T1 \times Y' + (T2 + Ts) \times X - T2 \times X' + REM}{T1 + Ts}$$ X: input valueY: output value X': previous input value Y': previous output value Ts: scan time set value Y=0, REM=0, and X=0 are output when the LLAG reset (RST) is "ON." #### [Operation of the Register] | A | F | В | I | J | : stored ×: not stored | |----|----|---|---|---|----------------------------------------------------------------| | *1 | *2 | 0 | 0 | 0 | *: indeterminate (Stored or not stored depending on the case.) | <sup>\*1:</sup> Will not be stored if the operation starts with a $\vdash$ . Will be stored if the operation does not start with a $\vdash$ . #### [Example(s)] #### Integer type operation MW00100 to MW00105 are used for the parameter table. Real number type operation MF00200 to MF00208 are used for the parameter table. <sup>\*2:</sup> Will not be stored if the operation starts with a |-. Will be stored if the operation does not start with a |-. #### **FGN Instruction** 4.11.9 [Format] [ Head Address of Parameter Table ] FGN Register address Register address with subscript [Description] The FGN instruction generates a function curve in accordance with the contents of parameter table that is set in advance. Although the inputs to the FGN instruction can be integer type, double-length integer type, or real number type values, th configuration of the parameter table will differ according to the type of values. Table 4.27 Table of Integer Type FGN Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |------|------|--------|----------------|---------------------------------------|-----| | 0 . | w | N | Number of data | Number of pairs of X and Y | IN | | 1 | W | X1 | Data 1 | · · · · · · · · · · · · · · · · · · · | IN | | 2 | W | Y1 | Data 1 | | IN | | - 3 | W | X2 | Data 2 | | IN | | 4 | W | Y2 | Data 2 | | IN | | : | : | | : | : | : | | 2N-1 | w | XN | Data N | | IN | | 2N | W | YN | Data N | | IN | Table 4.28 Table of Double-length Integer or Real Type FGN Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |------|------|--------|----------------|----------------------------|----------| | 0 | W | N | Number of data | Number of pairs of X and Y | IN | | 1 | W | | (Reserve) | Reserve register | IN | | 2 | L/F | X1 | Data 1 | | IN | | 4 | L/F | Y1 | Data 1 | | IN | | 6 | L/F | X2 | Data 2 | | IN | | 8 | L/F | Y2 | Data 2 | | IN | | : | : | : : | : | : | <b>:</b> | | 4N-2 | L/F | XN | Data N | | IN | | 4N | L/F | YN: | Data N | | IN | If the data set in the parameter table for the FGN instruction are X<sub>n</sub> and Y<sub>n</sub>, the data must be set so that $X_n \leq X_{n+1}$ . The FGN instruction searches for an $X_n/Y_n$ pair within the parameter table for which $X_n \leq X \leq X_{n+1}$ and computes the output value Y according to the following formula: $$Y = Y_n + \frac{Y_{n+1} - Y_n}{X_{n+1} - X_n} \times (X - X_n) \quad (1 \le x \le N - 1)$$ The relationship between the data set in parameter table and the input value X and output value Y will be as shown in Fig. 4.10. Fig. 4.10 Relationship between Input and Output Values If an $X_n/Y_n$ pair, which satisfies $X_n \le X \le X_{n+1}$ for an input value X, does not exist in the parameter table, the result will be as follows: ① If $$X < X_1$$ : $Y=Y_1 + \frac{Y_2 - Y_1}{X_2 - X_1}$ (X-X<sub>1</sub>) ② If $$X > X_1$$ : $Y=Y_{n+1} + \frac{Y_n - Y_{n-1}}{X_n - X_{n-1}} (X-X_1)$ #### NOTE An operation error may occur if the parameters are not set correctly. A division error will occur if the number of data (number of X/Y pairs) is 0. When using the FGN instruction for a double-length integer type operation, be sure to execute " – double-length integer type register" immediately before the FGN instruction. #### [Operation of the Register] | Α | F | В | I | J | |----|----|---|---|---| | *1 | *2 | 0 | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) \*1: Will not be stored if the operation starts with a $\vdash$ . Will be stored if the operation does not start with a $\vdash$ . \*2: Will not be stored if the operation starts with a ╟.. Will be stored if the operation does not start with a ╟.. #### [Example(s)] Integer type operation (number of data: N=20) #W00000 to #W00040 are used for the parameter table. Double-length integer type operation (number of data: N=20) #L00000 to #L00080 are used for the parameter table. Real number type operation (number of data: N=20) #F00000 to #F00080 are used for the parameter table. #### NOTE The following form of usage is not allowed. #### 4.11.10 IFGN Instruction [Format] [ Head Address of Parameter Table ] IFGN Re Register address with subscript [Description] The IFGN instruction generates a function curve in accordance with the contents of a parameter table that is set in advance. Although the inputs to the IFGN instruction can be integer type, double-length integer type, or real number type values, the configuration of the parameter table will differ according to the type of values. The parameter tables are the same as those for the FGN instruction. Refer to the table 4.27 and the table 4.28. If the data set in the parameter table for the IFGN instruction are $X_n$ and $Y_n$ , the data must be set so that $Y_n \leq Y_{n+1}$ . The IFGN instruction searches for an $X_n/Y_n$ pair within the parameter table for which $Y_n \leq Y \leq Y_{n+1}$ for an input value Y and computes the output value X according to the following formula: $$X = X_n + \frac{X_{n+1} - X_n}{Y_{n+1} - Y_n} (Y - Y_n)$$ The relationship between the data set in parameter data and the input value Y and output value X will be as shown in Fig. 4.11. Fig. 4.11 Relationship between Input and Output Values If an $X_n/Y_n$ pair, which satisfies $Y_n \le Y \le Y_{n+1}$ for an input value Y, does not exist in the parameter table, the result will be as follows: ① If $$Y < Y_1$$ : $X = X_1 + \frac{X_2 - X_1}{Y_2 - Y_1}$ $(Y - Y_1)$ ② If $$Y > Y_1$$ : $X = X_1 + \frac{X_n - X_{n-1}}{Y_n - Y_{n-1}} (Y - Y_{n-1})$ #### NOTE An operation error may occur if the parameters are not set correctly. A division error will occur if the number of data (number of X/Y pairs) is 0. When using the IECN instruction for a double length integer type operations. When using the IFGN instruction for a double-length integer type operation, be sure to execute " — double-length integer type register" immediately before the IFGN instruction. [Operation of the Register] | A | F | В | I | J | : stored ×: not stored | |----|----|---|---|---|----------------------------------------------------------------| | *1 | *2 | 0 | 0 | 0 | *: indeterminate (Stored or not stored depending on the case.) | <sup>(</sup>Stored or not stored depending on the case.) <sup>\*1:</sup> Will not be stored if the operation starts with a $\vdash$ . Will be stored if the operation does not start with a $\vdash$ . \*2: Will not be stored if the operation starts with a $\vdash$ . Will be stored if the operation does not start with a $\vdash$ . IFGN Instruction #### [Example(s)] Integer type operation (number of data: N=20) #W00000 to #W00040 are used for the parameter table. Double-length integer type operation (number of data: N=20) #L00000 to #L00080 are used for the parameter table. Real number type operation (number of data: N=20) #F00000 to #F00080 are used for the parameter table. #### NOTE The following form of usage is not allowed. #### LAU Instruction #### 4.11.11 LAU Instruction [Format] [ Head Address of Parameter Table ] LAU Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Description] The LAU instruction is used to perform acceleration and deceleration at a fixe acceleration/deceleration rate upon input of a speed reference (value of the A register). The operation is carried out in accordance with the contents of a parameter table that is set in advance. The input (X) to the LAU operation must be an integer type or reasonmeter type value. The configuration of the parameter table will differ according to whether the parameters are of an integer type or of a real number type. Double length integer type parameters cannot be used (operations will be performed with each parameter being handled as an integer consisting of the lower 16 bits). Table 4.29 Table of Integer Type LAU Instruction Parameters | ADR | Туре | Symbol | Name - | · Specification | Ι/O | |-----|------|--------|------------------------------------------|----------------------------------------------------------------|---------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OU'I | | 1 | W | LV | 100% input level | Scale of the 100% input | IN | | 2 | W | AT | Acceleration time | Time for acceleration from 0% to 100% (0.1s) | IN | | 3 | W | BT | Deceleration time | Time for deceleration from 100% to 0% (0.1s) | IN | | 4 | W | QT | Quick stop time | Time for quick stop from 100% to 0% (0.1s) | IN | | 5 | W | V | Current speed | LAU output (also output to the A register) | OUT | | 6 | W | DVDT | Current acceleration /deceleration speed | Scaled with the normal acceleration rate being set to 5000. | OUT | | 7 | W | | (Reserve) | Reserve register | | | 8 | W | VIM | Previous speed reference | For storage of the previous value of the speed reference input | OUT | | 9 | W | DVDTK | Remainder | Scaling coefficient of the current acceleration | OUT | | | | | · | /deceleration speed (DVDT) (-32768 $\sim$ 32767) | | | 10 | L | REM | Remainder | Remainder of the acceleration/deceleration rate | OUT | #### \*1: Relay I/O Bit Assignment | | _ | | | | |--------|--------|-----------------------------|---------------------------------------------------|-----| | BIT | Symbol | Name | Specification | I/O | | 0 | RN | Line is running | "ON" is input while the line is running. | IN | | 1 | QS | Quick stop | "OFF" is input upon quick stop. *1 | IN | | 2 | DVDTF | DVDT Operation not executed | "ON" is input at non-execution of DVDT operation. | IN | | 3 | DVDTS | DVDT Operation selection | Selection DVDT operation type | IN | | 4 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 | ARY | In acceleration | "ON" is output during acceleration. | OUT | | 9 | BRY | In deceleration | "ON" is output during deceleration. | OUT | | A | LSP | Zero speed | "ON" is output at a speed of 0. | OUT | | В | EQU | Coincidence | "ON" is output when input value = output value. | OUT | | C to F | | (Reserve) | Reserve relay for output | OUT | <sup>\*1:</sup> When the quick stop (QS) is "OFF", the quick stop time is used for the acceleration/deceleration time. Table 4.30 Table of Real Number Type LAU Instruction Parameters | ADR | Туре | Symbol | Name | Specification | Ι/O | |-----|------|--------|----------------------|----------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | W | | (Reserve) | Reserve register | | | 2 | F | LV | 100% input level | Scale of the 100% input value | IN | | 4 | F | AT | Acceleration time | Time for acceleration from 0% to 100% (s) | IN | | 6 | F | BT | Deceleration time | Time for deceleration from 100% to 0% (s) | IN | | 8 | F | QТ | Quick stop time | Time for quick stop from 100% to 0% (s) | IN | | 10 | F | V | Current speed | LAU output (also output to the F register) | OUT | | 12 | F | DVDT | Current acceleration | Current acceleration/deceleration is output. | OUT | | | | | /deceleration speed | | | \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | I/O | |--------|--------|-----------------|-------------------------------------------------|-----| | 0 | RN | Line is running | "ON" is input while the line is running. | IN | | 1 | QS | Quick stop | "OFF" is input upon quick stop. | IN | | 2 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 | ARY | In acceleration | "ON" is output during acceleration. | OUT | | 9 | BRY | In deceleration | "ON" is output during deceleration. | OUT | | A | LSP | Zero speed | "ON" is output at a speed of 0. | OUT | | В | EQU | Coincidence | "ON" is output when input value = output value. | OUT | | C to F | | (Reserve) | Reserve relay for output | OUT | The following operations are performed inside the LAU instruction: #### Integer Type LAU Instruction Acceleration rate (ADV) = $$\frac{LV \times Ts (0.1ms) + REM}{AT (0.1s) \times 1000}$$ Deceleration rate (BDV) = LV $\times$ Ts (0.1ms) + REM $BT (0.1s) \times 1000$ Quick stop rate (QDV) = $$\frac{LV \times Ts (0.1ms) + REM}{QT (0.1s) \times 1000}$$ V': previous speed output value Ts: scan time set value (ms) VI: speed reference input When VI > V' ( $V' \ge 0$ ): V = V' + ADV; In acceleration (ARY) ON When $VI < V' (V' \le 0)$ : V = V' - ADV; In acceleration (ARY) ON When VI > V'(V'<0): V = V' + BDV; In deceleration (BRY) ON When VI < V'(V>0): V = V' - BDV; In deceleration (BRY) ON When QS=ON (VI>V', V'<0): V = V' + QDV; In deceleration (BRY) ON When QS=ON (VI < V', V' > 0): $V = V'^-QDV$ ; In deceleration (BRY) ON - \* If the DVDT operation instruction (DVDTF) is ON, a current acceleration/deceleration operation (DVDT) is performed. - If DVDTF is OFF, DVDT = 0 is output. If DVDTF is ON, a current acceleration/deceleration operation (DVDT) is output after one of the following operations has been performed through DVDT operation selection (DVDTS). If DVDTS is ON: DVDT = $\frac{V - V'}{ADV} \times 5000$ If DVDTS is OFF: DVDT = $(V \times DVDTK) - (V' \times DVDTK)$ ; DVDTK: DVDT coefficient. At V = 0, the zero speed (LSP) is ON, at VI=V, coincidence (EQU) turns ON. When the "line is running" (RN) is "OFF," V=0, DVDT=0, and REM=0 are output. ## LAU Instruction #### **Real Number Type LAU Instruction** Acceleration rate (ADV) = $$\frac{LV \times Ts (0.1ms)}{AT(s) \times 10000}$$ Deceleration rate (BDV) = $$\frac{-\text{LV} \times \text{Ts (0.1ms)}}{\text{BT(s)} \times 10000}$$ Quick stop rate (QDV) = $$\frac{-\text{LV} \times \text{Ts (0.1ms)}}{\text{QT(s)} \times 10000}$$ V': previous speed output value VI: speed reference input Ts: scan time set value (ms) When VI > V' (V>0) $V = V' + \Delta T V \cdot T_{I}$ V = V' + ADV: "In acceleration" (ARY) is ON When VI < V'(V'<0) V = V' - ADV: "In acceleration" (ARY) is ON When VI < V'(V > 0) V = V' + BDV: "In deceleration" (BRY) is ON When VI > V' (V'<0) V = V' - BDV: "In deceleration" (BRY) is ON When QS=ON (V'> VI $\geq$ 0) V = V' + QDV: "In deceleration" (BRY) is ON When QS=ON (V'< $VI \le 0$ ) V = V' - QDV: "In deceleration" (BRY) is ON The current acceleration/deceleration speed (DVDT) is output after the following operation is carrout: When the "line is running" (RN) is "OFF," V=0 and DVDT=0 are output. #### [Operation of the Register] | Α | F | В | I | J | : stored ×: not stored | |----|----|---|---|---|----------------------------------------------| | *1 | *2 | 0 | 0 | 0 | * : indeterminate (Stored or not stored deno | (Stored or not stored depending on the case.) ## [Example(s)] Integer type operation Use MW00100 to MW00106 for the parameter table. Head address of parameter table LAU output value Real number type operation Use MF00200 to MF00212 for the parameter table. <sup>\*1:</sup> Will be stored if the operation starts with a $\vdash$ . Will not be stored if the operation does not start with a $\vdash$ . <sup>\*2:</sup> Will not be stored if the operation starts with a $\parallel$ - . Will be stored if the operation does not start with a $\parallel$ - . #### 11.12 SLAU Instruction [Format] [ Head Address of Parameter Table ] SLAU Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Description] The SLAU instruction is used to perform acceleration and deceleration at variable acceleration/deceleration rates upon input of a speed reference (value of the A register). The operation is carried out in accordance with the contents of a parameter table that is set in advance. For integer type SLAU instruction, a positive or a negative value for speed reference input can be entered. For real number type SLAU instruction, only a positive value for speed reference input can be entered. Do not use a negative value therefore. Set it so that the linear acceleration and deceleration time (AT/BT) ≥ S-curve acceleration and deceleration time (AAT/BBT). The input (X) to the SLAU operation must be an integer type or real number type value. The configuration of the parameter table will differ according to whether the parameters are of an integer type or of a real number type. Double-length integer type parameters cannot be used (operations will be performed with each parameter being handled as an integer consisting of the lower 16 bits). Table 4.31 Table of Integer Type SLAU Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|--------|------------------------------------------------------|---------------------------------------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output.*1 | IN/OUT | | 1 | W | LV | 100% input level | Scale of the 100% input | IN | | 2 | W | AT | Acceleration time | Time for acceleration from 0% to 100% (0.1s) | IN | | 3 | W | BT | Deceleration time | Time for deceleration from 100% to 0% (0.1s) | IN | | 4 | W | QT | Quick stop time | Time for quick stop from 100% to 0% (0.1s) | IN | | 5 | W | AAT | S-curve acceleration time | Time spent in the S-curve region of acceleration (0.01-32.00s) | IN | | 6 | W | BBT | S-curve deceleration time | Time spent in the S-curve region of deceleration (0.01-32.00s) | IN | | 7 | W | V | Current speed | SLAU output (also output to the A register) | OUT | | 8 | W | DVDT1 | Current acceleration/deceleration<br>speed 1 (DVDT1) | Scaled with the normal acceleration rate being set to 5000. | OUT | | 9 | W | | (Reserve) | Reserve register | | | 10 | W | ABMD | Speed increase upon holding | Amount of change in speed after hold instruction and until stabilization. | OUT | | 11 | W | REM1 | Remainder | Remainder of the acceleration and deceleration rate | OUT | | 12 | W | | (Reserve) | Reserve register | | | 13 | W | VIM | Previous speed reference | For storage of the previous value of the speed reference. | OUT | | 14 | L | DVDT2 | Current acceleration/deceleration<br>speed 2 (DVDT2) | 1000 times of the current acceleration/ deceleration speed | OUT | | 16 | L | DVDT3 | Current acceleration/deceleration<br>speed 3(DVDT3) | Current acceleration/deceleration speed(=DVDT2/1000) | OUT | | 18 | L | REM2 | Remainder | Remainder of the S-curve region acceleration and deceleration rate | OUT | | 20 | W | REM3 | Remainder | Remainder of the current speed | OUT | | 21 | W | DVDTK | DVDT1 coefficient | Scaling coefficient of the current acceleration | IN | | | | | | deceleration speed 1 (DVDT1) (-32768 to 32767) | | \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | I/O | |--------|-------------------|------------------------------|----------------------------------------------------|-----| | 0 | RN | Line is running | "ON" is input while the line is running. | IN | | 1 | $\mathbf{QS}^{T}$ | | "OFF" is input upon quick stop. | IN | | 2 | DVDTF | DVDT1 operation not executed | "OFF" is input at non-execution of DVDT1 operation | IN | | 3 | DVDTS | DVDT1 operation selection | Selection of DVDT1 operation type | IN | | 4 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 | ARY | In acceleration | "ON" is output during acceleration. | OUT | | 9 | BRY | In deceleration | "ON" is output during deceleration. | OUT | | A | LSP | Zero speed | "ON" is output at a speed of 0. | OUT | | В | EQU | Coincidence | "ON" is output when input value = output value. | OUT | | C | EQU | (Reserve) | Reserve relay for output | OUT | | D | CCF | Work relay | System internal work relay | OUT | | E | BBF | Work relay | System internal work relay | OUT | | F | AAF | Work relay | System internal work relay | OUT | Table 4.32 Table of Real Number Type SLAU Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-------|------|--------|-----------------------------------|---------------------------------------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | W | | (Reserve) | Reserve register | | | ${2}$ | F | LV | 100% input level | Scale of the 100% input value | IN | | 4 | F | AT | Acceleration time | Time for acceleration from 0% to 100% (s) | IN | | 6 | F | BT | Deceleration time | Time for deceleration from 100% to 0% (s) | IN | | 8 | F | QT | Quick stop time | Time for quick stop from 100% to 0% (s) | IN | | 10 _ | F | AAT | S-curve acceleration time | Time spent in the S-curve region of acceleration (s) | IN | | 12 | F | BBT | S-curve deceleration time | Time spent in the S-curve region of deceleration (s) | IN | | 14 | F | V | Current speed | SLAU output (also output to the F register) | OUT | | 16 | F | DVDT | Current acceleration/deceleration | Current acceleration/deceleration speed is output. | OUT | | 18 | F | ABMD | \ | Amount of change in speed after hold instruction and until stabilization. | OUT | \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | I/O | |--------|--------|-----------------|-------------------------------------------------|------| | 0 | RN | Line is running | "ON" is input while the line is running. | IN | | 1 | QS | Quick stop | "OFF" is input upon quick stop. | IN - | | 2 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 | ARY | In acceleration | "ON" is output during acceleration. | OUT | | 9 | BRY | In deceleration | "ON" is output during deceleration. | OUT | | A | LSP | Zero speed | "ON" is output at a speed of 0. | OUT | | В | EQU | Coincidence | "ON" is output when input value = output value. | OUT | | C to F | | (Reserve) | Reserve relay for output | OUT | The following operations are performed inside the SLAU instruction: #### Integer Type SLAU Instruction Acceleration rate (ADV) = $\frac{\text{(LV} \times \text{Ts(0.1ms)+REM1)}}{\text{(LV} \times \text{Ts(0.1ms)+REM1)}}$ $AT(0.1s) \times 1000$ When VI > V' ( $V' \ge 0$ ) outside the S-curve region (ADVS > ADV): V = V' + ADV; In acceleration (ARY) ON When VI < V' $(V' \le 0)$ : V = V' - ADV; In acceleration (ARY) ON Deceleration rate (BDV) = $$\frac{\text{(LV} \times \text{Ts}(0.1\text{ms}) + \text{REM1})}{\text{BT}(0.1\text{s}) \times 1000}$$ When VI > V' (V'< 0) outside the S-curve region (BDVS < BDV): V = V' + BDV; In deceleration (BRY) Of When VI < V'(V > 0): V = V' - BDV; In deceleration (BRY) Of Quick stoppage rate (QDV) = $$\frac{\text{(LV} \times \text{Ts}(0.1\text{ms}) + \text{REM1})}{\text{QT}(0.1\text{s}) \times 1000}$$ When QS=ON (VI > V', V'<0): V = V' + QDV; In deceleration (BRY) ON When QS=ON (VI < V', V'>0): V = V' - QDV; In deceleration (BRY) ON (Note) At quick stop, the movement is not curve but linear (same as during L quick stop). Acceleration rate in the S-curve region (ADVS) = ADVS' $\pm$ AADVS $$AADVS = \frac{ADV \times Ts(0.1ms) + REM2}{AAT(0.01s) \times 100}$$ When VI > V' ( $V' \ge 0$ ) inside the S-curve region (ADVS < ADV): V = V' + ADVS; In acceleration (ARY) Of When VI < V' ( $V' \le 0$ ): V = V' - ADVS; In acceleration (ARY) ON Deceleration rate in the S-curve region (BDVS) = BDVS' ± BBDVS $$BBDVS = \frac{BDV \times Ts(0.1ms) + REM2}{BBT(0.01s) \times 100}$$ When VI > V' (V'< 0) inside the S-curve region (BDVS < BDV): V = V' + BDVS; In deceleration (BRY) ON When VI < V' (V'>0): V = V' -BDVS; In deceleration (BRY) ON V': previous speed output value Ts: scan time set value (ms) VI: speed reference input \* If the DVDT operation instruction (DVDTF) is ON, a current acceleration/deceleration speed operation 1 (DVDT1) is performed. If DVDTF is OFF, DVDT1 = 0 is output. IF DVDTF is ON, a current acceleration/deceleration speed operation 1 (DVDT1) is output after one of the following operations has been performed through DVDT1 operation selection (DVDTS). If DVDTS is ON: DVDT1 = $\frac{V - V'}{ADV} \times 5000$ If DVDTS is OFF: $(V \times DVDTK) - (V' \times DVDTK)$ ; DVDTK: DVDT coefficient. \* The current acceleration/deceleration speed 2 (DVDT2) is output as follows: During acceleration inside the S-curve region: DVDT2 = $\pm$ ADVS During acceleration outside the S-curve region: DVDT2 = $\pm$ ADV During deceleration inside the S-curve region: DVDT2 = $\pm$ BDVS During deceleration outside the S-curve region: DVDT2 = $\pm$ BDV \* The speed increase upon holding (ABMD) is output after the following operation is performed. $ABMD = \frac{DVDT2' \times DVDT2'}{2 \times AADVS(BBDVS)};$ $DVDT2' = Current \ acceleration/deceleration \ speed 2 \ (DVDT2) \ previous \ value$ \* At V = 0, the zero speed (LSP) is ON, at VI=V, coincidence (EQU) turns ON. \* When the line running signal (RN) is "OFF," V=0, DVDT1=0, DVDT2=0, DVDT3=0, ABMD=0, REM1=0, REM2=0, and REM3=0 are output. ## **Real Number Type SLAU Instruction** Acceleration rate (ADV) = $$\frac{LV \times Ts (0.1ms)}{AT(s) \times 10000}$$ When VI > V' (V'> 0) outside the S-curve region (ADVS > ADV): V = V' + ADV $$\begin{array}{ll} \text{Deceleration rate (BDV)} = \frac{-\text{ LV} \times \text{Ts (0.1ms)}}{\text{BT(s)} \times 10000} & \text{When VI < V' (V'>0) outside the S-curve region} \\ \text{(BDVS < BDV): V = V' + BDV} \end{array}$$ Quick stop rate (QDV) = $$\frac{-\text{LV} \times \text{Ts (0.1ms)}}{\text{QT(s)} \times 10000}$$ When QS=ON (V'> VI): $$V = V' + \text{QDV}$$ Acceleration rate in the S-curve region (ADVS) = ADVS' $\pm$ AADVS: where ADVS' = ADVS previous value $$AADVS = \frac{ADV \times Ts (0.1ms)}{AAT(s) \times 10000}$$ When VI > V' (V'> 0) inside the S-curve region (ADVS < ADV): V = V' + ADVS Deceleration rate in the S-curve region (BDVS) = BDVS' ± BBDVS: where BDVS = BDVS previous value $$BBDVS = \frac{BDV \times Ts (0.1ms)}{BBT(s) \times 10000}$$ When VI < V' (V'> 0) inside the S-curve region (BDVS > BDV): V = V' + BDVS V': previous speed output value VI: speed reference input Ts: scan time set value (ms) #### SLAU Instruction The current acceleration/deceleration speed (DVDT) is output after the following operation is carrout: During acceleration inside S-curve region: DVDT = ADVS During acceleration outside S-curve region: DVDT = ADV During deceleration inside S-curve region: DVDT = BDVS During deceleration outside S-curve region: DVDT = BDV The speed increase upon holding (ABMD) is output after the following operation is performed. $$ABMD = \frac{DVDT \times DVDT}{2 \times AADVS(BBDVS)}$$ When the "line is running" signal (RN) is "OFF", V=0, DVDT=0, and ABMD=0 are output. #### [Operation of the Register] | A | F | В | I | J | : stored ×: not stored | |----|----|---|----|---|-----------------------------------------------------------------| | *1 | *2 | 0 | -0 | 0 | * : indeterminate (Stored or not stored depending on the case.) | <sup>\*1:</sup> Will be stored if the operation starts with a $\vdash$ . Will not be stored if the operation does not start with a $\vdash$ . #### [Example(s)] Integer type operation Use MW00100 to MW00111 for the parameter table. Real number type operation MF00200 to MF00218 are used for the parameter table. Fig. 4.12 Motion by SLAU <sup>\*2.</sup> Will not be stored if the operation starts with a $\Vdash$ . Will be stored if the operation does not start with a $\Vdash$ . PWM Instruction #### .11.13 PWM Instruction [Format] [ Head Address of Parameter Table ] **PWM** Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Description] The PWM instruction converts the value of the A register to PWM as input value (-100.00 to 100.00%, units: 0.01%), and the result is output to the B register and the parameter table. Double-length type integer operations and real number type operations are not allowed. Time of ON output and number of ON outputs are expressed as follows. Time of ON output = $\frac{PWMT(X+10000)}{20000}$ Number of ON outputs = $\frac{PWMT(X+10000)}{Ts \times 20000}$ X: input value Ts: scan time set value (ms) When 100.00% is input: all ON When 0% is input: 50% duty (50% ON) When -100.00% is input: all OFF When the PWM reset (PWMRST) is "ON", all internal operations are reset. PWM operations are performed with that instant as the starting point. After powering up, first turn "ON" PWMRST and clear internal operations. Then use the PWM instruction. Table 4.33 Table of PWM Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|----------|----------------------------------|-------------------------------------------|--------| | 0 | W | RLY | Relay I/O | Relay input, relay output *1 | IN/OUT | | 1 | W | PWMT | PWM cycle | PWM cycle (1 ms) (1 to 32767 ms) | IN | | 2 | W | ONCNT | | ON output setting timer (1 ms) | OUT | | 3 | W | CVON | ON output count timer | ON output count timer (1 ms) | OUT | | 4 | W | CVONREM | ON output count timer remainder | ON output count timer remainder (0.1 ms) | OUT | | 5 | W | OFFCNT | OFF output setting timer | OFF output setting timer (1 ms) | OUT | | 6 | W | CVOFF | OFF output count timer | OFF output count timer (1 ms) | OUT | | 7 | W | CVOFFREM | OFF output count timer remainder | OFF output count timer remainder (0.1 ms) | OUT | #### \*1: Relay I/O Bit Assignment | BIT | Symbol | Name | Specification | I/O | |--------|--------|------------|-----------------------------------------------|-----| | 0 | PWMRST | PWM reset | "ON" is input when PWM is reset | IN | | 2 to 7 | | (Reserve) | Reserve relay for input | IN | | 8 | PWMOUT | PWM output | PWM is output (two-value output: ON=1, OFF=0) | OUT | | 9 to F | | (Reserve) | Reserve relay for output | OUT | [Example(s)] MW00100 is used as PWM input and MW00200 to MW00207 as a parameter table. PWM reset with the first scan of DWG.L (SB000001 when used with DWG.H) Head address of parameter table ## 4.12 Table Data Operation Instructions When an error occurs at the execution of table data operation instruction, an error code is set to A register and B register is turned ON. For the error codes, refer to Table 4.34. Table 4.34 List of Errors | Error code | Error name | Contents | |------------|-------------------------------------------|--------------------------------------------------| | 0001H | Reference table not defined | The target table has not been defined. | | 0002H | Outside row number range | The row numbers of the table element are not i | | | 2 | the range of the target table. | | 0003H | Outside column number range | The column numbers of the table element are no | | | * • | in the range of the target table. | | 0004H | Wring number of elements | The number of target elements is not correct | | 0005H | Insufficient space in storage destination | Area for storing is not adequate. | | 0006H | Wrong element format | The format of the specified element is wrong. | | 0007H | Cue buffer error | An attempt is made to read the cue buffer when | | | | is empty, or the buffer is written to by pointe | | | · | advance when it is full. | | 0008H | Cue table error | The designated table is not a cue type table. | | 0009H | System error | An unexpected error is detected internally in th | | | | system during instruction execution. | #### 4.12.1 Block Read Instruction (TBLBR) [Format] [Head Address of Transfer Destination Data] [Head Address of Parameter Tab TBLBR Transfer source table name Register address (except for # and C registers) Register address with subscript (except for # and C registers) Register address Register address with subscript [Description] The block read instruction consecutively reads, in block format, elements of the file register table specified by table name, row number, and column number. The instruction then stores the elements in a consecutive region beginning with the specified register. The type of the elements read is automatically judged based on the table specified. The format of the register stored at is ignored. The read value is stored according to the table element format without format conversion. In referencing a table, if there is anything invalid in the name, row number, column number or insufficient data length storage, an error is reported, and the data is not read. The contents of the register for storage are kept. Upon normal completion, the number of words transmitted is set in the A register, the B register turns OFF. When an error occurs, an error code is set in A register, and B register turns ON For error codes, refer to Table 4.34. Table 4.35 Table of Block Read Instruction Parameters | ADR | Туре | Symbol | Name | Specification | 1/0 | |-----|------|--------|------------------------------------|-----------------------------------------------------------|-----| | 0 | L | ROW1 | Table element beginning row number | Target table element beginning row number (1 to 65535) | IN | | 2 | L | | | Target table element beginning column number (1 to 32767) | IN | | 4 | · w | | | Number of row elements (1 to 32767) | IN | | 5 | W | CLEN | Number of column elements | Number of column elements (1 to 32767) | IN | [Operation of the Register] | A | F | В | I | J | |---|---|---|---|---| | × | 0 | × | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] From the table defined as TABLE 1, using DW00010 to DW00013 as a parameter table, data (element type is integer type) from the starting table element position to the end position are stored in block form in the area starting from MW00100. ## 12.2 Block Write Instruction (TBLBW) [Format] TBLBW Transfer source table name [Head Address of Transfer Destination Data] Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Head Address of Parameter Table] Register address with subscript [Description] The block write instruction consecutively stores a consecutive region beginning with the designated register, using block format in elements of the file register table specified by table name, row number, and column number. The data is processed assuming the form of the elements in the storage and the format of the storage source register conform. In referencing a table, if there is anything invalid in the name, row number, column number, or insufficient length at data destination, an error is reported, and the data is not read. The contents of the register for storage are kept. Upon normal completion, the number of words transmitted is set in the A register, the B register turns OFF. When an error occurs, an error code is set in A register, and B register turns ON. For error codes, refer to Table 4.34. Table 4.36 Table of Block Write Instruction Parameters | ADR | Туре | Symbol | Name | Specification | ΙΟ | |-----|--------------|--------|------------------------------------|-----------------------------------------------------------|----| | 0 | $\mathbf{L}$ | ROW1 | Table element beginning row number | Target table element beginning row number (1 to 65535) | IN | | 2 | L | COL1 | | Target table element beginning column number (1 to 32767) | IN | | 4 | W | RLEN | Number of row elements | Number of row elements (1 to 32767) | IN | | 5 | W | CLEN | Number of column elements | Number of column elements (1 to 32767) | IN | #### [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | × | 0 | × | 0 | O | $\bigcirc$ : stored $\times$ : not stored \* : indeterminate (Stored or not stored depending on the case.) [Example(s)] From the table defined as TABLE 1, with DW00010 to DW00013 as a parameter table, data (element type is integer type) from the starting table element position to the end position are stored in block form in the area beginning with MW00100. ## 4.12.3 Row Search Instruction: Vertical Direction (TBLSRL) [Format] TBLSRL Name of table to be searched. [Head Address of Search Data] Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Head Address of Parameter Table] Register address Register address with subscript [Description] The row search instruction searches the column element of a file register table specified by table name, row number, and column number, and if there is data which matches the data of the register, reports that row number. The type of the data to be searched is automatically judged based on the table specified. In referencing a table, if there is anything invalid in the name, row number, column number, or insufficient length at data destination, an error is reported. Upon normal completion, the B register turns OFF. If matching column elements were found, a "1" is set in the search result, and in register A, the corresponding row number is set. If matching column elements were not found, a "0" is set in the search result. When an error occurs, an error code is set in A register, and B register turns ON. For error codes, refer to Table 4.34. **Table 4.37 Table of Row Search Instruction Parameters** | ADR | Type | Symbol | Name | Specification | I/ | |-----|------|--------|----------------------------------|----------------------------------------------------------|----------------------------------------------| | 0 | L | ROW1 | | Head row number of the target table element (1 to 65535) | IN | | 2 | L | ROW2 | Last row number of table element | Last Tow Humber of the target table crement (1 to oboot) | IN | | 4 | L | | Table element column number | Column number of the target table element (1 to 32767) | IN | | 6 | w | FIND | Search result | Search results | Ot | | | | | · | 0: No matching row 1: Matching row exists | <u>L </u> | [Operation of the Register] | A | F | В | Ι | J | |---|---|---|---|---| | X | 0 | X | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] The table defined as TABLE1 is searched for data which matches MW00100 (when the type of the searched table is integer) with DW00010 to DW00013 as a parameter table. TBLSRL TABLE1, MA00100, DA00010 → MW000011 ## Column Search Instruction: Horizontal Direction (TBLSRC) [Format] [Head Address of Search Data] [Head Address of Parameter Table] TBLSRC [Name of table to be searched.], [Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Register address with subscript (except for # and C register)] [Description] .12.4 The column search instruction searches the row element of a file register table specified by table name, row number, and column number, and if there is data which matches the data of the register, reports that column number. The type of the data to be searched is automatically judged based on the table specified. C registers) In referencing a table, if there is anything invalid in the name, row number, column number, or insufficient length at data destination, an error is reported. Upon normal completion, the B register turns OFF. If matching row elements were found, a "1" is set in the search result, and in register A, the corresponding column number. If matching column elements were not found, a "0" is set in the search result. When an error occurs, an error code is set in A register, and B register turns ON. For error codes, refer to Table 4.34. **Table 4.38 Table of Column Search Instruction Parameters** | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|---------|-------------------------------------|-------------------------------------------------------------|-----| | 0 | L | ROW | Table element row number | Row number of the target table element (1 to 65535) | IN | | 2 | L | COLUMN1 | Head column number of table element | Head column number of the target table element (1 to 32767) | IN | | 4 | | | | Last column number of the target table element (1 to 32767) | | | 6 | W | | Search result | 11.11.11.11.11.11.11.11.11.11.11.11.11. | OUT | | | | | | 0: No corresponded column 1: Corresponded column exists | | [Operation of the Register] | Α | F | В | I | J | : stored ×: not stored | |---|---|---|---|---|----------------------------------------------------------------| | X | 0 | × | 0 | 0 | *: indeterminate (Stored or not stored depending on the case.) | [Example(s)] The table defined as TABLE1 is searched for data which matches MW00100 (when the type of the searched table is integer) with DW00010 to DW00013 as a parameter table. #### **Block Clear Instruction (TBLCL)** 4.12.5 [Format] Target table name TBLCL Head Address of Parameter Tablel Register address Register address with subscript [Description] The block clear instruction clears the data of the block element of a file register table specified by table name, row number, and column number. If the type of the element is a character string, a space is written, and a 0 is written if it is a numerical value.If both the head row number and the head column number of the table element destination are 0, the entire table will be cleared. In referencing a table, if there is anything invalid in the name, row number, column number, or insufficient length at data destination, an error is reported, and the data is not read. Upon normal completion, the number of words cleared is set in the A register, the B register turns OFF. When an error occurs, an error code is set in A register, and B register turns ON. For error codes, refer to Table 4.34. Table 4.39 Table of Block Clear Instruction Parameters | A | DR 7 | Гуре | Symbol | Name | Specification | ľ | |-----|------|------|--------|-------------------------------------|-------------------------------------------------------------|----| | | ) | L | ROW | Head row number of table element | Head row number of the target table element (0 to 65535) | IN | | 1 2 | 2 | L | COLUMN | Head column number of table element | Head column number of the target table element (1 to 32767) | IN | | | Į | w | RLEN | Number of row elements | Number of row elements (1 to 32767) | IN | | E | 5 | w | CLEN | Number of column elements | Number of column elements (1 to 32767) | IN | [Operation of the Register] [Example(s)] | A | F | B. | I | J | |---|---|----|---|---| | × | 0 | × | 0 | 0 | $\supset$ : stored $\times$ : not stored : indeterminate (Stored or not stored depending on the case.) The designated block in the table defined as TABLE1 is cleared using DW00010 to DW00013 as a parameter table. | TBLCL TABLE1, DA00010 | |-----------------------| |-----------------------| ## 12.6 Inter Table Block Transfer Instruction (TBLMV) [Format] [Head Address of Parameter Table] TBLMV Transfer source table Transfer destination table name Register address Register address with subscript [Description] The inter table block transfer instruction transfers the data of a block element of a file register table specified by table name, row number, and column number to another block. Transfers both between different tables and transfers within the same table are possible, but if the type of the transfer source and transfer destination are not identical, an error is reported, and the data cannot be written. In referencing a table, if there is anything invalid in the name, row number, column number, or insufficient length at data destination, an error is reported, and the data is not read. Upon normal completion, the number of words transferred is set in the A register, the B register turns OFF. When an error occurs, an error code is set in A register, and B register turns ON. For error codes, refer to Table 4.34. Table 4.40 Table of Inter Table Block Transfer Instruction Parameters | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|---------|-------------------------------------|---------------------------------------------------------------------------|-----| | 0 | L | ROW1 | Head row number of table element | Head row number of the transfer source table element (1 to 65535) | IN | | 2 | L | | Head column number of table element | Head column number of the transfer source table element (1 to 32767) | IN | | 4 | W | RLEN | Number of row elements | Number of transfer row elements (1 to 32767) | IN | | 5 | W | | Number of column elements | Number of transfer column elements (1 to 32767) | IN | | 6 | L | | Head row number of table element | Head row number of the transfer destination table element (1 to 65535) | IN | | 8 | L | COLUMN2 | Head column number of table element | Head column number of the transfer destination table element (1 to 32767) | IN | [Operation of the Register] | Α | F | В | I | J | |---|---|---|---|---| | × | 0 | × | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] There are tables defined as TABLE1 and TABLE2. The designated block in TABLE1 is transferred to the designated block in TABLE2 using DW00010 to DW00015 as a parameter table. ## 4.12.7 Cue Table Read Instruction (QTBLR, QTBLRI) [Format] QTBLR Transfer source table name [Head Address of Transfer Destination Data] Register address (except for # and C registers) Register address with subscript (except for # and C registers) [Head Address of Parameter Table] Register address Register address with subscript [Description] The cue table read instruction continuously reads column elements of a file register table specified by table name, row number, and column number, and stores it in consecutive areas beginning with the specified register. The type of the element to be read is automatically judged based on the table specified. The type of the register for storage is ignored. The read value is stored according to the table element formal without type conversion. The cue table read pointer is not changed by a QTBLR instruction. In referencing a table, if there is anything invalid in the name, row number, column number, insufficient length at data destination, or the cue buffer is empty, an error is reported, the data is not read, and the cue pointer does not advance. The contents of the register for storage are kept. Upon normal completion, the number of words transferred is set in the A register, the B register turns OFF. When an error occurs, an error code is set in A register, and F register turns ON. The pointer value does not change. For error codes, refer to Table 4.34. Table 4.41 Table of Cue Table Read Instruction Parameters | ADR | Туре | Symbol | Name | Specification | 1/0 | |-----|------|---------|-----------------------------------------|--------------------------------------------------------------------|-----| | 0 | L | ROW | Relative row numbers for table elements | Relative column number of the target table element (0 to 65535) | IN | | 2 | L | COLUMN | Head column number of table element | Head column number of the target table element (1 to 32767) | IN | | 4 | w | CLEN | Number of column elements | Number of column elements to be continuously read out (1 to 32767) | IN | | 5 | W | Reserve | | | | | 6. | L | RPTR | Read pointer | Read pointer of the cue after execution | OU | | 8 | L | WPTR | Write pointer | Write pointer of the cue after execution | JO | By setting relative row numbers for the table elements, the actual row position read will vary as in Table 4.42. Table 4.42 Settings for Relative Row Numbers for Table Elements | Relative row numbers | Row read | Remark Pointer advance for QTBLRI only | | |----------------------|---------------------------|----------------------------------------|--| | 0 | Read pointer row | | | | 1 | Write pointer row | No pointer advance | | | 2 | (Write pointer row)-1 | No pointer advance | | | 3 | (Write pointer row)-2 | No pointer advance | | | • | • | : | | | n | (Write pointer row)-(n-1) | No pointer advance | | [Operation of the Register] | I | Α | F | В | I | J | |---|---|---|---|---|---| | | X | 0 | × | 0 | 0 | $\bigcirc$ : stored $\times$ : not stored \*: indeterminate (Stored or not stored depending on the case.) [Example(s)] Column element data (element format assumed to be integer) from the table defined as TABLE1 is stored for the number of column elements beginning with MW00100 | QTBLRI TABLE1, MA00100, DA00010 | MB000000 | |---------------------------------|-----------| | | ⇒ MW00011 | using DW00010 to DW00012 as a parameter table. # Cue Table Write Instruction (QTBLW, QTBLWI) | [Format] | | [Head Address of<br>Transfer Source Data] | [Head Address of<br>Parameter Table] | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--------------------------------------------------| | | $egin{bmatrix} \mathbf{QTBLW} \ \mathbf{QTBLWI} \end{bmatrix} egin{bmatrix} \mathbf{Transfer} & \mathbf{destination} \ \mathbf{table} & \mathbf{name} \end{pmatrix}$ , | Register address Register address with subscript | Register address Register address with subscript | #### [Description] 12.8 The cue table write instruction continuously reads data from consecutive areas beginning with the specified register, and writes it to column elements of a file register table specified by table name, row number, and column number. Data is processed assuming the format of the element of the table at the location to be stored at is the same as the type of the register storage source. The cue table write pointer is not changed by a QTBLW instruction. The cue pointer is advanced one row by a QTBLWI instruction. In referencing a table, if there is anything invalid in the name, row number, column number, insufficient length at data destination, or the cue buffer is full, an error is reported, the data is not written, and the cue pointer does not advance. Upon normal completion, the number of words transferred is set in the A register, the B register turns OFF. When an error occurs, an error code is set in A register, and B register turns ON. The pointer value does not change. For error codes, refer to Table 4.34. **Table 4.43 Table of Cue Table Write Instruction Parameters** | ADR | Туре | Symbol | Name | Specification | I/O | |-----|------|---------|-----------------------------------------|-------------------------------------------------------------------|----------------| | 0 | L | ROW | Relative row numbers for table elements | Relative column number of the target table element (0-65535) | IN | | 2 | L | COLUMN | Head column number of table element | Head column number of the target table element (1 to 32767) | IN | | 4 | W | CLEN | Number of column elements | Number of column elements to be continuously written (1 to 32767) | IN | | 5 | W | Reserve | | | <del>' </del> | | 6 | L | RPTR | Read pointer | Read pointer of the cue after execution | OUT | | 8 | L | WPTR | Write pointer | Write pointer of the cue after execution | OUT | By setting relative row numbers for the table elements, the actual row position write will vary as in Table 4.44. Table 4.44 Settings for Relative Row Numbers for Table Elements | Relative row numbers | Row write | Remark Pointer advance for QTBLWI only | | |----------------------|---------------------------|----------------------------------------|--| | 0 | Write pointer row | | | | 1 | Write pointer row | No pointer advance | | | 2 | (Write pointer row)-1 | No pointer advance | | | 3 | (Write pointer row)-2 | No pointer advance | | | | | | | | n | (Write pointer row)-(n-1) | No pointer advance | | [Operation of the Register] | | Α | F | В | I | J | : stored ×: not stored | |--|---|---|---|---|---------|-----------------------------------------------------------------| | | X | 0 | X | 0 | $\circ$ | * : indeterminate (Stored or not stored depending on the case.) | [Example(s)] Integer form consecutive data for the number of column elements beginning with MW00100 is written in column element data in the table defined as TABLE1 using DW00010 to DW00013 as a parameter table. | QTBLWI TABLE1, MA00100, DA00010 | MB000000 | |---------------------------------|-----------------------| | | $\Rightarrow$ MW00011 | ## 4.12.9 Cue Pointer Clear Instruction (QTBLCL) [Format] QTBLCL [Transfer source table name] [Description] The cue pointer clear instruction returns the cue read and cue write pointer of the file register table specified by table name to initial status (first row). Upon normal completion, a "0" is set in the A register, the B register turns OFF When an error occurs, an error code is set in A register, and B register turns ON. For error codes, refer to Table 4.34. [Operation of the Register] | <b>A</b> | F | В | I | J | : stored ×: not stored | |----------|---|-----|---|---|-----------------------------------------------------------------| | × | 0 | . × | 0 | 0 | * : indeterminate (Stored or not stored depending on the case.) | [Example(s)] The cue read and cue write pointer of TABLE1 are reset to initial status. | MB000000 | |--------------------| | | | .⇒ <b>MW</b> 00011 | | | # **5** SFC PROGRAMMING The programming method, in which SFC's (sequential function charts) are used, is described in this chapter. ## 5.1 Configuration of an SFC Program As shown in Fig. 5.1, an SFC program is composed of an SFC flowchart, an SFC action box, and an SFC output definition time chart. Fig. 5.1 Configuration of an SFC Program ### 5.2 Execution of SFC As shown in Fig. 5.2, the SFC program is executed by the SFC instruction in the ladder program. The SFC program is executed through step transition control, which is managed by the use of system step numbers. The system automatically assigns a system step number to each step name. The as signed system step number can be checked at the SFC Output Definition Time Chart screen of the CP-717. Since the system step number will be changed when an SFC step is added or deleted, do not make changes in the SFC flowchart while the line is running. Fig. 5.2 SFC Instruction Table 5.1 I/O Registers | I/O Symbol | Registers that can<br>be designated (V=) | Description | |------------------------------------------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | VB O O O O O O O O O O O O O O O O O O O | S, I, O, M, D, C,<br># | <ul> <li>SFC execution instruction</li> <li>Execution control (step transition control) of the SFC is carried out when this register is ON.</li> <li>The current system step will always be set to the initial step when this register is set to OFF.</li> </ul> | | VA | M, D | <ul> <li>Designation of the head register number of the register area for the SFC system operation.</li> <li>See Section 5.3, "SFC System Operation Register" for details.</li> </ul> | | VΒΔΔΔΔΔΔ<br>(OUT) | O, M, D | <ul> <li>SFC step transition output (becomes ON when step transition is carried out).</li> <li>Within a parallel process, this will contain the result of the final parallel process sequence.</li> </ul> | | VW AAAAA | O, M, D | <ul> <li>Designation of the user step number output corresponding to the current system step</li> <li>See Section 5.7, "Step Name Designation Method" for details.</li> </ul> | ## .3 SFC System Operation Registers The system operation registers necessary for the execution of an SFC program are set up as shown in Table 5.2. When an SFC program is to be used, these registers may not be used for other purposes. Table 5.2 Assignment of the SFC System Process Registers | Register No. | Name | Description | | | | | | | | |-----------------------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------|--|--|--|--|--|--|--| | VW □ □ □ 00 | System step - current value | System step number when an ordinary process is being carried out*1. | | | | | | | | | 01 | System step - previous value | System step number prior to transition when an ordinary | | | | | | | | | | • • | process is being carried out. | | | | | | | | | 02 | Transition timer for count | Count register used for the transition timer when an ordinary | | | | | | | | | | | process is being carried out*1. | | | | | | | | | 03 | User step search input | For searching for the system step corresponding to the user step. | | | | | | | | | | | User step no.: Bit 0 to Bit E. search execution command: Bit F. | | | | | | | | | 04 | SFC output bit *3 - 1 | Output data from the SFC Output Definition Time Chart (0 to 15). | | | | | | | | | 05 | SFC output bit *3 - 2 | Output data from the SFC Output Definition Time Chart (16 to 31). | | | | | | | | | 06 | SFC output bit *3 - 3 | Output data from the SFC Output Definition Time Chart (32 to 47). | | | | | | | | | 07 | SFC output bit *3 - 4 | Output data from the SFC Output Definition Time Chart (48 to 63) | | | | | | | | | 08 | | | | | | | | | | | | For SFC parallel process | For system use | | | | | | | | | | control | · | | | | | | | | | 09 | | • | | | | | | | | | 10 | | Stan number of each present when a small land in | | | | | | | | | 04 SFC<br>05 SFC<br>06 SFC<br>07 SFC<br>08 For conf<br>09 10 : For 17 | For SFC function operation | Step number of each process when a parallel process is being carried out.*2 | | | | | | | | | | | being carried out. | | | | | | | | | 18 | | | | | | | | | | | ; | For SFC function operation | Count register used for the transition timer for each parallel | | | | | | | | | | | process when a parallel process is being carried out.*2 | | | | | | | | | 26 | SFC output bit *3 - 5 | Output data from the SFC Output Definition Time Chart (64 to 79). | | | | | | | | | 27 | SFC output bit *3 - 6 | Output data from the SFC Output Definition Time Chart (80 to 95). | | | | | | | | | 28 | | Output data from the SFC Output Definition Time Chart (96 to 111). | | | | | | | | | 29 | SFC output bit *3 - 8 | Output data from the SFC Output Definition Time Chart (112 to 127). | | | | | | | | \*1: Ordinary process: Only a single step is processed. <sup>\*2</sup>: Parallel process: A plurality of steps are processed simultaneously and in parallel by parallel process branching. \*3: SFC output bit: In parallel processing, the logical sum (OR) of the outputs of the parallel process steps is output. #### SFC Flowchart 5.4 The SFC flowchart is prepared using steps, transition conditions, and connection designations. Th sequence proceeds from the initial step in accordance with the transition conditions and the transition to the next step is performed when conditions are satisfied. The transition of the execution of th steps is performed from top to bottom. If the SFC program cannot be prepared with just one flow chart, it can be divided into a plurality of flowcharts (or composed of subroutines). Step: One step in a sequence. - · Expressed with a box ( \_\_\_\_\_\_ ) and a step name (with 6 or less alphanumeric or symboli characters). - · A step can be in the logic state of ON (active) or OFF (inactive) and when a step becomes OI (active), the SFC Action Box associated with the step is executed. - ·A system step number controlled by the system is assigned to the step automatically. The SF is controlled by means of these step numbers. - Transition condition: The logic condition that must be satisfied for step transition. - NO contact condition ( ): Step transition is carried out when ON. NC contact condition ( ): Step transition is carried out when OFF. - · Timer transition condition (+): Step transition is carried out after the set time. Single-token Structure (designation of ordinary branching connection) - · An ordinary process branching or convergence is expressed with a single lin ( \_\_\_\_ ) and only one of the branch processes is executed. If a plurality of conditions are satisfied the condition at the left side has priority. - · Branching designation, convergence designation, and converging connection designation ma be used. Multi-token Structure (designation of parallel branching connection) - $\cdot$ A parallel process branching or convergence is expressed with a double line ( $\Longrightarrow$ ) and parallel processes are executed simultaneously and in parallel. - Branching designation, convergence designation, and converging connection designation may - The number of parallel process branches must 6 or less. - · At the branching point of a parallel process, the parallel processes are started simultaneously after the transition to the step. - · At the parallel process convergence point, the transition to the step following the convergence point is carried out when all of the parallel processes have reached the step prior to the convergence point and the transition conditions are satisfied. #### .5 SFC Action Box The SFC Action Box is prepared using the ABOX and SBOX instructions. The program, that is to be executed when a step in the SFC flowchart becomes ON (active), is prepared in the SFC Action Box. This program is prepared with ladder programming language and text type language. One step of an SFC Action Box Program will consist of the instruction sequence up to the ABOX instruction or SBOX instruction of the next step and the SFC Action Box Program comprising all steps is ended with an AEND instruction . It is not necessary to create an action box for each step. An Action Box is created only for steps which require processing. #### ABOX Instruction With this instruction, the corresponding program is executed on each scan from the point at which the corresponding step is entered and until the transition to the next step is carried out. #### SBOX Instruction With this instruction, the corresponding program is executed just once at the point of the transition to the corresponding step. ## 5.6 SFC Output Definition Time Chart The SFC Output Definition Time Chart is used to designate the output data for each SFC step in time chart form. The output data that are designated at the SFC Output Definition Time Chart are output to the SFC system operation registers (VW \\_ 04 to VW \\_ 07, Step name Each step name is displayed in each column. Number of output points Can be designated in multiples of 16 (max. = 128). Output name Can be specified with 8 or less alphanumeric characters. This is used as a comment. | 1 | 1 | 000 | - 001 | - 002 | 003 | 004 | 005 | 006 | 007 | | |-----|----------|------|-------|-------|------|------|------|------|---------------|---------| | No. | OUTPUT | 5-00 | 5-01 | 5-02 | 5-03 | S-04 | 5-05 | 5-06 | 5-07 <b>←</b> | Step Na | | 000 | STOPLAMP | | | | | | | | | 1 | | 001 | RUNLAMP | | | | **- | | | | | | | 002 | OPBNCMD1 | | | | | | _ | | | ] | | 003 | CL05ECM1 | | | | | | | | | | | 004 | OPENCMD2 | | | | L | | | | | | | 005 | CLOSECM2 | | | | | | | | | | | 006 | WEIGHTOM | | | | + | | | | | | | 007 | COMATERN | | | | | | | | | | | 800 | COMASERN | | | | | | | | L | ] | | 009 | NEXISTP1 | | | | | | | | | ' | | 010 | INATERN | | | | | | | | | | | 011 | INV2RUN | | | | | | | | | | | 012 | AUXLAMP | | | | | | | | | - | | 013 | CMDERHOR | | | | | | | | | | | 014 | WORKSW1 | | [ | | | | | | | | | 015 | MEXIST11 | | | | | | | | | | | | | Ą | | | | | | : | <del></del> | 1 | ## Step Name Designation Method The user may designate step names freely as long as they are within 6 alphanumeric characters in length and start with a character from "A" to "Z". However, use the following designating method if the user step number of a specific step name is to be taken out. For step names designated by another method than the one above, the user step number becomes "0." In this case, a user step number which corresponds to the step name is not taken out. ## Taking Out System Step Nos. .8 The SFC controls the execution steps with the system step numbers that the system assigns automatically. In order to change the SFC execution forcibly to another step, take out the system step No. and change the execution step. If an execution step is to be changed forcibly, such as in forced execution of a error processing sequence, the program is prepared using the SFCSTEP instruction. The SFCSTEP instruction takes out the system step number assigned to the step name. A program example of a error processing sequence is shown below. ## NOTE - 1. If forced transition is to be performed, a timer transition condition cannot be used as a transition condition for the step which is the destination of transition. - 2. Do not execute forced transition of an execution step from a step located within a multi-token structure. ## 5.9 Precautions upon Preparation of an SFC Program Note the precautions shown in Table 5.3 upon preparing an SFC program. Table 5.3 Precautions upon Preparation of an SFC Program | Precaution | See Section | |------------------------------------------------------------------------------|--------------| | Only one SFC program can be programmed in one DWG. | | | The maximum number of steps in an SFC program is 500. | <del>-</del> | | A branching or converging connection cannot be designated below and above | 5.9.1 | | one transition condition. | | | A convergence point must be provided if a multi-token structure is branched. | 5.9.2 | | The number of branches in a multi-token structure must be 6 or less. | 5.9.3 | | $\Gamma$ One cannot prepare a plurality of subroutines which have the | | | same start step name and which contain a multi-token structure. | | | A subroutine containing a multi-token structure cannot be called from within | 5.9.4 | | a multi-token block. | | | A subroutine containing a multi-token structure cannot be called from with | 5.9.4 | | a single-token block unless the conditions for subroutines are satisfied. | _ | | Subroutines may only be nested up to 4 times (depth of the macro) in each | 5.9.4 | | step in a single-token or multi-token block. | | | Jumping to a step in the middle of another block cannot be performed from a | 5.9.4 | | step inside a single-token or multi-token block. | | | The timer transition instruction cannot be used in a subroutine called from | 5.9.4 | | a multi-token structure. | | | The same step name cannot be used in different blocks. | 5.9.5 | #### Subroutine (Macro) In cases where a step leads to more than 6 branches, the series of steps may be taken out and newly programmed as a separate block by assigning a representative step to the main routine. Such a block is called a subroutine (macro). #### **Block** A series of steps from a start step to an end step is called a block. ## .9.1 Restrictions concerning Branching and Converging Connections A single-token or multi-token branching or converging connection cannot be designated below and above one transition condition. If branching and converging connections are not designated correctly, the program cannot be written in. Examples of restrictions concerning branching and converging connections and correct programming methods are shown below. #### (Example 1) - ① Above : return point of a single-token structure Below : branching point of a multi-token structure - ② Above : convergence point of a multi-token structure Below : convergence point of a single-token structure #### (Example 2) - ① Above : branching point of a single-token structure Below : branching point of a multi-token structure - ② Above : convergence point of a multi-token structure Below : convergence point of a single-token structure 1 Above: branching point of a single-token structure Below: branching point of a multi-token structure ② Above: convergence point of a multi-token structure Below: convergence point of a single-toker structure ① Above : convergence point of a multi-token structure Below : branching point of multi-token structure # Restriction concerning Branching and Converging Connections in a Multi-Token Structure A convergence point must be provided if a multi-token structure is branched. 5.9.2 If branching and converging connections are not designated correctly, the program cannot be written in. The multi-token structure remains branched since a step is set as an end step within a branch of a multi-token structure. #### 5.9.3 Restriction of the Number of Branches in a Multi-Token Structure If there are 6 or more branches in one block in a single-token structure, the block may be divided in two to prepare the program. However, such a program cannot be prepared in the case of a multi-token structure. The maximum number of steps that can be executed parallel in a multi-token structure is 6. A program with more than 6 branches will therefore be erroneous. A program will also be erroneous if there are a plurality of blocks having the same start step name and containing a multi-token structure (see Examples 1 and 2). The program cannot be written in such cases. Change the program so that the number of parallel executed steps will be 6 or less. There are no restrictions in the number of branches in the case of a single-token structure. ## 9.4 Restrictions concerning Subroutines Several conditions, which depend on whether the calling source of the subroutine (main routine) and the subroutine itself are a single-token structure or a multi-token structure, must be satisfied when preparing a subroutine in an SFC program. The program cannot be written in unless such conditions are satisfied. | Subroutine Main routine | Single-token block | Multi-token block | |--------------------------|--------------------|-------------------| | Single-token block | See ①. | See ②. | | Multi-token block | See ③. | See 4. | - When calling a subroutine with a single-token block from a single-token block A compose error will occur if the following conditions are not satisfied (Conditions) - 1. Subroutines must not be nested more than 4 times. - 2. Jumping must not be performed to a step in the middle of the subroutine. - When calling a subroutine with a multi-token block from a single-token block - · A compose error will occur if conditions 1 and 2 below are not satisfied. - · A compile error will occur if condition 3 below is not satisfied. (Conditions) - 1. Subroutines must not be nested more than 4 times. - 2. Jumping must not be performed to a step in the middle of the subroutine. - 3. The subroutine side must not be branched immediately into a multi-token block. - 3 When calling a subroutine with a single-token block from a multi-token block - · Compose error will occur if conditions 1 and 2 below are not satisfied. - "WARNING" is issued if condition 3 below is not satisfied. (Conditions) - 1. Subroutines must not be nested more than 4 times. - 2. Jumping must not be performed to a step in the middle of the subroutine. - 3. A timer transition instruction must not be used inside the subroutine. - 4 When calling a subroutine with a multi-token block from a multi-token block - · Compose error will occur. (1) Restrictions concerning Nesting (Depth of Macro) Subroutines can only be nested up to 4 times (depth of macro). Prepare the program so the subroutines will be nested only 4 times or less. #### (2) Restrictions concerning Jumping Programs, in which jumping is performed to a step in the middle of a subroutine as shown below, cannot be prepared. Shown below are examples of restrictions concerning jumping and correct programming methods. ## (3) Restrictions concerning Branching Branching into a multi-token structure cannot be performed immediately after the start step of a subroutine called by a main routine. Shown below are examples of restrictions concerning branching and correct programming methods. #### (4) Restrictions concerning the Timer Transition Condition Instruction A timer transition instruction cannot be used in a subroutine that is called from a multi-token structure. If a timer is required, prepare a program in which an on-delay timer instruction is used outside the SFC (ladder program) and received by a coil and the coil is used as an NO contact transition instruction of the SFC. This programming method is shown below. #### NOTE The timer will operate correctly in the following exceptional cases. However, ordinarily, change the program as shown above to avoid restrictions. - (1) When the following conditions are satisfied in one multi-token block: (Conditions) - 1. Only one subroutine is called from the multi-token structure, and - 2. Only one timer transition instruction is used in the subroutine called, and - 3. The timer transition instruction is not inside an SFC loop circuit. - (2) When the following conditions are satisfied when there are a plurality of subroutines called from a multi-token structure in one multi-token block: (Conditions) - 1. There is only one subroutine which uses a timer transition instruction, and - 2. The timer transition instruction is not inside an SFC loop circuit. ## 5.9.5 Restrictions concerning Step Names With the exception of the start step names and end step names in a macro, the same step name cannot be used for different blocks. This condition applies in common to multi-token blocks and single-token blocks. Change the step names to prepare the program in such cases. A program cannot be written in if the same step name is used. # 6 TABLE FORMAT PROGRAMMING Table format programming methods, by which programs of a specific application are prepared in an FIF (fill in form) form by the use of tables, are described in this chapter. Constant tables, I/O conversion tables, interlock tables, part composition tables, and other various tables are made available. Some tables cannot be used with the programming device CP-717. ## 6.1 Types of Table Format Programs As shown in Table 6.1, there are 6 types of table format programs. For functions, only the M registe constant table and the # register constant table can be used. Table 6.1 Types of Table Format Programs | Name | Usage and Function | DWG | Function | |--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------| | Constant table<br>(M register) | Used for setting the various constant data, such as mechanical and electrical specifications of equipment, etc., that are used in common by different drawings. Data names, symbols, units, and setting ranges can be designated | 0 | 0 | | Constant table<br>(# register) | <ul> <li>Used for setting various constant data, such as tension control parameters and position control parameters, that are used exclusively in a certain drawing.</li> <li>Data names, symbols, units, and setting ranges can be designated.</li> </ul> | 0 | 0 | | I/O conversion<br>table | <ul> <li>The I/O conversion processing parts of various processing programs may be prepared in a table.</li> <li>Is provided with the scale conversion function and the bit signal conversion function.</li> <li>Data names, symbols, units, and output conversion ranges can be designated.</li> </ul> | 0 | × | | Interlock table | <ul> <li>Used for preparing various types of interlocks.</li> <li>A signal name and symbol can be designated for each input/output.</li> <li>An interlock can be prepared as a combination of logical product (AND) and logical sum (OR) operations using NO contact and NC contact signals.</li> </ul> | 0 | × | | Part composition table | · Fixed-pattern circuits can be prepared and registered as standard software parts as necessary. | 0 | × | | Constant<br>Table (C register) | <ul> <li>Used in setting various types of data constants used in common on various drawings of mechanical and electrical sources of the equipment.</li> <li>The data name, symbol, units, setting range, etc. can be designated.</li> </ul> | × | × | O: can be used, X: cannot be used #### NOTE Make the table format programming on the programming device CP-717. # **Execution of Table Format Programs** .2 Each table format program is executed with the XCALL instruction. Table 6.1 Execution Method for Table Format Program The set values for the constant table (# register) and the constant table (C register) are directly stored in # register and C register respectively. Thus, it is not necessary to use the XCALL instruction for the constant table (# register) and the constant table (C register). ## 6.3 Constant Table (M Register) The M register constant table is used for setting various constant data, such as mechanical and electrispecifications of equipment, etc., that are used in common by different drawings. ## 6.3.1 Outline of the Constant Table (M Register) To use the M register constant table, first a constant table is defined as shown in Fig. 6.2. The constant table are then set using the defined constant table. When the constant table is stored, M register comments are prepared or renewed automatically accord to the data name, symbol, unit, and register number of each row. These comments are used for comme display in the program screens and for comment printout upon printout of documents. Fig. 6.2 Preparation of the M Register Constant Table ## Preparing the Constant Table (M Register) ## (1) Defining the Constant Table (M Register) The following items are set in defining the M register constant table. A maximum of 200 constants may be set. ① Data Name Designate the data name of the constant. ② Symbol Designate the symbol of the constant. ③ Unit .3.2 Designate the unit of the constant. **4** Lower Limit Designate the lower input limit of the constant. **5** Upper Limit Designate the upper input limit of the constant. 6 Save Point Designate the M register into which the set values are stored. ## (2) Inputs into the Constant Table (M Register) The set value are input after the definition of the M register constant table has been completed. | TO-CPUT- | | | | 2.2 | | - Lancaria | |-------------------------|-----------|-----------|-----------------------------------------|-------------------------------|-------------|----------------------------------------| | KG DataName | 5ymbol ** | SevePoint | SETVAL | Unit | Lowert.mat | UpperLimit | | UNE TOP SPEED · | MAX-SPD | MW00000 | 15000 | 0.1mpm | 3000 | 20000 | | 2 SPEED REF.100% VALUE | SP 100% | MW00001 | 25000 - | - | 10000 | 30000 | | 3 JOG LAU ACCEL TIME | LAUAT | MW00010 | 1000 | 0.1s | 300 | 2000 | | JOG LAU DECEL TIME | LAU DT | MW00011 | 1000 | 0.1s | 300 | 2000 | | JOG LAU QUICK STOP TIME | LAU QDT | MW00014 | 500 | 0.1s | 300 | 2000 | | B JOG SLAU ACCEL TIME | SLAU AT | MW00015 | 50 | 0.1s | 10 | 100 | | JOG SLAU DECEL TIME | SLAU DT | MW00017 | 10 | 0.1s | 1 | 100 | | 88 | | | | ļ | | | | 9 Pl | PI | MW00020 | 3.1416E+000 | • | 3.1416E+000 | 3.1416E+000 | | 10 | | | *************************************** | ***************************** | | | | 118 | | | | | | | | · · | 1 | | ··· | - | | <del>}</del> | | 13 | 1 | | | | | ************************************** | | XX | - | | | ţ | | | | 15 | 1 | | | <u> </u> | ···· | | ## 6.4 Constant Table (# Register) The # register constant table is used for setting various constant data, such as tension control parameter and position control parameters, that are used exclusively in a certain drawing. ## 6.4.1 Outline of the Constant Table (# Register) As shown in Fig. 6.3, the # register constant table is prepared in the same manner as the # regist constant table. A plurality of pages (up to 10 pages/DWG) can be used for the # register constant table With the # register constant table, the settings of a plurality of pages are stored in the # registers of t designated drawing (DWG). Also, the # register comments are prepared when the settings are store When the constant table is stored, # register comments are prepared or renewed automatically according to the data name, symbol, unit, and register number of each row. These comments are used for commendisplay in the program screens and for comment printout upon printout of documents. Fig. 6.3 Preparation of the # Register Constant Table ## Preparing the Constant Table (# Register) ## (1) Defining the Constant Table (# Register) The following items are set in defining the # register constant table. A maximum of 100 constants may be set per page. ① Data Name Designate the data name of the constant. ② Symbol Designate the symbol of the constant. 3 Unit 4.2 Designate the unit of the constant. 4 Lower Limit Designate the lower input limit of the constant. ⑤ Upper Limit Designate the upper input limit of the constant. 6 Save Point Designate the # register into which the set values are stored. #### (2) Inputs into the Constant Table (# Register) The set values are input after the definition of the # register constant table has been completed. When the input of the set values has been completed, the set values of the various definition data are stored in the # registers of the designated drawings. | te CPU# Section | List profile | | | | | | |---------------------------|--------------|-----------|-----------------------------------------|--------|-------------|-------------| | o DataName | Symbol 3 | SavaPoint | SETVAL | Unit | LowerLimit | UpperLimit | | LINE TOP SPEED | MAX-SPD | #W00000 | 15000 | 0.1mpm | 3000 | 20000 | | SPEED REF.100% VALUE | SP 100% | #W00001 | 25000 | | 10000 | 30000 | | JOG LAU ACCEL TIME | LAUAT | #W00010 | 1000 - | 0.1s | 300 | 2000 | | JOG LAU DECEL TIME | LAU DT | #W00011 | 1000 | 0.1s | 300 | 2000 | | 5 JOG LAU QUICK STOP TIME | LAU QDT | #W00014 | 500 | 0.1s | 300 | 2000 | | JOG SLAU ACCEL TIME | SLAU AT | #W00015 | 50 | 0.1s | 10 | 100 | | 7 JOG SLAU DECEL TIME | SLAU DT | #W00017 | 10 | 0.1s | 1 | 100 | | 87 | Į. | | | | | | | ₽ PI | PI | #F00020 | 3.1416E+000 | - | 3.1416E+000 | 3.1416E+000 | | Ŭ. | | } | | | | | | î. | | | | | | 1 | | 2 | | | | 1 | | | | 9 · | | 1 | | | | | | A) | | | | | | | | 5 | I | | *************************************** | | | | ### 6.5 I/O Conversion Table The I/O conversion table enables the I/O conversion process of various processing programs to be prepar as a table. Changes in I/O specifications can be made by simply changing definitions in the table. #### 6.5.1 Outline of the I/O Conversion Table With the I/O conversion tables, tables for input conversion and tables for output conversions a respectively prepared using different DWG's for each processing program. Fig. 6.4 Preparation of the I/O Conversion Table # Preparing the I/O Conversion Table Scale conversion of numerical data and various signal conversions of bit signals can be designated with the I/O conversion table. Up to 1200 I/O conversions may be designated with one table (DWG). #### (1) Scale Conversion Function Addition, subtraction, multiplication, and division operations, that use immediate values and arbitrary registers, can be used as scale conversion functions. The following items should be set. Data Name Designate the data name of the data to be converted. 2 Input 5.5.2 Designate the register number, the unit, and the symbol of the input data at each row. ③ Scale Conversion Designate addition, subtraction, multiplication, or division, that uses immediate values and arbitrary registers, for scale conversion. Setting Range Designate the upper and lower limits for the output. ⑤ Output Designate the number of the register into which the conversion result is to be stored and the unit and the symbol of the output data at each row. | | - CPUP | | | | | | | | | | | |------------|---------------------------|----------------------------------------------|-----|--------|-----------|------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------|--------------| | o. | U.S.a. North | | | TOX. | state (gr | 505 | Range | Scale Conversion (6) Signal Conversion See | | Ouesa | T. | | ** | | <b>**</b> ********************************** | | Person | U | Loren Lyra | Upper Lind | The second secon | Suntra | Netween. | 150 | | ₩, | ENTRY TENSION | TEN1 | וטו | ₩0100 | Kg/1024 | -1008 | 2000 | *10000 / 1024 | TENT LC | :MW01000 | 0.1% | | <u> </u> | CENTER TENSION | | | | Kg/1024 | -2000 | 3000 | * 10000 / 1024 | | MW01001 | | | 3 | EXIT TENSION | | | IW0102 | | . 0 | 10000 | | | MW01002 | | | | Not POR MEASURING[600P/RE | | | | | . 0 | 8000 | + 1000 * 3336 / 19000 - 2226 | | MW02001 | · | | × . | Not BR MEASURING[600P/REV | :IBR-PL | G | ĭ₩0201 | | 1000 | | + MW05000 * MW03330 / MW10000 - MW0 | 220 IBR-PLG | MW02002 | · | | <b>M</b> . | | <u> </u> | | | | ) | | 1 | | , | | | <u>.</u> | | | | | | ( | | | | <del> </del> | <u> </u> | | Ž. | | ; | | | | | 1 | | 1 | <del></del> | <del> </del> | | ú | | | - [ | | | | ; | | ······································ | · | · | | 9 | | : | | | | | [ | *************************************** | i | <u> </u> | · | | à. | | · | | | | | | | ···· | <del></del> | į | The I/O conversion designation of the 1st row of the above example realizes the same function as the following program. ``` ├ IW0100 × 10000 ÷ 1024 ⇒ MW01000 ``` The I/O conversion designation of the 3rd row of the above example realizes the same function as the following program. The I/O conversion designation of the 5th row of the above example realizes the same function as the following program. ``` \vdash IW0201 + MW05000 × MW03330 ÷ MW01000 − MW02220 < 01000 [\vdash 01000 ] > 30000 [\vdash 30000 ] \Rightarrow MW02002 ``` ## (2) Bit Signal Conversion Table The 9 types of bit signal conversion shown in Table 6.2 can be designated. **Table 6.2 List of Conversion Symbols** | Name | NO contact | |--------------------------------------|----------------| | NO contact | A() | | NC contact | B() | | Pulsed NO contact | PA ( ) | | Pulsed NC contact | PB() | | NO contact timer | TA (000.00) | | NC contact timer | TB (DDD.DD) | | Designated time pulse for NO contact | PTA (□□□ . □□) | | Designated time pulse for NC contact | PTB (□□□ . □□) | | NO contact chattering prevention | CTA (□□□.□□) | The following items should be set. ① Data Name Designate the name of the signal to be converted. ② Input Designate the relay number and the symbol for the input signal of each row. 3 Bit Signal Conversion Set Designate 9 types of bit signal conversion. ④ Output Designate the number and symbol of the relay into which the conversion result is to be stored for each row. | | | | | · | | | | | ***** / *** ** | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|-------|-----------------------------------------|-------------|-----------------------------------------|-------------------------|----------|----------------|-----------------------------------------| | [ L02 ] I/O Conversion TBL P00001\PINIS | 1 CP9200 | SHVCPU | 1 CP- | 9200SH Of | fline Local | | | | | | | DIES CRUE | | | | | | | | | | 1646 | | No. Cata Marie | | (speak | 100 | Telling | Rafton * | Strate Convention | Pt Signal Convenion Set | 1000000 | Const. | 0.305.20 | | | Symbol | Rogelar | Ura | Cover Land | Upper Link | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Symbol | Register | Un | | LINE RUN PS | EXES : | 1804001 | | | | A0 | | LN-RUN | MB040001 | | | LINE EMERGENCY STOP P8 | EXES | 1804002 | | | | 80 | | LNSTOP | MB040002 | | | W P.D No 1 COATER JOINT DETECT | 1 | 1904003 | | | | PAO | | | MB040003 | | | WPD No 2 COATER JOINT DETECT | 1 | 1804004 | | | | P8() | | | MB040004 | | | S ENTRY COIL CAR SKD1 COIL CETECT | CC1 PH5 | 1804005 | | | - | TA(1.00) - | | I-COIL . | MB040005 | l | | | CC3 PH2 | 1804006 | | | | TB(1.00) | | O-COIT | M8040006 | | | No 1 PA EXIT STRIP DETECT | · in | IBC4007 | | | | PTA(1 00) | | | MB040007 | ŧ . | | | CC1 LS1 | 1804008 | | | | PTB(1.00) | | | MB040008 | | | PRESSURE SWACTLENTRY HYD.UNIT | PS005 | (B04009 | | | | GT(1.90) | | | MB040009 | ( | | 180 | 1 | | , | *************************************** | | | | | | | | | | | din i | | TO STI | 10 THE RE. | Table Delines | a Mari | | 400 | | Committee of the Commit | | | | | | | | | | *************************************** | **Equivalent Ladder Programs** The bit signal conversion designation of the 1st row of the above example realizes the same function as the following program. The bit signal conversion designation of the 2nd row of the above example realizes the same function as the following program. The bit signal conversion designation of the 3rd row of the above example realizes the same function as the following program. The bit signal conversion designation of the 4th row of the above example realizes the same function as the following program. ``` IB04004 EB[[][[]] | MB040004 | PB0 ``` The bit signal conversion designation of the 5th row of the above example realizes the same function as the following program. ``` 1B04005 001.00 EW [] | MB040005 | TA(1.00) ``` The bit signal conversion designation of the 6th row of the above example realizes the same function as the following program. ``` IB04006 001.00 EWIIIII MB040006 (IB(1.00) ``` The bit signal conversion designation of the 7th row of the above example realizes the same function as the following program. The bit signal conversion designation of the 8th row of the above example realizes the same function as the following program. The bit signal conversion designation of the 9th row of the above example realizes the same function as the following program. (Note): The E registers are registers used by the controller. It is impossible for a user to directly read or write. #### 6.6 Interlock Table The interlock table is used to prepare various interlocks, for starting conditions, running conditio etc. of devices, in table format. #### 6.6.1 Outline of the Interlock Table As shown in Fig. 6.5, the interlock table is composed of one main interlock table and the correspond sub interlock tables. One sub interlock table may be set for one row of the main interlock table. The sinterlock table is used to prepare specific input signals for the main interlock table. The main interlock table may be divided into several blocks. The maximum number of blocks is 26 and each block handled as an independent interlock. When the interlock table is stored, comments for the regist (relays) are prepared or renewed automatically according to the data name, symbol, and register num (relay number) of each row. These comments are used for comment display in the program screens a for comment printout upon printout of documents. Fig. 6.5 Preparation of the Interlock Table #### Preparing the Interlock Table Each interlock table (main or sub interlock table) is prepared in the same manner as follows. A maximum of 500 rows and 25 columns of data can be set. - ① Classification of the I/O signal: This is designated according to the mode (M). The following 4 modes can be used. - · I : Designates a signal to be an input signal. - · S : Designates an output signal from a sub interlock table to be used as an input signal. - · O: Designates a signal to be an output signal. - · X : Designates the contact of an output signal to be used as an input (self-hold circuit). - ② Data Name Designate the name of the interlock condition to be input for each row. ③ Symbol .2 Designate the symbol of the interlock condition to be input for each row. 4 Register Designate the register number of the interlock condition to be input for each row. ⑤ Interlock Input Condition For each input signal, designate the interlock condition, which is to be used as the condition for obtaining the logic product (AND) for each column. The NO contact condition ( $\bigcirc$ ) and the NC contact condition ( $\bigcirc$ ) can be used as interlock conditions. 6 Interlock Input Condition For each output signal, designate ( ) the above mentioned interlock conditions to be used as conditions for obtaining the logic sum (OR) for the corresponding row. The logical product (AND) of the input symbols, which were designated as the interlock conditions, is determined for each column and the output signal is prepared as the logic sum (OR) condition of the logical product results of the columns designated at each output signal row. Thus the following interlock table will be equivalent to the ladder program shown in the next page. | | | Interlock TBL P00001\PINIS1 CP9200SH\( | CPU1 CP-9200 | ISH Offline | Loc | al | | | | | | | <b>a</b> 3 | |------|-----|----------------------------------------|--------------|-----------------------------------------|----------|-----------|------|--------------------------------------------|-----------------------------------------|------------|----------|---|------------| | HA: | - C | PU# | | | | | | | | | | | | | No | | Date Name | Symbol | Register | 13 | 24 | 3 | 1 | 5 6 | 17 | 8 | 9 | 10 | | AUT | | M2 ROLL is use | M2-USE | MB010000 | | | Ø | | | i | | | - 2 | | AU2 | 1 | M4 ROLL is use | M4-USE | MB010001 | | | O | | | | <u> </u> | | | | AU3 | | | | | | | T . | | | 1 | 1 | | | | AQ4 | S | M1 ROLL INV READY | M1-PREP | MB010010 | O | O | Ö | O | *************************************** | | 1 | 1 | | | A05 | S | M2 ROLL INV READY | M2-PREP | MB010011 | O | | | .munt. | | ********** | <u> </u> | - | | | AOE | S | M3 ROLL INV READY | M3-PREP | MB010012 | | | | ÖÏ | | | ÷ | 1 | | | A07 | S | M4 ROLL INV READY | M4-PREP | MB010013 | Ō | , John L. | ā | | | | - | T | | | A08 | S | M5 ROLL INV READY | M5-PREP | MB010014 | Ō | O | | O | <u> </u> | | Í | 1 | 16 | | 409 | | , | | | | | | | | _ | † | 1 | -1 | | A10 | 0 | LINE RUNNING CONDITIONS | RUNINTL | MB01001F | | | | | <del>-</del> | | Ì | 1 | | | क्षा | | ************************************** | | *************************************** | 1 | | 1 | 21. T. | | | ļ | | | | 412 | | | | | Ť | | | | <del></del> | | <b>†</b> | 1 | | | di. | | | | | <b>`</b> | | | X | | ST III | | | | | | | | lMa | ave di | able | | NOOF | | | | 7 | | | ## Equivalent Ladder Program ## 6.7 Part Composition Table The part composition table is used to simultaneously prepare a plurality of circuits of a fixed patter such as solenoid circuits, accessory sequence circuits, etc. ## 6.7.1 Outline of the Part Composition Table The part composition table is composed of functions, that are used as parts, and the part composititable. The functions to be used as parts should be prepared before using them in the part composititable. Each part is composed of the main body of the function program and the function I/O definition. - A plurality of circuits, which use the designated parts, a prepared simultaneously. - Each circuit is prepared by defining the inputs and output of the circuit with the register numbers. Fig 6.6 Preparation of the Part Composition Table ## 7.2 Preparing the Part Composition Table With the part composition table, a plurality of circuits with the same pattern can be prepared simultaneously using designated parts. In the part composition table, one row corresponds to one circuit and names, inputs, and outputs are designated for each row to prepare a plurality of circuits. The parts to be used can be designated for each row. The maximum number of inputs and the maximum number of outputs is designated by the user. A maximum of 100 circuits can be prepared. ① Data Name Designate the name of each circuit. ② Part Name Designate the function symbol or user function name of the function to be used as a part. 3 Input Use register numbers to designate the inputs of each circuit. The register whose number is designated here will provide the input to the user function. 4 Output Use register numbers to designate the outputs of each circuit. (5) Head Work Designate the number, in word form, of the D register or # register which is to be the head work register to be used for each circuit. | T | -CPUE- | | | | | | | | | | | |-----|-------------------|----------|----------|---------|-----------------------------------------|-----------------------------------------|----------|--------------------|--------------|-----------------------------------------|-----------------| | ů. | Deta llame | PartName | iriput | | | | Output | 800.00 | H-1817 A 181 | HeadWak | REG No. | | | | | REMOTES | HUNNTE | STOPPE | RUNFR | GUN -7 | HUNSE | SPEED | TOW. | #47 | | a e | ROLL LUMB.PUMP | PUMPA | IB03000 | IB03001 | 1803002 | IB03003 | 1803008 | 1B03009 | MW01000 | DW00010 | | | 2 | M2 ROLL LUMB.PUMP | PUMPB | IB03010 | 1803011 | IB03012 | IB03013 | IB03018 | IB03019 | MW01001 | DW00014 | | | | M3 ROLL LUMB.PUMP | PUMPC | IB03020 | 1803021 | IB03022 | IB03023 | IB03028 | IB03029 | MW01002 | DW00018 | | | 4 | M4 ROLL LUMB.PUMP | PUMPD | 1803030 | IB03031 | IB03032 | IB03033 | IB03038 | IB03039 | MW01003 | DW00022 | [ | | * | ROLL LUMB.PUMP | PUMPE | 1803040 | IB03041 | IB03042 | IB03043 | IB03048 | IB03049 | MW01004 | DW00026 | | | 134 | | } | | | | *************************************** | 1 | | f | *************************************** | | | 7 | | | //t-Lan. | £ | | *************************************** | <b>†</b> | ****************** | | | | | 8 | | | ···· | | | | | | | | | | 5 | | | | | | | { | | | | *************** | | | * | | | | *************************************** | | | | | | | #### 6.7.3 Preparing the Function Program for Parts The parts (main bodies of function programs and function I/O definitions) to be used in a part composititable should be prepared in advance. Although the preparation method is the same as that for ordination programs, the following data are used for the input/output of parts and the work register. **Input of Parts** The inputs designated at the function I/O definition will be used as the inputs for the parts. Refer "Chapter 3 REGISTER MANAGEMENT METHOD" concerning the relationship between the input definition for a function and the input variables (X registers) used in the function. **Output of Parts** The outputs designated at the function I/O definition will be used as the outputs for the parts. Re to "Chapter 3 REGISTER MANAGEMENT METHOD" concerning the relationship between to output definition for a function and the output variables (Y registers) used in the function. Work Register The Z register corresponds to the D register of a DWG and the # register corresponds to the register of a drawing and the sum of the head work register number of the part composition tal and the relative register number of that register is used as the number of the actual work regist ## .8 Constant Table (C Register) The C register constant table is used for setting various data constants common to all DWG such as equipment and manufactured sources. A maximum of 200 constant tables (C register) can be created. #### 8.1 Outline of the Constant Table (C Register) Multiple definitions of set values are stored in the C register by the constant table (C register). Also, the C register comments are prepared at the same time the set values are stored. When the constant table is stored, C register comments are prepared or renewed automatically according to the data name, symbol, unit, and register number of each row. These comments are used for comment display in the program screens and for comment printout upon printout of documents. Fig. 6.7 Preparation of the C Register Constant Table ## 6.8.2 Preparing the Constant Table (C Register) (1) Defining the Constant Table (C Register) The following items should be set in defining the C register constant table. A maximum of 16384 constants may be set per page. ① Data Name Designate the data name of the constant. 2 Symbol Designate the symbol of the constant. 3 Unit Designate the unit of the constant. **4** Lower Limit Designate the lower input limit of the constant. ⑤ Upper Limit Designate the upper input limit of the constant. **6** Save Point Designate the C register into which the set values are to be stored. (2) Inputs into the Constant Table (C Register) The set values should be input after the definition of the C register constant table has been completed. | T#:-CPU#: | | | | | | | |---------------------------------------------|------------|--------|-------|-------------|-------------|-----------| | in Data Name | * Symbol | SETVAL | Unit | Lower Limit | Upper Limit | SavePoint | | Value of Pgain 1 amplification | P1-100 | 100 | amp. | 100 | 100 | CW00000 | | 2 P gain during stall | • Stall P | 30 | amp. | 1. | 2000 | CW00001 | | P gain during normal operation | Normal P | - 50- | amp. | - 1 | 2000 | CW00002 | | 4 LaU time during gain modification | P-LAU ' | 10 | S | 1 | 100 | CW00003 | | Deviation input value dead zone | · Dead zon | . 0 | | . 0 | .500 | CW00004 | | 6 Reserved | Reserved | 0 | · 5 - | 0. | ] .0 | : CW00005 | | Integration time | Int time | 50 | ms | | 1000 | CW00006 | | 8 Upper integration output limit | Int UL | 1000 | - | 0: | 100 | CW00007 | | 2 Lower integration output limit | lnt LL | -1000 | ]- , | -32767 | 32767 | CM00008 | | Integration output proportional coefficient | Prop.C | 0 | | , G . | 0 | CW00009 | | Integration output fixed coefficient | FixedC | 10000 | | 0 | 10000 | CW00010 | | 12. Upper Pl output limit | PIUL ' | 1000 | | 0. | 10000 | CW/00011 | | 13 Lower Pl output limit | PLL | -1000 | - | -32767 | 32767 | CW00012 | | A Pl output reset time | AST time | 0 | \$ | 0- | ) 0 | CW00013 | | 5 100% power value | 100% pw | 100 | - | 100 | 100 | CW00014 | | 6 Stall power proportion | Stall | 50 | - | 10 | 100 | CW00015 | | 7 Power command LAU time | pw LAU | 5 | . S | 1 . | 10. | CW00016 | | 16 | | | 1 | | | | | 18 | | | | | | | # 7 STANDARD SYSTEM FUNCTIONS chapter. ## 7.1 Data Trace Read Function (DTRC-RD) | Name of Function | DTRC-RD | | | | | | | | |------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------|-------------------------------------------------------------------------------|---------------------------------------------------------------|--|--| | Function | The nun | Reads out the trace data of the main controller unit and stores this data in the user registers. The data in the trace memory can be read out upon designating the record number and the number of records. The readout can be performed by designating just the necessary items in the record. | | | | | | | | Function<br>Definition | | | EXEC | -NO<br>-SIZ | NO ERROR STATUS ZE REC-SIZE | > | | | | I/O Definition | No. | . Name | I/O<br>Designatio | on* | | Description | | | | | 1 | EXECUTE | B-VAL | | Designation of the | e execution of data trace read | | | | | | GROUP-NO | I-REG | | | e data trace group No. (1 to 4) | | | | | 3 | REC-NO | I-REG | | · · | e head record No. for readout<br>record number -1) | | | | Input | 4 | REC-SIZE | I-REG | | 1 " | e number of records requested for readout | | | | | 5 . | SELECT | I-REG | | Item to be read ou | at (0001H to FFFFH) spond to data designations 1 to 16 of the | | | | | 6 | DAT-ADR | Address inp | out | Designation of the No. of the head register for readout (address of MW or DW) | | | | | | 1 | COMPLETE | B-VAL | | Completion of trac | ce read | | | | | 2 | ERROR | B-VAL | | Occurrence of erro | or | | | | Output | 3 | STATUS | I-REG | | Data trace read ex | xecution status | | | | 1 | 4 | REC-SIZE | I-REG | | Number of records | s read | | | | 1 | 5 | REC-LEN | I-REG | | Length (in words) of 1 record that is read | | | | <sup>\*:</sup> Indicates the I/O designation at the CP-717. ### Configuration of the Data Trace Read Execution Status (STATUS) | . Name | Bit No. | Remarks | | | | |---------------------------------------------------|-----------------|------------------------------------|--|--|--| | System reserved | bit0 to bit7 | | | | | | No trace definition | bit8 | The function will not be executed. | | | | | Group No. error | bit9 | The function will not be executed. | | | | | Designated record No. error | bit10 | | | | | | Error in the designated<br>number of records read | bit11 | The function will not be executed. | | | | | Data storage error | bit12 | The function will not be executed. | | | | | System reserved | bit13 and bit14 | | | | | | Address input error | bit15 | The function will not be executed. | | | | #### .1.1 Readout of Data The most recent record Nos. of trace groups are each stored in SW00100 to SW00103 as shown in Table 7.1. To read the most recent trace data, designate the most recent record No. as the record No. to be read. **Table 7.1 Newest Record Number** | System register number | Data trace definition | |------------------------|-----------------------| | SW00100 | For group 1 | | SW00101 | For group 2 | | SW00102 | For group 3 | | SW00103 | For group 4 | | SW00104 | | | SW00105 | | | SW00106 | <u> </u> | | SW00107 | | #### 7.1.2 Configuration of the Read Data ### (1) Data Configuration ### (2) Record Length A record is composed of the data for the selected items. Word length of 1 record = Bn $\times$ 1 word + Wn $\times$ 1 word + Ln $\times$ 2 words + Fn $\times$ 2 words Bn: Number of bit type register selected points Wn: Number of word type register selected points Ln: Number of double-length integer type register selected points Fn: Number of real number type register selected points A maximum of 16 points in total. Maximum record length = 32 words (e.g. when there are 16 double-length integer type real number type registers) Minimum record length = 1 word (e.g. when there is one bit type or integer type register) ### (3) Number of Records | Maximum number of records | 32512/record length | |-----------------------------------|---------------------| | Number of records when the record | 0 to 1016 | | length is the maximum | ; | | Number of records when the record | 0 to 32512 | | length is the minimum | • | ## 2 Trace Function (TRACE) | Name of Function | TRACE | | | | | | | |------------------------|----------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|---------------------------------------------|--------|--| | Function | Pe gr Pa | oup No. The tack CP-717 Op<br>Tracing is exe<br>The trace cou<br>The trace end<br>The trace end | tion control of the tracing of the trace data designated by the trace is defined at "Data Trace Definition" screen (refer to the Control Deration Manual (SIE-C877-17.4, -17.5) for details). Secuted when the trace execution command (EXECUTE) is set to O unter is reset when the trace reset command (RESET) is set to O I (TRC-END) output is also reset at this time. Id (TRC-END) output is set to ON when the trace execution could to the set count (set at Trace Definition). | | | | | | Function<br>Definition | | | | TRACE KECUTE SSET KOUP-NO | TRC-END<br>ERROR<br>STATUS | =====> | | | I/O Definition | No. | Name | I/O<br>Designation | on* | Description | | | | T4 | 1 | EXECUTE | B-VAL | Trace exec | Trace execution command | | | | Input | 2 | RESET | B-VAL | | Trace reset command | | | | | 3 | GROUP-NO | | | Designation of the trace group No. (1 to 4) | | | | Outnut | 1 | TRC-END | B-VAL | End of tra | | | | | Output | 2 | ERROR | B-VAL | Occurrence | | | | | | 3 | STATUS | I-REG | Trace exec | Trace execution status | | | <sup>\*:</sup> Indicates the I/O designation at the CP-717. ### Configuration of the Trace Execution Status (STATUS) | Name | Bit No. | Remarks | | | |----------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------|--|--| | Trace data full | bit0 | This becomes ON after one round of reading of the content in the data trace memory of the designated group has been completed. | | | | System reserved | bit1 to bit7 | • | | | | No trace definition | bit8 | The function will not be executed. | | | | Designated group No. error | bit9 | The function will not be executed. | | | | System reserved | bit10 to bit12 | | | | | Execution timing error | bit13 | The function will not be executed. | | | | System reserved | bit14 | | | | | System reserved | bit15 | | | | ## 7.3 Failure Trace Read Function (FTRC-RD) | Name of Function | | | | FTRC-RD | | | | | |------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------------------------|--|--|--|--| | Function | buf<br>fail | Reads the failure trace data and stores them in the user register. The data in the trace buffer can be read out upon designating the number of records needed. Either the failure occurrence data or the restoration data are designated for readout. Enables the reset (initialization) of the failure trace buffer. | | | | | | | | Function<br>Definition | | | EXECUT RESET TYPE REC-SI | ERROR> | | | | | | I/O Definition | No. | l | I/O<br>Designation* | Description | | | | | | | | EXECUTE | | Failure trace readout command | | | | | | | | RESET | | Failure trace buffer reset command | | | | | | _ , [ | 3, | TYPE | I-REG | Type of data read | | | | | | Input | | | - | 1 : Occurrence data<br>2 : Restoration data | | | | | | ļ | 4 | REC-SIZE | I-REG | Number of read records | | | | | | | $\iota^{-1}$ | - | | Occurrence data: 1 to 64 Restoration data: 450 | | | | | | .] | 5 | DAT-ADR | | Head register address for reading (address of MW or DW | | | | | | | 1 | COMPLETE | | Completion of failure trace read | | | | | | · | 4 | | | Occurrence of error | | | | | | | 2 | ERROR | | | | | | | | Output | <del></del> | ERROR<br>STATUS | | Failure trace read execution status | | | | | | Output | 3 | | I-REG | | | | | | <sup>\*:</sup> Indicates the I/O designation at the CP-717. ### Failure Trace Read Execution Status (STATUS) | Name | Bit No. | Remarks | |----------------------------|--------------|------------------------------------| | System reserved | bit0 to bit7 | | | No trace definition | bit8 | The function will not be executed. | | Designated group No. error | bit9 | The function will not be executed. | | System reserved | bit10 | | | Error in the designated | bit11 | The function will not be executed. | | number of records | | | | Data storage error | bit12 | The function will not be executed. | | System reserved | bit13 | | | System reserved | bit14 | | | Address input error | bit15 | The function will not be executed. | ### 3.1 Data Readout (Failure Occurrence Data) The readout will always be started from the most recent record. ### Readout Data Configuration (Failure Occurrence Data) #### (1) Data Configuration 3.2 ### (2) Record Configuration ### (3) Structure of Register Designation No. (2 words) Contains the failure detection relay information. | | Bit Configuration of ① | Bit Configuration of ② | |---|----------------------------------------------------------|--------------------------------------------| | 7 | Defined flag $(1 = defined, 0 = undefined)$ | System reserved (= 0) | | 6 | System reserved (= 0) | Data type | | 5 | | Bit = $0$ , Integer = $1$ , | | 4 | 0 = NO contact designation, $1 = NC$ contact designation | Double-length integer = 2, Real Number = 3 | | 3 | Type of variable | | | 2 | S=0, I=1 | Bit address 0 to F | | 1 | O=2, M=3 | | | 0 | | | #### (4) Number of Records | Minimum number of records | 0 | ← 0 = no failure occurrence data | |---------------------------|----|----------------------------------| | Maximum number of records | 64 | | ### 7.3.3 Data Readout (Failure Restoration Data) The number (amount) of restoration data is stored in SW00093 (ring counter for 1 to 9999). ### 7.3.4 Readout Data Configuration (Failure Restoration Data) ### (1) Data Configuration ### (2) Record Configuration ### (3) Number of Records | Minimum number of records | 0 | $\leftarrow 0 = \text{no failure restoration date}$ | |---------------------------|-----|-----------------------------------------------------| | Maximum number of records | 450 | | ## Inverter Trace Read Function (ITRC-RD) | Name of Function | IT | RC-RD | · · · · · · · · · · · · · · · · · · · | | | | | |------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------|---------------------------------| | Function | Reads out the trace data of the inverter and stores this data in the user registers. The data in the trace buffer can be read out upon designating the number of records needed. The readout can be performed upon designating just the necessary items in the record. [Applicable inverters] Inverters connected via CP-213, CP-215, or CP-216 | | | | | | | | Function<br>Definition | | | =====> | ABOI<br>DEV-<br>CIR-<br>ST-1<br>CH-N<br>REC- | -Typ<br>-No<br>No<br>Ho<br>-Size | BUSY COMPLETE ERROR STATUS REC-SIZE REC-LEN | ><br>><br>> | | I/O Definition | No. | Name | I/O<br>Designati | on* | | | Description | | | 1 | EXECUTE | B-VAI | , | Inverter tra | ce read | command | | | 2 | ABORT | B-VAI | , | Inverter tra | ce read | forced interruption command | | | മ | DEV-TYP | I-REG | | Type of trai<br>CP-213=<br>CP-215=<br>CP-216= | 2<br>1 | on device | | _ | 4 | CIR-NO | I-REG | | Line No.<br>CP-213: 1<br>CP-215: 1<br>CP-213: 1 | l to 8 | | | Input | 5 | ST-NO | I-REG | | Slave statio<br>CP-213: 1<br>CP-215: 1<br>CP-216: 1 | n No.<br>l to 31<br>l to 64 | | | | 6 | CH-NO | I-REG | | Transmission buffer channel No. (No designation) | | | | 1 | 7 | REC-SIZE | I-REG | | | | to be read (1 to 64) | | : | 8 | SELECT | I-REG | | Items to be read (0001H to FFFFH) Bits 0 to F correspond to trace data items 1 to 16. | | | | | 9 | DAT-ADR | Address in | put | Head addre<br>(address of | ss of dat<br>MW or I | a buffer register<br>OW) | | | 1 | BUSY | B-VAL | | The reading | of inve | rter trace data is in progress. | | | 2 | COMPLETE | B-VAL | | Completion | of inver | ter trace read | | Output | 3 | ERROR | B-VAL | | Occurrence | of error | | | Juipui | 4 | STATUS | I-REG | | | | execution status | | | 5 | REC-SIZE | I-REG | | Number of | | | | | 6 | REC-LEN | I-REG | | Length of re | ead reco | rd (for 1 record) | <sup>\*:</sup> Indicates the I/O designations at the CP-717. ### Configuration of the Inverter Trace Read Execution Status (STATUS) | Bit No. | Remarks | |--------------|--------------------------------------------------| | bit0 to bit8 | | | bit 9 | The function is not executed. | | bit10 | | | bit11 | The function is not executed. | | <u> </u> | | | bit12 | The function is not executed. | | bit13 | The function is not executed. | | bit14 | | | bit15 | The function is not executed. | | | bit0 to bit8 bit 9 bit10 bit11 bit12 bit13 bit14 | ### 7.4.1 Readout of inverter Trace Data The readout will always be started from the most recent record. ### 7.4.2 Readout Data Configuration ### (1) Data Configuration ### (2) Record Length A record is composed of the data of the selected items. Word length of 1 record = 1 to 16 words ### (3) Number of Records Maximum number of records = 120 ## Inverter Constant Write Function (ICNS-WR) .5 | Function The [App Investigation of the property propert | plicable inve | ranges of the erters] octed via CF | P-215, or CP-216 EXECUTE BUSY ABORT COMPLETE DEV-TYP ERROR CIR-NO STATUS ST-NO CB-NO CNS-TYP CNS-NO CNS-SIZE DAT-ADR | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Definition No. 1 E 2 A 3 I | EXECUTE<br>ABORT | I/O Designation B-VAL B-VAL | ABORT COMPLETE DEV-TYP ERROR CIR-NO STATUS ======>> ST-NO CNS-TYP CNS-NO CNS-SIZE DAT-ADR Description Inverter constant write command Inverter constant write forced interruption command | | 1 H<br>2 A<br>3 I | EXECUTE<br>ABORT | Designation<br>B-VAL<br>B-VAL | Description Inverter constant write command Inverter constant write forced interruption command | | 1 H<br>2 A<br>3 I | EXECUTE<br>ABORT | B-VAL<br>B-VAL | Inverter constant write command Inverter constant write forced interruption command | | 2 A<br>3 I | ABORT | B-VAL | Inverter constant write forced interruption command | | 3 [ | | | | | 4 ( | | I-REG | CP-215=1<br>CP-216=4 | | <u></u> | CIR-NO | I-REG | Line No.<br>CP-215: 1 to 8<br>CP-216: 1 to 8 | | Input 5 S | ST-NO | I-REG | Slave station No.<br>CP-215: 1 to 64<br>CP-216: 1 to 30 | | | CH-NO | I-REG | Transmission buffer channel No. (No designation) | | 7 0 | CNS-TYP | I-REG | Type of inverter constant 0 = direct designation of reference No., 1 = An, 2 = Bn, 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 10=Tn | | 8 C | CNS-NO | I-REG | Inverter constant No. (1 to 99) The upper limit will differ according to the type of inverter. If CNS-TYP = 0, designate the reference No. | | | CNS-SIZE<br>DAT-ADR | I-REG<br>Address inpu | Number of inverter constants<br>(number of data to be written) 1 to 100 | | | BUSY | B-VAL | Register address of set data (address of MW, DW, or #W) Inverter constants are being written in. | | 2 ( | COMPLETE | | The write-in of inverter constants has been completed. | | LINITANIT | <u> </u> | | Occurrence of error | | 4 S | ERROR | B-VAL | I BECHTTONCO OF OPPOY | <sup>\*:</sup> Indicates the I/O designations at the CP-717. ### **Configuration of Inverter Constant Write Execution Status (STATUS)** | Name | Bit No: | Remarks | | |-------------------------------------------------|--------------|-------------------------------|--| | System reserved | bit0 to bit7 | | | | Execution sequence error | bit 8 | The function is not executed. | | | Transmission parameter error | bit 9 | The function is not executed. | | | Designated type error | bit10 | The function is not executed. | | | Designated No. error | bit11 | The function is not executed. | | | Error in number (amount) of the designated data | bit12 | The function is not executed. | | | Transmission error | bit13 | The function is not executed. | | | Inverter response error | bit14 | The function is not executed. | | | Address input error | bit15 | The function is not executed. | | (Note): In the case of an inverter response error, the error codes from the inverter are indicated in bit0 to bit7. 01H(1): function code error 02H(2): reference No. error 03H(3): write-in count error 21H(33): write-in data upper/lower limit error 22H(34): write-in error (during running, during UV) Numbers in ( ) are of decimal expressions. ### 7.5.1 Configuration of the Write-in Data ### Method of Writing to an EEPROM Б.2 Procedures for writing constants to an EEPROM (inverter internal constant storage memory) are shown in Fig. 7.1. Fig. 7.1 EEPROM Write Procedures Constants written with the system function "ICNS-WR" are once entered in work memory. In order to actually store these in EEPROM, it is necessary to bring up the WRITE ENTER command as shown in Fig. 7.2. Fig. 7.2 WRITE ENTER Command ### (1) WRITE ENTER Command Using the "ICNS-WR" function, by writing the data "0" in the reference number "FFFD," the WRITE ENTER command is entered for the inverter. ### (2) Program Example An example of a program that writes "200" in the constant "C1-01" is shown in Fig. 7.3 (①, ②) ① First, write to the inverter work memory. <sup>\*:</sup> By turning DB00000 = ON, a one time only write can be executed. ② Actually writing to EEPROM. (Enter the WRITE ENTER command.) \*: By turning DB00000 = ON, a one time only write can be executed. Fig. 7.3 Program Example #### NOTE - The WRITE ENTER command writes all constants that have been written to work memory up to that point to the EEPROM. - · If power to the inverter is turned OFF, work memory data is lost, but data written to the EEPROM is saved. ## 7.6 Inverter Constant Read Function (ICNS-RD) Name of Function | Function Reads the inverter constants. The types and ranges of the inverter constants to be read can be designated. [Applicable inverters] Inverters connected via CP-213, CP-215, or CP-216. Function Definition Function Definition No. Name Designation OBS-TYP OBS-NO OBS-SIZE DAT-ADR I/O Definition No. Name Designation OBS-TYP OBS-NO OBS-SIZE DAT-ADR Inverter constant read execution command Inverter constant read forced interruption comm Type of transmission device CP-215=1 CP-216=4 4 CIR-NO I-REG Ine No. CP-215: 1 to 8 CP-216: 1 to 8 5 ST-NO I-REG Slave station No. CP-216: 1 to 30 6 CH-NO I-REG Type of inverter constant O = direct designation of reference No. 1 = An, 2 3 = Ch, 4 = Dh, 5 = Eh, 6 = Fh, 7 = Hh, 8 = Ln, 9 = Oh, The upper limit will differ according to the type of incerter constant No. (1 to 99) The upper limit will differ according to the type of incerter constant No. (1 to 99) The upper limit will differ according to the type of incerter constant No. (1 to 99) The upper limit will differ according to the type of incerter constant No. (1 to 99) The upper limit will differ according to the type of incerter constant No. (1 to 99) | TVAILE OF F CHICGOT | <u> </u> | | | · · · | | · | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------|----------------------------------|-----------------|----------|-----------------|------------------------------------------------| | Function Definition Definition Definition Definition Definition Definition Definition Description Descriptio | Function | The<br>[Ap | e types and ra<br>oplicable inve | anges<br>rters] | of the | inverter consta | | | Function Definition Definition Definition Definition Definition Definition Definition Definition Description | | 1 | | | | | ······································ | | Function Definition Definition Definition ST-NO ST | , | | _ | | EXECUTE | | | | Function Definition CIR-NO | | | , · <del>-</del> | ——- | ABORT | COMPLETE | | | Definition SI-NO | | į . | . == | =====> | DEV-TYP | ERROR | | | I/O Definition | | | . == | ====> | CIR-NO | STATUS | =====> | | I/O Definition | Definition | , | | ====> | ST-NO | | | | I/O Definition | · | | == | ====> | CEI-NO | • | | | I/O Definition No. Name Designation* Description 1 | | 4 | . == | ====> | ONS-TYP | | | | I/O Definition | | , | . == | ====> | CNS-NO | | | | I/O Definition | | | | ====> | ONS-SIZE | | | | Designation | | | | | - | DAT-ADR | | | Designation | | | | . L | | | <b>,</b> . | | 2 ABORT B-VAL Inverter constant read forced interruption comm 3 DEV-TYP I-REG Type of transmission device CP-215=1 CP-216=4 4 CIR-NO I-REG Line No. CP-215: 1 to 8 CP-216: 1 to 8 CP-216: 1 to 8 CP-216: 1 to 64 CP-216: 1 to 30 CR-216: | I/O Definition | No. | Name | | | | | | 3 DEV-TYP I-REG Type of transmission device CP-215=1 CP-216=4 4 CIR-NO I-REG Line No. CP-215: 1 to 8 CP-216: 1 to 8 5 ST-NO I-REG Slave station No. CP-215: 1 to 64 CP-216: 1 to 30 6 CH-NO I-REG Transmission buffer channel No. (No designation 7 CNS-TYP I-REG Type of inverter constant 0 = direct designation of reference No. 1 = An, 2 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 18 CNS-NO I-REG Inverter constant No. (1 to 99) | | 1 | EXECUTE | B.V | VAL | Inverter cons | tant read execution command | | CP-215=1 CP-216=4 4 | | 2 | ABORT | В | VAL | Inverter cons | tant read forced interruption command | | CP-216=4 4 CIR-NO | · [ | 3 | DEV-TYP | I-F | REG | • • | smission device | | A CIR-NO I-REG Line No. CP-215: 1 to 8 CP-216: 1 to 8 5 ST-NO I-REG Slave station No. CP-215: 1 to 64 CP-216: 1 to 30 6 CH-NO I-REG Transmission buffer channel No. (No designation 7 CNS-TYP I-REG Type of inverter constant 0 = direct designation of reference No. 1 = An, 2 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 1 8 CNS-NO I-REG Inverter constant No. (1 to 99) | | | | | ľ | | | | CP-215: 1 to 8 CP-216: 1 to 8 5 | | | <u> </u> | , . | | | | | CP-216: 1 to 8 5 | | 4 | CIR-NO | I-F | REG | | ٠ | | Input 5 ST-NO I-REG CP-215: 1 to 64 CP-216: 1 to 30 6 CH-NO I-REG Transmission buffer channel No. (No designation of the constant th | | ! | | | | | | | Input CP-215: 1 to 64 CP-216: 1 to 30 6 CH-NO I-REG Transmission buffer channel No. (No designation 7 CNS-TYP I-REG Type of inverter constant 0 = direct designation of reference No. 1 = An, 2 = 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 8 CNS-NO I-REG Inverter constant No. (1 to 99) | | <del></del> | CM NO | 7 7 | TO | | | | Input CP-216: 1 to 30 6 CH-NO I-REG Transmission buffer channel No. (No designation 7 CNS-TYP I-REG Type of inverter constant 0 = direct designation of reference No. 1 = An, 2 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 1 8 CNS-NO I-REG Inverter constant No. (1 to 99) | | 5 | S1-NO | 1-1 | EEG | | | | 6 CH-NO I-REG Transmission buffer channel No. (No designation 7 CNS-TYP I-REG Type of inverter constant 0 = direct designation of reference No. 1 = An, 2 = 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 2 = CNS-NO I-REG Inverter constant No. (1 to 99) | Input | • | | · · | | | | | 7 CNS-TYP I-REG Type of inverter constant 0 = direct designation of reference No. 1 = An, 2 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 8 CNS-NO I-REG Inverter constant No. (1 to 99) | - | 6 | CH-NO | I_E | REG | | | | 0 = direct designation of reference No. 1 = An, 2 = 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 1 = 8 CNS-NO I-REG Inverter constant No. (1 to 99) | | | | | | | | | 3 = Cn, 4 = Dn, 5 = En, 6 = Fn, 7 = Hn, 8 = Ln, 9 = On, 1<br>8 CNS-NO I-REG Inverter constant No. (1 to 99) | | | | 11 | | | | | 8 CNS-NO I-REG Inverter constant No. (1 to 99) | | | | | | | <b>Q</b> , , , , , , , , , , , , , , , , , , , | | | | 8 | CNS-NO | I-F | REG | | | | 1 | | | l . | | | | · · · · · · · · · · · · · · · · · · · | | If CNS-TYP = 0, designate the reference No. | | | | 1 | | | | | 9 CNS-SIZE I-REG Number of inverter constants | | 9 ' | CNS-SIZE | I-F | REG | | | | (number of data to be read) 1 to 125 | · | , | , | | | | | | 10 DAT-ADR Address input Register address of the data to be read (address | • | 10 | DAT-ADR | Addre | ss input | | ress of the data to be read (address of MW | | or DW) | | <u> </u> | DIVOV | | | | · · · · · · · · · · · · · · · · · · · | | 1 BUSY B-VAL Inverter constants are being read. | | | | | | | | | Output 2 COMPLETE B-VAL The reading of inverter constants has been comp | Output | | | | | | | | 3 Militar B-VAL Occurrence of error | | | | | | | | | 4 STATUS I-REG Inverter constant read execution status | · · · | 4 | DIATUS, | 1-1 | LEG | inverter cons | stant read execution status | ICNS-RD <sup>\*:</sup> Indicates the I/O designations at the CP-717. ### **Configuration of Inverter Constant Read Execution Status (STATUS)** | Name | Bit No. | Remarks | |-------------------------------------------------|--------------|-------------------------------| | System reserved | bit0 to bit7 | | | Execution sequence error | bit 8 | The function is not executed. | | Transmission parameter error | bit 9 | The function is not executed. | | Designated type error | bit10 | The function is not executed. | | Designated No. error | bit11 | The function is not executed. | | Error in number (amount) of the designated data | bit12 | The function is not executed. | | Transmission error | bit13 | The function is not executed. | | Inverter response error | bit14 | The function is not executed. | | Address input error | bit15 | The function is not executed. | (Note): In the case of an inverter response error, the error codes from the inverter are indicated in bit0 to bit7. 01H(1): function code error 02H(2): reference No. error 03H(3): Readout count error Numbers in ( ) are of decimal expressions. ### **Configuration of the Data Readout** ## 7.7 CP-213 Initial Data Setting Function (ISET-213) | Name of Function | | | | ISET-213 | | |------------------------|-----|----------|----------------------------|-----------------------------------------------------------------------|--| | Function | | | | nverter connected to the CP-213 line. A few scans are of the process. | | | Function<br>Definition | | <b>-</b> | EXECUT CIR-NO STATIO TOTAL | COMPLETE S-ERROR | | | I/O Definition | No. | Name | I/O<br>Designation* | Description | | | | 1 | EXECUTE | B-VAL | CP-213 initial data setting command | | | T., | 2 | CIR-NO | I-REG | CP-213 line No. (1 to 8) | | | Input | 3 | STATION | I-REG | Slave station No. (1 to 31) | | | | 4 | WORD-CNT | I-REG | Number of words of set data (1 to 127) | | | | 5 | DAT-ADR | | Head address of set data (MW, DW, #W) | | | | 1 | BUSY | B-VAL | CP-213 initial data setting in process | | | Outnut | 2 | COMPLETE | B-VAL | Completion of CP-213 initial data setting | | | Output | 3 | S-ERROR | B-VAL | Occurrence of error | | | | 4 | P-ERROR | B-VAL | Parameter error | | <sup>\*:</sup> Indicates the I/O designation at the CP-717. ## .8 Send Message Function (MSG-SND) | Name of Function | n | | | MSG-SND | | | | |------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Function | th<br>Th<br>be | Sends a message to the called station which is on the line and which is designated by the transmission device type. Supports a plurality of protocol types. The execution command (EXECUTE) must be held until COMPLETE or ERRO becomes ON. [Transmission Devices] CP-215, CP-216, CP-217, CP-218, CP-2500, CP-2520 [Protocols] MEMOBUS, non-procedural, MELSEC, OMRON | | | | | | | Function<br>Definition | | | | | | | | | I/O Definition | No. | Name | Designation* | Description | | | | | | $\frac{1}{2}$ | EXECUTE ABORT | B-VAL<br>B-VAL | Send message command Send message forced interruption command | | | | | | 3 | DEV-TYP | I-REG | Type of transmission device<br>CP-215 = 1<br>CP-216 = 4<br>CP-217 = 5<br>CP-218 = 6<br>CP-2500 = 3<br>CP-2520 = 7 | | | | | Innut | 4 | PRO-TYP | I-REG | Transmission protocol ** MEMOBUS = 1 non-procedural = 2 | | | | | Input | 5 | CIR-NO | I-REG | Line No. CP-215 = 1 to 8 CP-216 = 1 to 8 CP-217 = 1 to 24 CP-218 = 1 to 8 CP-2500 = 1 to 8 CP-2520 = 1 to 8 | | | | | | 6 | CH-NO PARAM | I-REG Address input | Transmission buffer channel No. CP-215 = 1 to 13 CP-216 = 1 to 3 CP-217 = 1 CP-218 = 1 to 10 CP-2500 = 1 to 14 CP-2520 = 1 to 15 Head address of set data (MW, DW, #W) | | | | | Output | 1 2 | BUSY<br>COMPLETE | B-VAL<br>B-VAL | Message is being sent. The sending of the message has been completed. | | | | | | 3 | ERROR | B-VAL | Occurrence of error | | | | <sup>\* :</sup> Indicates the I/O designation at the CP-717. <sup>\*\* :</sup> Designate the MEMOBUS protocol (= 1) if transmission is to be performed with the MELSEC or OMRON procedure. Protocol conversion will be carried out at the transmission device (CP-217, CP-218). Refer to (1) of 5.3.4, "OMRON Communication" or (2) of 5.3.4, "MELSEC Communication" of the Control Pack CP-9200SH User's Manual (SIE-C879-40.1) for details on the protocol conversion specifications. ### **PARAM** | | | Cont | ents | Remarks | |-----|--------|-------------------------|------------------|-----------------------------------------------------| | No. | IN/OUT | MEMOBUS | Non-procedural | Ivenidias | | 00 | OUT | Process result | Process result | | | 01 | OUT | Status | Status . | | | 02 | IN | Called station # | Called station # | Called connection # in the case of DEV-TYP = CP-218 | | 03 | SYS | System reserved | System reserved | | | 04 | IN | Function code | | | | 05 | IN | Data address | Data address | | | .06 | IN | Data size | Data size | <u> </u> | | 07 | IN | Called CPU# | Called CPU# | | | 08 | IN | Coil offset | | <u> </u> | | 09 | IN | Input relay offset | • | | | 10 | IN | Input register offset | | | | 11 | IN | Holding register offset | | | | 12 | SYS | For system use | For system use | | | 13 | SYS | System reserved | System reserved | | | 14 | SYS | System reserved | System reserved | | | 15 | SYS | System reserved | System reserved | | | 16 | SYS | System reserved | System reserved | | #### 7.8.1 Parameters | (4) | Process | Pacult | /DAF | (OOM AS | | |-----|---------|--------|------|---------|--| | /T1 | Process | Result | ULAL | MINUUI | | The process result is output to the upper byte. The lower byte is for system analysis. · 00 []:In process (BUSY) 10□ :End of process (COMPLETE) · 8 Ccurrence of error (ERROR) ### [Error Classification] · 81□□: Function code error The sending of an unused function code was attempted. Or, an unused function code was received. 82 : Address setting error The data address, coil offset, input relay offset, input register offset, or holding register offset setting is out of range. · 83 🛮 : Data size error The size of the sent or received data is out of range. · 84 □□: Line No. setting error The line No. setting is out of range. 85 : Channel No. setting error The channel No. setting is out of range. · 86□□: Station address error The station No. setting is out of range. 88 🗓 : Transmission unit error. An error response was returned from the transmission unit. (Refer to (2) of 7.8.1.) · 89 🔲 : Device selection error A non-applicable device is selected. ### (2) Status (PARM01) Outputs the status of the transmission unit. ### (a) Bit Assignment ### (b) COMMAND | Code | Symbol | Meaning | |------|---------|--------------------------------------------------------------| | 1 | U_SEND | Send generic message. | | 2 | U_REC | Receive generic message. | | 3 | ABORT | Forced interruption | | 8 | M_SEND | Send MEMOBUS command ··· completed upon receipt of response. | | 9 | M_REC | Receive MEMOBUS command ··· accompanies sending of response. | | C | MR_SEND | Send MEMOBUS response. | ### (c) RESULT | Code | Symbol | Meaning | |------|--------------|------------------------------------------------------------------| | 1 | SEND_OK | Sending has been completed correctly. | | 2 | REC_OK | Receiving has been completed correctly. | | 3 | ABORT_OK | Completion of forced interruption | | 4 | FMT_NG | Parameter format error | | 5 | SEQ_NG, | Command sequence error | | ŀ | or INIT_NG | The token has not been received yet. | | | | Not connected to a transmission system. | | 6 | RESET_NG, | Reset state | | ] | or O_RING_NG | Out-of-ring. The token could not be received even when the token | | | | monitor time was exceeded. | | 7 | REC_NG | Data receive error (error detected by a program of a lower rank) | ### (d) PARAMETER One of the error codes of Table 7.2 is indicated if RESULT = 4(FMT\_NG). Otherwise, this indicates the address of the called station. **Table 7.2 Error Codes** | Code | Error | |------|-------------------------------------------------| | 00 | No errors. | | 01 | Station address is out of range. | | 02 | Monitored MEMOBUS response receiving time error | | 03 | Resending count setting error | | 04 | Cyclic area setting error | | 05 | Message signal CPU No. error | | 06 | Message signal register No. error | | 07 | Message signal word count error | ### (e) REQUEST - 1 = Request - 0 = Completion of receipt report ### (3) Called Station # (PARAM02) [CP-215] 1 to 64: Message is sent to the designated station. 00FFH: Message is sent to all stations (broadcasting). [CP-216] 1 to 30: Message is sent to the designated station (possible only sending from the master station sending from a slave station). Note : With CP-216, message transmission between slave stations is not possible. [CP-217] 1 to 254: Message is sent to the station of designated device address. [CP-218] 1 to 20: Message is sent to the station of designated connection No. [CP-2500] 1 to 32: Message is sent to the designated station. 129 to 160: Message is sent to the stations of designated group address (group transmissio 00FFH: Message is sent to all stations (broadcasting). [CP-2520] 1 to 64: Message is sent to the designated station. 00FFH: Message is sent to all stations (broadcasting). ### (4) Function Code (PARAM04) The MEMOBUS function code to be sent is set. | | Function code | Setting | |-------------|------------------------------------------------------|---------| | 00H | Unused | × | | 01H | Read coil status | 0 | | 02H | Read input relay status | 0 | | 03H | Read contents of holding register | | | 04H | Read contents of input register | | | 05H | Change status of single coil | 0 | | 06H | Write into a single holding register | 0 | | 07H | Unused | × | | 08H | Loop-back test | 0 | | 09H | Read contents of holding register (expanded) | 0 | | 0AH | Read contents of input register (expanded) | 0 | | 0BH | Write into holding register (expanded) | 0 | | 0CH | Unused | X | | ODH | Discontinuous readout of holding register (expanded) | 0 | | 0EH | Discontinuous write into holding register (expanded) | 0 | | 0FH | Change status of a multiple coil | 0 | | 10H | Write into a plurality of holding registers | 0 | | 11H to 20H | Unused | × | | 21H to 3FH | System reserved | × | | 40H to 4FH | System reserved | × | | 50H or more | Unused · | × | $(\times : cannot be set, \bigcirc : can be set)$ Note: Only MW (MB) can be used as the sending/receiving register during master operation. T MB, MW, IB, and IW registers can be used respectively as the coil, holding register, in relay, and input registers during slave operation. ### (5) Data Address (PARAM05) The set contents will differ according to the function code as follows. - ① Request for readout from/write-in to coil or relay: Set the head bit address of the data. - 2 Request for continuous readout from/write-in to a register: Set head word address of the data. - 3 Request for discontinuous readout from/write-in to a register: Set head word address of the address table. | | Function code | Data Add | lress Setting Rang | ge | |-----|------------------------------------------------------|------------|--------------------|-------------| | 00H | Unused | Invalid | | <del></del> | | 01H | Read coil status | 0 to 65535 | (0 to FFFFH) | 10 | | 02H | Read input relay status | 0 to 65535 | (0 to FFFFH) | 10 | | 03H | Read contents of hold register | 0 to 32767 | (0 to 7FFFH) | 2 | | 04H | Read contents of input register | 0 to 32767 | (0 to 7FFFH) | 12 | | 05H | Change status of single coil | 0 to 65535 | (0 to FFFFH) | 10 | | 06H | Write into a single holding register | 0 to 32767 | (0 to 7FFFH) | 12 | | 07H | Unused | Invalid | | | | 08H | Loop-back test | Invalid | | | | 09H | Read contents of holding register (expanded) | 0 to 32767 | (0 to 7FFFH) | 2 | | 0AH | Read contents of input register (expanded) | 0 to 32767 | (0 to 7FFFH) | 2 | | OBH | Write into holding register (expanded) | 0 to 32767 | (0 to 7FFFH) | 12 | | 0CH | Unused | Invalid | | | | ODH | Discontinuous readout of holding register (expanded) | 0 to 32767 | (0 to 7FFFH) | 3 | | 0EH | Discontinuous write into holding register (expanded) | 0 to 32767 | (0 to 7FFFH) | 13 | | 0FH | Change status of a multiple coil | 0 to 65535 | (0 to FFFFH) | i <u>û</u> | | 10H | Write into a plurality of holding registers | 0 to 32767 | (0 to 7FFFH) | 2 | ### (6) Data Size (PARAM06) Set the size (in number of bits or number of words) of the data that is requested for readout or write-in. The setting range will differ according to the transmission module and the function code to be used. ### [CP-215] | Function code | | Data Size Setting Range | | | |---------------------------------------------------|---------------------------------------------------------|---------------------------------------|---------------------------------------|--| | | | CP-215/CP-218/CP-2520 | CP-216/CP-217-CP-2500 | | | 00H | Unused | Inva | alid | | | 01H | Read coil status | 1 to 2000 (1 to 07D | OH)/number of bits | | | 02H | Read input relay status | 1 to 2000 (1 to 07De | OH)/number of bits | | | 03H | Read contents of holding register | 1 to 125 (1 to 007DF | l)/number of words | | | 04H | Read contents of input register | 1 to 125 (1 to 007DF | I)/number of words | | | 05H | Change status of single coil | Inva | ılid | | | 06H | Write into a single holding register | Inva | ılid · | | | 07H | Unused | Inva | ılid | | | 08H | Loop-back test | Invalid | | | | | Read contents of holding register (expanded) | 1 to 508 (1 to 01FCH)/number of words | 1 to 252 (1 to 00FCH)/number of words | | | 0A | Read contents of input register (expanded) | 1 to 508 (1 to 01FCH)/number of words | 1 to 252 (1 to 00FCH)/number of words | | | 0B | Write into holding register (expanded) | 1 to 507 (1 to 01FBH)/number of words | 1 to 251 (1 to 00FBH)/number of words | | | OC | Unused | Inva | lid | | | 0D | Discontinuous readout of<br>holding register (extended) | 1 to 508 (1 to 01FCH)/number of words | 1 to 252 (1 to 00FCH)/number of words | | | OE | Discontinuous write into<br>holding register (extended) | 1 to 254 (1 to 00FEH)/number of words | 1 to 126 (1 to 007EH)/number of words | | | 0FH | Change status of multiple coil | 1 to 800 (1 to 0320H)/number of bits | | | | 10H Write into a plurality of holding registers | | 1 to 100 (1 to 0064H | | | ### (7) Called CPU # (PARAM07) Set the called CPU No. When the sending destination is CP-9200SH, set 1 or 2: For other cases, set 0. ### (8) Coil Offset (PARAM08) Set the offset word address of the coil. This is valid in the case of function codes 01H, 05H, and 0FH. ### (9) Input Relay Offset (PARAM09) Set the offset word address of the input relay. This is valid in the case of function code 02H. ### (10) Input Register Offset (PARAM10) Set the offset word address of the input register. This is valid in the case of function codes 04H and 0AH. ### (11) Holding Register Offset (PARAM11) Set the offset word address of the holding register. This is valid in the case of function codes 03H, 06H, 09H, 0BH, 0DH, 0EH, and 10H. ### (12) For System Use (PARAM12) The channel No. being used is stored. Make sure that this will be set to 0000H by the use program on the first scan after turning on the power. This parameter must not be changed by the user program thereafter since this parameter will then be used by the system. ### (13) Relationship between the Data Address, Size and Offset A = sending side offset address B = sending side data address C = receiving side offset address ### (14) When transmission protocol is set to non-procedural The settings of PARAM04, PARAM08, PARAM09, and PARAM10 are not necessary. Transmission enabled register is only MW. ### .8.2 Inputs ### (1) EXECUTE (Send Message Execution Command) When this command becomes "ON", the message is sent. This must be held until COMPLETE (completion of process) or ERROR (occurrence of error) becomes "ON". ### (2) ABORT (Send Message Forced Interruption Command) This command forcibly interrupts the sending of the message. This has priority over EXECUTE (send message execution command). ### (3) DEV-TYP (Transmission Device Type) Designates transmission device type. | | Transmission Device Type | |---------|--------------------------| | CP-215 | 1 | | CP-216 | 4 | | CP-217 | 5 | | CP-218 | 6 | | CP-2500 | 3 | | CP-2520 | 7 | ### (4) PRO-TYP (Transmission Protocol) Designates transmission protocol. When transmitting with MELSEC or OMRON procedures, specify MEMOBUS protocol (=1). Protocol is converted by the transmission device (CP-217, CP-218). MEMOBUS: Setting = 1 Non-procedural: Setting = 2 For details of protocol conversion specifications, refer to the following manuals. Control Pack CP-9200SH User's Manual (SIE-C879-40.1) 5.3.4 (1) "OMRON communications" 5.3.4 (2) "MELSEC communications" Note: In non-procedural transmission, a response is not received from the other station. ### (5) CIR-NO (Circuit No.) Designate the Circuit No. | | Circuit No. | |---------|------------------| | CP-215 | 1 to 8 (Option) | | CP-216 | 1 to 8 (Option) | | CP-217 | 1 to 24 (Option) | | CP-218 | 1 to 8 (Option) | | CP-2500 | 1 to 8 (Option) | | CP-2520 | 1 to 8 (Option) | #### (6) CH-NO (Channel No.) Designate the channel No. of the transmission unit. However, the channel number should be set so as not to be duplicated on a single line. | | Channel No. | |---------|-------------| | CP-215 | 1 to 13 | | CP-216 | 1 to 3 | | CP-217 | 1 | | CP-218 | 1 to 10 | | CP-2500 | 1 to 14 | | CP-2520 | 1 to 15 | ### (7) PARAM (Set Data Head Address) The head address of the set data is designated. For details of the set data refer to 7.8.1. "Parameters." ### 7.8.3 Outputs - (1) BUSY (In Process) Indicates that the process is being executed. Keep EXECUTE set to "ON". - (2) COMPLETE (Completion of Process) Becomes "ON" for only 1 scan upon normal completion. - (3) ERROR (Occurrence of Error) Becomes "ON" for only 1 scan upon occurrence of error. Refer to PARAM00 (7.8.1 (1)) and PARAM01 (7.8.1 (2)) concerning the cause. ### 8.4 Limitations Arising from Other Companies' Communications Protocols with the CP-217IF - (1) When Making a Dedicated Protocol Connection Link with the MELSEC Computer - Communication is possible with type 1 protocol (response possible only for full-dual connection). - With a MSG-SND function, receiving and sending with responce of ACPU common commands to and from the MELSEC sequencer are possible, but commands that may be used are limited (read out/write in of device memory, wrap test). - Designate MEMOBUS protocol (=1) for input of the PRO-TYP (transmission protocol) of the MSG-SND function. On the I/O definition screen for the transmission port, if MELSEC master is set, conversion to the corresponding MELSEC format is performed by the CP-217IF unit. Change designated parameters at this time to parameters of corresponding MEMOBUS procedures. Refer to the following manuals for correspondence of MELSEC commands and MEMOBUS function codes, and correspondence of registers for sending and receiving and device addresses on the MELSEC side. - · Control Pack CP-9200SH User's Manual (SIE-C879-40.1) 5.3.4 (2) "MELSEC communications" - In MEMOBUS → MELSEC format conversion, due to MELSEC protocol characteristic restrictions or MELSEC sequencer type characteristic restrictions, limits in addition to number of read out words of a register and other MEMOBUS procedures arise, so carefully read manuals related to connected equipment before using. Furthermore be sure to refer to the manual related to MELSEC computer link dedicated protocol type 1 commands. ### (2) When Making an OMRON Upward Linking Mode (SYSWAY) Connection - With a MSG-SND function, sending and receiving with response of commands to and from the OMRON sequencer are possible, but commands that may be used are limited (I/O relay/DM read out/write, wrap test). - Designate MEMOBUS protocol (=1) for input of the PRO-TYP (transmission protocol) of the MSG-SND function. On the I/O definition screen for the transmission port, if OMRON master is set, conversion to the corresponding OMRON format is performed by the CP-217IF unit. Change designated parameters at this time to parameters of corresponding MEMOBUS procedures. Refer to the following manuals for correspondence of OMRON commands and MEMOBUS function codes, and regarding correspondence of registers for sending and receiving and the relay (CH)/DM area on the OMRON side. - Control Pack CP-9200SH User's Manual (SIE-C879-40.1) 5.3.4 (1) "OMRON communications" - In MEMOBUS → OMRON format conversion, due to OMRON protocol characteristic restrictions or OMRON sequencer type characteristic restrictions, limits in addition to number of read out words of a register and other MEMOBUS procedures arise, so carefully read manuals related to connected equipment before using. Furthermore be sure to refer to the manual related to OMRON communications procedures. - This corresponds to transmission procedures by multi-programs stipulated in OMRON procedures, but set the upper limit for the number of words that can be accessed with one instruction to 125 words for DM register read out, and 100 words for write-in (restricted conditions of MEMOBUS procedures). #### 7.8.5 Program Example ## Receive Message Function (MSG-RCV) 9 | Name of Function | MSG-RCV | | | | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Function | Receives a message from a calling station which is on the line and which is designated by the transmission device type. Supports a plurality of protocol types. The execution command (EXECUTE) must be held until COMPLETE or ERROR becomes ON. [Transmission Devices] CP-215, CP-216, CP-217, CP-218, CP-2500, CP-2520 [Protocols] MEMOBUS, non-procedural, MELSEC, OMRON | | | | | Function<br>Definition | | | | EXECUTE MSG-RCV BUSY ABORT COMPLETE DEV-TYP ERROR PRO-TYP | | I/O Definition | No. | Name | I/O<br>Designation | Description | | Input | 1 2 3 | EXECUTE ABORT DEV-TYP PRO-TYP CIR-NO | B-VAL B-VAL I-REG I-REG | Receive message command Receive message forced interruption command Type of transmission device CP-215 = 1 CP-216 = 4 CP-217 = 5 CP-218 = 6 CP-2500 = 3 CP-2520 = 7 Transmission protocol ** MEMOBUS = 1 non-procedural = 2 Line No. CP-216 = 1 to 8 CP-215 = 1 to 8 CP-217 = 1 to 24 CP-218 = 1 to 8 CP-2500 = 1 to 8 | | | 7 | CH-NO PARAM | I-REG | CP-2520 = 1 to 8 Transmission buffer channel No. CP-215 = 1 to 13 CP-216 = 1 to 3 CP-217 = 1 CP-218 = 1 to 10 CP-2500 = 1 to 14 CP-2520 = 1 to 15 Head address of set data (MW, DW, #W) | | Output | 1<br>2<br>3 | BUSY<br>COMPLETE<br>ERROR | B-VAL<br>B-VAL<br>B-VAL | Message is being received. The receiving of the message has been completed. Occurrence of error | <sup>\* :</sup> Indicates the I/O designation at the CP-717. <sup>\*\*</sup> Designate the MEMOBUS protocol (= 1) if transmission is to be performed with the MELSEC or OMRON procedure. Protocol conversion will be carried out at the transmission device (CP-217, CP-218). Refer to (1) of 5.3.4, "OMRON Communication" or (2) of 5.3.4, "MELSEC Communication" of the Control Pack CP-9200SH User's Manual (SIE-C879-40.1) for details on the protocol conversion specifications. ### PARAM | | | Cont | ents | Remarks | | |-----|--------|-------------------------|-------------------|---------------------------------------------------------|--| | No. | IN/OUT | MEMOBUS | Process result | . Itematas | | | 00 | OUT | Process result | Process result | | | | 01 | OUT | Status | Status | , | | | 02 | OUT* | Calling station # | Calling station # | * Calling connection # in the case of DEV-TYP = CP-218. | | | 03 | SYS | System reserved | System reserved | | | | 04 | . OUT | Function code | | | | | 05 | OUT | Data address | Data address | | | | 06 | OUT | Data size | Data size | | | | 07 | OUT | Calling CPU# | Calling CPU# | | | | 08 | IN . | Coil offset | | | | | 09 | IN | Input relay offset | • | | | | 10 | IN | Input register offset | | • | | | 11 | IN | Holding register offset | | | | | 12 | IN | Write-in range LO | | | | | 13 | IN | Write-in range HI | | | | | 14 | SYS | For system use | For system use | | | | 15 | SYS | System reserved | System reserved | | | | 16 | SYS | System reserved | System reserved | | | <sup>\*</sup> When CP-218 is set for DEV-TYP, IN. (1) Process Result (PARAM00) ### 7.9.1 Parameters | The process result is output to the upper byte. The lower byte is for system analysis. | |--------------------------------------------------------------------------------------------| | · 00 □ : In process (BUSY) | | · 10 [ : End of process (COMPLETE) | | · 8 🗆 : Occurrence of error (ERROR) | | | | [Error Classification] | | · 81 🗀 : Function code error | | An unused function code was received. | | · 82 🔲 : Address setting error | | The data address, coil offset, input relay offset, input register offset, or holding regis | | offset setting is out of range. | | · 83 □ : Data size error | | The size of the sent or received data is out of range. | | · 84□□: Line No. setting error | | OTOD: Mile 110. Double-8 | The line No. setting is out of range. 85 🗀 : Channel No. setting error The channel No. setting is out of range. 86 🔲 : Station address error The station No. setting is out of range. 88 🔲 : Transmission unit error. An error response was returned from the transmission unit. (Refer to (2) of 7.9.1.) · 89 🗓 : Device selection error A non-applicable device is selected. #### (2) Status (PARAM01) Outputs the status of the transmission unit. See 7.8.1 (2), "Status (PARAM01)" for details. ### (3) Calling Station # (PARAM02) [CP-215, CP-216, CP-217, CP-2500, CP-2520] The station number of sending side is output. [CP-218] 1 to 20: The calling station connection number is set. ### (4) Function Code (PARAM04) Outputs the MEMOBUS function code received. | | Function code | Output | |------------|------------------------------------------------------|--------| | 00H | Unused | × | | 01H | Read coil status | 0 | | 02H | Read input relay status | Ŏ | | 03H | Read contents of holding register | Ŏ | | 04H | Read contents of input register | Ō | | 05H | Change status of single coil | Ō | | 06H | Write into a single holding register | Ō | | 07H | Unused | × | | 08H | Loop-back test | 0 | | _09H | Read contents of holding register (expanded) | Ō | | 0AH | Read contents of input register (expanded) | 0 | | _0BH | Write into holding register (expanded) | 0 | | 0CH | Unused | × | | 0DH | Discontinuous readout of holding register (expanded) | 0 | | 0EH | Discontinuous write into holding register (expanded) | 0 | | 0FH | Change status of a multiple coil | 0 | | 10H | Write into a plurality of holding registers | Ō | | 11H to 20H | Unused | × | | 21H to 3FH | System reserved | × | | 40H to 4FH | System reserved | × | | 50H to | Unused | X | $(\times : cannot be output, \bigcirc : can be output)$ Note: The MB, MW, IB, and IW registers can be used respectively as the coil, holding register, input relay, and input registers during slave operation. #### (5) Data Address (PARAM05) The data address requested by the sending side is output. #### (6) Data Size (PARAM06) The data size (number of bits or number of words) of the requested read or write is output. ### (7) Calling CPU # (PARAM07) The calling CPU No. is output. When the sending source is CP-9200SH, 1 or 2 is output. For other cases, 0 is output. ### (8) Coil Offset (PARAM08) Set the offset word address of the coil. This is valid in the case of function codes 01H, 05H, and 0FH. ### (9) Input Relay Offset (PARAM09) Set the offset word address of the input relay. This is valid in the case of function code 02H. ### (10) Input Register Offset (PARAM10) Set the offset word address of the input register. This is valid in the case of function codes 04H and 0AH. ### (11) Holding Register Offset (PARAM11) Set the offset word address of the hold register. This is valid in the case of function codes 03H, 06H, 09H, 0BH, 0DH, 0EH, and 10H. ### (12) Write-in Range LO (PARAM12), Write-in Range HI (PARAM13) Set the write allowable range for the request for write-in. A request which is outside of this rang will cause an error. This is valid in the case of function code 0BH, 0EH, 0FH, and 10H. $0 \le \text{Write-in Range LO} \le \text{Write-in Range HI} \le \text{Maximum value of MW Address}$ ### (13) For System Use (PARAM14) The channel No. being used is stored. Make sure that this will be set to 0000H by the use program on the first scan after turning on the power. This value must not be changed by the use program thereafter since this parameter will then be used by the system. ### (14) When Non-procedural is set for Transmission Protocol PARAM04 has no function. The settings of PARAM08, PARAM09, and PARAM10 are no necessary. The message receivable register is only MW. #### 7.9.2 Inputs ### (1) EXECUTE (Receive Message Execution Command) When this command becomes "ON", the message is received. This must be held until COMPLETE (completion of process) or ERROR (occurrence of error becomes "ON". ### (2) ABORT (Receive Message Forced Interruption Command) This command forcibly interrupts the receiving of the message. This has priority over EXECUTI (receive message execution command). ### (3) DEV-TYP (Transmission Device Type) Designates transmission device type. | | Transmission Device Type | |---------|--------------------------| | CP-215 | 1 | | CP-216 | 4 | | CP-217 | 5 | | CP-218 | 6 | | CP-2500 | 3 | | CP-2520 | 7 | ### (4) PRO-TYP (Transmission Protocol) Designates transmission protocol. When transmitting with MELSEC or OMRON procedures, designate MEMOBUS protocol (=1). Protocol is converted by the transmission device (CP-217, CP-218). MEMOBUS: Setting = 1 Non-procedural: Setting = 2 For details of protocol conversion specifications, refer to the following manuals. Control Pack CP-9200SH User's Manual (SIE-C879-40.1) 5.3.4 (1) "OMRON communications" 5.3.4 (2) "MELSEC communications" Note: In non-procedural transmission, a response is not sent to the other station. #### (5) CIR-NO (Line No.) Designate the Circuit No. | | Circuit No. | |---------|------------------| | CP-215 | 1 to 8 (Option) | | CP-216 | 1 to 8 (Option) | | CP-217 | 1 to 24 (Option) | | CP-218 | 1 to 8 (Option) | | CP-2500 | 1 to 8 (Option) | | CP-2520 | 1 to 8 (Option) | #### (6) CH-NO (Channel No.) Designate the channel No. of the transmission unit. However, the channel number should be set so as not to be duplicated on a single line. | | Channel No. | |---------|-------------| | CP-215 | 1 to 13 | | CP-216 | 1 to 8 | | CP-217 | 1 | | CP-218 | 1 to 10 | | CP-2500 | 1 to 14 | | CP-2520 | 1 to 15 | #### (7) PARAM (Setting Data Head Address) The head address of the set data is designated. For details of the setting data, refer to 7.9.1. "Parameters." #### 3 Outputs #### (1) Busy (in Process) Indicates that the process is being executed. Keep EXECUTE set to "ON". ### (2) COMPLETE (Completion of Process) Becomes "ON" for only 1 scan upon normal completion. ### (3) ERROR (Occurrence of Error) Becomes "ON" for only 1 scan upon occurrence of error. Refer to PARAM00 (7.8.1 (1)) and PARAM01 (7.8.1 (2)) concerning the cause. ## 7.9.4 Limitations Arising from Other Companies' Communications Protocols with the CP-217IF - (1) When Making a Dedicated Protocol Connection Link with the MELSEC Computer - Communication is possible with type 1 protocol (response possible only for full-dual connection - With a MSG-RCV function, receiving and sending with response of ACPU common command to and from the MELSEC master device are possible, but commands that may be used ar limited (read out/write in of device memory, wrap test). - Designate MEMOBUS protocol (= 1) by input of the PRO-TYP (transmission protocol) of the MSG-RCV function. On the I/O definition screen for the transmission port, if MELSEC slave is set, conversion to the corresponding MELSEC format is performed by the CP-217IF unit. Change designated parameters to parameters of corresponding MEMOBUS procedures. Refet to the following manuals for correspondence of MELSEC commands and MEMOBUS function codes, correspondence of registers for sending and receiving and device addresses on the MELSEC side. - Control Pack CP-9200SH User's Manual (SIE-C879-40.1) 5.3.4 (2) "MELSEC communications" (2) When Making an OMRON Upward Linking Mode (SYSWAY) Connection - With a MSG-RCV function, receiving and sending with responce of commands to and from th OMRON master device are possible, but commands that may be used are limited (I/O relay DM read out/write, wrap test). - Designate MEMOBUS protocol (= 1) for input of the PRO-TYP (transmission protocol) of the MSG-RCV function. On the I/O definition screen for the transmission port, if OMRON slave is set, conversion to the corresponding OMRON format is performed by the CP-217IF unit. Change designated parameters to parameters of corresponding MEMOBUS procedures. Refer to the following manuals for correspondence of OMRON commands and MEMOBUS function codes, regarding correspondence of registers for sending and receiving and the relation (CH)/DM area on the OMRON side. - Control Pack CP-9200SH User's Manual (SIE-C879-40.1) - 5.3.4 (1) "OMRON communications" - This corresponds to transmission procedures by multi-programs stipulated in OMRON procedures, but set the upper limit for the number of words that can be accessed with one instruction to 125 words for DM register read out, and 100 words for writing (restricted conditions of MEMOBUS procedures). ### 9.5 Program Example ## 7.10 Counter Function (COUNTER) | Name of Function | COUNTER | | | | | | |------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Function | Increments or decrements the current value when the count up/down command (UP-CMD, DOWN-CMD) changes from OFF to ON. When the counter reset command (RESET) becomes ON, the current counter value is set to 0. Also, the current counter value and the set value are compared and the comparison result is output. * The current value will not be incremented neither decremented if a counter error (current value > set value) occurs. | | | | | | | Function<br>Definition | | | UP-CMD DOWN-C | | | | | I/O Definition | No. | Name | I/O<br>Designation* | Description | | | | Input | 1<br>2<br>3<br>4 | UP-CMD<br>DOWN-CMD<br>RESET<br>CNT-DATA | B-VAL | Count up command (OFF → ON) Count down command (OFF → ON) Counter reset command Head address of data area for counter process (MW or DW register) Data area for counter counter process 1: Set value 2: Current value 3: Work flag | | | | Output | 1 2 | CNT-UP<br>CNT-ZERO | B-VAL | Becomes ON when current counter value = set value. Becomes ON when current counter value = 0. | | | | | 3 | CNT-ERR | B-VAL | Becomes ON when current counter value > set value. | | | <sup>\*:</sup> Indicates the I/O designation at the CP-717. # First-in First-out Function (FINFOUT) 11 | Name of Functio | n F | INFOUT | | • | | |------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | Function | si | ze, input size When the da data is seque the FIFO tak When the da ber of data as designated o When the re stored is set If "size of av | t-word header, output size) ta input commentially stored ole. ta output conce transferred utput data are set command to zero and thailable space | pe block data transfer function. The part and a data buffer. 3 words of the must be set before this function is remand (IN-CMD) becomes ON, the designated input data area around (OUT-CMD) becomes ON, the from the head of the data area of the ea. (RESET) becomes ON, the number of the EFFO table empty output (TBL-EN) for data (empty size) < input size le error (TBL-ERR) becomes ON. | e header part (data eferenced. signated number of to the data area of e designated numer FIFO table to the c (amount) of data | | Function<br>Definition | | | IN-CMD OUT-CMD RESET | FINFOUT TBL-FULL TBL-EMP TBL-ERR FIFO-TBL IN-DATA OUT-DATA | | | I/O Definition | No. | Name | I/O<br>Designation* | Description | | | Input | 1 | IN-CMD | B-VAL | Data input command (IN-CMD) | | | | 2 | OUT-CMD | B-VAL | Data output command (OUT-CMD) | FIFO Table<br>Configuration | | | | RESET | B-VAL | Reset command | 0: data size | | | 4 | FIFO-TBL | Address input | Head address of FIFO table | 1 : input size | | | | | | (MW or DW address) | 2 : output size | | | 5 | IN-DATA | Address input | Head address of input data | 3 : number of data stored | | | 6 | OTTO DATE | A 1 3 | (MW or DW address) | 4 : data | | | U | OUT-DATA | Adaress input | Head address of output data | İ | | Output | 1 | TBL-FULL | B-VAL | (MW or DW address) | | | <b>p</b> ••• | 2 | TBL-FULL TBL-EMP | B-VAL | FIFO table is full. | | | | 3 | TBL-ERR | B-VAL | FIFO table is empty. | | | * . T | | 122-11111 | 7- AVT | FIFO table error | | <sup>\*:</sup> Indicates the I/O Designation at the CP-717. ## **APPENDIX** The contents of Appendix are as follows: Appendix A: Types of Instruction Words Appendix B: List of Instructions Appendix C: Differences on Programming between CP-9200H and CP-9200SH The data type (bit type, integer type, double-length integer type, real number type) that can be used will differ for each instruction. Refer to Chapter 4 "BASIC INSTRUCTIONS" for details. ## A Types of Instruction Words | Type of Instruction Word | Instruction Words | |----------------------------------|------------------------------------------------| | Program control instruction | SEE FOR WHILE ON/OFF IFON/IFOFF | | | ELSE END FSTART FIN FOUT COMMENT | | , , | XCALL | | Direct I/O instruction | INS OUTS | | Relay circuit instruction | | | Logical operation instruction | ∧ ∨ ⊕ | | Numerical operation instruction | | | | INC DEC MOD REM TMADD TMSUB SPEND | | Numerical conversion instruction | INV COM ABS BIN BCD PARITY ASCII BINASC ASCBIN | | Numerical comparison instruction | | | Data operation instruction | ROTL ROTR MOVB MOVW XCHG SETW | | · | BEXTD BPRESS BSRCH SORT SHFTL SHFTR | | | COPYW BSWAP | | Basic function instruction | SQRT SIN COS TAN ASIN ACOS ATAN EXP LN LOG | | DDC instruction | DZA DZB LIMIT PI PD PID LAG LLAG | | | FGN IFGN LAU SLAU PWM | | Table data operation instruction | TBLBR TBLBW TBLSRL TBLSRC TBLCL TBLMV | | + | QTBLR QTBLRI QTBLW QTBLWI QTBLCL | | SFC instruction | SFC = Z + ABOX SBOX AEND SFCSTEP | | System function | COUNTER FINFOUT TRACE DTRC-RD FTRC-RD | | • | ITRC-RD MSG-SND MSG-RCV ISET-213 ICNS-WR | | | ICNS-RD | ## List of Instructions | Туре | Name | Symbol | [ ]<br>Instruction | Description | | Model | |----------------|-------------------|------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------| | | CDD 1331 ( | · | <del> </del> | | CP-9200SH | CP-9200H | | | SEE child drawing | SEE | 0 | Designate the No. of the child or<br>grandchild drawing to be<br>referenced after "SEE"<br>SEE H01 | 0 | 0 | | | FOR statement | FOR FEND | | Loop execution statement - 1 FOR V = a to b by c V : arbitrary integer register May specify as I or J. a, b, c: May specify an arbitrary integer. (b > a > 0, c > 0) FEND: END of FOR instruction | 0 | 0 | | ogram<br>ntrol | WHILE statement | WHILE<br>ON/OFF | | Loop execution statement - 2 WEND: END of WHILE-ON OFF | 0 | 0 | | structions | | L WEND | | instruction | | | | | IF statement | IFON/IFOFF - ELSE - IEND | | Conditional execution statement IEND: END of IFON/IFOFF instruction | 0 | 0 | | | END | FEND<br>WEND<br>IEND<br>DEND | | The exclusive END instruction is indicated automatically by the CP-717 for each of the above statements. DEND is indicated for the END of a drawing. Only "END" is accepted as an input from the CP-717; FEND, WEND, etc. will not be accepted. | 0 | 0 | | | COMMENT | "nnnnnnnn" | | Character strings enclosed in " will be handled as a comment. | 0 | 0 | | (continued) | | | [] . | | Device | | |------------------------------------|-------------------------------------------------------|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------| | Туре | Name | Symbol | Instruction | Description | CP-9200SH | CP-920 | | | Function I/F | FSTART | | Function referencing instruction | 0 | 0 | | | | FIN ' | | Function input instruction Stores input data from the designated input register into the function input register. Designated input register B-VAL: CPU internal register (B register) I-VAL: CPU internal register (A register) L-VAL: CPU internal register (A register) F-VAL: CPU internal register (F register) I-REG: arbitrary integer register L-REG: arbitrary double-length integer register F-REG: arbitrary real number register Address input | 0 | 0 | | Program<br>control<br>instructions | | FOUT | | Function output instruction Stores output data from the function output register to the designated output register. Designated output register B-VAL: CPU internal register (B register) I-VAL: CPU internal register (A register) L-VAL: CPU internal register (A register) F-VAL: CPU internal register (F register) I-REG: arbitrary integer register L-REG: arbitrary double-length integer register F-REG: arbitrary real number register | | 0 | | - | Expansion program execution instruction | XCALL | 0 | Instruction for referencing an expansion program*1. | 0 | | | Direct I/O | Input<br>instruction<br>(interruption<br>prohibited) | INS | 0 | INS MA00100 Data input and storage are executed with interruption prohibited. | 0 | - | | Instructions | Output<br>instruction<br>(interruption<br>prohibited) | OUTS | 0 | OUTS MA00100 ————————————————————————————————— | 0 | | <sup>\*1:</sup> There are four types of expansion programs which reference this instruction: constant table (M register I/O conversion table, interlock table, and part composition table. <sup>(</sup>Note) O mark in the "[ ] Instruction " column means that "[ ]" (conditional execution according to the vaof the immediately preceding B register) can be added to the instruction . | Туре | Name | Symbol | [ ]<br>Instruction | Description | | Model | |-------------------------------|------------------------------------------------------|---------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|-----------|----------| | | | <del> </del> | mstruction | | CP-9200SH | CP-9200H | | | NO contact | -1⊢ | •. | No limit in the serial circuit.<br>Bit type designation of any register as<br>a relay number is possible<br>(MB00011A). | 0 | 0 | | | NC contact | <u></u> -И- | | No limit in the serial circuit.<br>Bit type designation of any register as<br>a relay number is possible<br>(MB00011A). | 0 | 0 | | | Rise pulse | - <u></u> F- | | No limit in the serial circuit.<br>Bit type designation of any register as<br>a relay number is possible<br>(MB00011A). | 0 | 0 | | | Fall pulse | <u>}-</u> | | No limit in the serial circuit.<br>Bit type designation of any register as<br>a relay number is possible<br>(MB00011A). | 0 | 0 | | | On-delay timer<br>(Unit of measure-<br>ment: 10 ms) | -{'}- | | Set value: count register | Ο. | 0 | | elay<br>ircuit<br>istructions | Off-delay timer<br>(Unit of measure-<br>ment: 10 ms) | <b>-</b> [ }- | | Set value: any register,<br>constant (setting unit: 10ms)<br>Count register : M or D register | 0 | 0 | | | On-delay timer<br>(Unit of measure-<br>ment: 1s) | -[* ]- | | Set value: count register | 0 | | | | Off-delay timer<br>(Unit of measure-<br>ment: 1s) | -[*]- | | Set value: any register,<br>constant (setting unit: 1s)<br>Count register : M or D register | | | | | Coil | <b>–</b> બ | | H MW00200 = 00001 | 0 | 0 | | | Set coil | ЧsН | , | MB000000 MB000010 | 0 | 0 | | | Reset coil | -{R}- | | MB000020 MB000010 | 0 | 0 | | ľ | Branching/<br>convergence<br>point instruction | | | A branching or converging indication can be attached to any of the above relay type instructions. | 0 | 0 | Note) O mark in the "[ ] Instruction" column means that "[ ]" (conditional execution according to the value of the immediately preceding B register) can be added to the instruction. | , | | 71 | |-----|------|------| | (co | ntin | ued) | | (continued | ,<br> | | ГЪ | <b>.</b> | Device | Model | |----------------------------------------|------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------|--------| | Туре | Name | Symbol | Instruction | Description | CP-9200SH | CP-920 | | | AND | ^ | 0 | Integer type designation of any register or constant is possible. | 0 | 0 | | Logical<br>Operation<br>Instructions | OR | <b>V</b> | . 0 | Integer type designation of any register or constant is possible. | 0 | 0 | | | Exclusive OR | Ф | 0 | Integer type designation of any register or constant is possible. | 0 | 0 | | | Integer type entry | F | , 0 | Starts integer type operation. ⊢ MW00280+00100 ⇒ MW00220 | 0 | 0 | | - | Real number type entry | ⊪. | 0 | Starts real number type operation. - MW00280+00100 ⇒ MW00220 | 0 | 0 | | | Store | ' <b>⇒</b> | 0 | Stores operation result in designated register. | 0 | 0 | | | Add | + | 1 | Ordinary numerical addition (with operation error).* ⊢ MW00280+00100 ⇒ MW00220 All registers and constants can be designated | 0 | 0 | | Numerical<br>Operation<br>Instructions | Subtract | | 0 | Ordinary numerical subtraction (with operation error).* ⊢ MW00280-00100 ⇒ MW00220 All registers and constants can be designated. | 0 | 0 | | | Extended add | . ++ | , 0 | Closed numerical addition<br>(without operation error).<br>32768+1=-32768<br>$0 \rightarrow 32767 \rightarrow -32768 \rightarrow 0$ | 0 | 0 | | | Extended subtract | | : O | Closed numerical subtraction (without operation error). -32768-1=32767 0 → -32768 → 32767 → 0 | 0 | 0 | | | Multiply | × | 0 | In the case of integer type and double-<br>length integer type, use × and ÷ in<br>combination. | . 0 | 0 | | | Divide | ÷ | . 0 | , | 0 | 0 | <sup>\*:</sup> On the CP-9200H, an operation error will not occur with double-length operations. On the CP-9200S operation error will occur with double-length operations. | Туре | Name | Symbol | [ ]<br>Instruction | Description | Device<br>CP-9200SH | Model<br>CP-9200H | |-------------------------------------|-------------------------------|--------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------| | | Increment | INC | O, | Adds 1 to the designated register. INC MW00100 If MW00100= 99, the operation result = 100. | 0 | 0 | | umerical<br>peration<br>istructions | Decrement | DEC | 0 | Subtracts 1 from the designated register. DEC MW00100 If MW00100= 99, the operation result = 98. | 0 | 0 | | | Integer type MOD remainder | | 0 | ⊢ MW00100 × 01000 ÷ 00121 MOD ⇒ MW00101 In this example, the remainder of division is taken out. | 0 | 0 | | | Real number<br>type remainder | REM | 0 | ⊩ MF00200 REM 1.5<br>⇒MF00202 In this example, the remainder of division is taken out. | 0 | 0 | | | Time addition TMADD | | 0 | Addition of hrs/min/sec<br>TMADD MW00000, MW00100 | 0 | | | | Time subtraction | TMSUB | 0 | Subtraction of hrs/min/sec<br>TMSUB MW00000, MW00100 | 0 | | | | Time spend SPEND | | 0 | Finds elapsed time between two times. (Difference in yr/mo/day/hr/min/sec in total number of seconds.) SPEND MW00000, MW00100 | 0 | | | | | | | | | • | | |-------|------------------|---------------|----------|---------------|---------------------|------------------|--------------| | Note) | O mark in the "[ | ] Instruction | " column | means that "[ | ]" (conditional exe | cution according | to the value | | | | | | | to the instruction | | | | Tyme | Name | Symbol | [ ] | Description | | Model | |-----------------------------------------|---------------------------|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------|-----------|--------| | Туре | name | Dymbor | Instruction | Description | CP-9200SH | CP-920 | | | Sign inversion | INV | .0 | HMW00100 INV<br>If MW00100= 99, the operation result<br>= -99. | 0 | 0 | | | Complement of 1 | COM | | - MW00100 COM<br> If MW00100=FFFFH, the operation<br> result=0000H | 0 | , | | | Absolute value conversion | ABS | .0 | ⊢MW00100 ABS<br>If MW00100=-99, the operation<br>result=99 | 0 | 0 | | | Binary<br>conversion | BIN | 0 | ⊢ MW00100 BIN If MW00100=1234H (hexadecimal), the operation result = 01234 (decimal). | 0 | 0 | | Numerical<br>Conversion<br>Instructions | BCD conversion | BCD | .0. | ⊢ MW00100 BCD If MW00100= 1234 (decimal), the operation result = 1234H (hexadecimal). | 0 | 0 | | | Parity<br>conversion | PARITY | 0 | Calculates the number of binary expression bits that are ON (=1). HMW00100 PARITY If MW00100= F0F0H, the operation result = 8. | 0 | 0 | | | ASCII<br>conversion 1 | ASCII | 0 | The designated character string is converted to ASCII code and substituted in the register. ASCII MW00200 "ABCDEFG" | 0 | | | | ASCII<br>conversion 2 | BINASC | -0 | Sixteen-bit binary data is converted to four-digit hexadecimal ASCII code. BINASC MW00100 | 0 | | | | ASCII<br>conversion 3 | ASCBIN | 0 | The numerical value indicated by a four-digit hexadecimal ASCII code is converted to 16-bit binary data. ASCBIN MW00100 | 0 | | | (Note) O mark in the "[ ] Instruction " column means that "[ ]" (conditional execution according to the | valu | |---------------------------------------------------------------------------------------------------------|------| | of the immediately preceding B register) can be added to the instruction . | | | Туре | Name | Symbol | [ ]<br>Instruction | Description | Device<br>CP-9200SH | Model<br>CP-9200H | |--------------------------|--------------------------------------|--------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-------------------| | Type | < | < | 0 | ON or OFF is left in the B register as | CF-92008H | CP-9200H | | | ≦ ≤ | | 0 | a result of the comparison instruction. MB000010 | 0 | 0 | | | = | = | 0 | MB000010 ———————————————————————————————— | 0 | 0 | | | # | # | 0 | IFON | 0 | 0 | | omparison<br>ostructions | ≧ | ≧ | 0 | | 0 | 0 | | nstructions | > | > | 0 | | 0 | 0 | | | Range check | RCHK | 0 | Checks whether the value in the A register is in range or not. Lower Upper limit limit limit MW00100 RCHK -1000, 1000 If it is in range B register turns ON, if out of range, OFF. | ower Upper<br>nit limit<br>000, 1000<br>turns ON, if | | | | Bit rotation (L)<br>(left rotation) | ROTL | 0 | Bit-addr Count Width ROTL MB00100A $\rightarrow$ N = 1 W = 20 | 0 | | | | Bit rotation (R)<br>(right rotation) | ROTR | 0 | Bit-addr Count Width ROTR MB00100A $\rightarrow$ N = 1 W = 20 | 0 | | | | Bit transfer | MOVB | 0 | Source Desti. Width MOVB MB00100A →MB00200A W = 20 | 0 | | | | Word transfer | MOVW | 0 | Source Desti. Width MOVW MW00100 → MW00200 W = 20 | 0 | 0 | | ata<br>peration | Exchange | XCHG | 0 | Sourcel Source2 Width XCHG MW00100 → MW00200 W = 20 | 0 | 0 | | nstructions | Table<br>initialization | SETW | 0 | Desti. Data. Width SETW MW00200 → D = 00000 W = 20 | 0 | | | | Byte → BEXTD word development | | | The binary data string stored in the word form register area is developed a byte at a time into words. BEXTD MW00100 to MW00200 B = 10 | 0 | | | | Word →<br>byte compression | BPRESS | | The lower byte only of the word data stored in the word form register area are gathered into a byte string. BPRESS MW00100 to MW00200 B = 10 | 0 | | | _ | 3.7 | Crossbal | [] | Donomination | Device Mode | | |-------------------|-----------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------| | Туре | Name | Symbol | Instruction | Description | CP-9200SH | CP-920 | | | Data search | BSRCH | . 0 | A search is made, within the designated register range, for the position of data which match the stipulated data. BSRCH MW00000 W = 20 D = 100 R = MW00100 | | | | | Sort | SORT | 0 | A sort is performed on registers within<br>the designated register range.<br>SORT MW00000 W = 100 | | | | Data<br>Operation | Bit shift left | SHFTL | 0 | The designated bit strings are shifted to the left. SHFTL MB00100A N = 1 W = 20 | 0 | | | Instructions | Bit shift right | SHFTR | 0 | The designated bit strings are shifted to the right. SHFTR MB00100A N = 1 W = 20 | | | | | Word copy | COPYW | 0 | The designated register range is copied. Even if there is overlap between the copy destination and copy source, the copy will be correctly performed. COPYW MW00100 → MW00200 W = 20 | 0 | | | | Byte swap | BSWAP | 0 | The upper and lower bytes of the designated word variable are swapped. BSWAP MW00100 | | | | (Note) O mark in the "[ ] Instruction " column means that "[ ]" (conditional execution according | to the val | |--------------------------------------------------------------------------------------------------|------------| | of the immediately preceding B register) can be added to the instruction. | | | Туре | Name | Symbol | [ ]<br>Instruction | Description | Device<br>CP-9200SH | Model<br>CP-9200H | |---------------------------------|-------------|--------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------| | | Square root | SQRT | 0 | Taking the square root of a negative number will result in the square root of the absolute value multiplied by -1. -MF00100 SQRT | 0 | 0 | | | Sine | SIN | 0 | Input = in degrees | 0 | 0 | | | Cosine | cos | 0 | Input = in degrees | 0 | 0 | | | Tangent | TAN | 0 | Input = in degrees<br>⊩MF00100 TAN | 0 | 0 | | asic*<br>unction<br>istructions | Arc sine | ASIN | 0 | ⊩MF00100 ASIN | 0 | 0 | | | Arc cosine | ACOS | 0 | ⊩MF00100 ACOS | 0 | 0 | | | Arc tangent | ATAN | 0 | ⊩MF00100 ATAN | 0 | 0 | | | Exponent | EXP | 0 | ⊩MF00100 EXP<br>e <sup>MF00100</sup> | 0 | 0 | | 5<br> | Natural log | LN | 0 | -MF00100 LN log <sub>e</sub> (MF00100) | 0 | 0 | | | Common log | LOG | 0 | ⊩MF00100 LOG<br>log <sub>10</sub> (MF00100) | 0 | 0 | When using a basic function instruction with integer type data, scaling is necessary. For details, refer to Chapter 4 "BASIC INSTRUCTIONS". | Туре | Name | Symbol | [ ]<br>Instruction | Description | Device<br>CP-9200SH | Model<br>CP-9200 | |---------------------|------------------------------|--------|--------------------|-----------------------------|---------------------|------------------| | | Dead zone A | DZA | | ⊢MW00100 DZA 00100 | 0 | 0 | | | Dead zone B | DZB | ; ,.0 | ⊢MW00100 DZB 00100 | 0 | 0 | | | Upper/lower limit | LIMIT | . 0 | -MW00100 LIMIT -00100 00100 | 0 | 0 | | | PI control | PΙ | . 0. | ⊢MW00100 PI MA00 200 | 0 | 0 | | | PD control | PD | 0 | ⊢MW00100 PD MA00200 | 0 | 0 | | | PID control | PID | 0. 1 | ⊢MW00100 PID MA00200 | 0 | . 0 | | | First-order lag | LAG | 0 | -MW00100 LAG MA00200 | 0 | 0 | | DDC<br>Instructions | Phase-lead-lag | LLAG. | . 0 | ⊢MW00100 LLAG MA00200 | 0 | 0 | | | Function<br>generator | FGN | 0 | ⊢MW00100 FGN MA00200 | 0 | 0 | | | Inverse function generator | IFGN | 0 | ⊢ MW00100 IFGN MA00200 | 0 | 0 | | | Linear accelerator<br>unit 1 | LAU | 0 | ⊢MW00100 LAU MA00200 | 0 | 0 | | - | Linear accelerator<br>unit 2 | SLAU | 0 . | - MW00100 SLAU MA00200 | 0 | 0 | | | Pulse width<br>modulation | PWM | 0 | ⊢MW00100 PWM MA00200 | 0 | 0 | | Туре | Name | Symbol | [ ]<br>Instruction | Description | Device<br>CP-9200SH | Model<br>CP-9200H | |------------------------|--------------------------------------------|--------|--------------------|-------------------------------|---------------------|-------------------| | | Block read | TBLBR | 0 | TBLBR TBL1, MA00000, MA00100 | 0 | | | | Block write | TBLBW | 0 | TBLBW TBL1, MA00000, MA00100 | 0 | <u>.</u> | | | Row search<br>(vertical) | TBLSRL | 0 | TBLSRL TBL1, MA00000, MA00100 | 0 | | | | Column search<br>(horizontal) | TBLSRC | 0 | TBLSRC TBL1, MA00000, MA00100 | 0 | | | ible Data | Block transfer<br>between tables | TBLMV | 0 | TBLMV TBL1, TBL2, MA00000 | 0 | | | peration<br>structions | Cue table read<br>(pointer<br>stationary) | QTBLR | 0 | QTBLR TBL1, MA00000, MA00100 | 0 | | | | Cue table read<br>(pointer advances) | QTBLRI | 0 | QTBLRI TBL1, MA00000, MA00100 | 0 | | | | Cue table write<br>(pointer<br>stationary) | QTBLW | 0 | QTBLW TBL1, MA00000, MA00100 | 0 | | | | Cue table write (pointer advances) | QTBLWI | | QTBLWI TBL1, MA00000, MA00100 | 0 | | | · | Clear cue pointer | QTBLCL | 0 | QTBLCL TBL1 | 0 | | | Tymo | | Name Symbol I Description | | | Model | | |---------------------|------------------------------------------------|---------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------|---------| | Туре | Name | 25111001 | Instruction | Doscription | CP-9200SH | CP-9200 | | | SFC execution | SFC | | SFC EXECUTE OUT MA [] [] [] | 0 | 0 | | | NO contact<br>transition<br>judgment | <del></del> | | Designation of transition condition<br>= IB0010A (Cannot modify with a subscript.) | 0 | 0 | | | | | Designation of transition condition MB0012B (Cannot modify with a subscript.) | 0 | 0 | | | | Timer transition judgment | · + | | Transition timer set value + 10.00 (Cannot modify with a subscript.) | 0 | .0 | | SFC<br>Instructions | Action box | ABOX | | ABOX S10: The corresponding program is executed on each scan after transition to step box S10 and until transition to the next step. | 0 | 0 | | | - ; | SBOX | | SBOX S11: The corresponding program is executed just once upon transition to step box S11. | 0 | 0 | | | End action box | AEND | | End of SFC action box. | 0 | 0 | | | Branching/<br>convergence point<br>instruction | - - <del> </del> - - | · | Designation of branching point,<br>convergence point, and convergence<br>connection of SFC. | 0 | 0 | | | SFC step entry | SFCSTEP | 0 | SFCSTEP STEP name → DW00000<br>Store system STEP No. of designated<br>STEP in the A register. | 0 | | | Туре | Name | Symbol | [ ]<br>Instruction | Description | Device<br>CP-9200SH | Model | |-------------------|----------------------------------------|-----------|--------------------|----------------------------------------------------------------------|---------------------|----------| | | Counter | COUNTER | | Up/down counter | Cr-9200SH | CP-9200H | | | First-in first-out | FINFOUT | | First-in first-out function | 0 | 0 | | | Trace function | TRACE*1 | | Write-in of trace data into the data trace memory. | 0 | 0. | | | Data trace read function | DTRC-RD*2 | | Readout of data from data trace<br>memory to user memory | 0 | 0 | | | Failure trace read function | FTRC-RD | | Readout of data from failure trace memory to user memory. | 0 | | | ystem<br>unctions | Inverter trace read function | ITRC-RD | | Readout of data from inverter trace memory to user memory. | 0 | | | | Send message<br>function | MSG-SND*1 | | Send CP-215/CP-216/CP-217/CP-218/<br>CP-2500 message. | 0 | 0 | | | Receive<br>message<br>function | MSG-RCV*1 | | Receive CP-215/CP-216/CP-217/CP-218/CP2500 message. | 0 | 0 | | | Inverter<br>constant write<br>function | ICNS-WR | | Applies to the inverter connected to CP-215 or CP-216. | 0 | | | | Inverter<br>constant read<br>function | ICNS-RD | | Applies to the inverter connected to CP-215 or CP-216. | 0 | | | | CP-213 initial<br>data setting | ISET-213 | | Sets the initial data for the inverter connected to the CP-213 line. | 0 | | The CP-9200SH and the CP-9200H are slightly different. Equivalent to TRACE-RD function on the CP-9200H. # C Differences on Programming between CP-9200H and CP-9200SH For details of each instruction, refer to Chapter 4 "BASIC INSTRUCTIONS". | - | | Model | CP-920 | | CP-9200H | Remarks | |----------------|---------------|-----------------|----------------|----------------|--------------------|----------------------------| | Iten | ın. | | 1MB | 2MB | 01-020011 | | | 1 | Additional | Program control | XCALL | | | | | | | instruction | 1 | , | | | | ) | madrades , | | ROTR, ROTL, | MOVB, | 1 | 1. | | } | i | | SETW, COPYV | | | ,<br>( | | J | <i>i</i> | DDC instruction | RCHK | | None | ı | | J | ι , | | SFCSTEP | | 1 | ı | | 1 | 1 | System function | FTRC-RD | • | , | ſ | | J | f ' | Sequence | -[S] (set coi | | 1 | , | | | · | instruction | -[R]- (reset | coil) | | <u> </u> | | | Modified | DDC instruction | LAU (with both | | LAU and VLAU | | | J | instructions | 1 ! | of LAU and VI | | - 1-707 ATI | ı | | J | 1 | 1 | SLAU (with bo | | SLAU and VSLAU | 4 | | J | 1 | | of SLAU and V | /SLAU) | | 1 | | J | 1 | System function | DTRC-RD | | TRACE-RD | <i>i</i> | | J | 1 | , | TRACE | <u> </u> | TRACE | 1 | | . 1 | 1 | 1 | MSG-SND | | SND | 1 | | J | 1 | | MSG-RCV | <u> </u> | RCV<br>IN OUT | ł | | , ) | 1 | Direct I/O | INS, OUTS | | IN, OUT | <b>1</b> | | | L | instruction | N. | | LPID | · As CP-9200SH has no | | - 1 | Deleted | DDC instruction | 140 | one | MC-WRITE | memory card connection | | , , | instructions | System function | No. | one | MC-WRITE<br>MC-REA | function, the functions | | , J | 1 | , | 140 | ne | MC-CHK | related to memory card | | ( <sup>1</sup> | 1 | | No | one | LMUL | (MC-WRITE, MC-READ, | | ( ) | 1 | t | | one | LDIV | MC-CHK) are deleted. | | ( ) | 1 | | | пе | ; | · CP-9200SH supports | | 1 1 | 1 | • | 1 | | 1 | double-length integer | | 1 - 1 | 1 | | | | | multiplication/division | | ( ) | 1 | + | | | 1 | function (LMUL, LDIV) | | ( ) | 1 | ! | | | · | the instructions × and ÷ | | 4 | Application c | | equivalent to | | equivalent to | | | , | Аррисси | apacity | 12 k steps/CPU | ָּע | 4 k steps/CPU | | | 5 | Data | Register common | 32 k words/CP | | 16128 words | · With CP-9200H, M, I, an | | 1 | memory | to all DWGs (M) | | | (common for CPUs) | registers are common for | | 1 ' | money | Input register | 5 k words/CPU | σ | 128 words | CPU0 and CPU1. | | 1 ' | 1 | (I) | | | (common for CPUs) | With CP-9200SH, they a | | ŧ , | 1 | Output register | 5 k words/CPU | Ū | 128 words | unique each for CPU1 ar | | í ' | 1 | (O) | | | (common for CPUs) | CPU2. | | 1 ' | 1 | System register | 1 k words/CPU | Ū | 256 words/CPU | · With CP-9200H, D regis | | 1 ' | 1 | (S) | · | • | ; | is common to all DWG's. | | ( | - | Register unique | Max. 16 k wor | rds/DWG, | 2 k words/CPU | With CP-9200SH, it is | | [ | 1 : | to each DWG (D) | function | | 1 20110 | unique to each DWG. | | 1 | | DWG constant | Max. 16 k wor | rds/DWG, | Max. 512 words/DWG | | | 1 ' | | register (#) | function | | | registers are cleared at t | | 1 ' | 1 | Common constant | 16 k words/CP | ? <del>U</del> | None | power turned ON. With | | 1 | 1 | register (C) | | | , | 9200SH, they are not | | 1 | - | , | | | , | cleared at the power tur | | 1 | | ; | | | , | ON. | | 1 | 1 | | | | , | · The number and conten | | | | | | | · | S register are different | | | 1 | · | | | | between CP-9200H and | | 1 | • | | | | | 9200SH. | | = | | | 1 | | <del> </del> | | |-----------|-------------------|-------------------------------------|----------------------------------------------|--------------|--------------------------|------------------------------| | | Model<br>tem | | CP-92 | <del></del> | CP-9200H | Remarks | | tei | | | 1MB | 2MB | | | | 3 | Trace | Data trace | Max. 128 k w | ords | 192 k words (common | · With CP-9200SH, when the | | | memory | | (32 k words | | for CPUs) (32 k words | trace memory is not used, it | | i | | | × 4 groups)/C | | × 3 groups) | can be used for user | | | | Failure trace | Max. 4 k word | ls | None | program area. | | | | | $(64 \text{ items} \times 4)$ | 50)/CPU | | | | 7 | Table program | | Pos | sible | Not possible | | | } | Drawing/ | Starting (A) | 64 drawings | | 32 drawings | | | | function capacity | High-speed scan<br>(H) | 100 drawings | | 32 drawings | | | | | Low-speed scan<br>(L) | 100 drawings | | 32 drawings | | | | | Interruption (I) | 64 drawings | | 32 drawings | | | | | User function | 100 functions | | 32 drawings | | | | | Number of<br>steps/DWG,<br>function | 500 steps | | 300 steps | | | | | Drawing<br>hierarchy | 3 lays | | 2 lays | | | • | Shared memo | ory between CPUs | Possible when | M register | M register | | | | | | is set on the s | creen | _ | | | 0 | Program secr | et protection | Possible in units of drawing | | Possible in units of CPU | | | | Calendar fun | | Provided | | Not provided | | | 2 | MEMBUS I/E | י | M and I regist | ter | S, I, O, M, and D | | | | | | (possible by C | PU) | register | | | 3 | Servo | Area | Fixed I/O regi | ster | Common with | · For CP-9200SH, the | | | parameter | | (128 words/axis) | | M register | number and arrangement o | | | | | (IWC000 to IV | | (50 words/axis) | servo parameters and their | | | | | OWC000 to O | WFFFF) | (MW00000 | functions are partly | | | | | | | to MW00399) | different from those of | | | | Servo fixed | Settings on th | | Setting of M register | CP-9200H. | | | | parameter | (separated fro | | (included in servo | | | | | | servo paramet | | parameter) | | | 4 | Temperature | input | The system fu | | Temperature input | | | _ | | | MSG-SND is 1 | | display | | | 5 | Compatibility | of user program | Provided with conversion too | | <del>-</del> | | | | | , | | | | | | | | | the user program for<br>CP-9200H to that for | | | | | Ì | | | CP-9200H to 1 | nat ior | | | | $\exists$ | Batch loading | | At batch loadi | na program | At batch loading, | | | 1 | Parcii ioauilig | <b>i</b> | memory and d | | program memory and | | | | | | (S, I, O, M, an | | data memory (S and | | | | | | for each CPU | | D register) for each | | | | | | TOI CAULI OF U | are cleareu. | CPU are cleared, but | | | ŀ | | | I | | ior o are created, but I | | | | | | | | M register is not | | # MACHINE CONTROLLER CP-9200SH PROGRAMMING MANUAL New Pier Takeshiba South Tower, 1-16-1, Kaigan, Minatoku, Tokyo 105-6891 Japan Phone 81-3-5402-4511 Fax 81-3-5402-4580 #### YASKAWA ELECTRIC AMERICA, INC 2121 Norman Drive South, Waukegan, IL 60085, U.S.A. Phone 1-847-887-7000 Fax 1-847-887-7370 #### MOTOMAN INC. HEADQUARTERS 805 Liberty Lane West Carrollton, OH 45449, U.S.A. Phone 1-937-847-6200 Fax 1-937-847-6277 #### YASKAWA ELÉTRICO DO BRASIL COMÉRCIO LTDA. Avenida Fagundes Filho, 620 Bairro Saude-Sao Pāulo-SP, Brazil CEP: 04304-000 Phone 55-11-5071-2552 Fax 55-11-5581-8795 YASKAWA ELECTRIC EUROPE GmbH Am Kronberger Hang 2, 65824 Schwalbach, Germany Phone 49-6196-569-300 Fax 49-6196-888-301 #### Motoman Robotics Europe AB Box 504 S38525 Torsas, Sweden Phone 46-486-48800 Fax 46-486-41410 #### Motoman Robotec GmbH Kammerfeldstraße 1, 85391 Allershausen, Germany Phone 49-8166-900 Fax 49-8166-9039 #### VASKAWA FLECTRIC UK LTD. 1 Hunt Hill Orchardton Woods Cumbernauld, G68 9LF, United Kingdom Phone 44-1236-735000 Fax 44-1236-458182 #### YASKAWA ELECTRIC KOREA CORPORATION Kfpa Bldg #1201, 35-4 Youido-dong, Yeongdungpo-Ku, Seoul 150-010, Korea Phone 82-2-784-7844 Fax 82-2-784-8495 #### YASKAWA ELECTRIC (SINGAPORE) PTE. LTD. 151 Lorong Chuan, #04-01, New Tech Park Singapore 556741, Singapore Phone 65-282-3003 Fax 65-289-3003 YASKAWA ELECTRIC (SHANGHAI) CO., LTD. 4F No.18 Aona Road, Wargacqiao Free Trade Zone, Pudong New Area, Shanghai 200131, China Phone 86-21-5866-3470 Fax 86-21-5866-3869 #### YATEC ENGINEERING CORPORATION Shen Hsiang Tang Sung Chiang Building 10F 146 Sung Chiang Road, Taipei, Taiwan Phone 886-2-2563-0010 Fax 886-2-2567-4677 #### YASKAWA ELECTRIC (HK) COMPANY LIMITED Rm. 2909-10, Hong Kong Plaza, 186-191 Connaught Road West, Hong Kong Phone 852-2803-2385 Fax 852-2547-5773 #### **BEIJING OFFICE** Room No. 301 Office Building of Beijing International Club, 21 Jianguomenwai Avenue, Beijing 100020, China Phone 86-10-6532-1850 Fax 86-10-6532-1851 ### TAIPEI OFFICE Shen Hsiang Tang Sung Chiang Building 10F 146 Sung Chiang Road, Taipei, Taiwan Phone 886-2-2563-0010 Fax 886-2-2567-4677 #### SHANGHAI YASKAWA-TONGJI M & E CO., LTD. 27 Hui He Road Shanghai China 200437 Phone 86-21-6531-4242 Fax 86-21-6553-6060 #### BEIJING YASKAWA BEIKE AUTOMATION ENGINEERING CO., LTD. 30 Xue Yuan Road, Haidian, Beijing P.R. China Post Code: 100063 Phone 86-10-6233-2782 Fax 86-10-6232-1536 #### SHOUGANG MOTOMAN ROBOT CO., LTD. 7, Yongchang-North Street, Beijing Economic Technological Investment & Development Area, Beijing 100076, P.R. China Phone 86-10-6788-0551 Fax 86-10-6788-2878 YASKAWA ELECTRIC CORPORATION