Department of Applied Analysis and Computer Science Research Report CSTR 1001 March, 1970 THE DIALATOR SYSTEM FAUST USER'S GUIDE by Doron J.Cohen, Paul M.Fawcett Eric G.Manning & Larry Smith # Faculty of Mathematics University of Waterloo Waterloo, Ontario Canada Department of Applied Analysis and Computer Science Research Report CSTR 1001 March, 1970 THE DIALATOR SYSTEM FAUST USER'S GUIDE by Doron J.Cohen, Paul M.Fawcett Eric G.Manning & Larry Smith We wish to thank the Defence Research Board of Canada, the Northern Electric Research & Development Laboratories, Ottawa, and the Faculty of Mathematics of the University of Waterloc for financial, technical and moral support which made this system of programs possible. # FAUST USER'S GUIDE This is a user's guide to program FAUST of the DIALATOR system. (A system programmer's guide explaining internal workings of the program appears later.) This guide is laid out as follows: - SECTION 1) explains how faults of a circuit are defined. - SECTION 2) explains how failed circuit behaviour is displayed. - SECTION 3) explains how faults of a circuit are diagnosed. - SECTION 4) explains the FAUST control card. - SECTION 5) explains the FAUST instruction keywords and their usage. - SECTION 6) explains how selected faults are defined. - SECTION 7) explains the control cards needed to make a FAUST run on a system 360 computer under OS/360. - SECTION 8) contains a few examples of FAUST runs. - SECTION 9) lists the FAUST error messages. # SECTION 1) Definition of circuit faults Let us take a second look at CIRCUIT1, used in the TRAIZE user's manual. Suppose Al is faulty. The reason could be any of - (a) the output of Al is stuck at one, - (b) the output of Al is stuck at zero, - (c) the wire from X1 to A1 has opened up, - (d) the wire from X2 to Al has opened up. Just as in TRAIZE, where we described complete circuits by giving lead names, their functions, and their input references, we can now describe all single faults of a circuit by giving all single faults possible at the particular lead, plus all single faults possible between this lead and its input references. The former type of fault is called a basic fault; the latter is called an input fault. For CIRCUIT1 a list of all single faults would be: | 1 | | fault free circuit. | |----|------------|---------------------------| | 2 | A1 | output stuck at zero. | | 3 | A 1. | output stuck at one. | | 4 | A1 | open input diode from X1. | | 5 | Al | open input diode from X2. | | 6 | N1 | output stuck at zero. | | 7 | N1 | output stuck at one. | | 8 | N1 | open input diode from Xl. | | 9 | N1 | open input diode from X2. | | 10 | A2 | output stuck at zero. | | 11 | A2 | output stuck at one. | | 12 | A2 | open input diode from X1. | | 13 | A2 | open input diode from Al. | | 14 | <b>D</b> 1 | output stuck at zero. | | 15 | 91 | output stuck at one. | | 16 | 91 | open input diode from Al. | | 17 | 91 | open input diode from N1. | One other basic fault, not applicable here, can occur in circuits with feedback loops. (i.e. the circuit may have an open feedback diode). Notice that X1 and X2 have no associated faults. The reason for this is that the values at X1 and X2 are independent of CIRCUIT1. For simplicity, we will discuss at this time circuits with single faults only. The handling of multiple faults is discussed in Section 6 of this manual. # Section 2) Failed circuit displays In distinguishing failed circuits from each other and from the good circuit, it is important to see the outputs of the circuit under each fault condition. For CIRCUIT1 we could accomplish this as follows, (suppose the inputs are X1 = 0 and X2 = 0): ## DIAGRAM 2 Along the top of the table are listed the numbers of the particular faults. The first column is reserved for no faults. For each particular fault we write down the output, below the fault number, at A2 and \$1. You should check some of these values to verify that they are valid. A more complete picture, of the action in CIRCUIT1 under the 17 different conditions, can be obtained by listing all the leads rather than just the outputs. Let the inputs be X1 = 1 and X2 = 0, then the table display would be as follows: | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | |-----|---|---|----|---|---|---|---|-----|---|----|----|----|----|----|----|-----|----| | X1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | -1 | 1 | 1 | . 1 | 1 | | X 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | . 0 | 0 | | A1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | O | 0 | | N1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | A2 | 0 | 0 | 1. | 0 | 0 | 0 | 0 | : 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Ø1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | i | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | #### DIAGRAM 3 Diagram 3 gives us the value of every circuit signal under every possible single fault. Thus it tells us everything that we could possibly ask about the behaviour of CIRCUIT1 (under single faults). The above diagrams ( 2 & 3) are known as \$LVBS tables, meaning lead value bit string tables. Now that we have seen a way of displaying single faults of a circuit, we explain how you get FAUST to create such displays. We need instructions to manipulate the primary inputs of the circuit. In diagram 3 we wanted X1 to be one. In FAUST, SET X1 does this. To set X2 to zero FAUST uses RESET X2. Another valuable instruction is FLIP. This command changes the values on all specified leads. For example, if X1 and X2 are as in diagram 3 then FLIP X1, X2 changes X1 to zero and X2 to one. We need an instruction to activate the simulation routine; RUN does this. We also need instructions to show the \$LVBS. Since it is important that we see the \$LVBS after each run perhaps the instruction should be automatic. Even though an automatic showing after each run is good, we may wish to vary the amount of the \$LVBS to be shown. To do this FAUST provides the instructions TRACE and UNTRACE. Suppose we are presently following the action of leads A2 and \$\textstyle{0}1\$. If we say TRACE X1, X2, A1, N1, then the next display would be similar to diagram 3. The TRACE instruction, then, adds the specified leads to the list to be shown. If we followed the above statement with UNTRACE X1, X2, A1, N1 we would be back to a display similar to diagram 2. The UNTRACE instruction removes the specified leads from the list to be shown. There is need also, for an instruction to display the \$LVBS at times other than after a run. SHOW accomplishes this. ## Section 3) Diagnosis of faults We can now use the \$LVBS table displays of SECTION 2, to help distinguish the faults of CIRCUIT1. When the inputs X1 and X2 of CIRCUIT1 are both zero, the faults can be divided into 3 groups. The first group of faults 2,3,4,5,7,8,9,10,12,13,15 and 16 are associated with outputs A2 = 0 and $\emptyset 1 = 1$ ; the second group of faults 6, 14 and 17 with outputs A2 = 0 and $\emptyset 1 = 0$ , the third group of faults 10 with outputs A2 = 1 and $\emptyset 1 = 1$ . There is no group associated with outputs A2 = 1, $\emptyset 1 = 0$ . The <sup>\*</sup> except for large circuits, where the amount of output would be huge. third group is interesting since it contains only one fault. In effect, we have isolated fault 11; that is if X1 = 0 and X2 = 0 causes A2 = 1 and $\emptyset1 = 1$ we know the circuit has fault 10. The application of input strings, rather than single inputs, would increase diagnosing ability. Suppose we give commands: RESET X1, X2; TRACE A2, Ø1; RUN ; We will produce diagram 2 of Section 2). In the paragraph above we divided the faults, for this case, into the following groups: | *******<br>*GROUP 1*<br>*OUTPUT *<br>*OUTPUT *<br>* A2=0 *<br>* Ø1=0 *<br>******** | *******<br>*GROUP 2*<br>*OUTPUT *<br>* A2=0 *<br>* Ø1=1 *<br>******** | ******** *GROUP 3* *OUTPUT * * A2=1 * * 91=1 * ************ | |------------------------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------------------------| | 111: | 1 1 1 | 111 | | | | | | 111 | | | | Associated 6 | 2,3 | 11 | | Faults 14 | 4,5 | | | 17 | 7,8 | | | | 9,10 | | | | 12,13 | | | • | 15,16 | | | | 4.0 | | DIAGRAM 4 Suppose now we dictate: SET X1; TRACE X1, X2, A1, N1; RUN; We will get diagram 3 of SECTION 2. Look at DIAGRAM 3, keeping in mind the above groups. The outputs of the elements of group 1 are all (0,0), therefore no further distinction is accomplished. In group 2, fault 3 has output (1,1) which is different from the remainder of outputs for that group. A picture of our efforts is given by the following tree diagram. Using the above diagram we can now isolate fault 3. That is, if we apply inputs followed by (1,0); and if we observe the output patterns $$(A2,\emptyset1) = (0,1)$$ followed by (1,1) then fault 3 and only fault 3 must be present. Now we will look at some simple instructions for manipulating the diagnostic tree. Each time we wish to observe the output of a test we will say SORT. This instruction will sort the members of the present groups according to output and add a new level to the diagnostic tree. Now that a sort is not always done after each run. Thus we can simulate a test setup wherein we apply several test inputs between obversations of the circuit's outputs. To print the tree we use the instruction TREE. If we wish to save the tree and the \$LVBS in the file, we say, SAVE followed by the name it is to be saved under, and, to retrieve it from the file we use, BACKUP followed by the proper name. We can use the back up feature to try out tests and forget them if they do not produce good results. Here is a sample set of statements which will make a FAUST run for CIRCUIT1. %SAMP1: SIMULATE CIRCUIT=CIRCUIT1, DISP=NO, FAULTS=ALL; SORT; ACTIVATE ALL; TRACE ALL; FLIP X1,X2; RUN FAULTS=NO; SHOW ALL; RESET X1,X2; RUN; SORT; SET X1; RUN; SORT; RUN; SAVE RECNAME=TEST; TREE; END: DIAGRAM 6 The run would go as follows: First, the FAUST control card is read. The following output SORT; results: CPU TIME= 260,400.000, TOTAL CPU TIME= 0.000 MILLISECONDS. %SAMP1: SIMULATE CIRCUIT=CIRCUIT1,DISP=NO,FAULTS=ALL; 04540000SOURGE. CPU TIME= 139.991, TOTAL CPU TIME= 139.991 MILLISECONDS. ==LCID==CIRCUIT NAME: CIRCUIT1, OPTIONS: 0000 FAULTS OPTION: ALL ==FDIR==OLD DIRECTORY FETCHED. ===== CIRCUIT1 CIRCUIT RECORDS ===== CIRCUIT NODE NO.79 \$CIDS NODE NO.71 86 BYTES, STARTING REGION NO.12 WORD NO.525 \$LDSC NODE NO.78 168 BYTES, STARTING REGION NO.12 WORD NO.547 \$FMCS NODE NO.84 132 BYTES, STARTING REGION NO.12 WORD NO.450 \$SYMTA NODE NO.81 56 BYTES, STARTING REGION NO.12 WORD NO.492 \$REFS NODE NO.82 75 BYTES, STARTING REGION NO. 0 WORD NO. 20 \$TERM NOT FOUND. ==== STRUCTURES LOCATIONS ===== STRUCTURE: \$CIDS OF NODE NO.71, FETCHED 86 BYTES, STARTING REGION NO.12 WORD NO.525 STRUCTURE: \$LDSC OF NODE NO.78, FETCHED 168 BYTES, STARTING REGION NO.12 WORD NO.547 STRUCTURE: \$FMCS OF NODE NO.84, FETCHED 132 BYTES, STARTING REGION NO.12 WORD NO.450 STRUCTURE: \$SYMTA OF NODE NO.81, FETCHED 124 BYTES, STARTING REGION NO.12 WORD NO.492 STRUCTURE: \$REFS OF NODE NO.82, FETCHED 56 BYTES, STARTING REGION NO.12 WORD NO.589 STRUCTURE: \$SUCS OF NODE NO.83, FETCHED 75 BYTES, STARTING REGION NO. 0 WORD NO. 20 EV='01111110'B R= 126 ==FETCH==\$COPT STRUCTURE: \$COPT OF NODE NO.60, FETCHED 2610BYTES, STARTING REGION NO. 0 WORD NO.114 == FETCH== FAUST. \$OPTAB STRUCTURE: \$0PTAB OF NODE NO.35, FETCHED 324 BYTES, STARTING REGION NO.10 WORD NO.408 CPU TIME= 1,361.579, TOTAL CPU TIME= 1,501.570 MILLISECONDS. After each FAUST statement the amount of C.P.U. time required is tabulated, plus, the total amount of CPU time used since the beginning of execution is given. The first line of output indicates that the CPU timer has been initialized properly. The source statements of the FAUST deck listed above appear in the output with an eight digit number which is immediately followed by 'SOURCE.'. The FAUST control card causes a variable number of actions to take place depending on the parameters used. In this example the name 'CIRCUIT1' along with the names of its associated structures are fetched from the file directory into core. Next, for those names which have associated storage, their structures are fetched from the record file into core. Notice that with these structure names a number of bytes, a starting region, and a starting word are given, also for all structure names a node number is given. The usefulness of this information and an explanation of how the file system works is found in the FILE SYSTEM USER'S GUIDE. Next the circuit operators table, \$COPT, along with the FAUST operator's table, FAUST.\$OPTAB, are fetched from the file into core. Similar information about them is given as was given for the other structures. At this point all the necessary tables for CIRCUIT1 and for FAUST instructions are in core. The following output is a result of the FAUST instructions. ===== FAUST STATEMENTS ===== = DIAGNOSTIC TREE INITIALIZED. CPU TIME= 14.165, TOTAL CPU TIME= 1,515.735 MILLISECONDS. 0> 2.499, TOTAL CPU TIME= CPU TIME= 1,518.234 MILLISECONDS. SORT; 04550000SOURCE: CPU TIME= 113.326, TOTAL CPU TIME= 1,631.560 MILLISECONDS. ACTIVATE ALL; 04560000SOURCE. 2> 101.660, TOTAL CPU TIME= 1,733.220 MILLISECONDS. CPU TIME= TRACE ALL: 04570000SOURCE. CPU TIME= 68.328, TOTAL CPU TIME= 1,801.548 MILLISECONDS. Since the instruction INITREE, was not used the diagnostic tree was initialized automatically. The instruction SORT; creates the a first level of the tree. A glance at the tree below will show that this sort gives 0% diagnostic resolution. The instruction ACTIVATE ALL; sets activity bits of all leads on. Unless the user is very familiar with the behaviour of circuit models; he should use this instruction always. The instruction TRACE ALL; indicates that after each run we wish to see the \$LVBS for all leads of the circuit. The next two instructions give the following input, RUN FAULTS=NO; SHOW ALL: 04580000SOURCE. PROPOCATION: 1, 2, 3, 4, 5, 6, ==DIMUY== DONE. ``` @ 012345678901234567 NO. NAME -4 -3 -2 - ]. 0 1 X L 2 X2 0 000000000000000000 0 000000000000000000 3 A1 0 11111111111111111111 4 N1 5 A2 6 Ø1 4> 144.990, TOTAL CPU TIME= 1,946.538 MILLISECONDS. CPU TIME= @ 012345678901234567 NO. NAME -4 000000000000000000 -3 000000000000000000 -2 -1. 00000000000000000 1111111111111111111111 0 0 00000000000000000 1 X1 0 000000000000000000 2 X2 0 00000000000000000 3 A1 4 N1 0 1111111111111111111 0 000000000000000000 5 A2 0 1111111111111111111 6 Ø1 5> 78.328, TOTAL CPU TIME= 2,024.866 MILLISECONDS. CPU TIME= ``` The instruction RUN FAULTS=NO; causes the \$LVBS table to be printed. The 'PROPOGATION' statement indicates which leads have undergone any changes since the last run, since this is the first run all six lead numbers are printed. The \$LVBS is similar to the one described in SECTION 2) except for the following additions: There is one column for the activity bit vector headed by @. There is an extra column in the table headed by the number zero. This is a buffer column and can be ignored by the user. There are five rows above the lead names. These rows are used for workspace and they are printed only to aid debugging. They should be ignored by the user also. The next instruction SHOW ALL; displays the \$LVBS. Since nothing has been done since the last showing it is the same. Therefore this statement is redundant. The next three instructions give the following output. RESET X1,X2; RUN; SORT; 04590000SOURCE. 6> CPU TIME= 70.828, TOTAL CPU TIME= 2,095.694 MILLISECONDS. PROPOGATION: 3, 4, 5, 6, ==DIMUY== DONE. ``` @ 012345678901234567 NO. NAME 00000000000000000 -4 -3 00000000000000000 00000000000000000 -2 000000000000000000 -- 1 0 111111011111110111 0 00000000000000000 1 X1 0 00000000000000000 2 X2 3 A1 0 000100000000000000 4 N1 0 111111011111111111 5 A2 0 00000000001000000 0 1111110.1111110111 6 Ø1 CPU TIME= 79.994, TOTAL CPU TIME= 2,175.688 MILLISECONDS. 8> 49.996, TOTAL CPU TIME= 2,225.684 MILLISECONDS. CPU TIME= ``` The FAUST language allows more than one statement per line. In order that the CPU time can be given for each statement the number of a statement is printed immediately before the CPU time for that statement. The \$LVBS here is the same as was described earlier for inputs (X1,X2) = (0,0). The sort statement adds another level to the tree. See LEVEL 1 of the tree below. 04600000SOURCE The next card causes this output. SET X1; RUN; SORT; 9> 88.327, TOTAL CPU TIME= CPU TIME= 2,314.011 MILLISECONDS. PROPOGATION: 3, 5, ==DIMUY== DONE. NO. @ 012345678901234567 NAME -4 00000000000000000 -3 -2 -1 0 111111011011110111 1 X1 0 1111111111111111111 0 00000000000000000 2 X2 3 A1 0 000101000000000000 4 N1 0 11111110110111111111 0 000101000001010000 5 A2 0 111111011011110111 6 Ø1 10> CPU TIME= 79.161, TOTAL CPU TIME= 2,393.172 MILLISECONDS. 11> 56.663, TOTAL CPU TIME= CPU TIME= 2,449.835 MILLISECONDS. These three instructions perform the same actions as the previous three. Now, however, lead X1 is set to one. For results see LEVEL 2 of the tree below. # The output for the next statement is: SAVE RECNAME=TEST; 04610000SOURCE. ==STORE==CIRCUIT1.TEST.\$LVBS STRUCTURE: \$LVBS OF NODE NO.87, STORED 74 BYTES, STARTING REGION NO.12 WORD NO.612 ==STORE==CIRCUIT1.TEST.\$DIATR STRUCTURE: \$DIATR OF NODE NO.88, STORED 347 BYTES, STARTING REGION NO.12 WORD NO.699 12> 176.655, TOTAL CPU TIME= CPU TIME= 2,626.490 MILLISECONDS. At this point we wish to save the results under the recname TEST. Both the \$LVBS table and the diagnostic tree are saved under the names TEST.\$LVBS and TEST.\$DIATR. File information is given about these structures as well. If during some future run we wish to start testing again at this point we say. # BACKUP RECNAME=TEST; that is, of course, if we are still dealing with CIRCUITI. Instructions 13, 14 and 15 given output similar to instructions 9, 10 and 11. The values of X1 and X2 are changed. FLIP X1,X2; RUN; SORT: 04620000SOURCE. CPU TIME= 94.160, TOTAL CPU TIME= PROPOGATION: 4, 3, 2,720.650 MILLISECONDS. 5, ==DIMUY== DONE. 13> @ 012345678901234557 NO. NAME -4 00000000000000000 -3 00000000000000000 -2 000000000000000000 -1 00000000000000000 0 1111110101111110111 1 X1 0 0000000000000000 2 X2 0 111111111111111111 3 A1 0 000110000000000000 4 N1 0 11111110101111111111 5 A2 0 00000000001000000 6 Ø1 0 1111110101111110111 | 14> | | | |-----------|-------------------------|-------------------------| | CPU TIME= | 79.994, TOTAL CPU TIME= | 2,800.644 MILLISECONDS. | | 15> | | | | CPU TIME= | 51.663, TOTAL CPU TIME= | 2,852.307 MILLISECONDS. | 1.6> The next instruction TREE; will print out the entire tree which should have 4 levels (4 sort statements). The output is as follows, ``` 04630000SOURCE. TREE: CPU TIME= 82.494, TOTAL CPU TIME= 2,934.801 MILLISECONDS. ==TREE== FL= 0 HS= 0 LL= FP= HP= LP= 18 19; 1 NODES, 1 SUBSETS. LEVEL# 0 LEVEL# 1 3 NODES, 1 SUBSETS. LEVEL# 2 4 NODES, 2 SUBSETS. LEVEL# 4 NODES. 3 SUBSETS. ===== THE DIAGNOSTIC TREE ===== RESOLUTIONS: **** *001* LEVEL# 0 * () * 0.0%DIA. **** 0.0%DTC. **** **** LEVEL# *001*---- --*002*--*003* 66.6%DIA. **** **** **** 17.6%DTC. **** **** **** **** *001*----*002*--*003* *004* LEVEL# 2 * 2 *---* 3 *--* 0 * 33.3%DIA. * 0 * **** ***** **** **** 28.5%DTC. **** *001*--*002* *003* *004* LEVEL# 3 * 2 *--* () * * () * 11.1%DIA. * 2 * **** **** **** 10.0%DTC. # 9# # 1.1# # 6# # 3# MACHINE# 1# # 8# 2# # 5# # 14# OVER ALL 4# # 13# 7# 31.2%DIA. # 50.0%DTC. # 10# # 12# # 15# # 16# # 17# ``` CPU TIME= 236.651, TOTAL CPU TIME= 3,171.452 MILLISECONDS. END; 04640000SOURCE. The first part of the output lists the parameters given by the user, by default in this example. This is followed by a list of levels, their number of nodes, and the number of subsets at each level. To the left of the tree an indication is given as to the diagnostic resolution (DIA) and the detection resolution (DTC) (i.e. how many faulty machines have been distinguished from the good machine). In this example we have completely isolated 3 machines out of 17. On each level of the tree the nodes are numbered from left to right. The top number in each node indicates the position of the node on its level. We can identify any node of the tree by giving this node number and the proper level number. The lower number in each node indicates the output pattern of the faulty circuits associated with that node. This decimal number when changed to its binary equivalent indicates the output of OUTPUT#1, OUTPUT#2,...- in that order. There is no confusion as to which output is number one etc. The ordering is assigned previously by TRAIZE (see SECTION 8), example 1). Since CIRCUIT1 has only 2 outputs the lower number can be one of 0.1.7% or 3. The failed circuits associated with a node are all those included in the subtree formed with the particular node as root. The next output is a listing of the file directory tree and will be discussed in the file system's USER'S GUIDE. ``` - DIALATOR ... KEY-WORD INDEX ***** DIALATOR KEY-WORDS TABLE ***** 7 8 9 $CIOS 10 $COPT 11 $CTRES 12 $DIATR 13 $FMCS 14 $LOSC 15 $LVBS 16 $UPTAB 17 $REFS 18 $FMC 19 $SUCS 20 $SYMIA 21 $TEUS 22 $TERM **** THE DIRECTORY TREE **** *ND. REC_NAME SIZ* * STB SRG TYP SIS DAU* ``` \*\*\*\* DIRECTORY LISTING \*\*\*\* 98 AVAIL PUINTER. 40 REGIONS USED . 24 STRUCTURES RECOGNIZED. 141 NODES IN THE DIRECTORY. 141 DESIRED NO. OF NODES. 22 KEY-WORDS RECOGNIZED. 700312 DATE OF LAST CHANGE. ``` * 9 ALBLOCK * -1 -1 0 28 * 8 $CIDS 86* * 767 0 2 -1 10* * 27 $CIDS 86* * 803 10 2 -1 29* ``` ``` * 45 $CIDS * 57 0 2 -1 * 46.$SUC$ 162* * 909 11 7 47 -1* # 47 SSYNTA # 973 11 5 -1 * 7 $CIDS * 950 11 2 -1 86* 48* * 49 $FMCS 740* *1288 11 4 50 -1* ************ * 50 $REFS 197* *1473 11 6 52 -1* ******* * 52 $SUCS 342* *1500 11 7 53 -1* ******** * 53 $5YMTA 58C* *1586 11 5 -1 -1* * 21 EXAMPLE 0* * -1 -1 0 60 25* * 10 $1.05C 410* * 511 10 3 24 -1* * 24 $FMCS 308* * 614 10 4 54 -1* * 64 *10 4 54 -1* * 62 SCTRES 0* * -1 -1 10 -1 61* * 3 $LVBS 197* * 749 10 13 63 -1* ``` ``` * 63 $DIATR 554* *1731 11 11 -1 -1* * 64 $CIDS 86* * 708 10 2 -1 66* * 66 $LDSC 608* * 245 12 3 67 -1* * 67 $SYMTA * 106 10 5 68 68 SREFS 0 0 6 69 * 69 $5UC$ 210+ * 397 12 7 -1 -1* * 71 %CIDS * 525 12 2 96 * 78 $LDSC * 547 12 3 * 81 $5YMTA * 492 12 5 82 96 TEST * 86 $LVB$ 74* * 699 12 13 97 -1* * 97 SDIATR 347* * 966 12 11 -1 -1* * 90 $CIDS 86* * 70 12 2 -1 92* ********** # 92 $LDSC 718# # 786 12 3 93 -1# # 93 $SYMTA # 92 12 5 94 + 94 $REFS + 198 12 6 95 * 95 $SUCS 270* * 631 12 7 -1 -1* ``` 98 NJUES IN THE DIR TREE 29 NODES IN THE FREE LIST. 89056 BYTES USED IN RECUROS. 198944 BYTES FREE. 44 UNUSED NUDES. ==SDIR==DIRECTORY REWRITTEN 700312 004129100 CPU TIME= 1,794.885, TUTAL CPU TIME= 4,643.027 MILLISECONDS. # SECTION 4) FAUST control card The basic rules for writing the FAUST control card are the same as for the TRAIZE control card. (See TRAIZE user's guide.) Referring to diagram 6 of SECTION 3): a '%' sign must appear in column one, followed by a runname, followed by a keyword (SIMULATE instead of TRAIZE), followed by a circuit name which must be known, followed by parameters. The DISP parameter explains disposition of the run results,\* DISP can have four values. If we wish to save these results unconditionally, we put DISP = YES. If we do not wish to save the run results in the file we put DISP = NO. If we wish to create new entries in the file directory for the run results we put DISP = NEW. If we wish to overwrite already existing records of run results with the same name we put DISP = OLD. The FAULTS parameter explains the fault option desired; FAULTS can have four values. If we wish to simulate all single faults of a circuit we put FAULTS = ALL. If we wish to simulate the circuit with no faults, we put FAULTS = NO. If we wish to simulate the circuit with selected faults which do not exist in the DIALATOR file for that circuit (i.e. we have not made a previous run with these same selected faults of the circuit and stored them), we put FAULTS = GET. Note, when this value of the parameter is specified statements defining the selected faults must follow the control card. \* If we wish to simulate the circuit with selected faults previously run and stored in the DIALATOR file, we put FAULTS = name, where name is the runname of the previous <sup>\*</sup> These statements are described in SECTION 6) <sup>\* &#</sup>x27;ron results', meaning the diagnostic tree and the \$LVBS. run referred to above. For instance the control card: % SAMP17: SIMULATE CIRCUIT=CIRCUIT1,FAULTS=SAMP2; refers to a previous runname SAMP2, under which some selected faults, now desired, are stored in the DIALATOR file. The list parameter explains that we do or do not want the description of the specified circuit printed. If we wish to have the circuit description printed, we put LIST = YES, if we do not, we put LIST = NO. The default values of DISP, FAULTS and LIST are NO. ## SECTION 5) FAUST Statements All FAUST statements must begin with an instruction word. Some instruction words have qualifiers following. All statements must end with a semicolon. Diagramatically statements are of the form: instruction word [qualifiers]; The following is a list of valid instruction words for FAUST statements, presently. == FAUST OPTAB == ACTIVATE BACKUP DEACTIVATE END FLIP IN1 FAULT INITREE RESET RUN SAVE SET SHOW SORT TRACE TREE UNTRACE DIAGRAM 7 # Rules for FAUST qualifiers - 1) A <u>lead name</u> can be any valid name (maximum of 6 characters) referring to a known lead. - 2) A <u>lead number</u> can be any valid lead number and must be preceded immediately by a '#' symbol. - 3) A <u>lead list</u> can be the word - a) ALL meaning all leads. - or b) INPUTS meaning all primary inputs. - or c) OUTPUTS meaning all primary outputs. - or d) FBKS meaning all feedbacks. - or e) a lead name - or f) a lead number - or g) any combination of b), c), d), e), f), separated by commas. - 4) A <u>faulty machine number</u> can be any number referring to a valid fault number. - 5) A list of faulty machines can be - a) a faulty machine number - or b) a faulty machine number followed by 'TO' followed by a larger faulty machine number - or c) any combination of (a) and (b) - NOTE: Any list of faulty machines must be enclosed in round brackets e.g. (1, 3 TO 6, 12, 14) is valid - NOTE: Any words not separated by a delimiter must have at least one blank between them. # Description of FAUST statements with the instruction word ## 1) SET This instruction sets the value of specified leads to one. Format of this statement type is as follows: - a) SET followed by - b) a list of faulty machines followed by $^{\star}$ - c) a list of leads followed by - d) the keyword ACTIVE or UNACTIVE followed by - e) ; The list of faulty machine options would be of value if we had wished to set the specified leads only for particular faults. If this phrase is omitted the specified leads will be set for all faults. The keywords ACTIVE and UNACTIVE allow the user to manipulate the activity bits \*\* of the successors. The default is ACTIVE. This option will not be fully described in this manual. #### 2) RESET This instruction sets the value of any specified leads to one. Format of this statement is the same as for SET. #### 3) FLIP This instruction changes the values of specified leads from one to zero or from zero to one. Format of this statement is the same as for SET. <sup>\*</sup> all phrases in this script signify optional qualifiers. <sup>\*\*</sup> activity bits are discussed in the FAUST programmer's guide. ## 4) TRACE This instruction adds the specified leads to the list of leads to be included in the \$LVBS displays. Format of this statement is as follows: - a) TRACE followed by - b) lead list followed by - c); TRACE followed by no list reactivates the tracing routine, (this is used after a blank UNTRACE statement has been used). #### 5) UNTRACE This instruction removes the specified leads from the list of leads to be included in the \$LVBS displays. Format of this statement is the same as for TRACE. ## 6) SHOW This instruction displays the \$LVBS including the specified leads. Format of this statement is the same as for TRACE except b) is not optional. ## 7) SAVE This instruction saves the diagnostic tree and the \$LVBS table. These data structures are stored under the fully qualified names: CIRCUITNAME.RECNAME.\$LVIS where CIRCUITNAME is and CIRCUITNAME.RECNAME.\$DIATR the circuit name as specified on the control card and RECNAME is the record name specified by the RECNAME= option of the SAVE statement. #### a) SAVE followed by Format of this statement is as follows: - b) RECNAME='recname' followed by - c) ; If the RECNAME= option is omitted \$CTRES.runname is used where the runname from the control card is used. ## 8) BACKUP This instruction retrieves the diagnostic tree and \$LVBS under the fully qualified names used in the SAVE instruction. Format of this statement is the same as for SAVE. # 9) RUN This instruction activates the simulation routine to update the \$LVBS display. Format of this statement is as follows: - a) RUN followed by - b) FAULTS=NO or FAULTS=ALL followed by - c) ',' when b) and d) are used followed by - d) MAXIT= maxit followed by - e) : The FAULTS option can be used to specify simulation runs with a different set of faulty machines, in its absence FAULTS option of the control card is used. The MAXIT option specifies the maximum number of iterations through the feedback nodes during the simulation. The default value for MAXIT is 8. #### 10) SORT This instruction looks at the output and sorts the faulty machines within a group according to their output thus creating a new level on the diagnostic tree. Format of this statement is as follows: - a) TREE followed by - b) FIRST= fl followed by - c) ',' when b) and d) are used followed by - d) ROOT= hs followed by - e) ',' when d) and f) are used followed by - f) LAST= II followed by - g) ; If all the parameters are left out the entire tree is printed. FIRST option: fl is the first level to be printed. ROOT option: if hs is greater than zero the hs subset on the fl level is used as the root of the printed tree, namely the tree is printed only from that node down. If hs is zero(default value) then the complete fl level is printed as the first level of the printed tree. LAST option: ll is the last level of the tree to be printed( if omitted the whole remainder of the tree is printed). Suppose we have a tree of the following form: DIAGRAM 8 If we put TREE FIRST=2,LAST=3; the entire second and third levels will be printed. If we put TREE ROOT=1; the entire tree will be printed. If we put TREE FIRST=2, ROOT=5; the following will be printed. DIAGRAM 9 # 12) INITREE This instruction can be used to initialize the diagnostic tree in core. This statement need not appear at the beginning of FAUST statements since the tree will be initialized automatically. Format of this statement is as follows: - a) INITREE followed by - b) UB= upper bound on the tree followed by - c) ; The option b) is present so the programmer can control the amount of core taken by the tree. The default for UB is three times the number of faulty machines. If the INITREE statement is used after the first FAUST statement, the current version of the diagnostic tree in core is deleted and a new data structure is allocated with appropriate upper bound. This instruction combined with SAVE and BACKUP facilitate the creation of several diagnostic trees for the same circuit at the same run. # 13) INIFAULT This instruction causes the \$LVBS table to be initialized with the stuck at one and stuck at zero faults. Format of this statement is as follows: - a) INIFAULT followed by - b); # 14) ACTIVATE # and 15) DEACTIVATE These instructions allow the user to manipulate the activity bits\* and thus change the model for which this program is designed. Therefore the user must do so with care. For normal circuit runs the user should put near the beginning of his FAUST statements # ACTIVATE ALL; The uses of these instructions will not be described further in this manual. Format of these instructions is as follows: - a) ACTIVATE or DEACTIVATE followed by - b) lead list followed by - c) ; <sup>\*</sup> activity bits are discussed in the FAUST programmer's guide. # SECTION 6) Selected faults definition statements The purpose of the facility to create a set of selected faults for a circuit, as opposed to all single faults, is twofold. First, if we are not interested in all faults the option will save space and time on the computer, and second; the option has the capability of creating multiple faults. Each statement.defines a set of faults to be associated with a specified lead. Format of the statements are as follows. - a) lead name followed by - b) ALL - or c) s@1 - or d) s@0 - or e) OFD - or f) any combination of (c), (d), (e) followed by - q) / ALL - or h) / selected list of input references followed by - i) ; If all the optional phrases are missing, all faults for the specified lead are assumed. The '/' sign is to separate the basic faults from the input faults. # Multiple faults If we wish to associate more than one fault with same faulty machine we can do so using the '+' sign. For example, suppose we wish to consider the fault, Al is stuck at one and A2 has an open input diode from Xl. We would describe this fault as follows: The plus sign will combine the faults of first statement with that of the second. In general, as long as each statement specifies only one fault, the plus sign will combine into one fault, the faults of all of the statements with the statement immediately preceding them. In the case that more than one fault is specified per lead the first fault of a statement with a plus sign is combined with the last fault of the statement ahead. Consider the following fault descriptions for CIRCUIT1. e.g. 1. A1 s @ 1, s @ 0; + N1 s @ 1, s @ 0/X1,X2; + A2 s @ 0/X1,A1; The selected faults list would be - 1. Al s @ 1. - 2. Al s @ 0 and Nl s @ 1. - 3. N1 s @ 0. - 4. N1 open input diode from X1. - 5. N1 open input diode from X2 and A2 s @ O. - 6. A2 open input diode from X1. - 7. A2 open input diode from A2. - e.g. 2. A1 s @ 1; + N1 s @ 1, s @ 0/X1,X2;A2 s @ 0/X1; The selected faults list would be - 1. Al s@1 and Nl s@1. - 2. Nl s@0. - 3. Nl open input diode from Xl. - 4. Nl open input diode from X2. - 5. A2 s@0. - 6. A2 open input diode from X1. - e.g. 3. Al s@1; + Nl s@1; + A2 s@1; + $\emptyset$ 1 s@0; The selected faults list would be 1. Al s@1 and N1 s@1 and A2 s@1 and Ø1 s@0. The Late would be At the end of any selected faults list the keyword END, followed by a semicolon, must appear. # SECTION 7) Control Cards for FAUST The following deck is an example of the necessary control cards used to make a FAUST run on a system 360 under OS/360. ``` //FAUST1 JOB 'P0785SYSTRUC,TIME=(,59),PAGES=999',CLASS=A,MSGLEVEL=1 //JOBLIB DD DSNAME=P0785.LMAN2,DISP=SHR //GO EXEC PGM=FAUST,REGION=250K //SYSPRINT DD SYSOUT=A //GO.RECDIR DD DSNAME=U0664.RECDIR,DISP=OLD //GO.RECFILE DD DSNAME=U0664.RECFILE,DISP=OLD //SYSIN DD * ``` Place your FAUST deck here. ## SECTION 8) FAUST Examples give the following output: The following examples of FAUST runs are provided to help the user become more familiar with the FAUST language. The examples are runs on CIRCUIT1. These FAUST statements ``` %SAMP2: SIMULATE CIRCUIT=CIRCUIT1, DISP=NO, LIST=YES, FAULTS=ALL; INITREE; ACTIVATE ALL; INIFAULT; RUN; SHOW ALL; SET X1; TRACE A2,\emptyset1; RUN; SORT; TREE; BACKUP RECNAME=TEST; TRACE N1; FLIP X1,X2; RUN; SORT; UNTRACE Ø1; RUN; SORT; TREE; END; ``` # EXAMPLE 2 CPU TIME = 260,400,000, TUTAL CPU TIME = 0. 0.000 MILLISECONDS. \$SAMP2: SIMULATE CIKCUIT=CIRCUITI, DISP=NG, LIST=YES, FAULTS=ALL; CPU TIME= 142,490 MILLISECONDS. Choshooosource. ==LCID==CIRCUIT NAME: CIRCUITI, OPTIONS: 600C FAULTS OPTION: ALL ==FCIR==CLO DIRECTORY FETCHED. ===== CIRCLITI CIRCUIT RECORDS ===== CIRCUITI NCDE NO. 79 | \$010 <b>\$</b> | NODE | NO. 71 | 7.1 | 86 BYTES, STARTING REGION NO. | NC. | REGION | NO. | 12 | 12 WORD NO. 525 | NO. | 525 | |-----------------|-------|---------|-----|--------------------------------|------|---------|-------------|-----|-----------------|--------|-----| | <b>\$</b> FBSC | NODE | NO. 78 | 78 | 168 BYTES, STARTING REGION NO. | 9N1 | KEGI ON | •<br>0<br>2 | 12 | 12 WORD NU. 547 | N<br>N | 247 | | SEMCS | NCT B | FOUND. | | | | | | | | | | | \$SYMTA | NOOF | NC. 31 | 81 | 124 BYTES, STARTING REGION NU. | 1 NG | KEGI ON | •<br>0.N | 1,2 | 12 MORD NG. 492 | Š | 765 | | <b>SREFS</b> | NODE | NC. 82 | 95 | 56 BYTES, STARTING REGION NO. | SNI. | REGION | •<br>0<br>2 | 12 | 12 MORD NU. 589 | )<br>Z | 585 | | <b>\$</b> SPCS | NCDE | N.O. 83 | 83 | 75 EYTES, STARTING REGIUN NO. | ING | REGI UN | • ON | ۲. | P MURD NG. 20 | )<br>Z | 32 | | | | | | | | | | | | | | NCT FUUND. SIERM | | 114 | | 35 - | | | | | | | | | | | | | | | | 525 | 450 | |----------------|----------------------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | NO. | | | | | | | | | | | | | | | | | | O.N. | »<br>DN | | | | | | | | | | | | | | | | | | | | | WORD | MURD | | | . 0 | | | | | | | | | | | | | | | | | | 12 | 12 | | | O | • | | | | | | | | | | | | | | | | | o<br>N | ON | | | REGION | | | | | | | | | | | | | | | | | | KEG10N | REGIUN | | | TES, STARTING | | | | | | | | | | | | | | | • | | | YIES, STARTING | BYTES, STAKTING | | | | | | | | | | | | | | | | | | | | • | • | | | | 261 | 1 | | X1 | X 2 | | | X | 2X | | | X | A1 | | : | A : | -<br>Z | | າວ | 1.32 | | R= 110; | T OF NODE NO. 60, FETCHED OLT CIRCUITS LISTING ===== | 1117017 3303 | STUCK AT | STOCK AT U | IPUT DIJOE | STUCK AT 2 | STUCK AT U | PUT DIUDE | ⊌PUT CIGDE | STUCK AT 2 | SIUCK AT UN | HPLI CICOE F | PUT DIODE H | STUCK AT ZE | SICCR AL CNE | VPUT CIOUE FR | TECT CICOL TX | SFMCS CREATED. | . <b>S</b> C L D S | \$010\$<br>CF | | EV=*01101110*B | ==FEICH==\$COPI<br>STRUCTURE: \$CUPI<br>===== SINGLE FAU | NAME | A . | A 1 | AL | N | T. | Z | -1<br>Z | 0 A2 | 1 A2 | 2 A2 | 3 A2 | 4 61 | ເກັ | | <b>T</b> 0 / | CIRCLIT1.\$C105.\$ | = STORE=<br>TRUCTU | =STORE=<br>TRUCTUR | | | V=*01101110*8 R= 11 | R= 110;<br>OF NODE NO. 60,FETCHED 2619 BYTES,STARTING REGION NO. 0 WORD NO. 11 | R= 110; UF NODE NO. 60,FETCHED 2619 BYTES,STARTING REGION NO. 0 WORD NO. 11 AULT AULT | R= 110; UF NODE NU. 60,FETCHED 2619 BYTES,STARTING REGION NO. 0 WORD NO. 11 AULT CIRCUITS LISTING ===== AULT FREE CIRCUIT. AULT FREE CIRCUIT. AULT FREE CIRCUIT. AUTHOR STUCK AT ZERO | R= 110; UF NODE NO. 60,FETCHED 2619 BYTES,STARTING REGION NO. 0 WORD NO. 11 AULT AULT AULT AULT FREE CIRCUIT. AULT AULT FREE CIRCUIT. AULT FREE CIRCUIT. AULT FREE CIRCUIT. AULT FREE CIRCUIT. AUTHOR STUCK AT ZERO AUTHOR STUCK AT JERO AUTHOR STUCK AT JONE AND STUC | R= 110; OF NODE NU. 60, FETCHED 2619 BYTES, STARTING REGION NO. 0 WORD NO. 11 LT CIRCUITS LISTING ==== AULT AULT AULT AULT AULT AULT AULT AUL | DE NODE NU. 60, FETCHED 2619 BYTES, STARTING REGION NO. 0 WORD NO. 11 LT CIRCUITS LISTING ===== AULT AULT AULT AULT AULT AULT AULT AULT AULT FREE CIRCUIT. AULT A | DE NODE NU. 60, FETCHED 2619 BYTES, STARTING REGION NO. 0 WORD NO. 11 LT CIRCUITS LISTING ==== AULT AULT AULT FREE CIRCUIT. AULT FREE CIRCUIT. AULT FREE CIRCUIT. AULT FREE CIRCUIT. AULT AULT FREE CIRCUIT. AULT A | R= 110; OF NODE NO. 60,FETCHED 2619 BYTES,STAKTING REGION NO. 0 WORD NO. 11 AULT CIRCUITS LISTING ==== AULT AU | CE NODE NO. 60, FETCHED 2619 BYTES, STARTING REGION NO. 0 WORD NO. 11. LT CIRCUITS LISTING ==== AULT AULT FREE CIRCUIT. F | DE NODE NU. 60,FETCHED 2619 BYTES,STARTING REGION NO. 0 WORD ND. 11 LT CIRCLITS LISTING ==== AULT AULT AULT FREE CIRCUIT. UITPUT STUCK AT ZERO UITPUT STUCK AT JERO UITPUT STUCK AT ZERO UITPUT STUCK AT JERO WAS PEN INPUT CIQUE FROM X1 PEN INPUT CIQUE FROM X2 UITPUT STUCK AT JERO X1 PEN INPUT CIQUE FROM X2 UITPUT STUCK AT JERO X2 UITPUT STUCK AT JERO | DE NODE NU. 60, FETCHED 2619 BYTES, STARTING REGION NO. 0 WORD NO. 111 AULT CIRCUITS LISTING ==== AULT FREE CIRCUIT. AUTHOR STUCK AT ZERO | R= 110; OF NODE NU. 60,FETCHED 2619 BYTES,STARTING REGIUN NO. 0 WORD NO. 11 LT CIRCUITS LISTING ==== AULT AULT AULT AULT AULT TEE CIRCUIT. AULT AULT AULT AULT AULT AULT AULT AULT | DE NODE NO. 60, FETCHED 2619 BYTES, STARTING REGION NO. 0 WORD NO. 11 AULT AULT AULT AULT AULT AULT FREE CIRCUIT. UTPUT STUCK AT ZERO A | DE NODE NO. 60, FETCHED 2619 BYTES, STARTING REGION NO. 11 LT CIRCUITS LISTING ==== AULT AULT AULT FREE CIRCUIT. AUTPUT STUCK AT LERO AUTPUT STUCK AT LERO AUTPUT STUCK AT GNE AULT FREE CIRCUIT. AUTPUT STUCK AT GNE AULT FREE CIRCUIT. AUTPUT STUCK AT GNE AUTPUT STUCK AT CROW | CF NODE NO. 60, FETCHED 2619 BYTES, STARTING REGION NO. 0 WORD NO. 11 LT CIRCUITS LISTING ===== AULT AULT AULT AULT AULT TUCK AT ZERO UTPUT STUCK AT ZERO UTPUT STUCK AT LERO | R= 110; UF NODE NU. 60, FETCHED Z619 BYTES, STARTING REGION NO. 0 WORU NO. 11 AULT FREE CIRCUIT. AULT FREE CIRCUIT. UTPUT STUCK AT ZERO | R= 110; OF NODE NO. 60,FETCHED 2619 BYTES,STARTING REGION NO. 0 WORD NO. 11. LIT CIRCUITS LISING ==== AULT AUL | DE NODE NO. 60, FETCHED 2619 BYTES, STARTING RECION NO. 0 WORD NO. 11. LLT CIRCUITS LISTING ===== AULT AULT AULT AULT AULT FREE CIRCUIT. AULT AULT AULT AULT AULT AULT AULT AULT | ULT CIRCUITS LISTING ==== LIT CIRCUITS LISTING ===== AULT FREE CIRCUIT. AULT FREE CIRCUIT. AULT FREE CIRCUIT. AUTHOR STUCK AT ZERO Z | 6 LEAUS. , A2 01 2 OUTPUTS , x2 X 2 INPLTS O FEECBACKS: 17 SINGLE FAULTS. 12 SUCCESSORS IN SS. O TERMINALS. 6 SYMBULIC NAMES. O FALST RUNS. 3 LOGIC LEVELS. | | | _ | | 14 | | | | | | | | | | |-------|--------------|----------|---|--------|----|-----------|---|------|---|------|---------|-----------|------------| | | S | INPUT# | | INPUT# | | | | | | | OUTPUT# | | OUIPUT# | | | OZ | ت | C | C | O | ß | O | 6 | 0 | 13 | c | 17 | C | | | FAULTS | 0 | င | 0 | ပ | 4 | ၁ | 00 | 0 | 12 | 0 | 16 | O | | | TED | 0 | 0 | 0 | C | m | C | 7 | 0 | 7 7 | 0 | 15 | 0 | | | ASSOCIA | 0 | C | | 0 | 7 | o | 9 | 0 | C. | 0 | <b>51</b> | O | | | | 3 4 5 | | | | | | | | | | | | | | PUT | 4 | | 4 | | 9 | | | | | | | | | | OUT | m | | m | | Ś | | 9 | | | | | | | | FANDUT | 3 • • | | 0 0 2. | | 2 | | 1 | | C. | | O | | | | NCES | 0 | | C | | 0 | | O | | C. | | O | | | | REFERE | O | c | C | C | 7 | ပ | 7 | c | m | 0 | 4 | ڼ | | | LVL. INPUT R | <b>ာ</b> | ~ | 0 | C, | | O | | 9 | | - | 3 | <b>(</b> ) | | <br> | LVL. | C | | ပ | | <b>,4</b> | | | | 7 | | 7 | | | ) ) ) | ATOM | a Z ] | | dNI | | ANO | | NAND | | ONA | | O.R | | | | NAME | 1 x1 | | 2 X2 | | 3 A1 | | 4 N1 | | 5 A2 | | 6 C1 | | | | Q | - | | • | | - | | - | | | | _ | | ==FEICH==FALSI.\$JPTAB STRUCTURE: \$OPTAB OF NUDE NO. 35,FEICHED 324 BYTES,STARTING REJION NO. 10 WORD NO. 408 CPU TIME= 1,501.583, FCTAL CPJ TIME= 1,444.073 MILLISECONDS. OCIONO00SOURCE. C0090000SUURCE. 00120000SOURCE. 00110000S0URCE. | 1,457.405 MILLISECONDS. | 1,459.904 MILLISECONDS. | 1,558.231 MILLISECONDS. | 1,561.564 MILLISECUNDS. | | 1,634.059 MILLISECONDS. | | 1,714.053 MILLISECGNDS. | | | • | 1,830,712 MILLISECONDS. | |-------------------------------------------------------------------------------------------|-------------------------|--------------------------------------------------------------------------------|-------------------------|----------|-------------------------|-----------------------------|-------------------------|-----------|--------------|-----------------|--------------------------| | 7.405 | 9.904 | 8.231 | 1.564 | | 4.059 | | 4.053 | | 6, | | 30.712 | | 1,45 | 1,45 | 1,55 | 1,56 | | 1,63 | | 1,71 | | ž | | 1,83 | | IME= | ſIME= | ſ.IME= | I ME= | | T I ME= | | -3WI1 | | 4 4 | | TIME= | | CPU 1 | CPU 1 | CPU | CPU | | CPU | | CPU | | 3, | | CPU | | LIZED.<br>TOTAL | TOTAL | LIZED.<br>TOTAL | TUTAL | | TOTAL | | TOTAL | | 2. | | TOTAL | | TEMENTS ====<br>EE INITILIZED.<br>13.332, TOFAL CPU TIME= | 2.499, TOTAL CPU TIME= | E INITI<br>3.327, | 3.333, TUTAL CPU TIME= | · • • • | 72.495, TOTAL CPU TIME= | | 79.554, TOTAL CPU TIME= | ALL; | • | | 116.659, TOTAL CPU TIME= | | STATE<br>TREE | . • | TREE | | Ø | 7 | ø<br>⊢.ਘੁ | 7 | SHCW ALL; | •• | N<br>E | 1.1 | | ===== FALST STATEMENTS =====<br>= DIAGNOSTIC TREE INITILLIZED.<br>CPU TIME= 13.332, TOFAL | 0><br>CPU TIME= | INITREE;<br>= DIAGNOSTIC TREE INITILIZED.<br>CPU TIME= 98.327, TOTAL CPU TIME= | 1><br>CPU TIME= | ACTIVATE | CPL TIME= | INIFAULT;<br>==INIFL==CCNE. | 32<br>CPU TIME= | # NOW | PRUPOGATION: | ==DIMUY== CGNE. | 4><br>CPU TIME= | | C P C | CPU | e D<br>CPU | L<br>CPU | 2 | CP. | <b>₩</b> ( | CPL | | PRC | ] == | CPL | OC130000SOURCE. ``` 1,981,535 MILLISECONDS. 2,054,030 MILLISECCNUS. 1,911.54C MILLISECONDS. 9 80.828, TOTAL CPU TIME= 69.995, ICIAL CPU TIME= 72.495, TUTAL CPU TIME= 00000000000000000000 2220202020202222 IIIIIICIIIIIIIIIIIIIIIIII 012345678501234567 3 TRACE A2,01; SORT; 000000 ð PROPOGATION: SET X1; NAME RUN: CPU TIME= CPU TIME= CPU TIME= - -3 -2 ``` 0015G0C0SOURCE. OF14COF DSDURCE. ==DIMUY== DONE. 012345678901234567 1111111011011111111 8 O O NAME A2 0 9 ů Z 2,164.856 MILLISECCNUS. 110,826, TUTAL CPU TIME= CPU TIME= OC160C00SOURCE. 6 | 2,215.686 MILLISECUNDS. | 2,304.013 MILLISECONDS. | LP= 19; | | DIAGNUSTIC TREE ===== | | | | | | | | | | | | | | 2,446.503 MILLISECCNDS. | | |-------------------------|-------------------------|------------------------|---------------------|-----------------------|--------------|------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----------|-------------|-------------|------|---------|------------|-----|-----|--------------------------|--| | 50.830, TUTAL CPU TIME= | 88.327, TOTAL CPU TIME= | 0 HS= 0 LL= 1<br>HP= 0 | 3 NODES, 1 SUBSETS. | 1 1 HE ===== | S.** | *001**CU2**003*<br>* 2 ** 3 ** C * | * * * | Table Section Control of | 1年 年 3年 年 6年<br>7年 年 5年 年 6年 | # 11# # 1 | 7# # 13# | # 30 ( | #O- | # ## UN | 16# | 17# | | 142.490, TüTAL CPU TIME= | | | CPU TIME= | TREE;<br>CPU TIME= | ==TREE== FL=<br>FP= 18 | LEVEL# 0 | | RESOLUTIONS: | LEVEL# 0 *0<br>66.64DIA. * | | | MACHINE# # | - | 12.5%DIA. # | 43.7%DTC. # | ** * | e #e | * <b>*</b> | # | 10> | CPU TIME= | | OC170000SOURCE. | <del></del> | |-------------| | S | | ш | | ) | | اا<br>لذا | | X. | | CNAM | | < | | ŭ | | ¥ | | | | α. | | KUP. | | ¥ | | N<br>V | | â | | | | ==FETCH==CIRCUITI.TEST.\$LVBS<br>STRUCTURE: \$LVBS OF NODE | IRCUITI.<br>\$LVBS | •TEST,<br>OF | ST. \$LVBS<br>OF NODE NO. | • 0 | 86,FETCHED | | 74 BYTES, STARTING REGION NO. 12 WORD NO. 699 | REGION NO. | 12 WORD NO. | 669 | |------------------------------------------------------------|---------------------|--------------|----------------------------|-------|-------------|-----------|-----------------------------------------------|------------|------------------|---------| | ==FETCH==CIRCUITI.TEST.SUIATR SFRUCTURE: SDIATR OF NODE N | IRCUITI,<br>\$DIATR | TEST, | EST. SUIATR<br>OF NGDE NO. | * 02. | 97, FЕТСНЕО | | 347 BYTES, STARTING REGION NO. 12 WURD NO. | REGION NO. | 12 WURD NO. | 996 | | CPU TIME= | 161, | .656 | 161.656, TOTAL CPU | CPU | TIME= | 2,608,159 | 2,608.159 MILLISECONDS. | | | | | TRACE NI; | : Z | | | | | | | 001800 | OC180000SOURCE. | | | CPU TIME= | 107, | .493, | 107.493, TOTAL CPU | CPU | IIME= | 2,715,652 | 2,715.652 MILLISECONDS. | | | - | | FLIP | FLIP X1, X2; | | | | | | | 00100 | 00190C00S0URCE. | - 40 | | CPU TIME= | 74' | .161, | 74.161, TCTAL CPU | CPU | 1 IME= | 2,789,813 | 2,789.813 MILLISECUNDS. | | | <b></b> | | »<br>NON | SURT; | | | | | | | 00200 | OCZCODON SOURCE. | | | PROPOGATION: | <br>Z | 3, | , , | 5 | <b>,</b> | | | | | | | ==DIMUY== DCNE. | DC NE. | | | | | | | | | | 2,902.305 MILLISECONDS. 112.492, TUTAL CPU TIME= CPU TIME= 14> NAME S S 52.495, TOTAL CPU TIME= 15> CPU TIME= 2,954.8°1 MILLISECCNUS. | ENTRACE | | | 00200100S0URCE. | |--------------------------|---------------------------------------------------------------|-------------------------|-----------------| | 16><br>CPU TIME= | | 3,050.628 MILLISECONDS. | | | | SORT; | | QQ20C200SQURCE• | | PROPOGATION: | | | | | ==DIMUY== CCNE. | .NE | | | | | • | | • | | NG. NAME<br>4 NI<br>5 A2 | 012345678901234567<br>c 1111110101111111111111111111111111111 | | | | 17><br>CPU TIME= | 104.993, TCTAL CPU TIME= | 3,155.621 MILLISECGNDS. | | | 18><br>CPU TIME= | 54.163, TOTAL CPU TIME= | 3,209.784 MILLISECUNDS. | | | TREE;<br>CPU TIME= | 90.827, TOTAL CPU TIME= | 3,300.611 MILLISECONDS. | CO210000SOURCE. | | ==IREE== FL=<br>FP= 18 | = C HS= 0 LL= 5<br>HP= 0 | LP= 19; | | | C #13A31 | 1 NODES, 1 SUBSETS. | | | | LEVEL# 1 | 3 NODES, 1 SUBSETS. | | | | LEVEL# 2 | 4 NUDES, 2 SUBSETS. | | | | LEVEL# 3 | 4 NODES, 3 SUBSETS. | | | | LEVEL# 4 | 3 NODES, 3 SUBSETS. | | | | | • | -7 | |---|---|----| | | | ۰, | | • | | ٠, | | | 2 | 2 | | | - | • | | ı | L | L | | | _ | • | | | | | | | | | | | | | | | MILLISECUNDS. | |---------------------------------------|-----------------------------------------------|----------------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------------------------------------| | | ***<br>***<br>***<br>***<br>***<br>***<br>*** | * * * * * * * * * * * * * * * * * * * | * * - * * * * * * * * * * * * * * * * * | * * 9 + * * * * * * * * * * * * * * * * | 3,571.427 MIL | | * * * * * * * * * * * * * * * * * * * | **** | * * * * * * * * * * * * * * * * * * * * | | * | π<br>Σ<br>π:<br>π: | | | * 001<br>* 2 * +<br>* 2 * +<br> | ************************************** | | * * * * * * * * * * * * * * * * * * * | # 1 | | <br> | | ****<br>****<br>****<br>****<br>****<br>**** | 0 +<br>0 +<br>+ + +<br>1 | * * * * * * * * * * * * * * * * * * * * | 4 4#<br>1 2#<br>1 1 2#<br>1 1 5#<br>1 1 5#<br>1 1 7#<br>2 7 0 - 816 • | | RESCLUTIONS: LEVEL# 0 0.03DIA. | LEVEL# 1<br>66.63DIA.<br>17.62DIC. | LEVEL# 2<br>33.3%DIA.<br>28.5%DIC. | ÁÚ | LEVEL# 4<br>0.0%DIA.<br>0.0%DIC. | 31.2%0IA.<br>50.0%DIC.<br>19><br>CPU TIME= | ===== THE DIAGNOSTIC TREE ===== The presence of LIST=YES in the control card statement causes the circuit description of CIRCUIT1 to be printed. The initial sort was not done in this run. Note the affect on the diagnostic tree; it does not have a singular root. The \$LVBS was not printed after the first RUN statement. The reason is that a TRACE statement must appear before the automatic display appears after each run. The statement ### BACKUP RECNAME=TEST; fetches the structures TEST.\$LVBS and TEST.\$DIATR into core, wiping out the previous \$LVBS and \$DIATR. The final tree is a 'super tree' of that printed in run SAMP1. The next example simulates CIRCUIT1 under multiple faults. The statements are: ``` %SAMP3: SIMULATE CIRCUIT=CIRCUIT1, DISP=NO, FAULTS=GET; A1 S@1,S@0; + N1 S@1,S@0/X1,X2; + A2 S@0/X1,A1; END; SORT; TRACE Ø1,A2; ACTIVATE ALL; SET X1; RUN; SORT: SET X2; RUN; SORT; TRACE ALL; RESET (1,3 \text{ to } 5) X2; RUN; SORT; END; ``` The resulting output is: # EXAMPLE CPU TIME= 260,400.000, TOTAL CPU TIME= 0.000 MILLISECONDS. SIMULATE CIRCUIT=CIRCUIT1,DISP=NU,FAULTS=GET; #SAMP3: S ONC80300SOURCE. #=LCID==CIRCUIT NAME: CIRCUITI, OPTIONS: 0000 FAULTS OPTION: GET ==FDIR==DIR EXPANDED FRCM 136 TO 141 NODES. ==FDIR==OLD DIRECTURY FETCHED. ===== CIRCUITI CIRCUIT RECORDS ===== | CIRCUITI NODE | | ON | 61 | | | | | | | | | |-----------------|------|--------|-----|-----|----------------------------|--------|-------------|----|-------------|-------------|-----| | \$010 <b>\$</b> | NODE | • ON | 11 | 86 | 86 BYTES, STARTING REGION | REGION | •0N | 12 | 12 WORD NO. | NO. | 525 | | \$LDSC | NODE | NO. | 7.8 | 168 | 168 BYTES, STARTING REGION | REGION | NO. | 12 | 12 WORD NO. | | 247 | | \$ FMC S | NUDE | • ON | 84 | 132 | 132 BYTES, STARTING REGION | REGION | • ON | 12 | 12 WURD NO. | | 450 | | \$ SYMTA | NODE | NO. 81 | .81 | 124 | 124 BYTES, STARTING REGION | REGION | NO. | 12 | 12 WORD NU. | »<br>ON | 765 | | SREFS | NODE | NO. | 8.2 | 56 | 56 BYTES, STARTING REGION | REGION | •<br>0<br>N | 12 | 12 WORD NO. | | 589 | | s s nc s | NODE | •ON | 83 | 15 | 75 BYTES, STARTING REGION | REGION | •<br>0<br>Z | Ç. | O WORD NO. | •<br>0<br>V | 50 | NOT FOUND. STERM | ===== STRUCTUR | ES LO | CATI | ≥ SNO | #<br>#<br>#<br># | | | | | | | | |--------------------------------------|-------|------|-------------|------------------|-------------|--------------------------------------------|-------|--------|-------------|-------------|-----| | STRUCTURE: SCI | 0.5 | PF | NODE | NO. | 71, FETCHED | 86 BYTES, STARTING REGIO | | 1. 12 | MORD | NO. | | | STRUCTURE: \$LDSC OF NODE NO. | SC | ÜF | NODE | NO. | 78, FETCHED | 168 BYTES, STARTING REGION | | NO. 12 | 12 WORD NO. | °OZ | 241 | | STRUCTURE: SSYMIA | MIA | J. | NODE | NO. | 81, FETCHED | 124 BYTES, STARTING REGIO | | ). 12 | WORD | OZ. | | | STRUCTURE: SRE | FS | OF. | NODE | 0N | 82, FETCHED | 56 BYTES, STARTING REGIO | | J. 12 | WORD | ON. | | | STRUCTURE: SUCS | cs | 7 | NODE | 0N | 83, FETCHED | 75 BYTES, STARTING REGIO | | • | WORD | S<br>O<br>N | | | EV=*01101110*B | _ | | . II | | :011 | | | | | | | | ==FETCH==\$COPT<br>STRUCTURE: \$COPT | 19.T | OF | OF NODE NO. | 0 | 60,FETCHED | 2610 BYTES, STARTING REGION NO. O MORD NO. | NO NO | . 6 | MORD | °0 N | 114 | ===== SELECTED FAULTS EVALUATION ===== FRNM = CIRCUITI. \$CTRES. SAMP3. \$SFMC FAULTS DESCRIPTION SOURCE: Al Sal, SaO; + NI Sal, SaO/X1, X2; + A2 SaO/X1, A1; END; --FLEV=- 3 FAULTY LEADS. HED 324 BYTES, STARTING REGION NO. 19 WORD NO. 408 1,819.883 MILLISECONDS. 35, FETCHED LOPIAB OF NODE NO. 35, FET-1,674,059, TOTAL CPU TIME= ==FETCH==FAUST . \$0PTAB STRUCTURE: \$0PTAB CPU TIME= congeneosource. rolengensource. orllonensource. 45 - | ECONDS. | ECONDS. | col3000 SOURCE. | econos. | no140000 SOURCE. | ECONDS. | ANT SOUND SOURCE. | ECONDS. | 00160000SURCE. | ECUNDS. | | |----------------------------------------------------------------------------------|-------------------------|-----------------|-------------------------|------------------|-------------------------|-------------------|-------------------------|----------------|-------------------------|--| | 1,830,715 MILLISECONDS. | 1,834.048 MILLISECONDS. | | 1,959.8/3 MILLISECONUS. | | 2,060.699 MILLISECONDS. | | 2,130,694 MILLISECONDS. | | 2,199,022 MILLISECONDS. | | | LIZED.<br>TOTAL CPU TIME= | TOTAL CPU TIME= | | TOTAL CPU 11ME= | | TOTAL CPU TIME= | | TOTAL CPU TIME= | SORT; | TUTAL CPU TIME= | | | ==== FAUST STATEMENTS ===<br>= DIAGNOSTIC TREE INITILIZ<br>CPU TIME= 10.832, TOT | 3,333, 101 | • <b>6</b> 1 | = 125.825, TOI | TRACE 01, A2; | = 100.826, TOI | ACTIVATE ALL: | *566*69 | SET XI; RUN; | 68.328 | | | ===== FAU<br>= DIAGNOS<br>CPU TIME= | O><br>CPU TIME= | SO8 | CPU TIME= | TRA | CPU TIME= | AC1 | CPU TIME= | SET | CPU TIME= | | 63 5 4 4 2, ==DIMUY== DONE. PROPOGATION: | | | | ON170900SOURCE. | ı | | | | | | nolennossaurce. | |--------------------------------------|-------------------------|-------------------------|-----------------|-------------------------|--------------|-----------------|------------|--------------------------------------|-------------------------|----------------------------------| | | 2,254.018 MILLISECONDS. | 2,305,681 MILLISECONDS. | | 2,394.841 MILLISECONDS. | | | | 2,449.034 MILLISECONDS. | 2,499.000 MILLISECONDS. | 2,588.16° MILLISECONDS. | | 012345678<br>1001CCCC1<br>1111111011 | 54.996, TUTAL CPU TIME= | 51.663, TOTAL CPU TIME= | RUN; SORT; | 89.166, TOTAL CPU TIME= | 3, 4, 5, 6, | • | 012345678 | 110111111<br>54.163, TOTAL CPU TIME= | 49.996, TOTAL CPU TIME= | L;<br>89.16°, TUTAL CPU TIME= | | NO. NAME a<br>5 A2 0<br>6 01 0 | CPU TIME= | 6><br>CPU TIME= | SET X2; | CPU TIME= | PROPOGATION: | ==DIMUY== DUNE. | NG. NAME & | 10 E | 9><br>CPU TIME= | TRACE ALL;<br>10><br>CPU TIME= 8 | 00190000SOURCE. RESET (1,3 TO 5) X2; For a detailed description of the selected faults for this run, see section 6), example 1 of this manual. ## SECTION 9) FAUST program error diagnostics The error messages of FAUST source errors are self explanatory. Here is output of an incorrect FAUST source deck. # EXAMPLE 4 CPU TIME= 260,400.000, TOTAL CPU TIME= 0.000 MILLISECONDS. 138.324 MILLISECONDS. CIRCUIT=CIRCUITI, DISP=NC, FAULTS=ALL; 138.324, TOTAL CPU TIME= SIMULATE CPU TIME= \* SAMP4: OCCBCOOD SOURCE. #=LCID==CIRCUIT NAME: CIRCUIII, OPTIONS: 0000 FAULTS OPTION: ALL ==FBIR==BIR EXPANDED FROM 141 TO 143 NUDES. ==FDIR==OLD DIRECTORY FETCHED. ==== CIKCUITI CIRCUIT RECORDS ===== 12 MORD NO. O WORD NO. 12 WORD NO. MORD NO. 12 MORU NO. 12 WORD NO. 12 BYTES, STARTING REGION NO. 124 BYTES, STARTING REGION NO. 56 BYTES, STARTING REGION NO. 75 BYTES, STARTING REGIUN NO. 86 BYTES, STARTING REGION NO. 168 BYTES, STARTING REGION NO. 132 Ø.3 ~**1** 62 73 86 82 CIRCLITI NGDE NO. NODE NO. NODE NO. NODE NO. NCUE NO. NCDE NO. NGDE NO. SYMIA S S FMC S SREFS S DOS **\$CIDS** STESC 450 525 247 492 589 70 NCT FCUND. STERM | STRUCTURE: \$FMCS SIRUCTURE: \$SYMTA STRUCTURE: \$REFS STRUCTURE: \$SUCS EV=*01111110*8 | 00<br>00<br>00<br>00<br>00<br>00 | STRUCTURE: \$LDSC OF NODE STRUCTURE: \$FMCS OF NODE STRUCTURE: \$SYMTA OF NODE STRUCTURE: \$REFS OF NODE STRUCTURE: \$SUCS OF NODE EV=*01111110*8 | | 78,FEICHED<br>98,FEICHED<br>81,FEICHED<br>82,FEICHED<br>83,FEICHED | 168<br>132<br>124<br>56<br>75 | BYTES, STARTING<br>BYTES, STARTING<br>BYTES, STARTING<br>AYTES, STARTING<br>BYTES, STARTING | REGION<br>REGION<br>REGION<br>REGION | | 12 WORD<br>12 WORD<br>12 WORD<br>12 WORD<br>0 WORD | | 24420 | |-----------------------------------------------------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------|-------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------|-----|----------------------------------------------------|----------|--------| | ==FEICH==\$CGPI<br>STRUCTURE: \$COPI | CF | CF NODE NO. | NO. | 60, FEICHED | 2610 | BYTES, STARTING | REGION | NO. | O WORD | RU NO. | Ä | | ==FETCH==FALST.\$UPTAB<br>STRUCTURE: \$UPTAB UF<br>CPU TIME= 1,009.935, | TAB<br>UF<br>935, | NODE NO.<br>TCTAL CPU | NO.<br>C.P.U | 35,FETCHED<br>TIME= 1,148. | 324<br>259 M | BYTES, STARTING | REGION | Š | 10 WG | HORD NO. | 408 | | | | | | | | | | ٠ | | | - 51 - | 1,164.090 MILLISECENDS. 1,161,591 MILLISECCNUS. ■ DIAGNUSTIC TREE INITILIZED. CPU TIME= 13.432, TOTAL CPU TIME= 2.499, TOTAL CPU TIME= CPU TIME= CPU TIME င် \* INVALID DELIMITER: : STATEMENT FLUSHED FRUM: ACTIVATE ACTIVATE: SETX1; TRACE 222.485, TOTAL CPU TIME= CPU TIME= OCO90000SOURCE. OC100000SOURCE. 1,336,575 MILLISECONUS. OC1400C0SOURCE. RUN: PROPEGATION: ==DIPUY== DCNE. CPU TIME= 84.161, TOTAL CPU TIME= 1,470.736 MILLISECONDS. CO130000SUURCE. # INVALID CPERATUR: RESET3 STATEMENT FLUSHED FROM: RESET3 **RESET3**; CPU TIME= 1,566.563 MILLISECONDS. 95.827, TUTAL CPU TIME= TREE RCGT=5; CPU TIME= 63.329, TOTAL CPU TIME= 1,629.892 MILLISECONDS. 5 0 ASSUMED. ##TREE## HS= 5 LL= HP= 0 HS= ==TREE== FL= 161 L P≡ 0 \*\*CCUNT\*\*INVALID PARM. P= IHESOOI SUBSCRIPTRANGE IN STATEMENT OCIOS AT DEFSET +014AB FROM ENTRY PUINT TREE CONDITION ERR UCCURRED IN STATEMENT COLOS AT LFFSET +014AB FRUM ENTRY POINT TREE CALLED, IN STATEMENT 00250, FRCM PROCEDURE WITH ENTRY PUINT FAUST \*\*FALSI\*\* FAILED. The first error is the use of a colon instead of a semicolon. The second is due to the absence of a blank between SET and X1. Note however another error has been missed due to the first two. There should be a semicolon after TRACE. The next error causes the program to halt. Here we have asked to have the diagnostic tree printed with the root at the 5th node on the first level. Since there is no fifth node the instruction fails and causes a PL1 error. # ERROR MESSAGE GLOSSARY For control card errors (i.e. errors of the form \*\*CCINT) see the section on error messages in the TRAIZE user's guide. | **FAUST**FAILED | |----------------------------------------------------------| | - if this message is not accompanied with any of the | | messages below the system has failed. | | *INVALID DELIMITER. STATEMENT. | | FLUSHED FROM: | | - check for missing semicolon etc. | | *INVALID LEAD#: | | - lead number is too large i.e. grater than the number | | of leads. | | *INVALID MACHINE#: | | - faulty machine number is greater than the number of | | faulty machines. | | *INVALID NAME: | | - check valid lead names. | | - remember a lead number must be preceded by a '#' sign. | | *INVALID OPERAND. STATEMENT FLUSHED FROM: | | - check spelling of the instruction word, also, use of | | qualifiers. | | *SURPLUS DELIMITER: | - possible blank leadname. # APPENDIXA Quick Reference Statement Guide ### DECK SETUP Faults definition statements iff FAULTS=GET, . . . . . END; FAUST test description, simulation and printout statements, END; ### SEMANTICS FOR CONTROL CARD runname - A symbolic name by which the results of this run would be identified. If DISP=NEW it must be different from any other run name of the simulated circuit, if DISP=OLD it must be a known name; otherwise an error will occur. circuitname - The name of the circuit to be simulated. It must be a known name of a circuit whose description can be found in the DIALATOR file, or in core. FAULTS - Defining faults to be used for this run: NO - no faults (default value) ALL - all faults GET - following is a set of fault definition statements to be compiled into a selected faults list and to be saved in the DIALATOR file under the runname specified on this card. runname - use the selected faults list which is stored under this runname in the DIALATOR file. DISP - The disposition of the run results: NO - do not save the run results. YES - save the run results. NEW - create new entries in the file for the run results. OLD - overwrite already existing records of run results with the same name. ## DEFINITIONS of SYNTACTIC PHRASES In the following definitions of FAUST and Faults Definition Statements the following syntactic phrases will be used: leadname ::= Any valid symbolic name (6 characters) referring to a known lead. leadno ::= Any valid lead number [0 < < N#] immediately preceded by a '#' symbol. (e.g. #34) \$11ist ::= {leadname | leadno} [,leadname | leadno,,,, ] | | | \$leads ::= ALL | [INPUTS | OUTPUTS | FBKS | \$11ist ,,,, ] \$11ist and \$leads are used for describing lists of leads referred to by their symbolic names, index numbers in the Description tables or by their group names inputs outputs or feedbacks. A \$leads containing the member ALL will refer to all the circuit leads. (e.g. X23,IN5,#17,#78,INPUTS). machino ::= Any valid [0 < < M#] faulty machine number. \$mlist ::= ( machino | [machino TO machino] ,,,, ) | \$ \$flist ::= ALL | {[S@1],[S@0],[OFD]} | \( \) \$flist is a list of fault types: stuck at one, stuck at zero and open feedback diode. ALL designates all the faults of the subject lead while a % means none of these faults. # Faults Definition Statements [+] leadname [ALL|\$flist][/{ALL \$llist}]; - to define selected faults. # Faults Simulation Statements {SET | RESET | FLIP} [mlist]leads[ACTIVE | UNACTIVE ; - to set, reset, or flip leads. {TRACE | UNTRACE | SHOW} [ • \$ leads]; - to trace, untrace, or show leads. {SAVE | BACKUP} [RECNAME=recname]; - to save or fetch in or from DIALATOR FILE RUN[FAULTS=NO ALL][,MAXIT=maxit]; - to simulate circuit SORT; - to look at output, sort, add level to tree TREE [FIRST=fl],[ROOT=hs],[LAST=ll]; - to show diagnostic tree INITREE [UB=upperbound on the tree]; - $\boldsymbol{-}$ to scratch old tree and initialize new one. INIFAULT; - to initialize \$LVBS with strict at faults. {ACTIVATE | DEACTIVATE}. \$leads; - to set or reset activity bits of leads.