Running display device implemented with a CPU

Information

  • Patent Grant
  • 4503428
  • Patent Number
    4,503,428
  • Date Filed
    Thursday, April 10, 1980
    44 years ago
  • Date Issued
    Tuesday, March 5, 1985
    39 years ago
Abstract
An electronic device with a dot matrix display panel capable of displaying characters, symbols or other patterns is implemented with a central processing unit (CPU). When the length of the characters, symbols and other patterns is in excess of the capacity of the display panel, those intelligence signals are sequentially shifted on the display panel and preferably dot by dot.
Description

BACKGROUND OF THE INVENTION
This invention generally relates to an electronic apparatus which stores a plurality of characters, symbols and similar display patterns and manifests a display function when desired as well as a data processing function.
In the past, it was possible for calculators to store telephone numbers and persons' names introduced via keys but impossible to display those characters on a display panel when those characters exceeded the capacity of the display panel.
OBJECTS AND SUMMARY OF THE INVENTION
It is therefore an object of the present invention to provide an improved electronic device which is able to store characters, symbols and similar display patterns without dividing them into several groups in light of a limited capacity of a display panel and display those display patterns while being continually shifted on the display panel. In other words, it becomes possible to introduce desired characters or symbols in numbers in excess of the capacity of a display panel via keys and thus store these characters or symbols in the form of a sentence when in a learn mode, as well as enabling a running display of the contents stored without punctuating these characters or symbols in accordance with the capacity of the display panel. In a preferred form of the present invention, these characters or symbols are shifted dot by dot on the display panel which is preferably of a dot matrix type.
On the other hand, the characters or symbols are displayed in a static (stationary) mode to avoid the operator's error in recognizing the significant positions of information on the display panel when the electronic device is used as a calculator.
Significant features of the present invention are enumerated as follows:
(1) A character storing electronic device which stores characters, symbols or other intelligence signals externally entered thereto and displays the same while being shifted on a display panel, even when those characters, symbols or other intelligence signals exceed the capacity of the display panel.
(2) An electronic device characterized in that both operands are displayed on a numerical display section of the display panel together with arithmetic symbols.
(3) An electronic device characterized in that a particular symbol is inserted between the end and beginning of characters, symbols or other intelligence signals contained within a character storage section to enable repeated display of those characters, symbols or other intelligence signals.
(4) In association with (1), it is decided whether all of the characters, symbols or other intelligence signals stored can be displayed at the same time, thus selecting either a static display mode or a running display mode.
(5) In association with (1), a display means and a calculation means are commonly used and a key input means and the display means are also commonly used.
(6) In association with (5), intermediate or final results of arithmetic operations are displayed in a static mode.
(7) An electronic device has a means for storing characters, symbols or other intelligence signals and a means for displaying the stored state of these characters, symbols or other intelligence signals.
(8) In association with (2), the arithmetic symbols are displayed on the right side of the first operand or on the left side of the second operand.
(9) An electronic device as set forth in (7) wherein whether the device is in a character write state is displayed together with the stored state of characters or symbols on the same display panel.
(10) An electronic device adapted for storing and displaying characters or symbols, in which an interrupted calculation is available during the course of a character display mode.
(11) An electronic device which stores characters, symbols or other intelligence signals externally entered thereto and displays the same, wherein both characters and numbers can be entered thereto at the same time.
(12) An electronic device which is capable of displaying characters or symbols stored therein automatically when a power is switched on.





BRIEF DESCRIPTION OF THE DRAWINGS
For a more complete understanding of the present invention and for further objects and advantages thereof, reference is now made to the following description taken in conjunction with the accompanying drawings, in which:
FIGS. 1 through 8 are flow charts for explanation of operation of one preferred form of the present invention;
FIG. 9 is a schematic block diagram of an overall structure of the one preferred form of the present invention;
FIG. 10 is a diagram showing a format of a RAM within a display unit control in the above preferred form of the present invention;
FIGS. 11 and 12 are diagrams showing a key input mode in the above preferred form of the present invention;
FIGS. 13 through 17 are diagrams showing a display mode in the above preferred form of the present invention;
FIGS. 18 and 19 show key arrangements to exchange according to a selected mode in the above preferred form of the present invention;
FIG. 20 is a front view of the appearance of the above preferred form of the present invention;
FIG. 21 shows a display state in which characters or symbols are sequentially shifted according to the above preferred form of the present invention;
FIG. 22 exemplifies key operations and a display mode when the above illustrated embodiment is used as a calculator;
FIG. 23 illustrates a display in the above illustrated embodiment;
FIG. 24 is a perspective view of the appearance of the above illustrated embodiment;
FIGS. 25-A and B are a wiring diagram of a specific example of a central processor unit (CPU) in the embodiment shown in FIG. 9;
FIGS. 26 through 35 are explanation diagrams of basic information processing steps according to the present invention;
FIG. 36 is a program chart showing the procedure for key input processing;
FIG. 37 is a key input circuit diagram for explanation of the procedure shown in FIG. 36;
FIG. 38 is a flow chart showing a further modification in a modified-1 section of FIG. 3;
FIG. 39 is a flow chart showing a further modification in a modified-2 section of FIG. 4;
FIG. 40 is a flow chart showing a further modification in a modified-3 section of FIG. 4;
FIG. 41 is a RAM map within the CPU in the illustrated embodiment of the present invention;
FIG. 42 is a diagram showing the relationship between a word memory and its contents in the illustrated embodiment of the present invention;
FIG. 43 is a diagram showing the relationship between key strobe signals and input terminals of the microprocessor in the illustrated embodiment of the present invention;
FIG. 44 shows key codes used in the above embodiment of the present invention;
FIG. 45 shows character codes used in the above embodiment of the present invention; and
FIG. 46 is a description diagram as to the symbols used in flow charts of FIGS. 1 through 8.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
(OVERALL STRUCTURE OF ONE PREFERRED EMBODIMENT OF THE INVENTION)
As viewed in FIG. 9, one preferred embodiment of the present invention comprises a key unit, a display unit, a display unit control for supplying and controlling display intelligence signals to the display unit, a buffer, a character generator for converting display codes from the display unit control into display pattern information and a central processing unit (CPU) which controls key inputs and supply of display information to the display unit control, executes various arithmetic and logic operations and processes the display information.
The display unit may comprise a well known display medium of a dot matrix type (for example, a 5.times.7 matrix) and is supplied the display information from the display unit control. The display unit control has a buffer memory for storing the display information to be supplied to the display unit in the form of character codes, the output of the buffer memory being applied to the character generator for conversion into display segment information and supply to the display unit. The outputs C.sub.1 -C.sub.n of the display unit control provide for the display unit control signals which help in converting the character codes within the display unit control into the segment information.
Accordingly, when it is desired to display any intelligence signals, information is always supplied to and displayed on the display unit by loading desired character codes or bit signals into display digit positions of the display unit or the buffer memory within the display unit control. The buffer memory within the display unit control may be implemented with a conventional RAM from which information can be read. The above mentioned CPU executes read and write operations on the display unit control. Signals BM and BL from the CPU are address signals which specify the address of the buffer memory within the display unit control, a signal DIO is a data bus signal and a R/W signal is a write signal to the buffer memory. The key unit is under control of outputs Son and inputs Kin from and to the CPU.
The buffer memory within the display unit control is illustrated in FIG. 10. Assuming that an address code is comprised of 4 bits, each character is defined by 8 bits BL=0, 1, etc. A second memory which exactly corresponds to the memory within the display unit control is implemented with a RAM area of the CPU chip. When the CPU prepares the display information to be displayed, it is stored within the RAM area of the CPU in the form of the character codes. When the CPU comes into a display mode, these codes are transferred into the buffer memory within the display unit control. As stated briefly above, the character codes thus transferred into the buffer memory are always converted into the segment information via the character generator and supplied to the display unit.
[CPU ARCHITECTHRE]
FIGS. 25-A and 25-B show a logic wiring diagram of a specific example of the CPU scheme the details of which will be now described. The reference numbers .circle.1 , .circle.2 , etc. used herein indicate control instructions derived from a program store. In the following description flip flops are labeled F/F.
RAM (random access memory): this is of a 4 bit input and output capacity and accessible to a specific digit position thereof as identified by a digit address and a file address.
BL: a digit address counter associated with the memory RAM.
DC.sub.1 : a digit address decoder associated with the memory RAM.
BM: a file address counter associated with the memory RAM.
DC.sub.2 : a file address decoder for the memory RAM
AD.sub.1 : this serves as an adder and a subtractor respectively in the absence and presence of a control instruction .circle.14 .
AD.sub.2 : an adder
G.sub.1 : a gate for providing either a digit "1" or an operand I.sub.A to an input to the adder/subtractor AD.sub.1 and delivering I or I.sub.A when a control instruction .circle.15 or .circle.16 is developed, respectively.
G.sub.2 : an input gate provided for the memory digit address counter BL, which enables the output of the adder/subtractor AD.sub.1, the operand I.sub.A and another operand I.sub.B to pass therethrough respectively when control instructions .circle.10 , .circle.11 and .circle.12 are developed.
G.sub.3 : a gate to provide a digit "1" or the operand I.sub.A to an input to the adder/subtractor, the former being provided upon the development of an instruction .circle.5 and the latter upon the development of an instruction .circle.6 .
G.sub.4 : an input gate to the memory file address BM which enables the output of the adder AD.sub.2, the operand I.sub.A and the contents of an accumulator ACC to pass upon the development of instructions .circle.7 , .circle.8 and .circle.9 .
G.sub.5 : a file selection gate for the memory RAM
DC.sub.3 : a decoder which translates the operand I.sub.A and supplies a gate G.sub.6 with a desired bit specifying signal.
G.sub.6 : an input gate to the memory RAM, which contains a circuit arrangement for introducing a binary code "1" into a specific bit position of the memory identified by the operand decoder DC.sub.3 and a binary code "D" into a specific bit position identified by DC.sub.3, respectively, when a control instruction .circle.2 or .circle.3 is developed. Upon the development of an instruction .circle.4 the contents of the accumulator ACC are read out.
ROM: a read only memory
PL: a program counter PL which specifies a desired step in the read only memory ROM.
DC.sub.4 : a step access decoder for the read only memory
G.sub.7 : an output gate which shuts off transmission of the output of the ROM to an instruction decoder DC.sub.5 when a judge flip flop F/F J is set.
DC.sub.5 : an instruction decoder adapted to decode instruction codes derived from the ROM and divide them into an operation code area I.sub.O and operand areas I.sub.A and I.sub.B, the operation code being decoded into any control instruction .circle.1 - .circle.61 . The decoder DC.sub.5 is further adapted to output the operand I.sub.A or I.sub.B as it is when sensing an operation code accompanied by an operand.
AD.sub.3 : an adder increments one the contents of the program counter PL.
G.sub.8 : an input gate associated with the program counter PL provides the operand I.sub.A and transmits the contents of a program stack register SP when the instructions .circle.20 and .circle.61 are developed, respectively. When the instructions .circle.20 , .circle.61 and .circle.60 are being processed, any output of the adder AD.sub.3 is not transmitted. Otherwise the AD.sub.3 output is transmitted to automatically load "1" into the contents of the program counter PL.
FC: a flag F/F
G.sub.9 : an input gate for the flag F/F FC, which introduces binary codes "1" and "0" into the flag flip flop FC when the instructions .circle.17 and .circle.18 are developed, respectively.
G.sub.10 : a key signal generating gate provides the output of the memory digit address decoder DC.sub.1 without any change when the flag F/F FC is in the reset state (0), and renders all outputs I.sub.l -I.sub.n "1" whatever output DC.sub.1 provides when FC is in the set state (1).
ACC: an accumulator of 4 bits long
X: a temporary register of 4 bits long
G.sub.11 : an input gate for the temporary register X transmits the contents of the accumulator ACC and the stack register SX respectively upon the development of the instructions .circle.29 and .circle.59 .
AD.sub.4 : an adder executes a binary addition on the contents of the accumulator ACC and other data. The output C.sub.4 of the adder AD.sub.4 assumes "1" when the fourth bit binary addition yields a carry.
C: a carry F/F
G.sub.12 : an input gate for the carry F/F, which sets "1" into the carry F/F C in the presence of "1" of the fourth bit carry C.sub.4 and "0" into the same in the absence of C.sub.4 (0) upon the development of .circle.1 . "1" and "0" are set into C upon the development of .circle.21 and .circle.22 , respectively.
G.sub.13 : a carry (C) input gate enables the adder AD.sub.4 to perform binary additions with a carry and thus transmits the output of the carry F/F C into the adder AD.sub.4 in response to the instruction .circle.25 .
G.sub.14 : an input gate provided for the adder AD.sub.4 and transfers the output of the memory RAM and the operand I.sub.A upon the development of .circle.23 and .circle.24 , respectively.
F: an output buffer register having a 4-bit capacity.
G.sub.15 : an input gate which enables the contents of the accumulator ACC to enter into F upon the development of .circle.31 .
SD: an output decoder decodes the contents of the output buffer F into display segment signals SS.sub.1 -SS.sub.n.
W: an output buffer register
SHC: a shift circuit for the output buffer register, which shifts the overall bit contents of the output buffer register W one bit to the right at a time in response to .circle.32 or .circle.33 .
G.sub.16 : an input gate for the output buffer register W leads "1" and "0" into the first bit position of W upon .circle.32 and .circle.33 , respectively. Immediately before "1" or "0" enters into the first bit position of W the output buffer shift circuit SHC becomes operative.
NP: an output control flag F/F.
G.sub.17 : an input gate to the output control flag F/F for receiving "1" and "0" upon the development of .circle.34 and .circle.35 , respectively.
G.sub.18 : an output control gate provided for the buffer register W for providing the respective bit outputs thereof at one time only when the flag F/F NP is in the set state (1).
J: a judge F/F
IV.sub.1 -IV.sub.4 : inverter circuits
G.sub.19 : an input gate for the judge F/F J for transferring the state of an input KN.sub.1 into J upon the development of .circle.36 . In the case where KN.sub.1 =0, J=1 because of intervention of the inverter IV.sub.1.
G.sub.20 : an input gate for the judge F/F J adapted to transfer the state of an input KN.sub.2 into J upon .circle.37 . When KN.sub.2 =0, J=1 because of intervention of the inverter IV.sub.2.
G.sub.21 : an input gate for the judge F/F J adapted to transfer the state of an input KF.sub.1 into J upon .circle.38 . When KF.sub.1 =0, J=1 because of the inverter IV.sub.3.
G.sub.22 : an input gate for the judge F/F J adapted to transfer the state of the input KF.sub.2 into J upon .circle.39 . When KF.sub.2 =0, J=1 because of the intervened inverter IV.sub.4.
G.sub.23 : an input gate provided for the judge flip flop J for transmission of the state of an input AK into J upon the development of .circle.40 . When AK=1, J=1.
G.sub.24 : an input gate G.sub.24 is provided for the judge flip flop J to transmit the state of an input TAB into J pursuant to .circle.41 . When TAB=1, J=1.
G.sub.25 : a gate provided for setting the judge F/F J upon the development of .circle.42 .
V.sub.1 : a comparator compares the contents of the memory digit address counter BL with preselected data and provides an output "1" if there is agreement. The comparator V.sub.1 becomes operative when .circle.43 or .circle.44 is developed.
G.sub.26 : an input gate to the comparator V.sub.1. The data n.sub.1 to be compared are a specific higher address value which is often available in controlling the RAM. n.sub.1 and n.sub.2 are provided for comparison purposes upon the development of .circle.43 and .circle.44 , respectively.
G.sub.27 : an input gate provided for the decision F/F J to enter "1" into J when the carry F/F C assumes "1" upon the development of .circle.45 .
DC.sub.6 : a decoder decodes the operand I.sub.A and helps decisions as to whether or not the contents of a desired bit position of the RAM are "1".
G.sub.28 : a gate transfers the contents of the RAM as specified by the operand decoder DC.sub.6 into the judge F/F when .circle.46 is derived. When the specified bit position of the RAM assumes "1", J=1.
V.sub.2 : a comparator decides whether or not the contents of the accumulator ACC are equal to the operand I.sub.A and provides an output "1" when the affirmative answer is provided. The comparator V.sub.2 becomes operative according to .circle.47 .
V.sub.3 : a comparator decides under .circle.48 whether the contents of the memory digit address counter BL are equal to the operand I.sub.A and provides an output "1" when the affirmative answer is obtained.
V.sub.4 : a comparator decides whether the contents of the accumulator ACC agree with the contents of the RAM and provides an output "1" in the presence of the agreement.
G.sub.29 : a gate which transfers the fourth bit carry C.sub.4 occurring during additions into the judge F/F J. Upon the development of .circle.50 C.sub.4 is sent to F/F J. J=1 in the presence of C.sub.4.
F.sub.A : a flag F/F
G.sub.31 : an input gate which provides outputs "1" and "0" upon the development of .circle.52 and .circle.53 , respectively.
G.sub.32 : an input gate provided for setting the judge F/F J when the flag flip flop FA assumes "1".
F.sub.B : a flag F/F
G.sub.33 : an input gate for the flag F/F, which provides outputs "1" and "0" upon .circle.55 and .circle.56 , respectively.
G.sub.34 : an input gate for the judge flip flop J is adapted to transfer the contents of the flag flip flop F.sub.B into the F/F J upon the development of .circle.54 . F=1 when F.sub.B =1.
G.sub.35 : an input gate associated with the judge F/F J is provided for transmission of the contents of an input .beta. upon .circle.19 . When .beta.=1, J=1.
G.sub.36 : an input gate associated with the accumulator ACC is provided for transferring the output of the adder AD.sub.4 upon .circle.26 and transferring the contents of the accumulator ACC after inverted via an inverter IV.sub.5 upon .circle.27 . The contents of the memory RAM are transferred upon .circle.28 , the operand I.sub.A upon .circle.13 , the 4 bit input contents k.sub.1 -k.sub.4 upon .circle.57 , and the contents of the stack register SA upon .circle.59 .
IV.sub.5 : an inverter circuit
SA: a stack register provides the output outside the present system.
SX: a stack register which also provides the output outside the system.
G.sub.37 : an input gate associated with the stack register SA transfers the accumulator ACC upon .circle.58 .
G.sub.38 : an input gate associated with the stack register SX transfers the contents of the temporary register X.
SP: a program stack register
G.sub.39 : an input gate associated with the program stack register for loading the contents of the program counter PL incremented by "1" through the adder into the program stack register.
F.sub.D : a flag F/F
F.sub.E : a flag F/F
G.sub.40 : an input gate to the judge F/F J for shifting the contents of the flag F/F F.sub.D into F/F J in response to .circle.64 . Accordingly, J=1 when F.sub.D =1.
G.sub.41 : an input gate to the flag F/F F.sub.D, which provides "1" and "0" under control of .circle.62 and .circle.63 , respectively.
G.sub.42 : an input gate to the judge F/F J for shifting the contents of the flag F/F F.sub.E into F/F J in response to .circle.67 . Accordingly, J=1 when F.sub.E =1.
G.sub.43 : an input gate associated with the flag F/F F.sub.E, which provides "1" and "0" under control of .circle.65 and .circle.66 , respectively.
G.sub.44 : an input gate to the judge F/F J to transfer the contents of the input .beta. under control of .circle.68 . J=1 when .alpha.=1.
G.sub.45 : a gate to transfer the contents of the accumulator ACC into a terminal D.sub.I/O upon receipt of .circle.73 .
G.sub.46 : a gate which gates the operands I.sub.A and I.sub.B onto display and key input controlling flags N.sub.1 and N.sub.2 under .circle.69 .
G.sub.47 : a gate which transfers a predetermined number of bits from the memory RAM and becomes operative under control of the state of the key input controlling flag N.sub.2.
EO: an Exclusive-OR logic circuit which acts on the contents of the memory file address counter BM and the operand I.sub.A.
SB: a circuit which takes "1" from the contents of the memory digit address counter BL in response to .circle.75 .
X.sub.B : a temporary storage memory digit address counter which stores the output of G.sub.2 in response to .circle.81 and provides its output for DC.sub.1.
Y: a temporary storage memory digit address counter which stores the output of G.sub.2 in response to .circle.82 and provides its output for DC.sub.1.
S: a temporary storage memory digit address counter which stores the output of G.sub.2 in response to .circle.83 and provides its output for DC.sub.1.
RW: a signal generator which develops a write/read signal for an external memory under .circle.70 and .circle.71 .
PSC: a power supply control circuit which supplies a system power voltage V.sub.DD upon .circle.84 .
Z.sub.1 : a circuit which zeros the memory file address upon .circle.80 .
An illustrative example of the instruction codes contained within the ROM of the CPU structure, the name and function of the instruction codes and the control instructions developed pursuant to the instruction codes will now be tabulated in Table 1.
TABLE 1______________________________________Instruction InstructionCode Name Control Instruction______________________________________1 I.sub.O SKIP .circle.422 I.sub.O AD .circle.23 , .circle.263 I.sub.O ADC .circle.23 , .circle.26 , .circle.25 , .circle.14 I.sub.O ADCSK .circle.23 , .circle.26 , .circle.25 , .circle.50 , .circle.15 I.sub.O I.sub.A ADI .circle.24 , .circle.26 , .circle.506 I.sub.O I.sub.A DC .circle.24 , .circle.26 , .circle.507 I.sub.O SC .circle.218 I.sub.O RC .circle.229 I.sub.O I.sub.A SM .circle.210 I.sub.O I.sub.A RM .circle.311 I.sub.O COMA .circle.2712 I.sub.O I.sub.A LDI .circle.1313 I.sub.O I.sub.A L .circle.28 , .circle.814 I.sub.O I.sub.A LI .circle.28 , .circle.8 , .circle.15 , .circle.10 , .circle.4315 I.sub.O I.sub.A LD .circle.28 , .circle.8 , .circle.14 , .circle.15 , .circle.10 , .circle.4416 I.sub.O I.sub.A X .circle.28 , .circle.4 , .circle.817 I.sub.O I.sub.A XI .circle.28 , .circle.4 , .circle.8 , .circle.15 , .circle.10 , .circle.4318 I.sub.O I.sub.A XD .circle.28 , .circle.4 , .circle.8 , .circle.14 , .circle.16 , .circle.10 , .circle.4419 I.sub.O I.sub.A LBLI .circle.1120 I.sub.O I.sub.A I.sub.B LB .circle.8 , .circle.1221 I.sub.O I.sub.A ABLI .circle.16 , .circle.10 , .circle.4322 I.sub.O I.sub.A AMBI .circle.6 , 723 I.sub.O I.sub.A T .circle.2024 I.sub.O SKC .circle.4525 I.sub.O I.sub.A SKM .circle.4626 I.sub.O I.sub.A SKBI .circle.4827 I.sub.O I.sub.A SKAI .circle.4728 I.sub.O SKAM .circle.4929 I.sub.O SKN.sub.1 .circle.3630 I.sub.O SKN.sub.2 .circle.3731 I.sub.O SKF.sub.1 .circle.3832 I.sub.O SKF.sub.2 .circle.3933 I.sub.O SKAK .circle.4034 I.sub.O SKTAB .circle.4135 I.sub.O SKFA .circle.5136 I.sub.O SKFB .circle.5437 I.sub. O SKFD .circle.6438 I.sub.O SKFE .circle.6739 I.sub.O WIS .circle.3240 I.sub.O WIR .circle.3341 I.sub.O NPS .circle.3442 I.sub.O NPR .circle.3543 I.sub.O ATF .circle.3144 I.sub.O LXA .circle.2945 I.sub.O XAX .circle.29 , .circle.3046 I.sub.O SFA .circle.5247 I.sub.O RFA .circle.5348 I.sub.O SFB .circle.5549 I.sub.O RFB .circle.5650 I.sub.O SFC .circle.1751 I.sub.O RFC .circle.1852 I.sub.O SFD .circle.6253 I.sub.O RFD .circle.6354 I.sub.O SFE .circle.6555 I.sub.O RFE .circle.6656 I.sub.O SKA .circle.6857 I.sub.O SKB .circle.1958 I.sub.O KTA .circle.5759 I.sub.O STPO .circle.5860 I.sub.O EXPO .circle.58 , .circle.5961 I.sub.O I.sub.A TML .circle.62 , .circle.2062 I.sub.O RIT .circle.6163 I.sub.O I.sub.A I.sub.B LNI .circle.6964 I.sub.O READ .circle.70 , .circle.7265 I.sub.O STOR .circle.71 , .circle.7366 I.sub.O I.sub.A EX .circle.28 , .circle.4 , .circle.85 , .circle.1667 I.sub.O DECB .circle.74 , .circle.75 , .circle.4468 I.sub.O BMTA .circle.7669 I.sub.O ATBM .circle.970 I.sub.O BTA .circle.7771 I.sub.O ATB .circle.7872 I.sub.O MTB .circle.7973 I.sub.O SAG .circle.8074 I.sub.O SAX .circle.8175 I.sub.O SAY .circle. 82 , .circle.8076 I.sub.O SAP .circle.8377 I.sub.O I.sub.A LDY .circle.28 , .circle.85 , .circle.10 , .circle.14 , .circle.43 , .circle.8278 I.sub.O OFF .circle.8479 I.sub.O I.sub.A LDA .circle.28 , .circle.8580 I.sub.O ROT .circle.86 , .circle.8781 I.sub.O INCB .circle.14 , .circle.10 , .circle.4382 I.sub.O I.sub.A EXCI .circle.28 , .circle.4 , .circle.85 , .circle.14 , .circle.15 , .circle.10 , .circle.4383 I.sub.O I.sub.A EXCD .circle.28 , .circle.4 , .circle.85 , .circle.75 , .circle.74 , .circle.44______________________________________
INSTRUCTION DESCRIPTION LISTED IN TABLE 1
SKIP:
Only the program counter PL is incremented without executing a next program step instruction, thus skipping a program step.
AD:
A binary addition is effected on the contents of the accumulator ACC and the contents of the RAM, the addition results being loaded back into the accumulator ACC.
ADC:
A binary addition is effected on the contents of the accumulator ACC, the memory RAM and the carry F/F C, the results being loaded back to the accumulator ACC.
ADCSK:
A binary addition is effected on the contents of the accumulator ACC, the memory RAM and the carry flip flop C, the results being loaded into the accumulator ACC. If the fourth bit carry C.sub.4 occurs in the results, then a next program step is skipped.
ADI:
A binary addition is achieved upon the contents of the accumulator ACC and the operand I.sub.A and the results are loaded into the accumulator ACC. If the fourth bit carry C.sub.4 is developed in the addition results, then a next program step is skipped.
DC:
The operand I.sub.A is fixed as "1010" (a decimal number "10") and a binary addition is effected on the contents of the accumulator ACC and the operand I.sub.A in the same way as in the ADI instruction. The decimal number 10 is added to the contents of the accumulator ACC, the results of the addition being loaded into ACC.
SC:
The carry F/F C is set ("1" enters into C).
RC:
The carry F/F C is reset ("0" enters into C).
SM:
The contents of the operand I.sub.A are decoded to give access to a desired bit position of the memory specified by the operand ("1" enters).
RM:
The contents of the operand I.sub.A are interpreted to reset a desired bit position of the memory specified by the operand ("0" enters).
COMA:
The respective bits of the accumulator ACC are inverted and the resulting complement to "15" is introduced into ACC.
LDI:
The operand I.sub.A enters into the accumulator ACC.
L:
The contents of the memory RAM are sent to the accumulator ACC and the operand I.sub.A to the file address counter BM.
LI:
The contents of the memory RAM are sent to the accumulator ACC and the operand I.sub.A to the memory file address counter BM. At this time the memory digit address counter BL is incremented. If the contents of BL agree with the preselected value n.sub.1, then a next program step is skipped.
LD:
The contents of the memory RAM are exchanged with the contents of ACC and the operand I.sub.A is sent to the memory file address counter BM. The memory digit address counter BL is decremented. In the event that the contents of BL agree with the preselected value n.sub.2, then a next program step is skipped.
X:
The contents of the memory RAM are exchanged with the contents of the accumulator ACC and the operand I.sub.A is loaded into the memory file address counter BM.
XI:
The contents of the memory RAM are exchanged with the contents of the accumulator ACC and the operand I.sub.A is sent to the memory file address counter BM. The memory digit address counter BL is incremented. In the event that BL is equal to the preselected value n.sub.1, a next program step is skipped.
XD:
The contents of the memory RAM replaces the contents of the accumulator ACC, the operand I.sub.A being sent to the memory file address counter BM. The memory digit address counter BL at this time is incremented. If the contents of BL are equal to n.sub.2, then a next program step is skipped.
LBLI:
The operand I.sub.A is loaded into the memory digit address counter BL.
LB:
The operand I.sub.A is loaded into the memory file address counter BM and the operand B to the memory digit address counter BL.
ABLI:
The operand I.sub.A is added to the contents of the memory digit address counter BL in a binary addition fashion, the results being loaded back to BL. If the contents of BL are equal to n.sub.1, then no next program step is carried out.
ABMI:
The operand I.sub.A is added to the contents of the memory file address counter BM in a binary fashion, the results being into BM.
T:
The operand I.sub.A is loaded into the program step counter PL.
SKC:
If the carry flip flop C is "1", then no next program step is taken.
SKM:
The contents of the operand I.sub.A are decoded and a next program step is skipped as long as a specific bit position of the memory specified by the operand I.sub.A assumes "1".
SKBI:
The contents of the memory digit address counter BL are compared with the operand I.sub.A and a next succeeding program step is skipped when there is agreement.
SKAI:
The contents of the accumulator ACC are compared with the operand I.sub.A and if both are equal to each other a next program step is skipped.
SKAM:
The contents of the accumulator ACC are compared with the contents of the RAM and if both are equal a next program step is skipped.
SKN.sub.1 :
When the input KN.sub.1 is "0", a next program step is skipped.
SKN.sub.2 :
When the input KN.sub.2 is "0", a next program step is skipped.
SKF.sub.1 :
When the input KF.sub.1 is "0", a next program step is skipped.
SKF.sub.2 :
When the input KF.sub.2 is "0", a next program step is skipped.
SKAK:
When the input AK is "1", a next program step is skipped.
SKTAB:
When the input TAB is "1", a next program step is skipped.
SKFA:
When the flag F/F F/A assumes "1" a next program step is skipped.
SKFB:
When the flag F/F F.sub.B assumes "1", a next program step is skipped.
SKFD:
When the flag F/F F.sub.D assumes "1", a next program step is skipped.
SKFE:
When the flag F/F F.sub.E assumes "1", a next program step is skipped.
WIS:
The contents of the output buffer register W are one bit right shifted, the first bit position (the most significant bit position) receiving "1".
WIR:
The contents of the output buffer register W are one bit right shifted, the first bit position (the most significant bit position being loaded with "0").
NPS:
The output control F/F N.sub.p for the buffer register W is set ("1" enters).
NPR:
The buffer register output control flip flop N.sub.p is reset ("0" enters therein).
ATF:
The contents of the accumulator ACC are transferred into the output buffer register F.
LXA:
The contents of the accumulator ACC are unloaded into the temporary register X.
XAX:
The contents of the accumulator ACC are exchanged with the contents of the temporary register X.
SFA:
The flag F/F FA is set (an input of "1").
RFA:
The flag F/F FA is reset (an input of "0").
SFB:
The flag flip flop F.sub.B is set (an input of "1").
RFB:
The flag flip flop F.sub.B is reset (an input of "0").
SFC:
An input testing flag F/F F.sub.C is set (an input of "1").
RFC:
The input testing flag F/F F.sub.C is reset (an input of "0").
SFD:
The input testing flag F/F F.sub.D is set (an input of "1").
RFD:
The input testing flag F/F F.sub.D is reset (an input of "0").
SFE:
The input testing flag F/F F.sub.E is set (an input of "1").
RFE:
The input testing flag F/F F.sub.E is reset (an input of "0").
SKA:
When an input .alpha. is "1", a next program step is skipped.
SKB:
When an input .beta. is "1", a next program step is skipped.
KTA:
The inputs k.sub.1 -k.sub.4 are introduced into the accumulator ACC.
STPO:
The contents of the accumulator ACC are sent to the stack register SA and the contents of the temporary register X to the stack register SX.
EXPO:
The contents of the accumulator ACC are exchanged with the stack register SA and the contents of the temporary register X with the stack register SX.
TML:
The contents of the program counter P.sub.L incremented by one are transferred into the program stack register SP and the operand I.sub.A into the program counter P.sub.L.
RIT:
The contents of the program stack register SP are transmitted into the program counter P.sub.L.
LN.sub.1 :
The operands I.sub.A and I.sub.B enter the display and key input controlling flag F/Fs N.sub.1 and N.sub.2, respectively.
READ:
Data externally applied to D.sub.I/O are introduced into the accumulator ACC.
STOR:
The contents of the accumulator ACC are unloaded into D.sub.I/O.
EX:
The contents of the memory RAM are exchanged with that of the accumulator ACC and an exclusive-OR'ed output of the operand I.sub.A and the contents of the memory file address counter B.sub.M is supplied to B.sub.M.
DECB:
The memory digit address counter B.sub.L is decremented by "1". When the contents of B.sub.L are equal to the preset value n.sub.2, a next instruction is skipped.
BMTA:
The memory file address counter B.sub.M is unloaded into the accumulator ACC.
ATMB:
The accumulator ACC is unloaded into the file address counter B.sub.M.
BTA:
A selected one of the memory digit address counters B.sub.L, X.sub.B, Y and S is unloaded into the accumulator ACC.
ATB:
The accumulator ACC is unloaded into a selected one of the memory digit address counters B.sub.L, X.sub.B, Y and S.
MTB:
The memory RAM is unloaded into a selected one of the memory digit address counters B.sub.L, X.sub.B, Y and S.
SAG:
The memory file address which specifies a next step is reduced to "0000".
SAX:
The memory file address which specifies a next step is determined by the contents of X.sub.B.
SAY:
The memory file address which specifies a next step is determined by the contents of Y, while the file address is reset to "0000".
SAP:
The memory file address which specifies a next step is determined by the contents of S.
LDY:
The memory RAM is unloaded into the accumulator ACC and an exclusive-OR'ed output of the memory file address counter B.sub.M and the operand I.sub.A is introduced into B.sub.M. A selected one of B.sub.L, X, Y and S is incremented by one. However, when the selected counter is equal to the preset value n.sub.1, a next program step is skipped. The memory digit address which specifies a next step is determined by the contents of Y.
OFF:
The system power voltage V.sub.DD is switched OFF. Power supply continues in connection with a power supply control section to the RAM containing the built-in output buffer.
LDA:
The contents of the memory are unloaded into the accumulator and an exclusive-OR'ed output of the operand I.sub.A and the contents of the memory file address counter B.sub.M is returned back to B.sub.M.
ROT:
The contents of the accumulator is right shifted in cooperation with C F/F.
INCB:
The memory digit address counter B.sub.L is incremented. When the contents of B.sub.L agree with the preset value n.sub.1, a next instruction is skipped.
EXCI:
Exchange takes place between the accumulator and the memory and an exclusive-OR'ed output of the memory address counter B.sub.M and the operand I.sub.A is loaded back into B.sub.M and the digit address counter B.sub.1 is incremented. When B.sub.L =n.sub.1 a next step is skipped.
EXCD:
Exchange takes place between the accumulator and the memory and an exclusive-OR'ed output of the memory file address counter B.sub.M and the operand I.sub.A is loaded into B.sub.M and the digit address counter B.sub.L is decremented. When B.sub.L =n.sub.2, a next instruction is skipped.
Major processing operations of the CPU structure will now be described in sufficient detail.
(1) PROCEDURE OF LOADING A SAME VALUE N INTO A SPECIFIC REGION OF THE MEMORY (NNN.fwdarw.X)
TABLE 2______________________________________(Type 1) ##STR1##______________________________________
In Table 2,
P.sub.1 --The first digit position of the memory to be processed is specified by a file address m.sub.A and a digit address n.sub.E. (see FIG. 26)
P.sub.2 --The value N is loaded into ACC.
P.sub.3 --The value N is loaded into the specified region of the memory by exchange between the memory and ACC. With no change in the file address of the memory, m.sub.A is specified and the digit address is decremented to determine a digit to be next introduced. By determining n.sub.2 as the final digit value n.sub.A to be introduced, the next step P.sub.4 is skipped to complete the processing of the Type 1 since BL=n.sub.2 under the condition that the value N has been completely loaded into the specific region.
P.sub.4 --LDI and XD are carried out repeatedly from the program address P.sub.2 up to BL=V.
TABLE 3______________________________________(Type 2) ##STR2##______________________________________
In Table 3,
P.sub.1 --The digit of the memory to be processed is determined by the file address m.sub.B and the digit address n.sub.C.
P.sub.2 --The ACC is loaded with the value N.
P.sub.3 --By exchange between the memory and ACC the value N is loaded into the above specified region of the memory. This completes the processing of Type 2. An operand area of X.sub.D is necessary to the next succeeding process and not to this step.
TABLE 4______________________________________(Type 3) ##STR3##______________________________________
In Table 4,
P.sub.1 --The first digit of the memory to be processed is specified by the file address m.sub.C and the digit address n.sub.O.
P.sub.2 --The ACC is loaded with the value N.
P.sub.3 --By exchange between the memory and ACC the value N is loaded into that specified region of the memory. With no change in the file address of the memory m.sub.C is specified and the digit address is decremented in order to determine the digit to be next loaded therein.
P.sub.4 --It is decided whether the digit processed during the step P.sub.3 is the final digit n.sub.B. If it is n.sub.B, then the digit address is decremented to n.sub.A. An operand area of the SKI instruction is occupied by n.sub.A, thus loading the final digit with the value N. In reaching P.sub.4, conditions are fulfilled and the next step P.sub.5 is skipped, thereby terminating the type 3. If the conditions are not fulfilled, P.sub.5 is then reached.
P.sub.5 --The program address P.sub.2 is specified and P.sub.2 -P.sub.4 are repeated until BL=n.sub.A.
(2) PROCEDURE OF LOADING A PREDETERMINED NUMBER OF DIFFERENT VALUES INTO A SPECIFIC REGION OF THE MEMORY (N.sub.1, N.sub.2, N.sub.3, . . . .fwdarw.X)
(Type 1) For example, four digit values N.sub.4 N.sub.3 N.sub.2 N.sub.1 are loaded an arbitrary digit position in the same manner as above.
TABLE 5______________________________________ ##STR4##P.sub.1 --The first processed digit position of the memory is specified
P.sub.2 --A constant N.sub.1 is loaded into ACC.
P.sub.3 --Through exchange between the memory and the ACC the value N.sub.1 is loaded into the above specified region of the memory. The file address of the memory remains unchanged as m.sub.A, whereas the digit address is up for introduction of the next digit.
P.sub.4 --A second constant N.sub.2 is loaded into ACC.
P.sub.5 --Since the second digit of the memory has been specified during P.sub.3, the second constant N.sub.2 is loaded into the second digit position of the memory through exchange between the memory and ACC.
P.sub.6 -P.sub.9 --The same as in the above paragraph.
(Type 2) Any value of 0-15 is loaded into a predetermined register.
TABLE 6______________________________________ ##STR5##______________________________________
In Table 6,
P.sub.1 --The value N is loaded into ACC.
P.sub.2 --The value N is transmitted from ACC into the register X.
(3) PROCEDURE OF TRANSFERRING THE CONTENTS OF A SPECIFIC REGION OF THE MEMORY TO A DIFFERENT REGION OF THE MEMORY
TABLE 7______________________________________ ##STR6## ##STR7##______________________________________
In Table 7,
P.sub.1 --The first memory file address is specified as m.sub.A and the first digit address as n.sub.E. (see FIG. 28)
P.sub.2 --The contents of the first digit position of the memory are loaded into ACC and its designation, the second memory file address is specified as m.sub.B prior to the transmission step P.sub.3.
P.sub.3 --The first digit memory contents loaded into the ACC are replaced by the same second memory digit contents so that the first memory contents are transmitted into the second memory. In order to repeat the above process, the first memory file address m.sub.A is again set. The value of the final digit n.sub.A to be transmitted is previously selected to be n.sub.1. Since BL.fwdarw.n.sub.1 after the overall first memory contents have been sent to the second memory, the next step P.sub.4 is skipped to complete the processing of Type 1. The digit address is progressively incremented until BL=V (the final digit). Through the step P.sub.4 the file address is set up at m.sub.A to lead back to P.sub.2, thereby specifying the first memory.
P.sub.4 --The program address is set at the step P.sub.2 and the instructions P.sub.2 and P.sub.3 are repeatedly executed until BL=n.sub.1. The transmission step is advanced digit by digit.
In Table 8, it is noted that P.sub.1 specifies the region of the memory which is subject to the processing step, using the file address m.sub.A and the digit address n.sub.C. (see FIG. 29)
TABLE 8______________________________________ ##STR8## ##STR9##______________________________________
P.sub.1 --The region of the memory to be processed is determined by the file address m.sub.A and the digit address n.sub.C.
P.sub.2 --The contents of the memory as specified above are unloaded into ACC and the memory file address is set at m.sub.C prior to the next transmission step P.sub.4.
P.sub.3 --The digit address of the memory, the destination for the transmission process, is specified as m.sub.C. The destinated region of the memory is specified via the steps P.sub.2 and P.sub.3.
P.sub.4 --The contents of ACC are exchanged with the contents of the regions of the memory specified by P.sub.2 and P.sub.3. The operand of X has no connection with the present process.
TABLE 9______________________________________(Type 3) ##STR10##______________________________________
In Table 9,
P.sub.1 --The region of the memory to be processed is identified by the file address m.sub.A and the digit address n.sub.C. (see FIG. 30)
P.sub.2 --The contents of the memory region specified during P.sub.1 are unloaded into ACC.
P.sub.3 --The contents of the memory transmitted from ACC are sent to the register X, completing the type 3 processing.
(4) PROCEDURE OF EXCHANGING CONTENTS BETWEEN A SPECIFIC REGION OF THE MEMORY AND A DIFFERENT REGION (X.fwdarw.Y)
TABLE 10______________________________________ ##STR11## ##STR12##______________________________________
In Table 10,
P.sub.1 --The first memory file address to be processed is specified as m.sub.A and the first digit address as n.sub.E. (See FIG. 31)
P.sub.2 --The specific digit contents of the first memory are loaded into ACC and the second memory file address is specified as m.sub.B for preparation of the next step.
P.sub.3 --The specific digit contents of the first memory contained within ACC are exchanged with the same digit contents of the second memory specified by P.sub.2. The file address of the first memory is specified as m.sub.A in order to load the contents of the memory now in ACC into the first memory.
P.sub.4 --The contents of the second memory now in ACC are exchanged with the contents of the first memory at the corresponding digit positions so that the contents of the second memory are transferred to the first memory. Exchanges are carried out during the steps P.sub.2 -P.sub.4.
The first memory is specified on by the file address m.sub.A, while the digit address is incremented to select a next address.
Exchange is carried out progressively digit by digit. The final digit value n.sub.A is previously set at n.sub.1 such that B.sub.L =n.sub.1 after the exchange operation between the first memory and the second has been effected throughout the all digit positions, thus skipping the next step P.sub.5 and completing the processing of Type 1.
P.sub.5 --The program address P.sub.2 is selected and the instructions for P.sub.2 to P.sub.4 are executed repeatedly until B.sub.L =n.sub.1. The exchange operation is advanced digit by digit.
TABLE 11______________________________________ ##STR13## ##STR14##______________________________________
In Table 11,
P.sub.1 --The file address of the first memory to be processed is specified as m.sub.A and the digit address as n.sub.C. (see FIG. 32)
P.sub.2 --The contents of the specific digit position of the first memory are unloaded into ACC and the file address of the second memory is specified as m.sub.C and ready to exchange.
P.sub.3 --The digit address of the second memory, the destination for the exchange process, is specified as n.sub.O to determine the destinated memory address.
P.sub.4 --The contents of the first memory now within ACC are exchanged with that of the second memory. At the same time the file address m.sub.B of the first memory is again specified to transfer the contents of the first memory to the first memory.
P.sub.5 --The digit address n.sub.C of the first memory is specified to determine the destination address of the first memory.
P.sub.6 --The contents of the second memory now within ACC are exchanged with the contents of the first memory.
TABLE 12______________________________________ ##STR15## ##STR16##______________________________________
In Table 12,
P.sub.1 --The file address m.sub.A of the first memory to be processed is specified and the digit address n.sub.C is specified.
P.sub.2 --The contents of the first memory are loaded into ACC and the file address m.sub.C of the second memory is selected.
P.sub.3 --The exchange is carried out between the first and second memory so that the contents of the first memory are loaded into the second memory. Prior to the step P.sub.4 the file address m.sub.B of the first memory is selected again.
P.sub.4 --The exchange is effected between the contents of the second memory and the first memory.
TABLE 13______________________________________(Type 4) ##STR17##______________________________________
In Table 13,
P.sub.1 --The region of the memory to be processed is specified by the file address m.sub.A and the digit address n.sub.C. (see FIG. 34)
P.sub.2 --The contents of the memory region specified in P.sub.1 above are loaded into ACC. The file address m.sub.B is kept being selected prior to the exchange with the contents of the register X.
P.sub.3 --The exchange is effected between ACC and the register X so that the contents of the memory are shifted to the register X.
P.sub.4 --Through the exchange between ACC containing the contents of the register X and the memory, the contents of the register X are substantially transferred into the memory, thus accomplishing the Type 4 processing.
(5) PROCEDURE OF EFFECTING A BINARY ADDITION OR SUBTRACTION OF A GIVEN VALUE N ONTO A SPECIFIC REGION OF THE MEMORY
TABLE 14______________________________________ ##STR18## ##STR19##______________________________________
In Table 14,
P.sub.1 --The region of the memory to be processed is specified by the file address m.sub.B and the digit address n.sub.C. (see FIG. 35)
P.sub.2 --The contents of the memory specified by the step P.sub.1 are unloaded into ACC.
The memory file address is set again at m.sub.B to specify the same memory.
P.sub.3 --The operand specifies the value N to be added and the contents of the memory contained within ACC are added with the value N, the results being loaded back to ACC.
P.sub.4 --The sum contained with ACC is exchanged with the contents of the memory specified by the step P.sub.2, thus completing the Type 1 processing.
TABLE 15______________________________________ ##STR20## ##STR21##______________________________________
In Table 15,
P.sub.1 --The exchange is effected between the register X and ACC.
P.sub.2 --The operand specifies the value N to be added and an addition is carried out on the contents of the register X now within ACC and the value N, with the results back to ACC.
P.sub.3 --Through the exchange between the resulting sum within ACC and the contents of the register X, the processing of Type 2 (X+N.fwdarw.X) is performed.
TABLE 16______________________________________ ##STR22## ##STR23##______________________________________
In Table 16,
P.sub.1 --The region of the first memory to be processed is decided by the file address m.sub.B and the digit address n.sub.C.
P.sub.2 --The contents of the memory specified by P.sub.1 are loaded into ACC. The file address m.sub.C of the second memory is specified to return addition results to the second memory.
P.sub.3 --The operand specifies the value N to be added and the value N is added to the contents of the memory now within ACC, with the results being loaded into ACC.
P.sub.4 --The resulting sum within ACC is exchanged with the contents of the second memory as specified by P.sub.2, thus completing the processing of Type 3.
TABLE 17______________________________________ ##STR24## ##STR25##______________________________________
In Table 17,
P.sub.1 --There are specified the file address m.sub.B and the digit address n.sub.C of the memory to be processed.
P.sub.2 --Subtraction is carried out in such a way that the complement of a subtrahend is added to a minuend and the F/F C remains set because of the absence of a borrow from a lower digit position.
P.sub.3 --ACC is loaded with the subtrahend N.
P.sub.4 --The complement of the subtrahend to "15" is evaluated and loaded into ACC.
P.sub.5 --In the event that any borrow occurs during the subtraction, the complement of the subtrahend to "16" is added to the minuend. If a borrow free state is denoted as C=1, then a straight binary subtraction of ACC+C+M.fwdarw.ACC is effected.
P.sub.6 --The resulting difference during P.sub.5 is returned to the same memory through the exchange between ACC and that memory.
TABLE 18______________________________________ ##STR26## ##STR27##______________________________________
In Table 18,
P.sub.1 -P.sub.5 --Same as Type 4
P.sub.6 --To load the resulting difference during P.sub.5 into the second memory, the file address m.sub.C and the digit address n.sub.C of the second memory are selected.
P.sub.7 --Through exchange the resulting difference is transferred from ACC into the second memory as specified by the step P.sub.6.
TABLE 19______________________________________ ##STR28## ##STR29##______________________________________
In Table 19,
P.sub.1 --The file address m.sub.B and the digit address n.sub.C of the memory ready for the step P.sub.5 are selected.
P.sub.2 --Subtraction is carried out in the manner of adding the complement of a subtrahend to a minuend and the F/F C remains set because of the absence of a borrow from a lower digit position.
P.sub.3 --ACC is loaded with the subtrahend N.
P.sub.4 --The complement of the subtrahend to "15" is evaluated and loaded into ACC.
P.sub.5 --To accomplish calculations with the contents of the register X, the memory as specified by P.sub.1 is loaded with the contents of ACC.
P.sub.6 --The contents of the register X are transmitted into ACC through the exchange process. After this step the memory contains the complement of the subtrahend to "15" and ACC contains the contents of X.
P.sub.7 --ACC+M+C corresponds to X-N and the results of a binary subtraction are loaded into ACC.
P.sub.8 --The contents of ACC are exchanged with the contents of X and the value of X-N is transmitted into X, thereby completing the processing of Type 6.
TABLE 20______________________________________ ##STR30## ##STR31##______________________________________
In Table 20,
P.sub.1 --The file address m.sub.B and the digit address n.sub.C of the memory to be processed are selected.
P.sub.2 --One-digit subtraction is effected in the manner of adding the complement of a subtrahend to a minuend, in which case F/F C remains set.
P.sub.3 --ACC is loaded with a minuend.
P.sub.4 --The exchange is effected between the memory (the subtrahend) and ACC and the memory file address remains as m.sub.B for preparation of P.sub.7.
P.sub.5 --The complement of a subtrahend in ACC to "15" is evaluated and loaded into ACC.
P.sub.6 --In the event that there is no borrow from a lower digit position, the complement of a subtrahend to "16" is added to a minuend. If a borrowless state is denoted as C=1, then N-M is substantially executed by ACC+C+M, the resulting difference being loaded into ACC.
P.sub.7 --Since the memory file address remains unchanged during P.sub.4, the difference is unloaded from ACC back to the memory, thus completing the processing of Type 7.
TABLE 21______________________________________ ##STR32## ##STR33##______________________________________
In Table 21,
P.sub.1 --The file address m.sub.B and the digit address n.sub.C of the memory to be processed are selected.
P.sub.2 --The contents specified by the step P.sub.1 and corresponding to a subtrahend are loaded into ACC. The file address m.sub.C of the second memory is specified for preparation of a step P.sub.5.
P.sub.3 --The complement of the subtrahend to "15" is evaluated and loaded into ACC.
P.sub.4 --The operand is made a minuend plug "1". This subtraction is one digit long and accomplished by adding the complement of the subtrahend to the minuend. A conventional complementary addition is defined as ACC+C+M as in the Type 7 processing in the absence of a borrow as defined by C=1. Since the ADI instruction carries C, ACC+1 is processed in advance. This completes the processing of Type 8 of N-M, the results being stored within ACC.
P.sub.5 --The difference obtained from the step P.sub.4 is transmitted into the second memory specified by P.sub.2.
TABLE 22______________________________________ ##STR34## ##STR35##______________________________________
P.sub.1 --(When M+1) ACC is loaded with a binary number "0001" (=1).
P.sub.1 '--(When M-1) ACC is loaded with a binary number "1111" (=15).
P.sub.2 --The file address m.sub.B and the digit address n.sub.C of the memory to be processed are selected.
P.sub.3 --The contents of the memory specified by P.sub.2 are added to the contents contained within ACC during P.sub.1 or P.sub.1 ', the sum thereof being loaded into ACC. In the case of P.sub.1 ACC+1 and in the case of P.sub.1 ' ACC-1.
P.sub.4 --The results are unloaded from ACC to the original memory position, thus completing the processing fashion of Type 9.
(6) PROCEDURE OF EFFECTING A DECIMAL ADDITION OR SUBTRACTION BETWEEN A SPECIFIC REGION OF THE MEMORY AND A DIFFERENT REGION
TABLE 23______________________________________ ##STR36## ##STR37##______________________________________
In Table 23,
P.sub.1 --The first digit position of the first memory to be processed is identified by the file address m.sub.A and the digit address n.sub.E.
P.sub.2 --The carry F/F C is reset because of a carry from a lower digit position in effecting a first digit addition.
P.sub.3 --The contents of the specific digit position of the first memory are loaded into ACC and the file address m.sub.B of the second memory is selected in advance of additions with the contents of the second memory during P.sub.4.
P.sub.4 --"6" is added to the contents of the specific digit position of the first memory now loaded into ACC for the next succeeding step P.sub.5 wherein a decimal carry is sensed during addition.
P.sub.5 --ACC already receives the contents of the first memory compensated with "6" and a straight binary addition is effected upon the contents of ACC and the contents of the second memory at the corresponding digit positions, the results being loaded back to ACC. In the event a carry is developed during the binary addition at the fourth bit position, P.sub.7 is reached without passing P.sub.6. The presence of the carry during the fourth bit addition implies the development of a decimal carry.
P.sub.6 --In the event the decimal carry failed to develop during the addition P.sub.5, "6" for the process P.sub.4 is overruded. An addition of "10" is same as a subtraction of "6".
P.sub.7 --The one-digit decimal sum is unloaded from ACC into the second memory and the digit address is incremented for a next digit addition and the file address m.sub.A of the first memory is selected. The final digit to be added is previously set at n.sub.1. Since BL=n.sub.1 after the overall digit addition is effected upon the first and second memory, the next succeeding step P.sub.8 is skipped to thereby complete the processing of Type 1.
P.sub.8 --The program address P.sub.3 is selected and the instructions P.sub.3 -P.sub.7 are repeatedly executed until BL=n.sub.1. A decimal addition is effected digit by digit.
TABLE 24______________________________________ ##STR38## ##STR39##______________________________________
In Table 24,
P.sub.1 --The first digit position of the first memory to be processed is specified by the file address m.sub.A and the digit address n.sub.E.
P.sub.2 --Subtraction is performed in the manner of adding the complement of a subtrahend to a minuend and F/F C is set because of the absence of a borrow from a lower digit position during the first digit subtraction.
P.sub.3 --The contents of the specific digits in the first memory, the subtrahend, are loaded into ACC and the file address m.sub.B of the second memory is specified in advance of the step P.sub.7 with the second memory.
P.sub.4 --The complement of the subtrahend to "15" is evaluated and loaded into ACC.
P.sub.5 --In the event that there is no borrow from a lower digit place, the complement of the subtrahend is added to the minuend to perform a subtraction. On the contrary, in the presence of a borrow, the complement of the subtrahend is added to the minuend. If a borrowless state is denoted as C=1, then a binary addition of ACC+C+M.fwdarw.ACC is effected. The development of a carry, as a consequence of the execution of the ADSCK instruction, implies failure to give rise to a borrow and leads to the step P.sub.7 without the intervention of the step P.sub.6. Under these circumstances the addition is executed with the second memory, thus executing substantially subtraction between the first and second memories.
P.sub.6 --In the case where no carry is developed during the execution of the ADCSK instruction by the step P.sub.5, the calculation results are of the sexadecimal notation and thus coverted into a decimal code by subtraction of "6" (equal to addition of "10").
P.sub.7 --The resulting difference between the first and second memories is transmitted from ACC into the second memory. The digit address is incremented and the file address m.sub.A of the first memory is specified in advance of a next succeeding digit subtraction. The final digit to be subtracted is previously determined as n.sub.1. Since BL=n.sub.1 after the overall-digit subtraction has been completed, the next step P.sub.8 is skipped to thereby conclude the processing of Type 2.
P.sub.8 --After selection of the program address P.sub.3 the instructions P.sub.3 -P.sub.7 are repeatedly executed until BL=n.sub.1. The decimal subtraction is advanced digit by digit.
(7) PROCEDURE OF SHIFTING ONE DIGIT THE CONTENTS OF A SPECIFIC REGION OF THE MEMORY
TABLE 25______________________________________(Type 1) Right Shift ##STR40##______________________________________
In Table 25,
P.sub.1 --The file address m.sub.A and the digit address n.sub.A of the memory to be processed are determined.
P.sub.2 --ACC is loaded with "0" and ready to introduce "0" into the most significant digit position when the right shift operation is effected.
P.sub.3 --The exchange is carried out between XCC and the memory and the digit address is decremented to specific a one digit lower position. The memory address is still at m.sub.A. XD is repeated executed through P.sub.4 and P.sub.3. By the step ACC.rarw..fwdarw.M "0" is transmitted from ACC to the most significant digit position of the memory which in turn provides its original contents for ACC. When the digit address is down via B and XD is about to be executed at P.sub.3 via P.sub.4, the second most significant digit is selected to contain the original content of the most significant digit position which has previously been contained within ACC. At this time ACC is allowed to contain the contents of the second most significant digit position. The least significant digit is previously selected as n.sub.2. If the transmission step reaches the least significant digit position BL=n.sub.2 is satisfied and P.sub.4 is skipped. In other words, the digit contents are shifted down to thereby conclude the processing of Type 1.
P.sub.4 --XD is repeated at P.sub.3 until BL=V.
TABLE 26______________________________________(Type 2) Left Shift ##STR41##______________________________________
In Table 26,
P.sub.1 --The file address m.sub.A and the least significant digit n.sub.E of the memory to be processed are determined.
P.sub.2 --ACC is loaded with "0" and ready to introduce "0" into the least significant digit position when the left shift operation is started.
P.sub.3 --The exchange is carried out between ACC and the memory and the digit address is incremented to specify a one digit upper position. The memory address is still at m.sub.A. XD is repeated executed through P.sub.4 and P.sub.3. By the step ACC.fwdarw.M, "0" is transmitted from ACC to the least significant digit position of the memory which in turn provides its original contents for ACC. When the digit address is up via P.sub.3 and XD is about to be executed at P.sub.3 via P.sub.4, the second least significant digit is selected to contain the original content of the least significant digit position which has previously been contained within ACC. At this time ACC is allowed to contain the contents of the second least significant digit position. The most significant digit is previously selected as n.sub.1.
If the transmission step reaches the most significant digit position, BL=n.sub.1 is satisfied and P.sub.4 is skipped. In other words, the digit contents are shifted up to thereby conclude the processing of Type 2.
P.sub.4 --XI is repeated at P.sub.3 until BL=V.
(8) PROCEDURE OF SETTING OR RESETTING A ONE-BIT CONDITION F/F ASSOCIATED WITH A SPECIFIC REGION OF THE MEMORY
TABLE 27______________________________________(Type 1) ##STR42##______________________________________
In Table 27,
P.sub.1 --The file address m.sub.B and the digit address n.sub.C of a region of the memory to be processed are determined.
P.sub.2 --"1" is loaded into a desired bit N within the digit position of the memory specified by P.sub.1, thus concluding the processing of Type 1.
TABLE 28______________________________________(Type 2) ##STR43##______________________________________
In Table 28,
P.sub.1 --The file address m.sub.B and the digit address n.sub.C of a region of the memory to be processed are determined.
P.sub.2 --"0" is loaded into a desired bit N within the digit position of the memory specified by P.sub.1, thus concluding the processing of Type 2.
(9) PROCEDURE OF SENSING THE STATE OF THE ONE-BIT CONDITIONAL F/F ASSOCIATED WITH A SPECIFIC REGION OF THE MEMORY AND CHANGING A NEXT PROGRAM ADDRESS (STEP) AS A RESULT OF THE SENSING OPERATION
TABLE 29______________________________________ ##STR44##______________________________________
In Table 29,
P.sub.1 --There are specified the file address m.sub.B and the digit address n.sub.C where a desired one-bit conditional F/F is present.
P.sub.2 --In the case where the contents of the bit position (corresponding to the conditional F/F) specified by N within the memory region as selected during P.sub.1 assume "1", the step proceeds to P.sub.4 with skipping P.sub.3, thus executing the operation OP.sub.1. In the event that the desired bit position bears "0", the next step P.sub.3 is skipped.
P.sub.3 --When the foregoing P.sub.2 has been concluded as the conditional F/F in the "0" state, the program step P.sub.n is selected in order to execute the operation OP.sub.2.
(10) PROCEDURE OF DECIDING WHETHER THE DIGIT CONTENTS OF A SPECIFIC REGION OF THE MEMORY REACH A PRESELECTED NUMERAL AND ALTERING A NEXT PROGRAM ADDRESS (STEP) ACCORDING TO THE RESULTS OF THE DECISION
TABLE 30______________________________________ ##STR45##______________________________________
In Table 30,
P.sub.1 --The region of the memory which contains contents to be decided is identified by the file address m.sub.B and the digit address n.sub.C.
P.sub.2 --The contents of the memory as identified during P.sub.1 are unloaded into ACC.
P.sub.3 --The contents of ACC are compared with the preselected value N and if there is agreement the step advances toward P.sub.5 without executing P.sub.4 to perform the operation OP.sub.1. P.sub.4 is however reached if the contents of ACC are not equal to N.
P.sub.4 --The program address (step) P.sub.n is then selected to perform the operation OP.sub.2.
(11) PROCEDURE OF DECIDING WHETHER THE PLURAL DIGIT CONTENTS OF A SPECIFIC REGION OF THE MEMORY ARE EQUAL TO A PRESELECTED NUMERAL AND ALTERING A PROGRAM STEP ACCORDING TO THE RESULTS OF THE DECISION
TABLE 31______________________________________ ##STR46##______________________________________
In Table 31,
P.sub.1 --The region of the memory to be judged is identified by the file address m.sub.B and the first digit address n.sub.E.
P.sub.2 --The value N is loaded into ACC for comparison.
P.sub.3 --The value V within ACC is compared with the digit contents of the specific region of the memory and if there is agreement P.sub.5 is reached without passing P.sub.4 to advance the comparison operation toward the next succeeding digit. P.sub.4 is selected in a non-agreement.
P.sub.4 --In the case of a non-agreement during P.sub.3 the program address (step) P.sub.n is specified to execute the operation forthwith.
P.sub.5 --The digit address is incremented by adding "1" thereto. This step is aimed at evaluating in sequence a plurality of digits within the memory. The ultimate digit to be evaluated is previously determined as (V). The comparison is repeated throughout the desired digit positions. If a non-agreement state occurs on the way, the operation OP.sub.2 is accomplished through P.sub.4. In the case where the agreement state goes on till BL=V, there is selected P.sub.7 rather than P.sub.6 to perform the operation OP.sub.1.
P.sub.6 --When the agreement state goes on during P.sub.5, P.sub.3 is reverted for evaluation.
(12) PROCEDURE OF DECIDING WHETHER THE CONTENTS OF A SPECIFIC REGION OF THE MEMORY ARE SMALLER THAN A GIVEN VALUE AND DECIDING WHICH ADDRESS (STEP) IS TO BE EXECUTED
TABLE 32______________________________________ ##STR47##______________________________________
In Table 32,
P.sub.1 --The file address m.sub.B and the digit address n.sub.C of the memory are decided.
P.sub.2 --The contents of the memory as specified during P.sub.1 are unloaded into ACC.
P.sub.3 --N is the value to be compared with the contents of the memory and the operand area specifies 16-N which in turn is added to the contents of ACC, the sum thereof being loaded back to ACC. The occurrence of a fourth bit carry during the addition suggests that the result of the binary addition exceeds 16, that is, M+(16-N).gtoreq.16 and hence M.gtoreq.N. The step is progressed toward P.sub.4.
P.sub.4 --When M.gtoreq.N is denied, the program step P.sub.n is selected to carry out the operation OP.sub.2.
(13) PROCEDURE OF DECIDING WHETHER THE CONTENTS OF A SPECIFIC REGION OF THE MEMORY ARE GREATER THAN A GIVEN VALUE AND DECIDING WHICH ADDRESS (STEP) IS TO BE EXECUTED
TABLE 33______________________________________ ##STR48##______________________________________
In Table 33,
P.sub.1 --The file address m.sub.B and the digit address n.sub.C of the memory are decided.
P.sub.2 --The contents of the memory as specified during P.sub.1 are unloaded into ACC.
P.sub.3 --N is the value to be compared with the contents of the memory and the operand area specifies 15-N which in turn is added to the contents of ACC, the sum thereof being loaded back to ACC. The occurrence of a fourth bit carry during the addition suggests that the result of binary addition exceeds 16, that is, M+(15-N).gtoreq.16 and hence M.gtoreq.N+1 and M>N. The step is progressed toward P.sub.5 with skipping P.sub.4, thus performing the operation OP.sub.1. In the absence of a carry (namely, M>N) the step P.sub.4 is reached.
P.sub.4 --When M.gtoreq.N is denied, the program address (Step) P.sub.n is selected to carry out the operation OP.sub.2.
(14) PROCEDURE OF DISPLAYING THE CONTENTS OF A SPECIFIC REGION OF THE MEMORY
TABLE 34______________________________________(Type 1) ##STR49## ##STR50## ##STR51## ##STR52##P.sub.1 --The bit number n.sub.1 of the buffer register W is loaded intoACC to reset the overall contents of the buffer register W for generatingdigit selection signals effective to drive a display panel on a time
P.sub.2 --After the overall contents of the register W are one bit shifted to the right, its first bit is loaded with "0". This procedure is repeated via P.sub.4 until C.sub.4 =1 during P.sub.3, thus resetting the overall contents of W.
P.sub.3 --The operand I.sub.A is decided as "1111" and AC+1111 is effected (this substantially corresponds to ACC-1). Since ACC is loaded with n.sub.1 during P.sub.1, this process is repeated n.sub.1 times. When the addition of "1111" is effected following ACC=0, the fourth bit carry C.sub.4 assumes "0". When this occurs, the step is advanced to P.sub.4. Otherwise the step is skipped up to P.sub.5.
P.sub.4 --When the fourth bit carry C.sub.4 =0 during ACC+1111, the overall contents of W are reduced to "0" to thereby complete all the pre-display processes. The first address P.sub.6 is set for the memory display steps.
P.sub.5 --In the event that the fourth bit carry C.sub.4 =1 during ACC+1111, the overall contents or W have not yet reduced to "0". Under these circumstances P.sub.2 is reverted to repeat the introduction of "0" into W.
P.sub.6 --The first digit position of the memory region which contains data to be displayed is identified by the file address m.sub.A and the digit address n.sub.A.
P.sub.7 --After the contents of the register W for generating the digit selection signals are one bit shifted to the right, its first bit position is loaded with "1" and thus ready to supply the digit selection signal to the first digit position of the display.
P.sub.8 --The contents of the specific region of the memory are unloaded into ACC. The file address of the memory still remains at m.sub.A, whereas the digit address is decremented for the next succeeding digit processing.
P.sub.9 --The contents of the memory is shifted from ACC to the buffer register F. The contents of the register F are supplied to the segment decoder SD to generate segment display signals.
P.sub.10 --To lead out the contents of the register W as display signals, the conditional F/F N.sub.P is supplied with "1" and placed into the set state. As a result of this, the contents of the memory processed during P.sub.9 are displayed on the first digit position of the display.
P.sub.11 --A count initial value n.sub.2 is loaded into ACC to determine a one digit long display period of time.
P.sub.12 --ACC-1 is carried out like P.sub.3. When ACC does not assume "0" (when C.sub.4 =1) the step is skipped up to P.sub.14.
P.sub.13 --A desired period of display is determined by counting the contents of ACC during P.sub.12. After the completion of the counting P.sub.15 is reached from P.sub.13. The counting period is equal in length to a one-digit display period of time.
P.sub.14 --Before the passage of the desired period of display the step is progressed from P.sub.12 to P.sub.14 with skipping P.sub.13 and jumped back to P.sub.12. This procedure is repeated.
P.sub.15 --N.sub.P is reset to stop supplying the digit selection signals to the display. Until N.sub.p is set again during P.sub.10, overlapping display problems are avoided by using the adjacent digit signals.
P.sub.16 --The register W is one bit shifted to the right and its first bit position is loaded with "0". "1" introduced during P.sub.7 is one bit shifted down for preparation of the next succeeding digit selection.
P.sub.17 --It is decided whether the ultimate digit of the memory to be displayed has been processed and actually whether the value n.sub.E of the last second digit has been reached because the step P.sub.8 of B.sub.L -1 is in effect.
P.sub.18 --In the event that ultimate digit has not yet been reached, P.sub.8 is reverted for the next succeeding digit display processing.
P.sub.19 --For example, provided that the completion of the display operation is conditional by the flag F/F FA, FA=1 allows P.sub.20 to be skipped, thereby concluding all the displaying steps.
P.sub.20 --If FA=1 at P.sub.19, the display steps are reopened from the first display and the step is jumped up to P.sub.6.
TABLE 35______________________________________(Type 2) ##STR53## ##STR54## ##STR55## ##STR56##In Table 35,
P.sub.1 --The bit number n.sub.1 of the buffer register W is loaded into ACC to reset the overall contents of the buffer register W for generating digit selection signals effective to drive a display panel on a time sharing basis.
P.sub.2 --After the overall contents of the register W are one bit shifted to the right, its first bit is loaded with "0". This procedure is repeated via P.sub.4 until C.sub.4 =1 during P.sub.3, thus resetting the overall contents of W.
P.sub.3 --The operand I.sub.A is decided as "1111" and AC+1111 is effected (this substantially corresponds to ACC-1). Since ACC is loaded with n.sub.1 during P.sub.1, this process is repeated n.sub.1 times. When the addition of "1111" is effected following ACC=0, the fourth bit carry C.sub.4 assumes "0". When this occurs, the step is advanced to P.sub.4. Otherwise the step is skipped up to P.sub.5.
P.sub.4 --When the fourth bit carry C.sub.4 =0 during ACC+1111, the overall contents of W are reduced to "0" to thereby complete all the pre-display processes. The first address P.sub.6 is set for the memory display steps.
P.sub.5 --In the event that the fourth bit carry C.sub.4 =1 during ACC+1111, the overall contents of W have not yet reduced to "0". Under these circumstances P.sub.2 is reverted to repeat the introduction of "0" into W.
P.sub.6 --The upper four bits of the first digit position of the memory region which contains data to be displayed are identified by the file address m.sub.A and the digit address m.sub.A.
P.sub.7 --The contents of the specific region of the memory are unloaded into ACC. The file address of the memory still remains at m.sub.A, whereas the digit address is decremented to specify the lower four bits.
P.sub.8 --The contents of ACC, the upper four bits, are transmitted into the temporary register X.
P.sub.9 --The contents of the specific region of the memory are unloaded into ACC. The file address of the memory still remains at m.sub.A, whereas the digit address is decremented to specify the upper four bits of the next succeeding digit.
P.sub.10 --The contents of ACC are unloaded into the stack register SA and the contents of the temporary register X into the stack register SX.
P.sub.11 --After the contents of the register W for generating the digit selection signals are one bit shifted to the right, its first bit position is loaded with "1" and thus ready to supply the digit selection signal to the first digit position of the display.
P.sub.12 --To lead out the contents of the register W as display signals, the conditional F/F N.sub.p is supplied with "1" and placed into the set state. As a result of this, the contents of the memory processed during P.sub.10 are displayed on the first digit position of the display.
P.sub.13 --A count initial value n.sub.2 is loaded into ACC to determine a one digit long display period of time.
P.sub.14 --ACC-1 is carried out like P.sub.3. When ACC assumes "0" P.sub.15 is reached and when ACC.noteq.0 (when C.sub.4 =1) the step is skipped up to P.sub.16. This procedure is repeated.
P.sub.15 --A desired period of display is determined by counting the contents of ACC during P.sub.14. After the completion of the counting P.sub.17 is reached from P.sub.15. The counting period is equal in length to a one-digit display period of time.
P.sub.16 --Before the passage of the desired period of display the step is progressed from P.sub.14 to P.sub.16 with skipping P.sub.15 and jumped back to P.sub.14. This procedure is repeated.
P.sub.17 --N.sub.P is reset to stop supplying the digit selection signals to the display. Until N.sub.p is set again during P.sub.10, overlapping display problems are avoided by using the adjacent digit signals.
P.sub.18 --The register W is one bit shifted to the right and its first bit position is loaded with "0". "1" introduced during P.sub.7 is one bit shifted down for preparation of the next succeeding digit selection.
P.sub.19 --It is decided whether the ultimate digit of the memory to be displayed has been processed and actually whether the value n.sub.E of the last second digit has been reached because the step P.sub.9 of B.sub.L -1 is in effect.
P.sub.20 --In the event that ultimate digit has not yet been reached, P.sub.7 is reverted for the next succeeding digit display processing.
(15) PROCEDURE OF DECIDING WHICH KEY SWITCH IS ACTUATED (SENSING ACTUATION OF ANY KEY DURING DISPLAY)
Reference is made to FIG. 36. In FIG. 36,
P.sub.1 -P.sub.18 --The display processes as discussed in (14) above.
P.sub.19 --After the overall digit contents of the register W are displayed, the flag F/F FC is set to hold all the key signals I.sub.l -I.sub.n at a "1" level. (see FIG. 37)
P.sub.20 --The step is jumped to P.sub.30 as long as any one of the keys connected to the key input KN.sub.1 is actuated.
P.sub.22 -P.sub.27 --It is decided whether any one of the keys each connected to the respective key inputs KN.sub.2 -KF.sub.2 and in the absence of any actuation the step is advanced toward the next succeeding step. To the contrary, the presence of the key actuation leads to P.sub.30.
P.sub.28 --When any key is not actuated, F/F FC is reset to thereby complete the decision as to the key actuations.
P.sub.29 --The step is jumped up to P.sub.6 to reopen the display routine.
P.sub.30 --When any key is actually actuated, the memory digit address is set at n.sub.1 to generate the first key strobe signal I.sub.1.
P.sub.31 --It is decided if the first key strobe signal I.sub.1 is applied to the key input KN.sub.1 and if not the step is advanced toward P.sub.33.
P.sub.32 --When the first key strobe signal I.sub.1 is applied to the key input KN.sub.1, which kind of the keys is actuated is decided. Thereafter, the step is jumped to P.sub.A to provide proper controls according to the key decision. After the completion of the key decision the step is returned directly to P.sub.1 to commence the displaying operation again (P.sub.Z is to jump the step to P.sub.1).
P.sub.33 -P.sub.38 --It is sequentially decided whether the keys coupled with the first key strobe signal I.sub.1 are actuated. If a specific key is actuated, the step jumps to P.sub.B -P.sub.D for providing appropriate controls for that keys.
P.sub.39 --This step is executed when no key coupled with the first key strobe signal I.sub.1. This step is to increment the digit address of the memory for the developments of the key strobe signals.
P.sub.40 -P.sub.44 --The appropriate key strobe signals are developed and KN.sub.1 -KF.sub.2 are sequentially monitored to decide what kind of the keys are actuated. Desired steps are then selected to effects control steps for those actuated keys.
P.sub.A --Control steps for the first actuated keys.
P.sub.X --P.sub.1 is returned to reopen the display operation after the control steps for the first key.
The configuration of the CPU will now be discussed in detail. FIG. 41 shows a RAM map within the CPU and FIG. 42 illustrates the relationship between the address of the word memory and its contents.
In those drawings regions BM.sub.0 -BM.sub.3 generally designated YO, XO, WO and ZO are registers mainly for use in arithmetic operations. The WO and ZO registers are available as buffer memories for the displaying of characters as described above. The region of the ZO register covering from BL=1 to HL=8 (in other words, the fourth bit position) is used as an output buffer for the SOn output (information stored in this region of the RAM is derived directly from the SOn terminal). The VO register (BM=4, BL=0-15) serves as a temporary storage for data. The numerical information is 8-digit long, for example. Each region of the respective registers stretching from BL=4 to BL=B stores data in a mantissa, each region BL=C is an auxiliary storage section and each region as defined by BL=D-BL=F stores the weight of the data, that is, an index section. BL=F is a section for storing a minus sign of the index section. The regions as defined by BM=5 and 6 constitute various conditional flip flops and counters.
The legends and their descriptions used in the drawings are as follows:
A: the state where any functional keys such as +, -, .times.and .div. has been actuated.
B: the state where the data have been entered.
C: the state where functional operations such as are executed.
D: the state where a decimal point is specified during the key entry mode.
E: the key entry state.
F: the state where an input is applied to the word memory.
G: the initial state where an input is about to enter the word memory.
H: the state where a shift instruction is derived.
X.sub.D : the location of a decimal point during the key entry mode.
X.sub.D ': the preparatory process region.
K.sub.U K.sub.L : store key codes and character codes.
FU: stores functional codes (+, -, .times. and .div.)
U,L: word memory addition counters which store the address of the word memory.
U',L': word memory as a region for preparatory steps.
Zs,Ws,Xs,Ys: minus sign storage regions of the respective registers.
U,M,L: running display counters as timer couters which decide the period for movement of running display characters.
BM=D-F: word memory regions of a 24-character length as depicted in FIG. 42.
(OPERATION OF THE PREFERRED EMBODIMENT)
With reference to flow charts, operation of the above illustrated embodiment of the present invention will now be discussed in detail. FIGS. 1 through 8 show a full length of the procedure carried on the device. FIG. 1 depicts the procedure by which a process is initiated on the word memory for the running display mode and inputs entered via the key unit are treated upon switching ON power supply. FIG. 2 depicts the procedure by which the keyed inputs are controlled, loaded and encoded under the normal display mode (including blinking symbols). FIG. 3 depicts the procedure by which the encoded key inputs are evaluated and proper steps are selected or the character codes are loaded in sequence into the storage memory. FIG. 4 shows respective processing steps for a CL key, a SET key, a CE key, a CALL key and an OFF key. FIGS. 5 and 5-1 show readout and other pretreatments before the contents of the word memory are displayed. FIG. 6 depicts steps before the results of arithmetic operations or the keyed inputs are displayed. FIG. 7 depicts steps for operating the character generator (decoder) to convert the 6-bit character codes into the pattern information compatible with the dot pattern of the display unit and lead that information to an external displaying buffer. FIG. 8 shows steps for loading the numerical input information and executing four-rule operations (+, -, .times. and .div.). FIG. 43 shows the relationship between the key strobe signals and their corresponding input terminals of the microprocessor. FIG. 44 is a table showing the key codes for internal processing. FIG. 45 is a table enumerating the character codes contained within the word memory.
The whole procedure illustrated in FIGS. 1 through 8 will be described in a stepwise manner. While the whole procedure is shown as being split into several processing blocks, it is obvious that those blocks are tied together to constitute a complete and massive process. A brief prospect of the whole procedure is readily appreciated upon consideration of the foregoing description with respect to the basis subroutines (1) to (15) depicted in Tables 2 through 33 and FIG. 36. For instance, the step XO VO (3) is effected in the same manner as discussed in the basic subroutine (3). Also, FIG. 46(A) suggests the step for deciding the operating step of the conditional F/F R, wherein Y (YES) represents the set state thereof and N (NO) represents the reset state. This step is executed in a similar manner to the basic subroutine (IX). The reference number (2)-1 respective Type 1 of the basic subroutine (2). An exemplary process as defined by a lateral circle in FIG. 46(B) is a process which is used repeatedly. The reference numbers 1 and 2 in FIG. 46(B) show conditions for completing its associated step as will be discussed later. A process as defined by broken lines in FIG. 46(C) is same as that as defined by the lateral circle. The arrow as depicted in FIG. 46(D) shows the destination of the next succeeding routine. In the case of FIG. 46(D) the step NOP KEY INPUT follows. The reverse triangle shaped symbol corresponds to the arrow in FIG. 46(D) such that the routine in FIG. 46(D) floods into the flow chart beginning with the triangle symbol in FIG. 46(E). LB m,n means that BM is specified by m and BL is specified by n. For instance, LB 7,F specifies the address of the RAM where BM=7 and BL=F.
FIG. 1 depicts the routine by which the running display mode is controlled for the word memory and the keyed inputs are invited after switching ON power supply.
The process l.sub.0 decides if BM, BL=(6,1), (6,0) are "6" and "9", respectively, and, if not, resets the word counter and clears the word memory. The contents of the word memory remain even when a main power supply is forced into the OFF state. However, the data within the memory might vanish in the event that power is shut off for any reason except by actuation of the OFF key or the date are not loaded in place within the memory. To detect such an erroneous condition, the main power supply is forced into the OFF state after "6" and "9" have been loaded into the regions BM, BL=(6,1), (6,0) upon actuation of the OFF key (see Oo in FIG. 4). On the other hand, when the data are properly stored within the memory, it is decided that the word memory is normal in its internal state since the data loaded under the OFF state remain unchanged upon switching ON power supply. Accordingly, when the regions BM,BL=(6,1), (6,0) do not assume "6" and " 9", the contents of the word memory is not guaranteed so that the whole data within the word memory are cleared and the address counter addressing the word memory is also cleared. Details of this operation are illustrated in FIG. 3.
The step l.sub.1 is a step which initializes the whole system upon switching ON power supply and specifically loads "7" and "8" into X.sub.D and Ba, respectively. It is appreciated that X.sub.D indicates the location of a decimal point and X.sub.D =0 means the decimal point at the first digit place (BL=4) and X.sub.D =7 that at the eighth digit place (BL=B). Since arithmetic operations are executed in exponent form except data entry, the decimal point is located at the most significant digit place of the mantissa section (i.e., X.sub.D =7). Ba is a balance processing counter which decides a period of key balance and accepts "8" under the initial condition. As a matter of fact, this counter is treated during the key entry mode (see FIG. 12).
The step l.sub.3 is a pretreatment for the running display mode. Since the information contained within the word memory (not including the results of arithmetic operations) is to be displayed, not only the internal memory for decimal point displaying but also that for preparation of the character codes are cleared. The step for judging and setting the word memory indicator S is executed when any input has been loaded into the word memory as best shown in FIG. 4. Especially, whether the data associated with the address (D, 0) (that is, the contents of the leading address of the word memory) are "0". Since when the data are "0" it is concluded that the word memory bears no information at the next succeeding and remaining portion thereof, the S flip flop is reset. However, if not "0", any input has been loaded at least at the leading portion of the word memory and the S flip flop has therefore been set.
In the given example, the display unit is of a 9-digit capacity and the step l.sub.4 decides if the overall characters within the word memory are equal to or less than 9. When the contents of the tenth character are "0", the static (not running) display process l.sub.5 begins. It is of no particular significance that BM, BL=E, 2 by virtue of L.sub.A .times.14 ATBM after reducing the RAM address to BM, BL:0, 2 via the step l.sub.4. It is possible that BM, BL=E, 2 directly.
A string of the steps leading from l.sub.6 is effected for performing the running display mode. X.sub.D ' is a control counter for loading and displaying a character representative of (space).fwdarw.(space) at the transitions of character displays and accepting "0" as its initial value. The running display mode is carried out in such a manner that the character codes stored at the word memory BM=D as shown in FIG. 13-3 are unloaded into the internal character code buffer as shown in FIG. 13-1 and outputted to the DSP unit control (WZ.fwdarw.DSP unit control) for displaying purposes. This situation goes on for a time. This period of time is determined by the step for processing the RUN DSP counter. After the period of time passed the next succeeding character F is shifted to the internal character code buffer as depicted in FIG. 13-2 and outputted and displayed in the same manner. Through repetition of such procedure a visual display runs sequentially to the left.
The step from FIG. 13-1 to 13-2 shifts left the W and Z memories and introduces the next succeeding character codes into the memory region where BL=0. The word memory address counter specifies the address of the character which is to be loaded into the memory region BL=0. l.sub.7 initializes this procedure.
The step l.sub.8 initializes each character of the counter which determines the length of the running display mode. E, 8, 0 during the step l.sub.8 implies 1110-1000-0000. The step l.sub.9 transfers the contents of the word memory as determined by the word memory address counter into the location BL=0 of the internal character code buffer as best shown in FIG. 5.
The step l.sub.IO transfers the codes within the internal character code buffer into the external display unit control as best shown in FIG. 7. The step .circle.a in FIG. 7 shifts display information such as decimal points and other symbols into the region covering BL=9-c as shown in FIG. 10. The step .circle.b is under a program for unloading BM=2-3, BL=0-8 of the internal RAM into the control section. Since the address for the display unit control is composed of 5 bits, only the F.sub.1 bit within BM is effective and the remaining bits are redundant. The steps l.sub.7 -l.sub.10 are effected as shown in FIG. 13.
The step l.sub.11 is a program which counts the period of time Ba of FIG. 12 and makes decision as to the keyed inputs. After the expiration of the period of time Ba, the keyed inputs establish key codes of 8 bits as shown in FIG. 4 in accordance with the respective actuated keys and thus set up the codes K.sub.U, K.sub.L, thereby actuating the procedure as shown in FIG. 3. Details of this procedure are illustrated in FIG. 2 wherein .circle.a is a step for deciding if the keyed inputs are present, .circle.b is a step for judging the respective keys and .circle.c is a step for conversion of the key codes.
The step l.sub.12 is executed until an overflow comes from a counter incrementing by one each time the keyed input is sensed. The length of this step decides the period of the running display mode. The next succeeding character codes are made ready after an overflow occurs during the step l.sub.12. The step l.sub.13 shifts the character codes previously displayed.
The step l.sub.14 decides if the upper 4 bits of the last prepared character codes are "0". If YES X.sub.D ' is loaded with "2" and the code .rarw. is unconditionally prepared as characters through l.sub.15 to thereby actuate the step l.sub.10. The step l.sub.16 presets the counter determining the length of the running display mode. On the other hand, if NO the step l.sub.17 increments the word memory address counter by two in order to specify the address for the chatacter which is next to be prepared. This is due to the fact that two units of BL within the word memory as shown in FIG. 13-3 constitute a word (character). When word counter specifies less than 24 characters, the subroutine (1) is selected to render the step l.sub.8 operative (for preparing and displaying the next character codes). In the case where 24 characters are fully loaded and the 24th character has been derived, the step l.sub.17 specifies the 25th character and is over to shift toward the subroutine (2). In this case the character ##STR57## is forcedly inserted. The step l.sub.13 develops pretendedly the (space) 1 and the steps l.sub.16 .fwdarw.l.sub.10 are carried out. The W and Z registers show "0000" at W(8) and Z(8), respectively, after one-digit shift through the step l.sub.13.
After the X.sub.D ' counter is loaded with "2" or "4", the step l.sub.18 answers NO and the step l.sub.19 places the spaced or the character.rarw.into the internal character code buffer with the help of the X.sub.D ' counter. When the second bit position of the X.sub.D ' is set, the character codes.rarw.are loaded into the character buffer BL=0. When the first bit is "1", the space following.rarw.is loaded. Because the "00" codes are developed pretendedly at BL=0 due to the shift operation on the W and Z registers, the step l.sub.16 is executed. The display mode begins again with the leading character in the word memory when X.sub.D ' is "0" due to the completion of the step (space) (space). The relation between the steps l.sub.7 and up for processing the X.sub.D ' counter and the display mode is illustrated in FIG. 14.
In the case where the character codes contained within the word memory are less than nine, the contents of the word memory are displayed in a static mode. This routine begins with the word memory display mode in FIG. 4. The step O.sub.1 (pretreatment of word memory DSP) as shown in FIG. 4 loads sequentially the internal character buffers WO and ZO, beginning with BL=0. The procedure as shown in FIG. 5 is now discussed below.
The word counter designates the memory address for the character to be first displayed. While the address is being decremented step by step, the character codes are loaded in succession into the internal character buffer in the order of increasing BL from BL=0 (see FIG. 15). The step P.sub.1 clears the character code buffers WO and ZO and the step P.sub.3 transfers the contents of the word counter into the second counter'. The step P.sub.4 reads out the character specified by the second word counter' and sends the same into the memory BL addressed by cpu X in the internal character buffer, cpu X being an X.sub.B register storing the digit address of the RAM. The step P.sub.2 sets up an initial state on cpu X with "0" which value is incremented by one every execution of the step P.sub.4. Once one character has been placed into the internal buffer, the step P.sub.5 takes "2" from the word counter' which designates the address of the characters. The terminating condition 2 implies the execution of the step P.sub.5 when the address specifies the first character or when the characters to be displayed are less than nine (the seventh digit in FIG. 15), thus terminating the process before display of the word memory. The terminating condition 1 is established to initiate the static display mode whereby nine digits still remaining within the word memory are displayed. The step P.sub.6 decides if cpu X is equal to "9" or the internal character buffer is full of the characters. YES is answered when all the nine characters are completely processed and NO is answered when the word memory is still vacant, followed by the step P.sub.4. The above procedure makes generally the character display mode ready.
Reverting the step l.sub.5 and down in FIG. 1, these steps seek up to what position in the word memory the characters are stored, for the purpose of starting the static display mode. Upon the completion of these steps the word counter designates the address for the last character stored within the word memory. Because it is obvious that the characters within the word memory are less than nine at the beginning of the step l.sub.5, the step l.sub.5 decides if the ninth character is "0." If not "0" the address E.O represents the address for the last character within the word memory and instead the word memory display process (FIG. 5) is selected. If "0" the step l.sub.20 decrements the word memory address counter in order to judge the contents of the eighth character.
The step l.sub.22 is a step which fetches the contents of the word memory. Pursuant to the instruction LAX D, D is fixed (1101) and BL is specified by cpu X which is loaded with the initial value E via the step l.sub.21. When the contents fetched are not "0", the pretreatment for the word memory display is executed. On the other hand, when they are "0", the step l.sub.23 decrements the value of cpu X by two and sets up the address for the next character. This makes it possible to decrement the word memory counter down to the position of the character bearing character codes other than "0." After loading of the value of the word memory counter, the pretreatment for the word memory display operation is effected in order to perform the static display mode on the word memory.
After the key entry mode where keys are introduced via the KEY IN process of FIG. 2 and the key codes K.sub.U and K.sub.L are developed via the step .circle.c , the procedure of FIG. 3 is carried out by which the course of the operation is selected according to the respective actuated keys and their associated character codes are loaded into the word memory under the character input state (SET mode).
n.sub.1 confines the KEY IN process to the CL and OFF keys under the error condition where Er F/F is set. The step n.sub.2 is effected only when the key codes K.sub.U =0 and K.sub.L .ltoreq.2. The step n.sub.2 is split depending upon whether K.sub.U is "0" or "1". In the latter case ("1"), decision is made as to the SET state and in the former case ("0") decision is made as to whether the actuated key belongs 0-9 or +, -, .times. and .div..
During the SET mode the key codes are converted again via the step n.sub.3 and loaded into the word memory via the steps n.sub.4 and up. The character codes at this moment are illustrated in FIG. 45. When K.sub.U =0 the keys K.sub.L .gtoreq.6 specify the character codes under the SET mode, those characters being converted via the steps n.sub.6 and n.sub.3 and loaded into the word memory via the steps n.sub.4 and up. Judgement of K.sub.L splits the key-related processes n.sub.7 when the set state is not present.
G F/F implies the first state where the character codes are loaded into the word memory. The SET key when actuated recovers the set state (FIG. 4). When YES is provided during the step n.sub.4, the first character is specified. The word counter is reset (the leading address of the word memory is specified) during n.sub.8 and the word memory is completely cleared and G F/F is reset to thereby unlock the initial state. During m.sub.0 the character codes K.sub.U and K.sub.L are stored within the word memory designating the address. At this moment the word counter designates the address of the word memory where the characters are now loaded. Since G F/F is reset when the next character is loaded into the word memory, the steps n.sub.4 n.sub.9 are effected with the latter (n.sub.9) incrementing the word counter by two (one-character) and designating the address of the word memory which an input is about to be introudced. The terminating condition 2 is evaluated to skip the input step n.sub.10 when the 24th character is specified. Otherwise, the character codes are loaded into the word memory during the step n.sub.10. Thereafter, the contents of the word memory are displayed via the procedure as depicted in FIG. 4.
O.sub.1 represents the procedure as shown in FIG. 5 by which the character codes of the characters to be displayed are loaded into the internal character buffer. The next succeeding step O.sub.2 the internal F/Fs for energizing decimal points are all reset. The step O.sub.3 decides if the character has been inputted into the word memory and sets the energizing F/F (S). The step O.sub.4 transfers the information in the internal character buffers W and Z into the display control.
Details of the key input process which follows are depicted in FIG. 2. While the key input process is executed during the running display subroutine of FIG. 1, the key input process in FIG. 2 enables the indicator showing the SET mode to blink. The step m.sub.1 sets up an initial condition for the counter which determines the length of blinking of the indicator. The counter may be realized by the above mentiond memory for the running display.
The step m.sub.2 is a read-in step with the balance time. As discussed above, the key input split process of FIG. 3 is executed in the presence of the keyed inputs. Unless the requirement for the keyed inputs is fulfilled, the step m.sub.3 is executed to increment the running display counter which has already been placed into the initial state. If no overflow occurs, the terminating condition 1 is reached to recover the key input process m.sub.2.
The steps m.sub.2 and m.sub.3 are repeatedly carried out. If an overflow occurs from the running display counter, the terminating condition 2 is satisfied during the step m.sub.3 to thereby start the step m.sub.4. The period of time until the overflow occurs during the step m.sub.3 during repeated execution of the steps m.sub.2 and m.sub.3 determines the length of blinking of the word memory indicator.
The step m.sub.4 decides if the word memory is available in loading the characters. F F/F is a F/F indicating the SET mode. The step m.sub.5 blinks the indicator in the set mode. The power one bit of the contents of the OA (8-bit address) within the display unit control, that is, S bit is fetched under the set mode. When S is "1", subtraction of "1" is effected and when S is "0" addition of "1" is effected, thus inverting the S bit each execution of the step m.sub.5. In other words, the display segment corresponding to S blinks when the character codes within the control are decoded and outputted.
When the respective keys CL, SET, CE, CALL and OFF are actuated during the running display mode or the normal key input mode, their associated processing routines are selected via the step n.sub.7 of FIG. 3. The respective processing routines are shown in FIG. 4.
(CL KEY)
The step O.sub.5 determines the operating conditions of F F/F representing whether the characters are in the set state. If NO, actuation of the CL key unlocks and clears the calculation state of the running display state. The CL step during the course O.sub.6 clears the input and calculation registers and sets up initial states for the various F/Fs. The step (display segment CL) clears all the bits of the RAM indicating energization of decimal points. The decimal points are located properly through the pretreatment for the data DSP, as will be more clear from FIG. 6. The contents of the XO register are converted into a form compatible with the display unit and in other words the character codes. After that, the steps O.sub.3 and up cause display outputs and effect the key input process again. Actuation of the CL key clears all of the word memory and the display unit during the set mode (character input state). The step O.sub.7 clears the word memory and initializes the word memory address counter. The step O.sub.8 sets G F/F to clear the displaying character buffers WO and ZO, followed by the step O.sub.2. G F/F implies the initial input state of the character memory and prevents the address counter from being incremented only when the leading character is inputted by virtue of the step n.sub.4 in FIG. 3.
(SET KEY)
The SET key establishes or unlocks the set mode when the whole system is not in the set mode or actually in the set mode, respectively. The step O.sub.9 is effected to decide if F F/F is in the set state and then the CL process following O.sub.6 is carried out. With the state F0 present, F F/F representing the set mode is set. The steps O.sub.8 and up are carried out to clear the display unit.
(CE KEY)
The CE (clear entry) key clears the keyed inputs when not in the set mode. It also specifies the character X when no shift key is actuated under the set mode and serves as the DEL key when the shift key is actuated (see FIG. 19).
The step O.sub.10 is effected when not in the set mode. Nothing occurs when B F/F is not set. When B F/F is set, the step O.sub.11 resets the F/F representing the key entry mode and transfers the previous data into VO which in turn feeds the received data into the XO register. Then, the data display process (display segment CL) O.sub.6 is effected to unlock the entry state and regain the previous state.
When in the set mode the step O.sub.12 decides if the shift key is actuated and if NO the character X key renders the step n.sub.3 of FIG. 3, K.sub.U +2 K.sub.U operative to enter the character codes. When the shift key is actuated this key behaves as the DEL (delete) key to delete the last input character or the character on the extreme right of the display unit. The step O.sub.13 zeros all the character codes K.sub.U, K.sub.L. The step O.sub.14 locates those codes into the word memory showing the word memory address counter. In addition, the step O.sub.15 decrements the word counter. The terminating condition 2 is satisfied when the thus deleted character is the leading character (or loaded into the leading address of the word memory). At this time the word memory is fully vacant so that G F/F indicating the initial input state of the word memory is set. Thereafter, the pretreatment before the word memory display operation is carried out.
(CALL KEY)
When not in the set mode, this key instructs the running display mode for the characters contained within the word memory. In addition, this key serves as the shift key under the set state. The shift key is set or reset repeatedly each time the key is actuated. When not in the set mode the step O.sub.16 clears the calculation state and starts the running display mode after the step l.sub.3 in FIG. 1. The step O.sub.17 inverts H F/F showing the shift state.
(OFF KEY)
The OFF key places the above illustrated calculator into the OFF state. The regions of an address (6,0), (6,1) are located with "9" and "6." These values are to make sure that the contents of the memory are quaranteed even upon switching ON power supply. Such confirmation is provided by the step l.sub.0 of FIG. 1. This OFF process is implemented with a hardware of a microprocessor responsive to the OFF instruction.
(DATA DSP PRETREATMENT)
The data within the XO register are converted into a form compatible with the display unit and thus into 8-bit character codes and thereafter loaded into the internal character buffers WO and ZO. In the case where a numeric 123.456 is in the XO register as shown in FIG. 16, the contents of the XO and X.sub.D registers are different between when in the entry mode (E) and when not in the entry mode (E. Under these circumstances a display pattern as shown in the right side of FIG. 16 is developed. Basically, the contents of the XO register are unloaded into the WO register and shift operation is effected due to the value X.sub.D to locate the lower 4 bits of the character codes. Since the upper four bits of the character codes are all 1(0001), all that is necessary is to load "1" (see FIG. 45).
When E is set (the entry mode) by Q.sub.1, the step Q.sub.2 transfers the contents of the XO register into the WO register as shown in FIG. 16-2. Under the circumstance the display at the first digit position of the display unit differs between the state A (with the four-rule keys actuated) and the state A0 (before the four-rule keys are actuated). X.sub.D ' is present instead of X.sub.D. In other words, the XO register and X.sub.D are held unchanged.
The step Q.sub.3 sets the decimal point bit and energizes its associated segment. The relationship between X.sub.D ' and the location of decimal points is shown in FIG. 16-3. This routine terminates establishment of the lower 4 bits of the numerical information. The step Q.sub.4 locates the upper 4 bits of the character codes into the ZO register (including so-called zero suppressing) and decides if the contents of the WO register assure "0" at the position W(8) or seeks the extreme left position where the address (BL) is equal to X.sub.D '.
The step Q.sub.5 decides if the numerical information is minus and if not the step Q.sub.6 inserts "1" into the region covering from BL detected by the step Q.sub.4 to BL=0. If minus the step Q.sub.7 locates the lower 4-bit value B at BL+1 of the WO register with a minus sign (-) and "1" into the region covering from the corresponding position of the ZO register to BL=0.
The step Q.sub.8 and up are steps for displaying symbols for the actuated four-rule keys together with a visual display of the numerical information. The codes indicative of the four-rule keys (+, -, .times., .div.) are loaded into the memory area Fu in the form of 4 bit codes by way of the step R.sub.1 of FIG. 8. The step Q.sub.8 recalls the codes relating to the four-rule keys and decides if A F/F indicating the actuated four-rule keys is in the set state. With the state A the contents of the WO and ZO registers are cleared at the position BL=0, thus completing this sequence of operation (Q.sub.9). Under the state A, B F/F and whether the data are inputted are decided. If YES the codes indicative of the four-rule keys are loaded into the WO and ZO registers at the extreme left side BL=8 or the extreme right side BL=0, respectively, when B or B0 is sensed. (see FIG. 22).
The step Q.sub.1 is coupled to the steps Q.sub.11 and Q.sub.12 when not in the key entry mode (E. As shown in FIG. 16-1, the steps Q.sub.11 and Q.sub.12 convert the data format in the case E0 into that in the case E.
The step Q.sub.11 converts the numerical information XO 1 (see FIG. 16-4) form the form (1) to the form (2) and adds "1" to the index portion w while shifting the mantissa portion, until the w register bears "0".
The next succeeding steps X.sub.D -w.sub.1 .fwdarw.X.sub.D ' determine where the decimal point is located in the mantissa portion in view of the weight of the w register, with the result being transferred to X.sub.D '. The step Q.sub.12 shifts right the data converted during the step Q.sub.11. The W register is shifted right only when WO(4) is "0" and X.sub.D '.noteq.0 (in other words, the decimal point is not located at the extreme right side). The step X.sub.D ' 1 X.sub.d ' is effected. The result is that the form E0 of FIG. 16-1 is converted into the form E. The step Q.sub.13 is similar to the step Q.sub.2 and converts the form (2) of FIG. 16-2 into the forms (2) and (3). Thereafter, the same procedure is carried out as do the steps Q.sub.3 and up.
The following sets forth some modified embodiments of the present invention. The modified form 1 of FIG. 3 replaces the corresponding part of FIG. 38. The modified form 2 of FIG. 4 replaces that of FIG. 39 and the modified form 3 of FIG. 4 replaces that of FIG. 40. The modified form 4 in FIG. 4 shows a modified NOP KEY INPUT process. It is also possible that the modified form 5 of FIG. 4 (RESET H) may be eliminated. Those modified embodiments of the present invention are are different from the above illustrated embodiment in the following aspects.
(1) A cursor is displayed on the extreme right side of the display during the period of time where the characters are loaded into the word memory, indicating the location of the character to be next introduced. When the word memory is full, no cursor is displayed.
(2) Once depressed the shift key holds the shift state until the key is actuated again. At this moment the cursor is displayed on the digit position (see FIG. 17).
Whereas the present invention has been described with respect to specific embodiments thereof, it will be understood that various changes and modifications will be suggested to one skilled in the art, and it is intended to encompass such changes and modifications as fall within the scope of the appended claims.
Claims
  • 1. An electronic device capable of displaying characters or symbols on a display in a running display mode or in a static display mode, said display having a predetermined display capacity, said device comprising:
  • memory means for storing a certain number of said characters or symbols;
  • comparator means responsive to the number of said characters or symbols stored in the memory means for determining if the number of said characters or symbols exceeds said predetermined display capacity; and
  • control means responsive to said comparator means for initiating said running display mode by sequentially shifting said characters or symbols across said display when the number of said characters or symbols stored in said memory means exceeds said display capacity, and initiating said static display mode by producing a stationary display of said characters or symbols on said display when the number of said characters or symbols stored in said memory means does not exceed said display capacity.
  • 2. An electronic device in accordance with claim 1, wherein the control means initiates said static display mode on said display when said electronic device functions as a calculator even if said comparator means determines that said characters or symbols stored in said memory means exceeds said predetermined display capacity.
  • 3. An electronic device in accordance with claim 2, wherein said display includes a numerical display section, and wherein a first operand, a second operand, and arithmetic symbols appear in said numerical display section of said display when said electronic device functions as said calculator.
  • 4. An electronic device in accordance with claim 1, wherein the storing means inserts an identifying symbol between the beginning and the end of said characters or symbols stored therein thereby enabling a repeated display of said characters or symbols on said display.
  • 5. An electronic device in accordance with claim 1, further comprising:
  • key input means for introducting said characters or symbols into said memory means.
  • 6. An electronic device in accordance with claim 3, wherein said arithmetic symbols are displayed on the right side of said first operand within said numerical display section of said display.
  • 7. An electronic device in accordance with claim 3, wherein said arithmetic symbols are displayed on the left side of said second operand within said numerical display section of said display.
Priority Claims (1)
Number Date Country Kind
54-44051 Apr 1979 JPX
US Referenced Citations (6)
Number Name Date Kind
3493956 Andrews et al. Feb 1970
4068226 Bowman et al. Jan 1978
4099247 Mikada et al. Jul 1978
4177518 Olander et al. Dec 1979
4196413 Sowa Apr 1980
4205312 Nelson May 1980