US3778773A - Matrix of shift registers for manipulating data - Google Patents

Matrix of shift registers for manipulating data Download PDF

Info

Publication number
US3778773A
US3778773A US00299245A US3778773DA US3778773A US 3778773 A US3778773 A US 3778773A US 00299245 A US00299245 A US 00299245A US 3778773D A US3778773D A US 3778773DA US 3778773 A US3778773 A US 3778773A
Authority
US
United States
Prior art keywords
information
rows
modules
registers
along
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
US00299245A
Inventor
D Hood
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nortel Networks Technology Corp
Original Assignee
Bell Canada Northern Electric Research Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Bell Canada Northern Electric Research Ltd filed Critical Bell Canada Northern Electric Research Ltd
Application granted granted Critical
Publication of US3778773A publication Critical patent/US3778773A/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/76Arrangements for rearranging, permuting or selecting data according to predetermined rules, independently of the content of the data
    • G06F7/78Arrangements for rearranging, permuting or selecting data according to predetermined rules, independently of the content of the data for changing the order of data flow, e.g. matrix transposition or LIFO buffers; Overflow or underflow handling therefor
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C19/00Digital stores in which the information is moved stepwise, e.g. shift registers
    • G11C19/38Digital stores in which the information is moved stepwise, e.g. shift registers two-dimensional, e.g. horizontal and vertical shift registers
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M9/00Parallel/series conversion or vice versa

Definitions

  • This invention relates to a matrix data manipulator and more particularly to one which is capable of providing serial-to-parallel or parallel-to-serial conversion of binary information. As well, it may provide data stream buffering which enables a plurality of information streams to be interleaved or separated, and also various other functions in a single versatile unit.
  • the parallel information may be converted back to a plurality of serial information streams by selectively transferring the information into a number of shift registers under the control of a decoder. The information is then fed out from each of the shift registers in serial form.
  • Serial-to-serial converters have also been developed to enable the interleaving of information from a number of slow speed data streams into a single high speed data stream or vice versa.
  • Serial-to-serial buffers also allow retiming of words without changing the data speed.
  • each of the above-described units utilizes a substantially different circuit configuration. However, with the advent of integrated circuit techniques, it is desirable to have a single versatile unit which can perform all of these various forms of data manipulation. Ideally each of the basic units should be flexible enough that it can be placed in tandem with others to provide larger capacity units when required.
  • a matrix data manipulator comprising a plurality of modules forming a matrix having a number of rows and columns.
  • Each of the modules has a pair of storage registers.
  • One of each of the pairs of storage registers is serially interconnected with the others along the rows to form a first plurality of shift registers for transferring information therealong.
  • Each of the modules also has a plurality of gates for controlling the intratransfer of information between the pair of storage registers in each of the modules, and also for controlling the intertransfer of information between the other of the pairs of storage registers of adjacent modules thereby forming a second plurality of shift registers.
  • the second plurality of shift registers is formed along each of the columns. This provides the aforementioned serial-to-parallel or parallel-to-serial conversion.
  • the data manipulator includes additional gates for controlling the intertransfer of information between the other of the pairs of storage registers of adjacent modules to form a third plurality of shift registers'along each of the rows. This provides the serial-to-serial buffering thus enabling the interleaving or separating of data information.
  • the invention may also encompass still further gates for controlling the intertransfer of information between the other of the pairs of storage registers of adjacent modules in a direction opposed to that controlled by the additional gates to form a fourth plurality of shift registers along the rows.
  • This permits word reversal; thus a serial data stream may be fed in with the least significant bit first, and be fed out serially with the most significant bit first.
  • FIG. 1 is a block schematic diagram of a matrix data manipulator in accordance with the present invention.
  • FIGS. 2 through 6 illustrate data information vs time for various operating configurations of the matrix data manipulator illustrated in FIG. 1.
  • the digital information will be defined in terms of positive logic utilizing ls and Os. Consequently, all registers and gates will respond to positive going clock or gate signals.
  • many of the clock pulses illustrated in FIGS. 2 through 6 are shown as a single vertical line designating the leading edge of the positive going signals. It will be understood that in reality, all such pulses have a finite width.
  • the matrix data manipulator comprises a 4X4 matrix of identical modules M M M M M Since each of the modules is identical, only the lower left-hand module M has been illustrated in detail.
  • a plurality of inputs, which are common to each of the modules, are utilized to apply con-v trol signals to the various logic elements within. For simplicity and clarity, a number of these common inputs are illustrated only in the module M It will be understood that they are present in all of the modules even though not shown. Additionally, the control signals applied to these various inputs will bear the same designation as the input itself. Hence in portions of the specification and drawings the control signal itself will be referred to rather than the particular input.
  • Each of themodules M M comprises a pair of type D flip flops (FFs) l0 and 11 which function as single-bit storage registers.
  • the logic level at the D input i.e., a 1 or 0, is stored in the FPS l0 and 11 during the positive going edge of a clock signal applied to the C input.
  • the stored information signal is present at all times at the Q output of the FFs 10 and 11.
  • Both FFs 10 and 11 may be cleared by applying a reset signal to the R input which is simultaneously applied to all modules through the C input.
  • the FFs 10 and 11 are controlled by clock input and output signals C, and C respectively, which are applied to all inputs bearing these designations.
  • Each of the modules also includes five two-input NAND gates 12, 13, 14, and 16 and a single five-input NAND gate 17. While in many instances, it is desirable that each of the modules or for that matter the entire matrix of modules be constructed as an integral unit, it will be appreciated that this form of construction need not be adhered to. Thus the identification of individual modules in FIG. I of the drawings is for purposes of clarity only and the utilization of individual unit blocks may not exist in the practical realization of the manipulator.
  • the present embodiment also includes a plurality of NAND gates N N N N N, which are utilized to control the output signals of the manipulator.
  • N N N N N The detailed structure of the matrix data manipulator will become readily apparent from the following circuit description of a number of its functions taken in conjunction with the FIGS. 2 through 6 illustrating various operating modes of the manipulator.
  • the interconnected FFs 10 form a plurality of shift registers along each of the rows; while the FPS 11 in conjunction with the coacting gates 13, 14, 16 and 17, form either a plurality of shift registers down the columns or a plurality of shift registers along the rows, the latter being capable of transmitting information in either direction.
  • FIG. 2 illustrates the timing sequence for a field of four 3-bit words.
  • the A input logic 1. All other control inputs are either as shown in FIG. 2 or are maintained at logic 0.
  • Corresponding bits of each of the words are applied simultaneously to the inputs D D D and D shown in FIG. 1. The information bits are coupled through the serial inputs 5, to the respective D inputs of the FFs 10.
  • the logic information is stored in the FFs 10 of the left-hand column of the matrix.
  • the application of subsequent clock pulses C results in the information in each column being transferred one column to the right through serial outputs S and inputs 8,.
  • three clock pulses C are applied to transfer the information of a single field into the first three columns.
  • the FFs 10 function as a plurality of shift registers along each of the rows of the manipulator. For example, for words W, X, Y and Z, each of 3 bits I, 2 and 3, would be stored as follows:
  • the information is transferred from the FFs 10 to the FPS 11 through the NAND gates 12 and 17 by application of both a control transfer signal C-, (which is applied simultaneously to all the gates 12) and a clock pulse C
  • a control transfer signal C- which is applied simultaneously to all the gates 12
  • a clock pulse C As an example, if a l is present at the Q output of a FF 10, the presence of a 1 on the C input causes the output of the NAND gate 12 to go to 0. Under quiescent conditions, the output from each of the NAND gates 12-16 is a 1 thereby making the output from the NAND gate 17 a 0. However, the presence of a 0 at the output of the NAND gate 12 forces the output of the NAND gate 17 to a 1 which is applied to the D input of the PF 11.
  • the concurrent application of the clock pulse C stores the applied information in the FF 11.
  • the first word is stored horizontally in the FFs 11 of the modules M M and M in the bottom row, with the balance of the words being stored in ascending order along the balance of the rows of the matrix.
  • a logic I is now applied to the vertical transfer input V Consequently, with the application of each clock pulse C the words are transferred in descending order of the FPS 11, down the columns through the vertical outputs V and inputs V,, and the NAND gates 13 and 17 of the matrix data manipulator.
  • FIG. 3 illustrates the timing sequence for a field of two 4-bit words.
  • the A input logic 1.
  • All other control inputs are either as shown in FIG. 2 or are maintained at logic 0.
  • the information bits from each word are applied in parallel to the inputs D D, and are then transferred along the rows by the application of clock pulses C
  • the application of a control signal C and a clock pulse C transfers the information from the FFs 10 through the NAND gates 12 and 17 to the corresponding FFs 11 in each of the modules of the two left-hand columns.
  • FIG. 4 illustrates the timing sequence for a field of three 4-bit words.
  • the C input logic I. All other control inputs are either as shown in FIG. 4 or are maintained at logic 0.
  • the outputs Q and Q are connected to the inputs P and P respectively.
  • Corresponding bits of each of the words are applied in parallel to the inputs D,-D and are then transferred along therows by the application of clock pulses C After a complete field has been fed in, the application of a control signal C, and a clock pulse C transfers the information from the FFs through the NAND gates 12 and 17 to the corresponding FFs 11 in each of the modules of the three bottom rows of the matrix.
  • the three words which are now stored horizontally, one in each of the rows, can now be fed out by application of a horizontal transfer signal H, and a succession of clock pulses C which transfer the information along the rows of FFs 11 via horizontal outputs H and inputs H,, and the NAND gates 14 and 17.
  • a single slow speed data stream may be fed in, transferred and then fed out in bursts of high speed data.
  • the E outputs of one row may be connected to the D input of the following rows, on the same matrix or other contiguous matrices, to extend the length of each of the shift registers.
  • FIG. 5 illustrates the timing sequence for a field of three 4-bit words. During operation in this mode, the
  • a input logic 1 All other control inputs are either as shown in FIG. 5 or are maintained at logic 0.
  • the outputs E, and E are connected to the inputs D, and D respectively.
  • a single high speed data stream is applied to input D and is then transferred along the rows by application of clock pulses C, until a complete field of 12 bits has been fed in. At this point, the bottom three rows of the matrix are filled.
  • the application of a control signal C After the input of a complete field, the application of a control signal C,
  • FIG. 6 illustrates the timing sequence for a field of four 4-bit wordsjDuring operation in this mode, the B input logic 1. All other control inputs are either as shown in FIG. 6 or are maintained at logic 0. The information for each word is applied serially to the inputs D,D, and is then transferred along the rows by the application of clock pulses C,. After the input of a'complete field, the application of a control signal C, and a clock pulse C transfers the information from the FFs 10 to the corresponding FF's 11 in each of the modules of the matrix.
  • the four words, which are now stacked horizontally along the rows, can now be fed out by application of the reverse input signal R, to the NAND gate 16, and a succession of clock pulses C
  • the information in the FFs 11 is then transferred from right to left along the rows through left outputs L and inputs L, to the outputs L
  • Application of the control signal B results in the information being serially fed out in reverse order from the outputs (1 -0,.
  • This operating mode enables incoming data to be presented serially, least significant bit first; and be fed out serially, most significant bit first or vice versa.
  • INFORMATION CIRCULATOR it may be desirable to circulate the information within each of the modules by the application of a clock pulse'to provide a form of clock disabling function. This can be achieved by applying a local transfer signal L tothe NAND gate 15 whereupon the information at the Q output 'of the FFs 11 is coupled around the outputs H L and the NAND gates 15 and 17 back to its own D input. The application of a clock pulse C will now return the information from the individual FFs 11 to itself.
  • the matrix data manipulator can be made to operate in various other modes not covered in the above examples.
  • the length of the shift registers may be varied.
  • various information bit delays can be achieved by feeding information in and out at different points of the matrix. It is also evident that some of the gates could be dispensed with in applications where some of the functions are not desired.
  • the matrix itself need not necessarily be of rectangular form. It could, for instance, be a parallelogram of modules in which the input to each row is displaced one or more columns to the left or right from the row immediately preceding it.
  • the FFs 10 are connected directly together to form the I rows of input shift registers, while the FF s 11 are interconnected via various gates 12-17 to form the rows or columns of output shift registers.
  • this arrangement could be reversed so that the input FFs are interconnected via the various gates while the output FFs are connected directly together.
  • both sets of FFs could be interconnected via various gates although no practical advantage is foreseen with this arrangement.
  • a matrix data manipulator comprising: a matrix of modules having a plurality of rows and columns; each of said modules having a first and a second storage register, the first storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong; first gating means for controlling the transfer of information from the first to the second storage register in each of said modules; and second gating means for controlling the transfer of information between adjacent second storage registers along each of said columns, said second gating means co-acting with said second storage registers to form a second plurality of shift registers along said columns.
  • a matrix data manipulator as defined in claim 1 which additionally comprises:
  • a matrix data manipulator as defined in claim 2 which additionally comprises:
  • fourth gating means for controlling the transfer of information between adjacent second storage registers along each of said rows in a direction opposed to that controlled by said third gating means, said fourth gating means co-acting with said second storage registers to form a fourth plurality of shift registers along said rows.
  • a matrix data manipulator comprising: a plurality of modules forming a matrix having a plurality of rows and columns; each of said modules having a pair of storage registers, one of each of the pairs of storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong; each of said modules also having a plurality of gating means for controlling the intratransfer of information between the pair of storage registers in each of the modules, and the intertransfer of information between the other of the pair of storage registers of adjacent modules to form at least a second plurality of shift registers.
  • a matrix data manipulator comprising:
  • each of said modules having a first and a second storage register, the first storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong;
  • first gating means for controlling the transfer of infor mation from the first to the second storage register in each of said modules
  • second gating means for controlling the transfer of information between adjacent second storage registers along each of said rows, said second gating means co-acting with said second storage registers to form a second plurality of shift registers along said rows.
  • a matrix data manipulator comprising:
  • each of said modules having a pair of single-bit storage registers, one of each of the pairs of single-bit storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring data information therealong;
  • first gating means for controlling the transfer of said data information from said one single-bit storage register to the other single-bit storage register in each of said modules
  • second gating means for controlling the transfer of said data information between said other single-bit storage registers of adjacent modules along each of said columns, said second gating means co-acting with said other single-bit storage registers to form a second plurality of shift registers along said columns;
  • third gating means for controlling the transfer of said data information between said other single-bit storage registers of adjacent modules along each of said rows, said third gating means co-acting with said other single-bit storage registers to form a third plurality of shift registers along said rows;

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)
  • Complex Calculations (AREA)
  • Memory System (AREA)
  • Shift Register Type Memory (AREA)

Abstract

A matrix of shift registers under the control of a plurality of gates for manipulating data information. The various functions which may be performed by the manipulator include serial-toparallel and parallel-to-serial conversion, serial-to-serial buffering and interleaving or separating streams of data information.

Description

United States Patent 1 Hood Bee. 11, 1973 1 1 MATRIX OF SHIFT REGISTERS FOR MANIPULATING DATA [75] Inventor: David Frederick Hood, Kanata,
Ontario, Canada [73] Assignee: Bell Canada-Northern Electric Research Ltd., Ottawa, Ontario, Canada [22] Filed: Oct. 20, 1972 [21] Appl. No.: 299,245
52 us. Cl. 340/166 R, 340/147 R 51 Int. Cl H043 3/00 [58] Field of Search 340/166 R [56] References Cited UNITED STATES PATENTS 3,480,959 11/1969 Richmond 340/166 X Primary ExaminerHarold l. Pitts Attorney-John E. Mowle [57] ABSTRACT A matrix of shift registers under the control of a plurality of gates for manipulating data information. The various functions which may be performed by the manipulator include serial-to-parallel and parallel-toserial conversion, serial-to-serial buffering and interleaving or separating streams of data information.
6 Claims, 6 Drawing Figures o r o INCOMING OUTGOING PAIEN'IED IIEIII I I973 SIIEEI2IIF2 FIELD-I FIELD-2 FIELD-3 BITS AT 0. -D4 I 2 l 3 CLOCK C I I CONTROL CT CONTROL V CLOCK C0 I l I I I I I WORDS AT Q. -Q:, I I OUTGOING FIELD-0 TIME INCOMING FIELD-I FIELD-2 I I2 |3|4 FIELD-2 Fig. 2
FIELD-3 FIEL.
I I 2 I FIELD-4 WORDS AT D|'-D4 I 2 CLOCK C; I CONTROL C CONTROL V CLOCK C0 I BITS AT Q "Q2 I I 4 FIELD-O TIME v INCOMING FIELD" FIELD-I FIELD-2 Fig. 3
FIELD-2 FIELD-3 ELD- BITS AT D|-D3 I 3 I CLOCK C1 I l CONTROL C CONTROL H CLOCK Co I I I II IIIIIIIIIIIIIIIIIIIIIIIIII BITS AT Q IBM 3 WORDS OUTGOING TIME INCOM I NG WORDS FIELD-I 2 3 II2I3I4 4 FIELD-O Fig. 4
FIELD-2 FIELD-2 FIELD-3 BITS AT D3 CLOCK c CONTROL c IIII III
IIIIIIIIIIIIIIIIIIII CONTROL V CLOCK Co 1 WORDS AT Q, -Q4 2 I 3 OUTGOING FIELD-0 TIME INCOMING FIELD-I FIELD- I Fig. 5
FIELD-2 FIELD-3 I I I II2I3I'4 I I l I I I I BITS AT Q1 -Q4 2 FIELD-O TIME OUTGOING FIELD-I FIELD-2 Fig. 6
FIELD-3 MATRIX OF SHIFT REGISTERS FOR MANIPULATING DATA FIELD OF THE INVENTION This invention relates to a matrix data manipulator and more particularly to one which is capable of providing serial-to-parallel or parallel-to-serial conversion of binary information. As well, it may provide data stream buffering which enables a plurality of information streams to be interleaved or separated, and also various other functions in a single versatile unit.
DESCRIPTION OF THE PRIOR ART In the handling of digital information, it is often necessary to convert the information streams from one form to another. This has resulted in the development of various forms of digital converters. For instance, a plurality of serial data streams can be fed concurrently into corresponding shift registers and thence fed out in parallel into a multiplex unit which sequentially selects each of the parallel outputs in turn to provide a train of parallel digital outputs.
Conversely, the parallel information may be converted back to a plurality of serial information streams by selectively transferring the information into a number of shift registers under the control of a decoder. The information is then fed out from each of the shift registers in serial form.
Serial-to-serial converters have also been developed to enable the interleaving of information from a number of slow speed data streams into a single high speed data stream or vice versa. Serial-to-serial buffers also allow retiming of words without changing the data speed.
Each of the above-described units utilizes a substantially different circuit configuration. However, with the advent of integrated circuit techniques, it is desirable to have a single versatile unit which can perform all of these various forms of data manipulation. Ideally each of the basic units should be flexible enough that it can be placed in tandem with others to provide larger capacity units when required.
SUMMARY OF THE INVENTION It has been discovered that the various functions of serial-to-parallel and parallel-to-serial conversion, seri al-to-serial buffering, and interleaving or separating 'of data information, can be achieved in a single, versatile data manipulator by providing a matrix of shift registers under control of a plurality of gates.
Thus, in accordance with the present invention there is provided a matrix data manipulator comprising a plurality of modules forming a matrix having a number of rows and columns. Each of the modules has a pair of storage registers. One of each of the pairs of storage registers is serially interconnected with the others along the rows to form a first plurality of shift registers for transferring information therealong. Each of the modules also has a plurality of gates for controlling the intratransfer of information between the pair of storage registers in each of the modules, and also for controlling the intertransfer of information between the other of the pairs of storage registers of adjacent modules thereby forming a second plurality of shift registers.
In one particular embodiment, the second plurality of shift registers is formed along each of the columns. This provides the aforementioned serial-to-parallel or parallel-to-serial conversion. In addition, the data manipulator includes additional gates for controlling the intertransfer of information between the other of the pairs of storage registers of adjacent modules to form a third plurality of shift registers'along each of the rows. This provides the serial-to-serial buffering thus enabling the interleaving or separating of data information.
The invention may also encompass still further gates for controlling the intertransfer of information between the other of the pairs of storage registers of adjacent modules in a direction opposed to that controlled by the additional gates to form a fourth plurality of shift registers along the rows. This permits word reversal; thus a serial data stream may be fed in with the least significant bit first, and be fed out serially with the most significant bit first.
BRIEF DESCRIPTION OF THE DRAWINGS An example embodiment of the invention will now be described with reference to the accompanying drawings in which:
FIG. 1 is a block schematic diagram of a matrix data manipulator in accordance with the present invention; and
FIGS. 2 through 6 illustrate data information vs time for various operating configurations of the matrix data manipulator illustrated in FIG. 1.
DESCRIPTION OF THE PREFERRED EMBODIMENT In the following example embodiment, the digital information will be defined in terms of positive logic utilizing ls and Os. Consequently, all registers and gates will respond to positive going clock or gate signals. For simplicity, many of the clock pulses illustrated in FIGS. 2 through 6 are shown as a single vertical line designating the leading edge of the positive going signals. It will be understood that in reality, all such pulses have a finite width.
Referring to FIG. I, the matrix data manipulator comprises a 4X4 matrix of identical modules M M M M M Since each of the modules is identical, only the lower left-hand module M has been illustrated in detail. A plurality of inputs, which are common to each of the modules, are utilized to apply con-v trol signals to the various logic elements within. For simplicity and clarity, a number of these common inputs are illustrated only in the module M It will be understood that they are present in all of the modules even though not shown. Additionally, the control signals applied to these various inputs will bear the same designation as the input itself. Hence in portions of the specification and drawings the control signal itself will be referred to rather than the particular input.
Each of themodules M M comprises a pair of type D flip flops (FFs) l0 and 11 which function as single-bit storage registers. The logic level at the D input, i.e., a 1 or 0, is stored in the FPS l0 and 11 during the positive going edge of a clock signal applied to the C input. The stored information signal is present at all times at the Q output of the FFs 10 and 11. Both FFs 10 and 11 may be cleared by applying a reset signal to the R input which is simultaneously applied to all modules through the C input. The FFs 10 and 11 are controlled by clock input and output signals C, and C respectively, which are applied to all inputs bearing these designations. Each of the modules also includes five two- input NAND gates 12, 13, 14, and 16 and a single five-input NAND gate 17. While in many instances, it is desirable that each of the modules or for that matter the entire matrix of modules be constructed as an integral unit, it will be appreciated that this form of construction need not be adhered to. Thus the identification of individual modules in FIG. I of the drawings is for purposes of clarity only and the utilization of individual unit blocks may not exist in the practical realization of the manipulator.
While not necessary to the basic structure of the matrix data manipulator, the present embodiment also includes a plurality of NAND gates N N N N N, which are utilized to control the output signals of the manipulator. The detailed structure of the matrix data manipulator will become readily apparent from the following circuit description of a number of its functions taken in conjunction with the FIGS. 2 through 6 illustrating various operating modes of the manipulator. As manifest in the following description, the interconnected FFs 10 form a plurality of shift registers along each of the rows; while the FPS 11 in conjunction with the coacting gates 13, 14, 16 and 17, form either a plurality of shift registers down the columns or a plurality of shift registers along the rows, the latter being capable of transmitting information in either direction.
SERIAL-TO-PARALLEL CONVERTER FIG. 2 illustrates the timing sequence for a field of four 3-bit words. During operation in this mode, the A input logic 1. All other control inputs are either as shown in FIG. 2 or are maintained at logic 0. Corresponding bits of each of the words are applied simultaneously to the inputs D D D and D shown in FIG. 1. The information bits are coupled through the serial inputs 5, to the respective D inputs of the FFs 10.
Upon application of a clock pulse C the logic information is stored in the FFs 10 of the left-hand column of the matrix. The application of subsequent clock pulses C, results in the information in each column being transferred one column to the right through serial outputs S and inputs 8,. In this particular embodiment, three clock pulses C, are applied to transfer the information of a single field into the first three columns. Thus, the FFs 10 function as a plurality of shift registers along each of the rows of the manipulator. For example, for words W, X, Y and Z, each of 3 bits I, 2 and 3, would be stored as follows:
COLUMNS Inputs 4 3 2 Rows D4 Z3 Z2 Z1 4 D3 (3 Y2 Y1 3 D2 X3 X2 X1 2 D1 W3 W2 W1 1 After storage of a complete field, the information is transferred from the FFs 10 to the FPS 11 through the NAND gates 12 and 17 by application of both a control transfer signal C-, (which is applied simultaneously to all the gates 12) and a clock pulse C As an example, if a l is present at the Q output of a FF 10, the presence of a 1 on the C input causes the output of the NAND gate 12 to go to 0. Under quiescent conditions, the output from each of the NAND gates 12-16 is a 1 thereby making the output from the NAND gate 17 a 0. However, the presence of a 0 at the output of the NAND gate 12 forces the output of the NAND gate 17 to a 1 which is applied to the D input of the PF 11. The concurrent application of the clock pulse C stores the applied information in the FF 11.
Conversely, if a 0 is present at the 0 output of the FF It} the output of gate 12 remains at the I level during the application of the control signal C Since all inputs to the NAND gate 17 remain l, the output of gate 17, which is stored in the PF 11, is a 0.
At this point in time, the first word is stored horizontally in the FFs 11 of the modules M M and M in the bottom row, with the balance of the words being stored in ascending order along the balance of the rows of the matrix. A logic I is now applied to the vertical transfer input V Consequently, with the application of each clock pulse C the words are transferred in descending order of the FPS 11, down the columns through the vertical outputs V and inputs V,, and the NAND gates 13 and 17 of the matrix data manipulator. Upon reaching the bottom row, the digital information contained in each word is fed out from the vertical output V and applied to the associated input of one of the NAND gates N N N and N Application of the logic 1 to the control input A results in the formation present at V being applied through the respective NAND gates N N N and N and the NAND gates N N N and N, to the outputs Q Q Q and Q For example, under quiescent conditions, all inputs to the NAND gates bi -N are 0. Consequently the inputs to the NAND gates N,-N are all 1 with the result that the outputs Q Q Q and Q, are 0. If now the vertical output V of module M goes to 1, both inputs to the NAND gate N will be ls forcing its output to a 0. The application of a 0 to the NAND gate N results in a I at the output Q Conversely, if the output V of the module M,., remains at 0, the output from the NAND gate N remains a 1 despite the presence of the 1 on input A. Consequently, the output Q, remains a 0.
This completes the serial-to-parallel conversion of a field of information. As is apparent from FIG. 2, because the FFs l0 and 11 are normally isolated from each other, except during the presence of the transfer signal C the bits of one field can be serially fed in at D,D while the words of the preceding field are being fed out in parallel at Q,-Q.,. As is also evident, the input and output clocks C and C do not necessarily run at the same rate. The only restriction is that the output of one field from the manipulator must be completed prior to the transfer of information from the FFs 10 to the FFs 11 in each module; otherwise information will be lost.
PARA LLEL-TO-SERIAL CON VERTER FIG. 3 illustrates the timing sequence for a field of two 4-bit words. During operation in this mode, the A input logic 1. All other control inputs are either as shown in FIG. 2 or are maintained at logic 0. The information bits from each word are applied in parallel to the inputs D D, and are then transferred along the rows by the application of clock pulses C After the input of a complete field, the application of a control signal C and a clock pulse C transfers the information from the FFs 10 through the NAND gates 12 and 17 to the corresponding FFs 11 in each of the modules of the two left-hand columns. The two words, which are now stacked vertically in the columns, can now be serially fed out by application of a vertical transfer signal V and a succession of clock pulses C As in the previous example, application of a control signal A results in the information being serially fed out from the outputs Q and Q It is evident from the preceding examples that any combination of bits and words may be converted from serial-to-parallel or parallel-to-serial up to a maximum of the 4X4 matrix. If a still larger conversion is required, a plurality of matrix data manipulators may be connected in tandem either horizontally or vertically by connecting the respective E outputs to the D inputs of a following horizontal unit and the Q outputs to the P inputs of a following vertical unit.
SERIAL-TO-SERIAL ACCELERATOR FIG. 4 illustrates the timing sequence for a field of three 4-bit words. During operation in this mode, the C input logic I. All other control inputs are either as shown in FIG. 4 or are maintained at logic 0. In addition, the outputs Q and Q, are connected to the inputs P and P respectively. Corresponding bits of each of the words are applied in parallel to the inputs D,-D and are then transferred along therows by the application of clock pulses C After a complete field has been fed in, the application of a control signal C, and a clock pulse C transfers the information from the FFs through the NAND gates 12 and 17 to the corresponding FFs 11 in each of the modules of the three bottom rows of the matrix. The three words which are now stored horizontally, one in each of the rows, can now be fed out by application of a horizontal transfer signal H, and a succession of clock pulses C which transfer the information along the rows of FFs 11 via horizontal outputs H and inputs H,, and the NAND gates 14 and 17. Information at the H output of the modules M M and M is directed through the appropriate NAND gatesby the application of a logic 1 on the control input C to the respective outputs 0,, Q and Q However, since the outputs of Q and Q, are coupled to'the inputs P, and P respectively, the information is forced back through the shift register of the next lower row until all of the information finally emanates sequentially from the output Q Consequently, in this operating mode, a plurality of slow speed input words can be interleaved and fed out in a single high speed data stream.
In an alternate embodiment of this operating mode, a single slow speed data stream may be fed in, transferred and then fed out in bursts of high speed data. Where the length of each word contains more than 4 bits, the E outputs of one row may be connected to the D input of the following rows, on the same matrix or other contiguous matrices, to extend the length of each of the shift registers.
SERIAL-TO-PARALLEL REDUCER FIG. 5 illustrates the timing sequence for a field of three 4-bit words. During operation in this mode, the
A input logic 1. All other control inputs are either as shown in FIG. 5 or are maintained at logic 0. In addition, the outputs E, and E, are connected to the inputs D, and D respectively. A single high speed data stream is applied to input D and is then transferred along the rows by application of clock pulses C, until a complete field of 12 bits has been fed in. At this point, the bottom three rows of the matrix are filled. After the input of a complete field, the application of a control signal C,
and a clock pulse C transfer the information from the FFs 10 to the corresponding FFs 11 in each of the modules of the bottom three rows. The three words, which are now stored horizontally along the rows, can now be fed out in parallel by application of a vertical transfer signal V, and a succession of clock pulses C Application of a control signal to the A lead results in the words being fed out in parallel from the outputs Q,Q,. It will be apparent that. the duration of the input and output words need not necessarily be the same. It is only essential that a complete field be emptied from the manipulator prior to the transfer of the following field from the FFs 10 to the FFs ll.
SERIAL-TO-SERIAL REVERTER FIG. 6 illustrates the timing sequence for a field of four 4-bit wordsjDuring operation in this mode, the B input logic 1. All other control inputs are either as shown in FIG. 6 or are maintained at logic 0. The information for each word is applied serially to the inputs D,D, and is then transferred along the rows by the application of clock pulses C,. After the input of a'complete field, the application of a control signal C, and a clock pulse C transfers the information from the FFs 10 to the corresponding FF's 11 in each of the modules of the matrix. The four words, which are now stacked horizontally along the rows, can now be fed out by application of the reverse input signal R, to the NAND gate 16, and a succession of clock pulses C The information in the FFs 11 is then transferred from right to left along the rows through left outputs L and inputs L, to the outputs L Application of the control signal B results in the information being serially fed out in reverse order from the outputs (1 -0,. This operating mode enables incoming data to be presented serially, least significant bit first; and be fed out serially, most significant bit first or vice versa.
INFORMATION CIRCULATOR In some instances, it may be desirable to circulate the information within each of the modules by the application of a clock pulse'to provide a form of clock disabling function. This can be achieved by applying a local transfer signal L tothe NAND gate 15 whereupon the information at the Q output 'of the FFs 11 is coupled around the outputs H L and the NAND gates 15 and 17 back to its own D input. The application of a clock pulse C will now return the information from the individual FFs 11 to itself.
By connecting various outputs back to inputs and clocking appropriately, it is obvious that the matrix data manipulator can be made to operate in various other modes not covered in the above examples. For instance, the length of the shift registers may be varied. Additionally, various information bit delays can be achieved by feeding information in and out at different points of the matrix. It is also evident that some of the gates could be dispensed with in applications where some of the functions are not desired.
Also, the matrix itself need not necessarily be of rectangular form. It could, for instance, be a parallelogram of modules in which the input to each row is displaced one or more columns to the left or right from the row immediately preceding it.
In the above-described example embodiment, the FFs 10 are connected directly together to form the I rows of input shift registers, while the FF s 11 are interconnected via various gates 12-17 to form the rows or columns of output shift registers. In an alternate embodiment this arrangement could be reversed so that the input FFs are interconnected via the various gates while the output FFs are connected directly together. Indeed, both sets of FFs could be interconnected via various gates although no practical advantage is foreseen with this arrangement.
What is claimed is: l. A matrix data manipulator comprising: a matrix of modules having a plurality of rows and columns; each of said modules having a first and a second storage register, the first storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong; first gating means for controlling the transfer of information from the first to the second storage register in each of said modules; and second gating means for controlling the transfer of information between adjacent second storage registers along each of said columns, said second gating means co-acting with said second storage registers to form a second plurality of shift registers along said columns. 2. A matrix data manipulator as defined in claim 1 which additionally comprises:
third gating means for controlling the transfer of information between adjacent second storage registers along each of said rows, said third gating meanS co-acting with said second storage registers to form a third plurality of shift registers along said rows. 3. A matrix data manipulator as defined in claim 2 which additionally comprises:
fourth gating means for controlling the transfer of information between adjacent second storage registers along each of said rows in a direction opposed to that controlled by said third gating means, said fourth gating means co-acting with said second storage registers to form a fourth plurality of shift registers along said rows. 4. A matrix data manipulator comprising: a plurality of modules forming a matrix having a plurality of rows and columns; each of said modules having a pair of storage registers, one of each of the pairs of storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong; each of said modules also having a plurality of gating means for controlling the intratransfer of information between the pair of storage registers in each of the modules, and the intertransfer of information between the other of the pair of storage registers of adjacent modules to form at least a second plurality of shift registers.
5. A matrix data manipulator comprising:
a matrix of modules having a plurality of rows and columns;
each of said modules having a first and a second storage register, the first storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong;
first gating means for controlling the transfer of infor mation from the first to the second storage register in each of said modules; and
second gating means for controlling the transfer of information between adjacent second storage registers along each of said rows, said second gating means co-acting with said second storage registers to form a second plurality of shift registers along said rows.
6. A matrix data manipulator comprising:
a matrix of modules having a plurality of rows and columns;
each of said modules. having a pair of single-bit storage registers, one of each of the pairs of single-bit storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring data information therealong;
first gating means for controlling the transfer of said data information from said one single-bit storage register to the other single-bit storage register in each of said modules;
second gating means for controlling the transfer of said data information between said other single-bit storage registers of adjacent modules along each of said columns, said second gating means co-acting with said other single-bit storage registers to form a second plurality of shift registers along said columns;
third gating means for controlling the transfer of said data information between said other single-bit storage registers of adjacent modules along each of said rows, said third gating means co-acting with said other single-bit storage registers to form a third plurality of shift registers along said rows;
so as to provide either serial-to-parallel conversion,
parallel-to-serial conversion or serial-to-serial buffering of the data information.

Claims (6)

1. A matrix data manipulator comprising: a matrix of modules having a plurality of rows and columns; each of said modules having a first and a second storage register, the first storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong; first gating means for controlling the transfer of information from the first to the second storage register in each of said modules; and second gating means for controlling the transfer of information between adjacent second storage registers along each of said columns, said second gating means co-acting with said second storage registers to form a second plurality of shift registers along said columns.
2. A matrix data manipulator as defined in claim 1 which additionally comprises: third gating means for controllinG the transfer of information between adjacent second storage registers along each of said rows, said third gating meanS co-acting with said second storage registers to form a third plurality of shift registers along said rows.
3. A matrix data manipulator as defined in claim 2 which additionally comprises: fourth gating means for controlling the transfer of information between adjacent second storage registers along each of said rows in a direction opposed to that controlled by said third gating means, said fourth gating means co-acting with said second storage registers to form a fourth plurality of shift registers along said rows.
4. A matrix data manipulator comprising: a plurality of modules forming a matrix having a plurality of rows and columns; each of said modules having a pair of storage registers, one of each of the pairs of storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong; each of said modules also having a plurality of gating means for controlling the intratransfer of information between the pair of storage registers in each of the modules, and the intertransfer of information between the other of the pair of storage registers of adjacent modules to form at least a second plurality of shift registers.
5. A matrix data manipulator comprising: a matrix of modules having a plurality of rows and columns; each of said modules having a first and a second storage register, the first storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring information therealong; first gating means for controlling the transfer of information from the first to the second storage register in each of said modules; and second gating means for controlling the transfer of information between adjacent second storage registers along each of said rows, said second gating means co-acting with said second storage registers to form a second plurality of shift registers along said rows.
6. A matrix data manipulator comprising: a matrix of modules having a plurality of rows and columns; each of said modules having a pair of single-bit storage registers, one of each of the pairs of single-bit storage registers being serially interconnected along each of said rows to form a first plurality of shift registers for transferring data information therealong; first gating means for controlling the transfer of said data information from said one single-bit storage register to the other single-bit storage register in each of said modules; second gating means for controlling the transfer of said data information between said other single-bit storage registers of adjacent modules along each of said columns, said second gating means co-acting with said other single-bit storage registers to form a second plurality of shift registers along said columns; third gating means for controlling the transfer of said data information between said other single-bit storage registers of adjacent modules along each of said rows, said third gating means co-acting with said other single-bit storage registers to form a third plurality of shift registers along said rows; so as to provide either serial-to-parallel conversion, parallel-to-serial conversion or serial-to-serial buffering of the data information.
US00299245A 1972-10-20 1972-10-20 Matrix of shift registers for manipulating data Expired - Lifetime US3778773A (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US29924572A 1972-10-20 1972-10-20

Publications (1)

Publication Number Publication Date
US3778773A true US3778773A (en) 1973-12-11

Family

ID=23153958

Family Applications (1)

Application Number Title Priority Date Filing Date
US00299245A Expired - Lifetime US3778773A (en) 1972-10-20 1972-10-20 Matrix of shift registers for manipulating data

Country Status (6)

Country Link
US (1) US3778773A (en)
JP (1) JPS4995547A (en)
DE (1) DE2352651A1 (en)
FR (1) FR2204085B1 (en)
GB (1) GB1422819A (en)
NL (1) NL7314388A (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2359562A1 (en) * 1976-07-20 1978-02-17 Labo Cent Telecommunicat DIGITAL SYSTEM TRANSPOSITION DEVICE
EP0021084A1 (en) * 1979-06-18 1981-01-07 Siemens Aktiengesellschaft Solid-state integrated semi-conductor memory
US4274085A (en) * 1979-06-28 1981-06-16 Motorola, Inc. Flexible mode DES system
EP0067384A2 (en) * 1981-06-17 1982-12-22 Digital Equipment Corporation Circuit for serializing and deserializing digital data
EP0119689A2 (en) * 1983-02-22 1984-09-26 Northern Telecom Limited Serial and parallel interface device
US4799040A (en) * 1983-03-30 1989-01-17 Tokyo Shibaura Denki Kabushiki Kaisha Data conversion circuit
WO1990007753A1 (en) * 1988-12-27 1990-07-12 Eastman Kodak Company Resequencing line store device
US5261046A (en) * 1988-12-27 1993-11-09 Eastman Kodak Company Resequencing line store device

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS57139851A (en) * 1981-02-24 1982-08-30 Fanuc Ltd Serial-parallel converter
JPS5972227A (en) * 1982-10-18 1984-04-24 Nippon Telegr & Teleph Corp <Ntt> Series and parallel converting circuit
JPS60169893A (en) * 1984-02-15 1985-09-03 シチズン時計株式会社 Bit pattern converter
US5305399A (en) * 1990-04-19 1994-04-19 Ricoh Corporation Two dimensional shift-array for use in image compression VLSI

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3480959A (en) * 1968-05-07 1969-11-25 United Aircraft Corp Range gated integrator

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3480959A (en) * 1968-05-07 1969-11-25 United Aircraft Corp Range gated integrator

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2359562A1 (en) * 1976-07-20 1978-02-17 Labo Cent Telecommunicat DIGITAL SYSTEM TRANSPOSITION DEVICE
EP0021084A1 (en) * 1979-06-18 1981-01-07 Siemens Aktiengesellschaft Solid-state integrated semi-conductor memory
US4274085A (en) * 1979-06-28 1981-06-16 Motorola, Inc. Flexible mode DES system
EP0067384A2 (en) * 1981-06-17 1982-12-22 Digital Equipment Corporation Circuit for serializing and deserializing digital data
EP0067384A3 (en) * 1981-06-17 1984-01-04 Digital Equipment Corporation Circuit for serializing and deserializing digital data
EP0119689A2 (en) * 1983-02-22 1984-09-26 Northern Telecom Limited Serial and parallel interface device
EP0119689A3 (en) * 1983-02-22 1986-11-20 Northern Telecom Limited Serial and parallel interface device
US4799040A (en) * 1983-03-30 1989-01-17 Tokyo Shibaura Denki Kabushiki Kaisha Data conversion circuit
WO1990007753A1 (en) * 1988-12-27 1990-07-12 Eastman Kodak Company Resequencing line store device
US5261046A (en) * 1988-12-27 1993-11-09 Eastman Kodak Company Resequencing line store device

Also Published As

Publication number Publication date
FR2204085B1 (en) 1976-11-19
JPS4995547A (en) 1974-09-10
NL7314388A (en) 1974-04-23
FR2204085A1 (en) 1974-05-17
GB1422819A (en) 1976-01-28
DE2352651A1 (en) 1974-05-09

Similar Documents

Publication Publication Date Title
US3778773A (en) Matrix of shift registers for manipulating data
EP0714534B1 (en) Multiple-port shared memory interface and associated method
US4032893A (en) Reconfigurable data bus
US5065369A (en) Video memory device
US3238298A (en) Multiplex communication system with multiline digital buffer
US4276611A (en) Device for the control of data flows
GB2110507A (en) Time division switching matrix
IE52044B1 (en) Time division multiplex telecommunication digital switching module
US3798607A (en) Magnetic bubble computer
US3281537A (en) Multiplex switching stage and its associated control circuits
JPH0327635A (en) Digital communication equipment
US4714922A (en) Interconnection networks
US3751597A (en) Time division multiplex network switching unit
US3281536A (en) Pcm switching stage and its associated circuits
Smith et al. Recirculating, pipelined, and multistage SIMD interconnection networks
US3553652A (en) Data field transfer apparatus
US4500986A (en) Asymmetrical time division matrix apparatus
US3806657A (en) Merging time slot interchanger for time division switching networks
US3281795A (en) Message assembly and distribution apparatus
US6590900B1 (en) Time and space sliced non-blocking network switching fabric
US4538260A (en) Electronic time switch
US3379836A (en) Time division multiplex telegraph message switching center employing time slot multiplication
US3299406A (en) Multiple access delay structures
JP2676077B2 (en) Serial-parallel conversion circuit
JP2509176B2 (en) Data speed conversion processing circuit