US20140055290A1 - Methods and Apparatus in Alternate Finite Field Based Coders and Decoders - Google Patents
Methods and Apparatus in Alternate Finite Field Based Coders and Decoders Download PDFInfo
- Publication number
- US20140055290A1 US20140055290A1 US14/064,089 US201314064089A US2014055290A1 US 20140055290 A1 US20140055290 A1 US 20140055290A1 US 201314064089 A US201314064089 A US 201314064089A US 2014055290 A1 US2014055290 A1 US 2014055290A1
- Authority
- US
- United States
- Prior art keywords
- state
- symbols
- finite field
- over
- symbol
- 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.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/13—Linear codes
- H03M13/15—Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes
- H03M13/151—Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes using error location or error correction polynomials
- H03M13/158—Finite field arithmetic processing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
- G06F7/38—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
- G06F7/48—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
- G06F7/483—Computations with numbers represented by a non-linear combination of denominational numbers, e.g. rational numbers, logarithmic number system or floating-point numbers
- G06F7/487—Multiplying; Dividing
- G06F7/4876—Multiplying
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F5/00—Methods or arrangements for data conversion without changing the order or content of the data handled
- G06F5/01—Methods or arrangements for data conversion without changing the order or content of the data handled for shifting, e.g. justifying, scaling, normalising
- G06F5/012—Methods or arrangements for data conversion without changing the order or content of the data handled for shifting, e.g. justifying, scaling, normalising in floating-point computations
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M7/00—Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/09—Error detection only, e.g. using cyclic redundancy check [CRC] codes or single parity bit
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/13—Linear codes
- H03M13/15—Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes
- H03M13/151—Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes using error location or error correction polynomials
- H03M13/1515—Reed-Solomon codes
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/13—Linear codes
- H03M13/19—Single error correction without using particular properties of the cyclic codes, e.g. Hamming codes, extended or generalised Hamming codes
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/23—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using convolutional codes, e.g. unit memory codes
Definitions
- U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 11/679,316 filed on Feb. 27, 2007 which claims the benefit of U.S. Provisional Application No. 60/779,068, filed Mar. 3, 2006, which are both incorporated herein by reference.
- U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 11/566,725 filed on Dec. 5, 2006 which claims the benefit of U.S. Provisional Patent Application Ser. No. 60/742,831, filed Dec. 6, 2005, which are both incorporated herein by reference.
- the present invention relates to apparatus and methods for coding and for decoding.
- it relates to methods and apparatus for coding and for decoding that apply an implementation of at least an n-state addition over an alternate finite field GF(n) and at least one n-state inverter defined by a multiplication over the alternate finite field GF(n) or an implementation of a truth table defined by said addition and inverter, with n>2, with n>3 or with n>4.
- Finite fields GF(n), including classical extension fields are known.
- coders apply additions and multiplications over a classical finite field GF(n). This makes certain elements of an encoder and/or decoder relatively predictable. It would make a coded signal of n-state symbols with n>2, n>3 or n>4, including certain check symbols generated as part of a code word less predictable if novel functions with attractive properties as defined in an alternate and currently unknown finite field would be used.
- a single truth table is implemented which is a truth table of an addition over an alternate finite field or a truth table of an addition over the alternate finite field that is modified in accordance with at least one inverter defined by a multiplication over an alternate finite field, wherein an alternate finite field has a neutral element that is not 0.
- an apparatus for encoding a first sequence of n-state symbols, each symbol being represented by a signal, comprising an input enabled to receive the first sequence of n-state symbols, a device implementing an addition over an alternate finite field GF(n) with n ⁇ 3, and an output that provides a second sequence of encoded symbols.
- coders, decoders, encryption devices and decryption devices that process a sequence of a plurality of n-state symbols or of a plurality of blocks of n-state symbols by applying at least two different finite fields GF(p) with p ⁇ n.
- one of the two finite fields GF(p) is an alternate finite field of the other finite field.
- FIGS. 1-7 illustrate Linear Feedback Shift Registers (LFSRs) representing a minimal polynomial to generate p state symbols representing states of a field over p q ;
- LFSRs Linear Feedback Shift Registers
- FIG. 8 illustrates reduction of an n-state truth table over at least one n-state inverter in accordance with an aspect of the present invention
- FIGS. 9-10 illustrate a sequence generator in accordance with an aspect of the present invention.
- FIG. 11 illustrates a coder in accordance with an aspect of the present invention
- FIG. 12 illustrates a coder in accordance with an aspect of the present invention
- FIG. 13 illustrates a decoder in accordance with an aspect of the present invention
- FIG. 14 illustrates a system that implements a truth table in accordance with an aspect of the present invention
- FIG. 15 illustrates a scrambler in accordance with an aspect of the present invention
- FIG. 16 illustrates a descrambler in accordance with an aspect of the present invention
- FIG. 17 illustrates a sequence generator in accordance with an aspect of the present invention
- FIGS. 18 and 19 illustrate a coder in accordance with an aspect of the present invention
- FIG. 20 illustrates a decoder in accordance with an aspect of the present invention
- FIGS. 21 and 22 illustrate coding matrices in accordance with an aspect of the present invention
- FIG. 23 illustrates a coder in accordance with an aspect of the present invention
- FIG. 24 illustrates another coder in accordance with an aspect of the present invention.
- FIG. 25 illustrates a device that implements a truth table in accordance with an aspect of the present invention
- FIG. 26 illustrates another device that implements a truth table in accordance with an aspect of the present invention
- FIG. 27 illustrates a coder in accordance with an aspect of the present invention
- FIG. 28 illustrates a coder in reverse direction in accordance with an aspect of the present invention
- FIG. 29 illustrates a communication system in accordance with an aspect of the present invention
- FIG. 30 illustrates part of a data storage system in accordance with an aspect of the present invention
- FIG. 31 illustrates another part of a data storage system in accordance with another aspect of the present invention.
- FIG. 32 illustrates a processor based system to perform coding and decoding steps in accordance with an aspect of the present invention
- FIG. 33 illustrates a Linear Feedback Shift Register (LFSR) in accordance with an aspect of the present invention
- FIGS. 34 and 35 illustrate a coder in accordance with an aspect of the present invention.
- FIG. 36 illustrates a method in accordance with various aspects of the present invention
- FIG. 37 illustrates an implementation of a method in accordance with various aspects of the present invention.
- FIGS. 38 and 39 illustrate n-state truth tables in accordance with various aspects of the present invention.
- n-valued or n-state herein is used generally as non-binary wherein n>2, unless the binary case is included.
- n-state symbol is used.
- An n-state symbol is a symbol that has one of n states.
- a symbol or an n-state symbol is a single entity.
- a symbol herein is being generated or processed as a signal by an apparatus.
- a symbol such as an n-state symbol can be represented by a single n-state signals that can have one of n states; it can also be represented and processed as a plurality of signals such as binary signals.
- check symbol is used.
- the binary check function is the XOR function
- a check symbol generated by the XOR function is a 0 if there was an even number of 1s and a 1 if there was an odd number of 1s.
- the name parity has no such meaning in n-valued functions. Accordingly the name check symbols will be used.
- Parity calculation in binary error correction is the process wherein a number of bits in a codeword or sequence or block have for instance an even parity or even number of 1s, including the parity bit. Assume one has an 8 bit code word [a b c d e f g h] and a parity bit p is added. For instance a rule for determining a parity symbol could be: the number of 1s in [a b c d e f g h p] should always be even.
- n-valued logic one may use different ways or functions to create a ‘parity’ or check symbol.
- a non-reversible parity n-valued operation is one wherein a 1 is added (modulo-n) to a sum when a symbol is not 0, and a 0 when a symbol is zero.
- the reversibility is related to determining the original value of the symbols of which a parity symbol is determined.
- One method as an aspect of the present invention is to apply reversible n-valued logic operations to calculate the ‘check’ or parity symbol of a sequence of n-valued symbols.
- n-valued self-reversing functions are in general not associative. This means that even though a function may be commutative, the order of variables in a multi-variable equation does matter.
- the expression (x1 sc1 x2 sc2 p1) should be evaluated as ⁇ (x1 sc1 x2) sc2 p1 ⁇ . In words: first evaluate (x1 sc1 x2) as ‘term’ and then ⁇ term sc2 p1 ⁇ .
- n-state or n-valued symbol is a symbol which assumes one of n possible states.
- One may also use the term n-valued.
- An n-state or n-valued symbol for processing in an apparatus or a device is represented by a signal.
- Such a signal may be a single signal, which has one of n states.
- a 4-state symbol has one of 4 states or values.
- a 4-state symbol may have the values or states 0, 1, 2 and 3. Each state is represented by a single n-valued signal.
- the value or state of a signal may be determined by a voltage. It should be clear that it is not required that the states 0, 1, 2 and 3 are represented by 0, 1, 2 and 3 Volt respectively.
- the 4 different states may be represented by for instance 0.5 V, 1 V, 1.25 V and 1.75 V.
- a state in an n-state signal may be represented by an optical signal of a particular wavelength which in certain cases are considered independent instances of a physical phenomenon. Linear combinations of these independent instances will just mix the states but will not create a signal of a different state. Circuitry or apparatus that processes these type of n-state signals are in general non-linear.
- an n-state symbol may be represented by 2 or more signals.
- each possible state of a 4-state symbol may be represented by 2 binary signals.
- n-state symbol is preferred.
- the field also has an operation multiply, which is also commutative and associative.
- elements of an extension field GF(q p ) are generated by a primitive polynomial in q of order p or by a p-state LFSR expressing such a polynomial.
- Such polynomials are provided for the binary extension fields in for instance the earlier mentioned book of Lin and Costello in appendix A.
- the adder sc81 over GF(8) of paragraph [0113] is created from elements in GF(8) generated by the binary LFSR 1400 of FIG. 1 with binary logic function 1401 being XOR. Assume that the initial state of the LFSR is [1 0 0]. The consecutively generated states are then:
- the state [0 0 0] is the forbidden or degenerative state of the LFSR and represents GF(8) state 0.
- modulo-2 addition of the individual binary elements of a GF(8) state one gets the GF(8) addition result. For instance [1 0 0] XOR [0 1 0] ⁇ [1 1 0] which is GF(8) state 4 in accordance with the state diagram.
- [0 1 0] XOR [0 0 1] ⁇ [0 1 1] which is the new representation of GF(8). So changing the initial state of the LFSR does not change the addition or the related multiplication.
- Each of these additions based on a primitive or minimal polynomial has the same multiplier over GF(p q ) over which the operation c*(a+b) is distributive.
- Each of the multipliers has an inverse in the field.
- Each field thus generated has a different 32-state addition function which is associative.
- Each field thus generated has the same multiplier function, which combined with the appropriate addition over GF(32) is distributive.
- n-state coders n-state decoders
- n-state sequence generators n-state LFSRs
- n-state polynomial and arithmetical circuits Any n-state switching function herein be it an n-state function with at least two inputs and an output or an n-state inverter can be implemented in a switching device.
- the switching device can be a true n-state switching device wherein an n-state symbol having one of n-states is represented by an n-state signal.
- an n-state switching function be it an n-state function with at least two inputs and an output or an n-state inverter, can be implemented in a memory device, wherein the corresponding truth table of an n-state function is implemented in a memory.
- a memory can be a true n-state memory. It can also be a binary memory, wherein an n-state symbol is represented as a binary word, and inputted, stored and outputted as a binary word of binary signals.
- An analog/digital (A/D) and digital/analog (D/A) converter can be used to generate a true n-state signal from a binary word.
- extension field GF(4) which is a traditional field is defined by the following addition and multiplication over GF(4) sc4 and m4 respectively of which the truth tables are provided in the following tables.
- a 4-state symbol can be represented by a 2-bit word.
- the functions are associative and distributive.
- the addition is also commutative and self-reversing.
- the multiplication is reversible with elements of the field. It is again noted that a multiplication with a constant (or element) of the field is applying an n-state inverter with an input and an output of which the function is defined by a column or a row in the truth table of m4.
- a first alternate or not traditional addition over alternate field GF(4) is provided in the following truth table.
- the ‘zero’ element is again 3 (any multiplication with 3 results in 3) and the ‘1’ element (multiplying a symbol ‘a’ with this element will again create ‘a’) is ‘0’. Furthermore, a division is defined within this field as each factor of multiplication ‘b’ has a reverse ‘b ⁇ 1 ’ which is also an element of the field. (element 0 has 0 as inverse; element 1 has element 2 as inverse; and element 2 has element 1 as inverse. Furthermore, element 3 is the ‘zero’ element).
- a multiplier over GF(4) in this case is actually a 4-state inversion.
- the inversion is indicated by [0 1 2 3] ⁇ [a b c d].
- This means that the elements in the vector [0 1 2 3] are transformed into the elements of vector [a b c d] in their corresponding positions or: 0 ⁇ a; 1 ⁇ b; 2 ⁇ c; and 3 ⁇ d, wherein a, b, c and d are elements of GF(4).
- the multipliers 0, 1, and 2 are defined by the 4-state inversion [0 1 2 3] ⁇ [0 1 2 3] for multiplier 0; [0 1 2 3] ⁇ [1 2 0 3] for multiplier 1; and [0 1 2 3] ⁇ [2 0 1 3] for multiplier 2.
- FIG. 8 shows a device 2101 which implements the function sc4 in 2100 , which may be a memory or a switching circuit with inputs a and b and an output c which represents a 4-state symbol c.
- the output symbol on c which is represented by a signal is determined by the truth table of sc4 and the input symbols on a and b which are also are represented by signals.
- inv1 is multiplier 2
- inv2 is multiplier 1.
- the input b of 2100 is determined by the columns of a truth table. Accordingly, one has to modify the rows of sc4 in accordance with inv1 and the columns of that transformation in accordance with inv2 to arrive at sc42. One can also say that sc4 is modified in accordance with inv1 and inv2.
- a sequence generator for generating a sequence of n-state symbols using implementations of the addition and multiplier or the inverter reduced form thereof is provided.
- the sequence generator generates an n-state pseudo-noise or maximum length sequence of n-state symbols.
- An n-state sequence generator can be implemented by an n-state Linear Feedback Shift Register (LFSR), either in Galois or Fibonacci configuration.
- LFSR Linear Feedback Shift Register
- An n-state LFSR based sequence generator in Galois configuration is shown in FIG. 9 as 2201 and 2202 .
- the LFSR has a shift register of 3 storage elements, each element able to store and provide an n-state symbol.
- n-state function sc is implemented between two storage element.
- the LFSR 2201 has 3 storage elements, two functions sc (though one may apply two different functions) and three inverters inv1, inv2 and inv3.
- the maximum length sequence that can be generated with this n-state generator is a sequence of n 3 ⁇ 1 n-state symbols.
- the function sc is the above defined 4-state adder sc4 over alternate or non-traditional field GF(4).
- the inverters inv1, inv2 and inv3 are the 4-state inverters defined by the rows or columns of the truth table of m4 over alternate field GF(4).
- a generator may also have other functions than sc4 and inverters defined by m4 over alternate field GF(4) or have a function sc4 defined over alternate field GF(4) and n-state inverters that are not defined by m4.
- the sequence generator provides a sequence ‘outg’ on an output.
- a 4-state inverter will be selected from m4 and being [0 1 2 3] which is the identity, [1 2 0 3] and [2 0 1 3].
- the inverter [3 3 3 3] is effectively a 0 inverter or open connection.
- a relatively simple method to determine if a sequence is a m-sequence has been developed by the inventor of the present invention for instance in U.S. Pat. No. 7,580,472 to Lablans issued on Aug. 25, 2009 and in U.S. Pat. No. 7,725,779 to Lablans issued on May 25, 2010, which are both incorporated herein by reference.
- An auto-correlation graph of an n-state sequence can determine if a sequence is an m-sequence or a pseudo-noise sequence.
- the standard method of calculating an n-state auto-correlation graph will show side-peaks. Some sequences, which are not m-sequences, also have side-peaks.
- the novel method determines a correlation value by adding a constant value to a sum if corresponding symbols in two sequences are identical and subtracting a constant or nothing when the two symbols are different. This will create a single peak correlation graph for any n-state m-sequence.
- inv1 [2 0 1 3] and in2 and inv3 are both [1 2 0 3].
- the function sc is sc4 in the alternate field GF(4).
- the generator can generate a 4-state m-sequence on ‘outg’ of length 63 4-state symbols. Assume that the initial state of the LFSR is [3 2 1], then the first 10 generated 4-state symbols on ‘outg’ are [1 3 1 2 0 2 3 3 1 1].
- the two functions sc in 2201 have inv2 and inv3 respectively at an input. These functions can be reduced to scv1 and scv2 respectively by modifying the first function sc in accordance with inv2 and the second sc in accordance with inv3 in accordance with the method as was described earlier herein. Because sc is commutative, the functions scv1 and scv2 will be non-commutative.
- the two functions sc in 2301 have inr2 and inr3 respectively at an input.
- the first function sc also has inr1 at an output.
- These functions sc can be reduced to scr1 and scr2 respectively by modifying the first sc in accordance with inr1 and inr2 and the second sc in accordance with inr3 as is shown in 2302 and according to the method as was described earlier. Because sc is commutative, the functions scr1 and scr2 will be non-commutative.
- a sequence generator as provided in FIGS. 9 and 10 can be combined by a circuit as provided in FIG. 8 wherein in the combination at least one function over an alternate field GF(n) such as GF(4) is used to generate an n-state combined sequence such as an n-state Gold sequence as is disclosed in U.S. Pat. No. 7,580,472 to Lablans issued on Aug. 25, 2009 which is incorporated herein by reference.
- GF(n) such as GF(4)
- a sequence generator applying functions over an alternate field GF(n) such as alternate field GF(4), be it a Gold sequence generator or an m-sequence generator or any other sequence generator, is applied to generate a ‘known’ sequence to be applied in a scrambler in one of the configurations as shown in FIG. 8 .
- a scrambler 2400 is illustrated in FIG. 11 . It has a sequence generator 2401 to generate a known sequence which is provided on an input to a scrambling device 2402 such as provided in FIG. 8 and explained above.
- the input of the ‘known’ sequence to device 2402 has an inverter ins1, which may be an identity.
- This inverter is preferably an inverter defined by a multiplication over an alternate field GF(n).
- the inverter ins1 may also be any reversible n-state inverter if 2402 implements an addition over an alternate field GF(n).
- a to be scrambled n-state sequence ‘in’ is provided on a second input of 2402 with n-state inverter ins2, which may be an identity inverter.
- the device 2402 scrambles ‘in’ against ‘known’ and generates on an output the scrambled n-state sequence ‘out’.
- the output has an n-state inverter ins3 which may be an identity inverter.
- the scrambler or coder of FIG. 11 has a corresponding descrambler by applying the corresponding descramblers as explained related to FIG. 8 . It is to be understood that for clarity inverters ins1, ins2 and ins3 are used to explain the working of the scrambler. However, the n-state function implemented in 2402 may be reduced in accordance with ins1, in2, ins3 so that 2402 implements a single reduced truth table without having inverters at inputs or output. A further requirement for correct descrambling with a descrambler is that the sequence generator of a descrambler is synchronized with a sequence generator used by the corresponding scrambler.
- LFSR based encoders such as LFSR based scramblers are known as streaming ciphers or streaming encoding as they work continuously generating a coded symbol after an input symbol has been entered.
- Yet another coder provided in accordance with an aspect of the present invention is a reversible transposition coder wherein symbols in a sequence of symbols are transposed in accordance in part at least with an n-state pseudo-noise or maximum-length sequence generated by using at least an n-state addition and one n-state inverter that are defined over an alternate finite field GF(n) as provided herein.
- Yet another coder is a coder with a hopping rule based on an n-state pseudo-noise or maximum-length sequence generated by using at least an n-state addition and one n-state inverter that are defined over an alternate finite field GF(n) as provided herein.
- Another coder provided in accordance with an aspect of the present invention is an n-state LFSR based scrambler and a corresponding self synchronizing descrambler in Fibonacci configuration using at least an addition function over an alternate field GF(n) and preferably with an addition and an inverter defined by a multiplication over the alternate field GF(n).
- An illustration of such a scrambler 2500 is shown in FIG. 12 .
- the illustrative scrambler has a 3 stage n-state shift register, each register element enabled to store and provide an n-state symbol. It is to be understood that an LFSR can have more shift register elements than 3, and also less than 3.
- the scrambler 2500 has feedback taps to implementations 2501 and 2502 .
- the LFSR 2500 has an output 2504 and an input 2505 .
- the output 2504 is connected to an input of an implementation 2503 of an n-state scrambling function indicated as being ‘sc’.
- Another input of 2503 receives a sequence of n-state symbols ‘in’ which may be inverted by an inverter ‘inv4’.
- the output of 2503 is connected to an input 2505 of the LFSR, which may include an inverter ‘inv1’.
- the output of 2503 or (if present) the output of ‘inv1’ will generate the sequence of scrambled n-state symbols ‘scram’ resulting from ‘in’.
- the scrambler may include additional inverters, for instance ‘inv2’ and ‘inv3’.
- the implementations 2501 , 2502 and 2503 all are indicated as implementing a function ‘sc’.
- At least one implemented truth table to realize an n-state LFSR based scrambler is an n-state truth table of an addition over an alternate field GF(n).
- a scrambler also implements at least one n-state inverter being defined by the multiplication over the alternate field GF(n).
- FIG. 12 in accordance with an aspect of the present invention implements one function ‘sc’ being the addition over the alternate field GF(n) and that 2 of the functions now designated as ‘sc’ may be any n-state reversible, or even non-reversible, n-state function.
- the self-reversing descrambler 2600 corresponding to the scrambler of FIG. 12 is shown in FIG. 13 .
- the descrambler 2600 has the same structure as the scrambler. However, the scrambled sequence ‘scram’ is provided on the input 2605 of the LFSR of the descrambler.
- the inputted symbols are also inputted on 2603 which may be an implementation of sc, potentially after inversion by inverter inv1r, wherein inv1 in the scrambler and inv1r in the descrambler establish identity.
- the inverters inv1 and inv1r combined should establish identity. This means that a symbol inverter by both inv1 and inv1r should be un-transformed.
- Implementation 2603 which may be a device implementing a 2-dimensional truth table is then the descrambling device that has also one input connected to output 2604 of the LFSR of FIG. 13 . An output of 2603 then outputs a descrambled symbol. If the scrambler has an inverter inv at the input of the scrambling device 2503 then 2603 should have the inverter inv4r at its output. Inverters inv4 and inv4r should establish identity.
- FIGS. 12 and 13 pertain to a 4-state device, that all functions sc are the addition sc4 over the alternate finite field GF(4) as provided above and that inv1 and inv4 are identity inverters and inv2 is 4-state inverter [1 2 03] and inv3 is 4-state inverter [2 0 1 3] as defined by the multiplication over the alternate finite field GF(4).
- any of the coders and decoders described herein may be implemented in true n-state devices, as disclosed for instance in U.S. Pat. No. 7,218,144 to Lablans issued on May 15, 2007 and U.S. Pat. No. 7,002,490 to Lablans issued on Feb. 21, 2006 and U.S. Pat. No. 7,548,092 to Lablans issued on Jun. 16, 2009 and in U.S. Pat. No. 7,643,632 to Lablans issued on Jan. 5, 2010, which are all incorporated herein by reference in their entirety.
- N-state memory devices are disclosed in U.S. Pat. No. 7,397,690 issued on Jul. 8, 2008 to Lablans and in U.S. Pat. No.
- a memory device or a dual memory device with appropriate clocking acts as a shift register element as is known to one of ordinary skill.
- a shift register and in particular an n-state LFSR can also be implemented in an addressable memory, which may be an addressable n-state memory as is disclosed in U.S. Patent Application Publication Ser. No. 20070088997 to Lablans published on Apr. 19, 2007 and in U.S. Patent Application Publication Ser. No. 20070098160 to Lablans published on May 3, 2007 which are all incorporated herein by reference.
- An n-state symbol with n>2 is a designation of a processing unit which is processed by an implementation of an n-state truth table with n>2.
- An n-state truth table can be a one dimensional truth table that defines an n-state inverter having one input and one output. It is a vector (which may be represented as a column or a row vector) that defines how each of n possible input states of an input symbol is transformed into a state of an output symbol.
- a reversible n-state inverter transforms one of n states of an input symbol into one of n states of an output symbol, wherein each of n input states is transformed into a unique output state.
- An inverter can also be non-reversible in which case n input states or transformed into less than n output states.
- An n-state truth table can also be 2-dimensional wherein an output n-state symbol is determined by 2 n-state input symbols.
- An implementation of a 2 dimensional n-state truth table can be an actual active switching device. It can also be a memory device. In that case an n-state output symbol may be addressed by 2 n-state input symbols. Or in other words: an n-state output symbol has an address that is determined by 2 n-state input symbols.
- Such an n-state truth table can be implemented as for instance a 2 by 2 matrix in a computer program running on a processor with memory such as an Intel® microprocessor with memory running a language such as MatLab® of The MathWorks, Inc. of Natick, Mass. or FreeMat, an open source computer programming language, available from ⁇ URLwww.sourceforge.net>.
- the following truth table of sc4 can be implemented and the function sc4 can be executed in such a processor system.
- Each n-state symbol in this implementation sample is represented by a plurality of binary symbols, wherein a binary symbol or a bit is represented by a binary signal. An n-state symbol is thus represented by a word of binary signals.
- An illustrative system that implements a truth table and transforms an input to an output is shown in FIG. 14 .
- a binary processor 2703 has an input to receive a binary word in_b. A binary word may be received as a serial sequence of bits or may be received on a plurality of parallel inputs.
- the binary input word may be generated from an n-state signal in_n on a device 2701 which may be an Analog/Digital (A/D) converter which transforms a single n-state signal into a plurality of binary signals.
- the system may be provided with two binary words ‘word1’ and ‘word2’ in series or in parallel. In the parallel case the system may have at least two A/D converters.
- the processor 2703 After having received a single, or after receiving at least two input words the processor 2703 will address in one embodiment of the present invention the memory 2702 with and address based on the single input word or with the two input words to find in 2702 the related output word.
- the memory provides the processor with the output symbol or output binary word which may be applied for further processing or will be provided on an output by the processor to provide out_b as for instance a binary word.
- the binary output word out_b is provided to a Digital/Analog (D/A) converter to generate an n-state signal out_n.
- D/A Digital/Analog
- the execution takes an extra step for inversion, requiring at least an additional clock pulse.
- a signal be it binary or n-state with n>2 may be an electric signal, an optical signal, a magnetic signal, a radiation, an magneto-optical signal, an electro-magnetic signal, a mechanical signal or a mechanical impulse, a presence of a material or a quantum-mechanical state or any other physical state of a material that will represent at least one of 2 states in one embodiment of the present invention or at least 1 of 3 states in a further embodiment of the present invention or at least 1 of 4 states in yet a further embodiment of the present invention.
- an n-state scrambler with an n-state LFSR in Galois configuration is provided and a corresponding self synchronizing descrambler. Illustrative embodiments are shown in FIGS. 15 and 16 .
- the scrambler 2800 of FIG. 15 is based on an n-state LFSR with a 3-stage shift register with two connecting n-state functions sc and a scrambling function sc that receives the to be scrambled n-state sequence on input ‘in’.
- Two feedback taps contain n-state inverters inv2 and inv3 respectively.
- the end feedback to the output that provides the scrambled n-state sequence ‘scram’ contains an n-state inverter inv1.
- a corresponding descrambler 2900 is shown in FIG. 16 .
- the scrambled sequence is provided on input ‘scram’.
- the tap from the input has n-state inverter inv1r, which combined with inverter inv1 of FIG. 15 forms identity.
- the descrambler 2900 also has inverters inv2 and inv3.
- the descrambled n-state sequence is provided on ‘dscram’. All functions in the example are called ‘sc’.
- a ‘scrambler’ and/or a descrambler in the configuration like FIGS. 15 and 16 only needs to have one of the devices or implementations named ‘sc’ to be an addition over alternate finite field GF(n).
- An inverter in a scrambler or descrambler that is like the Galois configuration in FIGS. 15 and 16 can be any n-state inverter, though preferably at least one inverter is defined by a multiplication over the alternate finite field GF(n).
- “Like” FIGS. 15 and 16 means a Galois configuration based scrambler with a corresponding Galois configuration shift register self synchronizing descrambler.
- Galois configuration means a shift register with at least two adjacent shift register elements connected through an implementation of an n-state truth table from an output of a first shift register element to an input of a directly adjacent shift register element in the signal flow direction as is shown in FIG. 15 .
- the connecting implementation is an implementation of an at least 2 dimensional n-state truth table.
- Fibonacci configuration means that no implementation of an at least 2-dimensional n-state truth table is placed between an output of a first shift register element to an input of a directly adjacent shift register element in the signal flow direction as is shown in FIG. 12 .
- an LFSR is provided wherein two adjacent shift register elements are connected through an inverter as is shown in FIG. 17 .
- the shift register elements 3001 and 3002 are connected through an inverter inv4 and not through an implementation of an at least two dimensional n-state truth table.
- the Galois LFSR 3000 in FIG. 17 is shown as a sequence generator with functions sc 1 and sc2 and feedback inverters inv1, inv2 and inv3 to generate an n-state sequence on output ‘seq’. By changing ‘inv4’ to one of 24 possible 4-state inverters one can generate several different 4-state m-sequences.
- a convolutional n-state encoder and decoder for n>2, including a forward encoder, a recursive encoder and a systematic encoder and corresponding decoders.
- These n-state encoders and corresponding decoders are disclosed in U.S. patent application Ser. No. 11/566,725 with Lablans as named inventor and filed on Dec. 5, 2006 which is incorporated herein by reference.
- These encoders may be forward coders, recursive coders and systematic coders or any combination thereof and their corresponding decoders.
- the functions and inverters applied in these coders and decoders include at least one addition and one inverter derived from a multiplication over an alternate finite field GF(n).
- FIG. 18 illustrates a forward convolutional coder 3100 with at least two different forward coders applying a shift register (in this case of 3 stages) with functions and inverters implemented.
- the coder 3100 is shown in its two component coders 3201 and 3202 . Each of the coders is provided with an input sequence of n-state symbols ‘in’.
- the coders 3201 and 3202 both use a forward connected shift register. Because both shift registers are provided with the same sequence their shift register states will be identical.
- Coder 3201 has four taps including the start tap with inverters inv11, inv12, inv13 and inv14 respectively connected to the function ‘sc’ which for illustrative purposes will all be the addition over alternate finite field GF(n).
- the output sequence is inverted by inverter inv15 to create output sequence out1. All inverters herein for illustrative purposes are assumed to be derived from the multiplication over alternate finite field GF(n).
- the coder 3202 is similar to 3201 , but has one less tap and thus function sc and has inverters inv21, inv22, inv23 and inv24 to generate sequence out2. All inverters and functions are again defined over alternate finite field GF(n).
- the corresponding decoders 3301 and 3302 are illustrated in FIG. 20 .
- the structure of the decoders is similar to that of the corresponding coders with some directions reversed. This requires that inv15 in the decoder 3301 is replaced by inv15 ⁇ 1 , inv11 in the decoder 3301 is replaced by inv11 ⁇ 1 , that inv21 in the decoder 3301 is replaced by inv21 ⁇ 1 , inv24 in the decoder 3301 is replaced by inv24 ⁇ 1 . Because of the field properties (which include associativity and distributivity) and the self reversing properties one can easily manipulate equations that determine output symbols and state of the shift register.
- an equation of a first n-state symbol in1 inputted on an n-state inverter that is defined by a multiplication over an alternate finite field GF(n) can be written as m1*in1, wherein m1 is the position of the column or row in the truth table of the multiplication. Accordingly, the inverter [0 1 2 3] in m4 of the alternate finite field corresponds with ‘0’; [1 2 0 3′ corresponds with ‘1’; [2 0 1 3]corresponds with ‘2’ and [3 3 3 3] corresponds with ‘3’.
- the ‘*’ operation then is different from the commonly used meaning of *.
- the content of the decoders 3301 and 3302 must be identical if the decoders are working error free. Assume that all inverters in the decoders are inverters [0 1 2 3] or ‘0’, which represents identity in this case.
- the following equations determine the content [s1 s2 s3] of the shift register when symbols n1 and m1 are entered on the inputs out1 and out2:
- the inverters in FIG. 19 are assigned as follows: all inverters as shown in 3201 are the inverter ‘2’ or [2 0 1 3] in the alternate finite field GF(4) and all inverters in 3202 are the inverter ‘1’ or [1 2 0 3] in the alternate finite field GF(4).
- the function ‘sc’ is again the addition in the alternate finite field GF(4).
- a similar approach can be applied to coders that include a recursive shift register and an encoder that includes an uncoded sequence which is usually called a systematic encoder.
- a similar approach using the functions over an alternate finite field GF(n) is applied to encoders with at least one shift register in Galois configuration as is disclosed in U.S. patent application Ser. No. 12/774,092 to Lablans filed on May 5, 2010 and which is incorporated herein by reference.
- an encoder that creates one or more n-state check symbols from one or more n-state data symbols generated by using at least an n-state addition and one n-state inverter that are defined over an alternate finite field GF(n) as provided herein, and that in one embodiment provides an error detection capability in a sequence containing an n-state data symbol and an n-state check symbol and that in a further embodiment provides an error correction capability in a sequence containing an n-state data symbol and an n-state check symbol.
- An example is provided using the function addition and at least one inverter based on a multiplication over alternate finite field GF(n) and the following relations in a (7,4) n-state Hamming code to generate 3 n-state check symbols from 4 n-state data symbols
- each of the k data symbols in a n-valued Hamming codeword should be a function of at least 2 check symbols. There are (n-k) check symbols.
- One check symbol in error should mean just that: only one check symbol and no data symbol is in error. No check symbol in error means that no single error has occurred. What one does with a Hamming code is mapping each state of a codeword into a unique word formed by check symbols. For a (7,4) n-valued Hamming code:
- x3 p1, p2, p3;
- x4 ⁇ p1, p2, p3;
- x1 has to be reconstructed from x2, x3, x4, p1, p2 and p3 which are not in error.
- N-state check symbols can be determined from at least 2 n-state data symbols by applying an addition and at least one inverter based on a multiplication over an alternate finite field as disclosed herein.
- the symbols in one embodiment are arranged in a matrix to determine at least a location of an error which may be called an erasure. Errors can be located by re-calculating the check symbols. Once errors are located one can use the expressions or equations that have been used to determine the check symbols and by using check symbols and data symbols that are known to be error free to create an expression that determines a correct state of a symbol in error.
- check symbols can be determined by arranging data symbols in a first matrix and determine a check symbol from a row or a column and arrange data symbols in a second matrix and determine a check symbol from a row or a column from the second matrix.
- the equations that determine a correct state of a symbol in error are derived from the equations or expressions that generate the check symbols.
- FIG. 21 illustrates an arrangement of 4 rows and 3 columns of n-state data symbols d i and m k and with two rows of check symbols p n and r n and 1 column of check symbols q j .
- check symbol on check symbols confirms that the check symbols are not in error. It is determined that d6 and m6 are in error.
- the equations in one embodiment is implemented by using the function addition and at least one inverter based on a multiplication over alternate finite field GF(n).
- n 4.
- Let 1*d2+2*d6+0*d10 q3.
- received was [d2 d6 d10 q3] [2 0 3 2]. It was already determined that d6 is in error.
- r 2 a 1 *d 5 +a 2 *m 5 +a 3 *d 6 +a 4 *m 6;
- d6 and m6 are in error and can be resolved from the set of two equations, for instance by applying Cramer's rule.
- the equations in one embodiment are again implemented by using the function addition and at least one inverter based on a multiplication over alternate finite field GF(n).
- At least two check symbols are generated by using the function addition and at least one inverter based on a multiplication over alternate finite field GF(n) with two expressions which have at least one n-state data symbol in common as a variable and wherein each check symbol is achieved by arranging n-state data symbols in different matrices.
- This embodiment is illustrated in FIG. 22 in matrices 3501 and 3502 . Assume data symbols d6, d7 and d11 in error. By arranging the data symbols d1, . . . , d12 in two different ways to generate check symbols one can determine the symbols in error, even if double errors occur in a row or a column that only generates a single check symbol. Like with the Hamming code one can establish a table that determines under what conditions which data symbol is in error. One can then use a check symbol generating expression or equation to determine the correct value of a symbol in error.
- an expression or equation (a*x1+b*x2+c*x3+ . . . m*xk) can be modified to ⁇ (x1 sc41 x2)+ ⁇ wherein sc41 is an implementation of a single non-commutative n-state function which is created by modifying ‘+’ in accordance with inverters ‘a’ and ‘b’ and wherein the addition ‘+’ function and at least one inverter based on a multiplication are defined over alternate finite field GF(n).
- a coder which is based on an n-state Linear Feedback Shift Register (LFSR) or expressions that evaluate the states and/or outputs of such an LFSR, wherein the LFSR through a function is provided with n-state data symbols and one output is a final state of the shift register as a plurality of check symbols, which can be applied to determine if an error has occurred in a sequence containing the data symbols and the final shift register content of the LFSR and wherein the LFSR and/or the expressions apply the addition ‘+’ function and at least one inverter based on a multiplication that are defined over alternate finite field GF(n).
- LFSR Linear Feedback Shift Register
- At least 4 n-state data symbols in this example are entered on a function ‘+’ to be combined with a content of the last shift register element of the LFSR which has at least 2 n-state shift register elements, which is in this case an n-state LFSR in Galois configuration.
- a Fibonacci configuration can also be used.
- the LFSR also has two n-state inverters of which at least one is defined by the multiplication over the alternate finite field GF(n).
- n 4 and inv1 is multiplier ‘1’ and inv2 is multiplier ‘2’.
- One can generate all codewords [x1 x2 x3 x4 s1 s2] wherein s1 and s2 represent the content of the shift register after processing.
- the content of the shift register at the start may be [0 0] or [3 3] or any other state.
- a word [1 0 3 2 0] is received.
- the check symbol is re-calculated from [1 0 3 2] to generate codeword [1 0 3 2 3] which is different from the received word, which indicates that an error had occurred.
- At least one erasure can be corrected in a coder as shown in FIG. 23 .
- an LFSR such as an n-state LFSR without actually running the LFSR
- FIG. 9 will be applied.
- each element in the shift register gets its own assigned symbol. For instance the first element has content [s1 3 3].
- the 3 is used because that is the ‘0’ element.
- the second element has as content [3 s2 3] and the final element has content [3 3 s3].
- sr1 sr2 sr3 start 0 3 3 3 0 3 3 3 0 1 3 3 1 0 3 2 3 0 1 2 3 1 2 3 2 2 0 1 3 3 1 2 3 2 2 1 3 2 4 2 3 0 2 2 1 3 2 1 5 3 0 2 2 1 3 2 1 0 6 0 2 1 1 3 3 1 0 1 7 2 1 2 3 3 2 0 1 2 8 1 2 0 3 2 0 1 2 1 9 2 0 2 2 0 3 2 1 1 10 0 2 2 0 3 1 1 1 2
- This approach uses the associative a distributive properties of the addition and multiplication.
- the table shows only the first 10 results of the content of the shift register. One can expand that to any length. It should be clear that after 63 cycles the content will return to the original initial content. The above also means that if an initial state of a shift register is known one can determine the actual content (and the generated symbol) at any time after and before the initial time without having to run the LFSR.
- the following table shows the content of the shift register of the LFSR of FIG. 23 after starting with content [3 3] and being entered with [x1 x2 x3 x4].
- the states of the two shift register elements are then:
- the combination of an addition and an inverter defined by a multiplication over alternate finite field GF(n) as applied in coders and decoders as shown in FIGS. 15-20 and FIG. 23 are implemented in a single non commutative truth table.
- One implementation of a combination of the above addition and inverter in a further embodiment of the present invention is a single non-commutative truth table stored in a memory device.
- the Feistel network is illustrated in FIG. 24 .
- 3721 is the coding or ciphering network and 3722 is the decoding or deciphering network.
- the order of use of 3721 and 3722 can the exchanged as long the one reverses the other.
- the working is well known to one of ordinary skill in the art, but will be briefly explained herein.
- a plaintext word 3701 of 2p (with p ⁇ 1 or p>1) n-state symbols with n ⁇ 2 will be spilt into two parts 3702 and 3703 of n-state symbols. These words and their parts may be binary symbols. They may also be n-state symbols with n>2. They may also be n-state symbols which are represented as binary symbols.
- n-state symbol may be represented by n-state signals to be processed by n-state switching functions. They also may be binary symbols represented by binary signals to be processed by binary switching functions. They may also be n-state symbols represented by binary signals that are processed by n-state switching functions that are implemented by binary switching technology. In the last case, signals and switching technology often represent symbols and functions over GF(2 q ) with q>1.
- word 3701 is split up in word 3702 and 3703 .
- Word 3703 is modified by an n-state function 3704 against a word K0.
- the n-state functions implemented in 3704 , 3706 and 3708 may be reversible or non-reversible. They have as input a known signal such as a key word K0, K1, . . . Kn or apply some known confusion scheme. These functions have to be applied with the same corresponding key in the coder 3721 and in reversed order in decoder 3722 .
- the n-state functions 3705 , 3707 and 3709 in coder 3721 have to be reversible n-state functions and have to be applied in reversed order in their corresponding reversing function in 3722 .
- the reversible n-state functions may be commutative or non-commutative but at least one of them is an addition over alternate finite field GF(n) or is an addition over alternate finite field GF(n) with at least one n-state inverter at an input or an output which is defined by a multiplication over the alternate finite field GF(n) or is an addition over alternate finite field GF(n) that is modified in accordance with an inverter which is defined by a multiplication over the alternate finite field GF(n) and is implemented as a single n-state truth table for instance in a memory device, wherein the truth table may be a non-commutative truth table.
- the first stage of 3722 has a function 3713 which reverses sc2 and can be called ds2.
- a word of k n-state symbols (with n ⁇ 2, or n>2, or n>3) and k ⁇ 2, is split at least in two sub-words of at least one symbol and wherein at least one of the sub-words is being processed by either an implementation of an addition over an alternate finite field or by an addition over an alternate finite field and an inverter defined by a multiplication over a finite field or by an implementation of a truth table of an addition over an alternate finite field that is modified in accordance with an inverter defined by an alternate finite field.
- At least the reversible part of for instance DES and AES in one embodiment of the present invention apply functions and inverters defined by the alternate finite fields as defined and explained herein.
- Feistel-like or Feistel network based encoders generally work in blocks of n-state symbols. A plurality of symbols that is received sequentially, rather than in parallel are thus considered words or blocks of symbols. These codes are generally called block codes as a coder can operate only after a block of symbols has been entered. The same applies to error correcting coders wherein check symbols are determined over a block of n-state symbols. A decoder cannot complete decoding until all symbols of a block have been entered into the decoder and can be processed.
- a two input n-state function of FIG. 24 may be represented by an n by n truth table.
- a truth table in one embodiment is implemented in a memory device. If the function is reversible a column and/or a row of the truth table have to be a reversible n-state inverter.
- An n-state inverter over GF(2 q ) can be implemented in binary logic for processing of words of q bits by using combinational binary circuitry, by switching outputs or by using a memory device.
- FIG. 38 shows in diagram an n-state switching device 3800 implementing an n-state function with inputs 3801 and 3802 and output 3803 .
- An inverter may be identity, which is a direct connection, which may is called a multiplier ‘0’ in the alternate finite field GF(4) as was developed above.
- the device 3804 implements the 4-state adder:
- one of the inverters 3805 , 3806 and 3807 is 4-state inverter [2 0 1 3] while the other 2 inverters are [0 1 2 3] or identity.
- Inverter 3805 has input 3802
- inverter 3806 has input 3802
- inverter 3807 has an output 3803 .
- inverter 3805 is [2 0 1 3].
- the device of FIG. 38 is reduced to the device of FIG. 39 (assuming that input 3801 determines a row in the truth table and input 3802 a column) with a device 3900 that implements a single truth table:
- the device of FIG. 39 in this example does not require separate inverters at inputs or output.
- the truth table of FIG. 39 is implemented on a processor for instance on a memory device of a processor.
- invert 3806 is [2 0 1 3] while the other inverters are identity. This results in a device 3900 that implements a single truth table:
- the device of FIG. 39 in this example does not require separate inverters at inputs or output.
- the truth table of FIG. 39 is implemented on a processor for instance on a memory device of a processor.
- inverter 3807 is [2 0 1 3].
- the device of FIG. 38 is reduced to the device of FIG. 39 with a device 3900 that implements a single truth table:
- the device of FIG. 39 in this example does not require separate inverters at inputs or output.
- the truth table of FIG. 39 is implemented on a processor for instance on a memory device of a processor.
- inverter 3805 is [2 0 1 3]
- inverter 3806 is [1 2 0 3]
- inverter 3807 is [2 0 1 3].
- the device of FIG. 38 is reduced to the device of FIG. 39 with a device 3900 that implements a single truth table:
- the device of FIG. 39 in this example does not require separate inverters at inputs or output.
- the truth table of FIG. 39 is implemented on a processor for instance on a memory device of a processor.
- x1 c ⁇ 1 *a ⁇ 1 *y+a ⁇ 1 *b*x2, keeping in mind that ‘+’ is self reversing and if a, b and c are 1 inverters in the alternate finite field GF(n) then a′, 1) 4 and c are also inverters in the alternate finite field GF(n).
- the device or implementation of FIG. 25 or 26 can be applied in any coder which processes an n-state symbol in accordance with an n-state addition over an alternate finite field GF(n) which is modified in accordance with at least one inverter which is defined by a multiplication over the alternate finite field GF(n) or has such an inverter at an input or an output.
- a coding device performs a polynomial arithmetical calculation over the alternate finite field GF(n). This means that additions, multiplications and divisions are all performed over the alternate finite field GF(n). The division over such a field is the reverse of the multiplication as was explained earlier. It is believed that calculations over finite fields are known. In general one performs these calculations over the classical fields GF(2 m ). One reason to apply GF(2 m ) is that symbols over GF(2 m ) can be represented in binary form as binary words using mainly XOR and AND operations. By using functions over an alternate finite field GF(n) the results become less predictable and hard to analyze for an unauthorized or uninformed receiver of n-state symbols coded or generated over an alternate finite field.
- a calculator over an alternate finite field has an implementation of an addition and an inverter both over an alternate finite field GF(n)
- an implementation may also be an implementation of a single truth table which is a truth table of an addition over an alternate finite field GF(n) modified in accordance of at least inverter which is defined by a multiplication over an alternate finite field GF(n).
- GF(4) has been provided. While GF(4) has not many alternate finite fields it still has at least 3 alternate finite fields. It will be shown that for instance GF(8) has many more alternate finite fields.
- the functions sc4a (addition) and m4a(multiplication) form a field: requirements of commutativity, associativity and distributivity are met.
- every power of an element of the field is also in the field:
- the functions sc4b (addition) and m4b(multiplication) form a field: requirements of commutativity, associativity and distributivity are met.
- every power of an element of the field is also in the field:
- At least one of the functions or inverters used in a coder during coding is changed from being defined in a first alternate finite field to being defined in a second alternate finite field.
- the functions and inverters are defined related to sc4a and m4a, and in a second instance to sc4b and m4b.
- sc is sc4a and the inverters inv1 and inv4 are identity and inverter inv2 is multiplier 2 in m4a and inv3 is multiplier 3 in m4a.
- FIG. 13 is the corresponding descrambler.
- the functions are changed to sc4b and m4b for coding the next 10 symbols.
- the initial state of the LFSR being [0 1 3] and the inputted symbols being twenty zeros [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
- the scrambler of FIG. 12 will generate [1 2 3 0 3 1 2 0 2 3 2 3 1 3 3 3 0 2 0 2 1].
- the descrambler follows the scrambler using the same initial state then the descrambled sequence will be twenty zeros.
- the descrambler keeps on using the same functions sc4a and m4a then the descrambled sequence will be [0 0 0 0 0 0 0 0 0 0 0 0 3 1 3 3 0 2 0 2 1 2] which is clearly not correct.
- Implementations of the functions herein in memory are easy to realize and easy to change. Accordingly it is not required to keep the same functions for a long period. If one so desires functions and/or inverters can be changed per coding of a single symbol.
- one may also change functions during coding of a word of n-state symbols.
- additions and inverters related to the multiplication in such finite fields can be used in coders and decoders as provided herein. It is believed to be a novel aspect that different additions as generated by primitive or minimal polynomials can be used in coders, including reversible coders that are provided herein. It is a further aspect of the present invention that coders and/or decoders provided herein apply inverters or a multiplication defined over the field, which in these cases is known as an extension field. These different additions can also be modified or provided with inverters that are not defined over the finite field.
- addition sc83 is associative, it has a neutral element (0) it is commutative and it is distributive with m82 which also has a neutral element and a zero element.
- the addition is also self reversing.
- the multiplication has for each multiplier an inverse in the field. Accordingly, sc83 and m82 form an alternate finite field GF(8) in which all of the coders and decoders as already described herein are enabled.
- m8a is not the traditional multiplication over GF(8).
- m8b is not the traditional multiplication over GF(8) and is also different from m8a.
- each column and row in the truth table of the addition is a self reversing n-state inverter.
- Communitivity also limits the construction. For each row selected in a truth table the next row selection becomes more restricted as the rows and columns are symmetric around the diagonal of the truth table.
- the next check is associativity.
- a next step is to find a corresponding multiplication.
- One can limit a search for appropriate rows or columns in a multiplication truth table by first limiting all to be considered n-state inverters to the reversible inverters that are distributive with the addition.
- the multiplication is also commutative further limiting a search for appropriate n-state inverters.
- a further limitation is that none of the inverters that are considered for an addition or multiplication should have an identical symbol in an identical position.
- the following illustrative example shows the truth tables of the addition and multiplication that define an alternate finite field GF(8) with neutral element ‘7’.
- the following illustrative example shows the truth tables of the addition and multiplication that define an alternate finite field GF(8) with neutral element ‘3’.
- the following illustrative example shows the truth tables of the addition and multiplication that define another alternate finite field GF(8) with neutral element ‘3’.
- a decoder is provided to a Reed Solomon coder that is enabled to detect at least one n-state symbol in error.
- a diagram of an illustrative encoder 4000 is shown in FIG. 27 .
- the n-state encoder 4000 has an n-state Linear Feedback Shift Register, in this example with 2 shift register elements s1 and s2.
- the encoder implements two n-state additions, which in this case are assumes to be identical additions over alternate finite field GF(n).
- the two functions may be different functions, but for illustrative purposes they are assumed to be the same.
- an inverter inv2 is included in a feedback tap and an inverter inv1 is included in the tap into the first shift register element. At least one of inv1 and inv2 is defined by a multiplication over alternate finite field GF(n).
- n-state symbols contains 4 n-state symbols [x1 x2 x3 x4], though more symbols may be entered.
- the shift register starts with an initial content [s1 s2].
- sc is an addition ‘+’ over an alternate finite field GF(n) and inverters inv1 and inv2 are constant multipliers ‘a’ and ‘b’ in the alternate finite field. This means that all functions are associate, distributive and commutative and the ‘+’ herein is self reversing.
- the following table shows the calculated states of the shift register starting with [s1 s2] as x1 and x2 are entered, as developed by executing the functions that are implemented in the coder.
- the end state of the shift register is then dependent on s1, s2, x1, x2, x3 and x4 and can be expressed as c1*s1+c2*s2+c3*x1+c4*x2+c5*x3+c6*x4 and can be represented as [c1 c2 c3 c4 c5 c6].
- c5*x3 can be achieved by composite processing.
- the simplest way to represent the states of the shift register is to represent each shift register as dependent upon the variables s1, s2, x1, x2, x3 and x4. For instance the initial content of the first shift register in FIG. 27 is s1 and does not depend on other variables. One can then represent this content as [s1 z z z z z] wherein z is the zero state.
- the second shift register has initial content [z s2 z z z z z].
- the first symbol x1 to be entered in the LFSR is then [z z x1 z z z] and so on.
- the zero element is 3.
- the neutral identity state for the state of s1, s2 etc.
- To determine an actual state one then substitutes this actual state for the identity state.
- the shift register starts with initial end content [s1e s2e] wherein s1e and s2e can be determined from the above step.
- the end state can be represented as: [s1e 3 3 3 3] and [3 s2e 3 3 3] or as [0 3 3 3 3] and [3 0 3 3 3 3].
- the outcome of the comparative states depends on the selected inverters.
- one creates a computer program for instance in Matlab® of The Mathworks of Natick, Mass. that implements the up and down version of an LFSR and determines the comparative states based on different inverters.
- Preferably at least one inverter is defined by a multiplication over the alternate finite field GF(n) and at least one function sc is defined by the alternate finite field. Based on a selected inverter one can review the comparative states and determine which configuration is most convenient to determine at least one symbol in error.
- an LFSR with at least three (3) shift register elements is created to determine three check symbols and send a word of a plurality of data symbols and the at least three check symbols to a receiving device that implements the comparative states calculations as explained herein. This allows the receiving device to determine at least 2 symbols in error. How detectable symbols in error are distributed over a codeword depends on the selected inverters.
- a very long sequence can be coded this way into a word with only two or more shift register elements.
- the number of comparative states will increase.
- the method as provided herein will still identify a symbol in error.
- the herein provided methods can be arranged to provide a fast way to determine an error location and resolve the symbols in error, for instance as compared to standard Reed Solomon methods. This is especially true for detecting one or more consecutive errors in a long sequence or even a very long sequence of symbols.
- the up/down approach is applied to a sequence of binary symbols.
- a coder as illustrated in FIG. 23 is a binary coder with inv1 and inv2 being identity and the ‘+’ being an implementation of a XOR function.
- the following table shows the comparative state table for this coder with an input of a sequence of 4 bits and an initial shift register state [0 0].
- n is smaller than 8.
- n 4.
- the following provides an addition and a multiplication over an alternate finite field GF(4).
- self reversing additions over such fields have been provided.
- a field can also be over n is an odd number.
- prime fields wherein n is prime or Z n are of interest.
- These and other fields are of interest in certain coders such as Elliptic Curve Coders.
- the ‘normal’ field is usually defined by using the modulo-n addition and the modulo-n multiplication.
- an alternate finite field is created over GF(n) wherein n is prime.
- an alternate finite field over GF(5) is provided that is defined by the following addition and multiplication.
- each multiplier has an inverse that is also in the alternate finite field: 0 has itself as inverse, the inverse of 1 is 2, the inverse of 2 is 1, and the inverse of 3 is 3.
- Each multiplier has an inverse in the field: 0 is the identity; 1 is self reversing; 2 has 4 as inverse and 4 has 2 as inverse.
- One can generate the states for an n-state extension field with n 3 2 with a 2-state LFSR with one of the above 3-state additions and an inverter being one of the inverters in the field in a sequence generator as shown in FIG. 32 .
- the following table shows the addition and multiplication over GF(9) that can be generated from this.
- the functions sc9a generated by inverting sc9 with the above inverter will create:
- sc9a is associative.
- a simple computer program will demonstrate that sc9a and m9a are distributive. There is a zero element, the multiplication has an identity (0), all non-zero elements in the field have an inverse that is also in the field, the functions are commutative. Accordingly, sc9a and m9a establish an alternate finite field GF(9). Other alternate finite fields can be constructed in a similar way.
- Galois Field (or finite field) arithmetic is widely used in cryptography.
- the applied fields can be for instance a field GF(p) with p being prime, or extension fields GF(p m ) with p being prime and m>1, wherein p preferably is 2, or composite fields GF((p m ) r ) with p being prime and m and r>1, or a prime field such as a Mersenne prime field GF(n) with n ⁇ p m and preferably n ⁇ 2 m .
- a parallel definition in the alternate finite field is related to the multiplication “*” over the finite field.
- An encoder modifies the statistical distribution of symbols in a coded message as disclosed in U.S. Pat. No. 7,659,838 issued on Feb. 9, 2010 to Lablans, which is incorporated herein by reference.
- a coder 3400 with a corresponding decoder 3401 is provided.
- the encoder 3400 in one embodiment of the present invention has a first coding stage 3402 in accordance with an encoding method as herein provided an using at least an implementation of an addition over an alternate finite field and preferably an addition over an alternate finite field and an inverter defined by a multiplication over an alternate finite field with an input sequence of symbols In, that generates a sequence Int of symbols.
- Sequence Int is provided to an encoding state 3403 which modifies the statistical distribution of symbols without changing the number of symbols to generate sequence Outc.
- a received sequence Outc is provided on decoding stage 3404 which reverses 3403 to generate Int with the previous statistical distribution of symbols which is provided to decoding stage 3405 which reverses encoder 3402 to generate original sequence In.
- An encoding step may be preceded or succeeded by signal processing including modulation, demodulation, detection, amplification or other signal processing as is known in the art.
- FIG. 35 illustrates an encoder 3500 wherein 3502 performs modification of statistical distribution of symbols and 3503 performs an encoding process in accordance with a method as provided herein using at least an implementation of an addition over an alternate finite field and preferably an addition over an alternate finite field and an inverter defined by a multiplication over an alternate finite field.
- FIG. 35 also illustrates a decoder 3501 with 3504 reversing 3503 and 3505 reversing 3502 .
- An alternate finite field GF(n) is not a classical finite field.
- At least one class of an alternate finite field GF(n) herein is defined as the field GF(n) defined by the addition scn wherein an element not represented by the field element 0 is the neutral element and by a corresponding multiplication. It is noted that a field can be defined by a single addition and one of a plurality of possible multiplications.
- an implementation of at least one addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>3 is applied in an encoder as provided herein.
- an implementation of at least one addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>3 is applied in an encoder as provided herein.
- an implementation of at least one addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>4 is applied in an encoder as provided herein.
- an implementation of at least one n-state function which is defined by a truth table that is a reduction of an addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n ⁇ 3 is applied in an encoder as provided herein.
- an implementation of at least one n-state function which is defined by a truth table that is a reduction of an addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n ⁇ 3 is applied in an encoder as provided herein.
- an implementation of at least one n-state function which is defined by a truth table that is a reduction of an addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>3 is applied in an encoder as provided herein.
- an implementation of at least one n-state function which is defined by a truth table that is a reduction of an addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>4 is applied in an encoder as provided herein.
- Extension fields created from the EQUAL and the NAND function from primitive or minimal polynomials may also be called alternate finite fields. However, they may also be considered as a different type of alternate finite field compared to those that cannot be generated from primitive or minimal polynomials only.
- an encoder that is provided in accordance with an aspect of the present invention is provided with a corresponding decoder.
- an encoder and a corresponding decoder use at least an implementation of an addition over an alternate finite field GF(n).
- inverters may be used or the addition may be modified in accordance with an inverter.
- an inverter defined by a multiplication defining the alternate finite field GF(n) is required or an implementation of an addition in accordance with an inverter over the alternate finite field is required.
- the here provided methods of encoding and decoding are used in a system, such as a communication system.
- a communication system may be a wired system or a wireless system.
- Such a system may be used for data transmission, telephony, video or any other type of transfer of information.
- a diagram of such a system is provided in FIG. 29 .
- 1101 is a source of information.
- the information is provided to a coder 1102 .
- the information provided to a coder 1102 may already be in a digital form. It may also be converted into digital form by the coder 1102 .
- the coder 1102 creates the coded symbols in a signal.
- the codewords are organized in such a way that up to a number of symbols in error can be identified as such.
- the thus created codewords may be provided directly to a transmission medium 1103 for transmission. They may also be provided to a modulator/transmitter 1106 that will modify the digital coded signal provided by 1102 to a form that is appropriate for the medium 1103 . For instance 1106 may create an optical signal or an electrical signal. Modulator 1106 may also be a radio transmitter, which will modulate the signal on for instance a carrier signal, and wherein 1103 is a radio connection.
- a receiver 1107 may receive, amplify, and demodulate the signal coming from 1103 and provide a digital signal to a decoder 1104 .
- the decoder 1104 applies the methods provided herein to decode symbols including correcting symbols in error.
- a decoded and/or error corrected signal is then provided to a target 1105 .
- a target may be a radio, a phone, a computer, a tv set or any other device that can be a target for an information signal.
- a coder 1102 may also provide additional coding means, for instance to form a concatenated or combined code. Additional information, such as synchronization or ID information, may be inserted during the transmission and/or coding process.
- the here provided methods and apparatus for coding including error correcting coding and decoding including error correcting decoding of signals can also be applied for systems and apparatus for storage of information. For instance data stored on a CD, a DVD, a magnetic tape or disk or in mass memory in general may benefit from error correcting coding.
- a system for storing symbols coded in accordance with an aspect of the present invention is shown in diagram in FIG. 30 .
- a source 1201 provides the information to be coded. This may be audio, video or any information data. The data may already be presented in n-valued symbols by 1201 or may be coded in such a form by 1202 .
- Unit 1202 may create code words of a plurality of data symbols with added check symbols as described herein as another aspect of the present invention.
- the thus created coded symbols may be provided directly to a channel 1204 for transmission to an information carrier 1205 .
- the information carrier 1205 may be an optical disk, an electro-optical disk, a magnetic disk, a magnetic tape, a flash memory device or any other device or medium that can store information.
- a modulator/data writer 1203 will be required to write a signal to a carrier 1205 .
- the channel may require optical signals, electrical signals or it may require magnetic or electro-magnetic or electro-optical signals.
- Modulator/data writer 1203 will create a signal that can be written via channel 1204 to a carrier 1205 . Additional information such as for ID and/or synchronization may be added to the data.
- FIG. 31 shows a diagram for decoding information read from a carrier 1305 .
- the information is read through a channel 1304 (such as an optical channel or electrical or magnetic or electro-magnetic or electro-optical channel) and provided in general to a detector 1303 that will receive and may amplify and/or demodulate the signal.
- the signal is then provided to a decoder 1302 .
- the information signal possibly readied for presentation as an audio or video signal or any other form is then provided to a target.
- the target may be a video screen, a compute, a radio or any other device that can use the decoded signal.
- N-valued symbols may be processed as binary words, being created from n-valued symbols by Analog/Digital converters.
- n-valued signals may be created from binary words by applying Digital/Analog converters.
- Switching functions may be created as customized n-valued circuits.
- U.S. Pat. No. 6,133,754 by Olson, issued Oct. 17, 2000 entitled “Multiple-valued logic circuit architecture; supplementary symmetrical logic circuit structure (SUS-LOC)” discloses embodiments of n-valued CMOS switches.
- SUS-LOC supplementary symmetrical logic circuit structure
- N-state logic embodiments for instance using look-up tables are also contemplated.
- an LFSR with may be part of a scrambler or a descrambler is implemented in an addressable memory and using an implementation of an n-state switching function.
- an LFSR implemented with an addressable memory applies an implementation of an addition over an alternate finite field, or an implementation of an addition over an alternate finite field and an inverter defined by a multiplication over an alternate finite field, or an implementation of a single truth table of an addition over an alternate finite field modified by an inverter defined by a multiplication over an alternate finite field.
- n is a large prime
- n can be a much smaller integer but with many different alternate finite fields are used.
- there are different alternate finite fields having the same addition but different multiplications as was shown herein.
- a coder and a decoder instead of one large finite field or one large alternate finite field many different smaller alternate finite fields are applied.
- the states are stored in an addressable memory, which makes processing much faster. Additional security is introduced by determining which alternate finite field to apply for instance based on a key or a pseudo-random sequence of symbols. In a further embodiment of the present invention, the order of alternate finite fields is changed per message, per time period or by any other pre-determined parameter that can be synchronized between sender and receiver.
- FIG. 32 illustrates a processor in accordance with an aspect of the present invention.
- a processing unit 50000 is provided to process at least binary words that represent an n-state symbol.
- the processing unit may also implement circuitry that implements n-state logic tables.
- the processing unit has at least one input/control port to provide the processing units directly with input and/or control signals.
- the processing unit may also have a communication port to receive external data. While the processing unit may have its own internal memory, preferably it is bi-directionally connected to a memory 50001 to store and retrieve data and instructions.
- the memory may work in binary mode or as a non-binary memory.
- the memory is a binary memory then if non-binary symbols are provided as non-binary signals a converter such as an A/D 50002 converts non-binary signals to binary words that are stored in 50001 .
- the processing unit process the n-state symbols in accordance with the herein provided encoding and/or decoding methods over an alternate finite field GF(n) and provides the result on an output. If the processing unit operates on binary words a converter such as a D/A converter 50003 generates non-binary signals from the binary words.
- a finite field and an alternate finite field are defined by an addition and a multiplication.
- an encoder or a corresponding decoder applies at least an implementation of an addition over an alternate finite field.
- This automatically requires that a multiplication over the alternate finite field also exists, even if such multiplication or an inverter defined by such multiplication is not used.
- Such an addition conceivably would be a modulo-6 addition.
- no set of multiplications in combination with the modulo-6 addition exists to create a finite field. Accordingly, an addition over a finite field, be it a classical field or a class of alternate fields, requires a corresponding multiplication.
- the truth table of classical addition and multiplication over this field can be provided as follows:
- the points (1,0) and (1,1), (6,0) and (6,6) among others also lie on the curve.
- Points in the alternate finite field that lie on the curve are: (0,5) and (0,7); (1,0) and (1,2); (4,1) and (4,5) and (3,1). These points are generated by evaluating all points of the finite field and checking if they are one the curve.
- an encoder or a decoder includes an implementation of a multiplication over an alternate finite field. If a constant multiplier or an equivalent inverter is required one can provide a constant input symbol on at least one input of such a multiplication which then in effect implements a constant multiplier.
- alternate finite fields with zero-elements not being 0 can be applied for instance in coding, decoding, encryption and decryption purposes in accordance with one or more aspects of the present invention.
- alternate finite fields are isomorphic to the finite fields that are for instance extension fields or composite fields. By having a different zero element in different alternate finite fields, there is no clear bijection between field elements. In other words, one cannot simply try different field element substitutions to find an alternate finite field.
- a method is provided to create a plurality of different alternate finite fields from a given finite field.
- the steps of such a method are illustrated in FIG. 36 .
- One uses an n-state reversible inverter ‘inv1’. For instance a finite field over GF(8) can be modified to an alternate finite field GFa(8).
- steps 3605 and 3607 the rows and columns of the truth table of a given addition and multiplication over GF(n) are modified in accordance with the inverter ‘inv1’ followed by a substitution of all the states by inversion with ‘rinv1’.
- a function ‘fn’ which can be the addition or the multiplication over GF(n) are implemented in a circuit 3701 , which can be a memory.
- the circuit has two inputs, 3703 and 3705 which each include the inverter ‘inv1’.
- the signals i1 and i2 are provided the inputs.
- the signals i1 and i2 represent a symbol in GF(n).
- a resulting signal representing a symbol is output on output 3707 which is inverted by inverter ‘rinv1’ and is for instance stored on a memory 3709 .
- Other implementations are possible.
- the output symbol is associated with input (i1,i2), so that the stored data represents the addition or multiplication over GFa(n) depending on what ‘fn’ was stored on 3701 .
- the system of FIG. 37 runs through all n 2 possible combinations of (i1,i2).
- FIG. 38 illustrates a truth table of an addition and multiplication over GF(8).
- n! n factorial
- a first n-state symbol is generated or transformed using an addition and a multiplication over a first alternate finite field GFa(n)
- a second n-state symbol is generated or transformed using an addition and a multiplication over a second alternate finite field GFa(n).
- a receiver is familiar with which alternate fields are applied and applies or recovers the first and the second n-state symbols.
- at least one alternate finite field has a zero element not being zero.
- at least both alternate finite fields have a zero element not being zero.
- the addition and multiplication over an alternate finite field GFa(n) with n>2 are applied in one or more of the applications, inventions or embodiments enclosed herein or incorporated herein by reference, including but not limited to n-state methods and devices with n>3 or with n>7: scramblers and descramblers, shift register based scramblers and descramblers, LFSRs, sequence generators, Gold sequence generators, sequence detectors, correlation circuits, convolutional coders and decoders, Reed-Solomon coders or any other error-correcting coder and decoder, encryption and decryption devices and Galois Field arithmetical methods and devices.
- an addition and a multiplication over an n-state alternate finite field GFa(n) are generated from an addition and multiplication of a given finite field GF(n).
- the multiplication can be determined by shifting (n ⁇ 1) elements as shown in the multiplication table of FIG. 38 .
- Such a finite field may be called a given or standard finite field. A multiplication of such a given finite field may also be derived from a true binary multiplication.
- the alternate finite field is determined relative to the given finite field by the method depicted in FIG. 36 and the apparatus of FIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity.
- the alternate finite field is determined relative to the given finite field by the method depicted in FIG. 36 and the apparatus of FIG. 37 wherein an inverter inv1 is a multiplication over the given field except the n-state inverter being the identity.
- the alternate finite field is determined relative to the given finite field by the method depicted in FIG. 36 and the apparatus of FIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity and except any n-state inverter that inverts 0 to 0.
- the alternate finite field is determined relative to the given finite field by the method depicted in FIG. 36 and the apparatus of FIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity and except any n-state inverter that inverts any of the n-states into the same n-state.
- the alternate finite field is determined relative to the given finite field by the method depicted in FIG. 36 and the apparatus of FIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity and except any n-state self reversing inverter.
- the alternate finite field is determined relative to the given finite field by the method depicted in FIG. 36 and the apparatus of FIG. 37 wherein an inverter inv1 is an n-state self-reversing inverter except the n-state inverter being the identity.
- the alternate finite field is determined relative to the given finite field by the method depicted in FIG. 36 and the apparatus of FIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity and the n-state inverter that inverts 0 to 0 but are not a multiplication over the given finite field.
- Finite field functions are presently implemented in XOR functions.
- one or more functions over an alternate finite field be it an addition, a multiplication or a multiplier modified addition are retrievably stored in a physical memory device, wherein each element in a table can be addressed and retrieved.
- a memory device can be an electrical device, an optical device, a magnetic device or any other device that is configured to store an n-state truth table and wherein each n-state symbol can be stored, addressed and retrieved.
- a division over a finite field is the reverse of a multiplication over that field. It has been show earlier and it can be easily checked that a constant multiplier over a finite field can be represented by its equivalent n-state inverter, for instance represented by the corresponding column or row in the truth table of the multiplication. A division is a reversal of a multiplication. A constant division can also be represented by its equivalent n-state inverter, for instance represented by the corresponding column or row in the truth table of the multiplication. That is: the reversing inverter of a multiplication is also a row or a column in the truth table of the multiplication. Accordingly, a multiplication over a finite field also defines a division over a finite field. Similarly, an addition over a finite field also defines a subtraction over the finite field.
- coders and encryption devices including processors configured to perform coding and encryption as well as decoding and decryption, apply finite field arithmetic, which is also known as galois field arithmetic.
- an alternate galois field arithmetic device is provided that performs a galois field addition and a multiplication, or a galois field addition and a division, or a galois field subtraction and a multiplication, or a galois field subtraction and a division over an alternate finite field wherein a zero element is not 0. Because all finite field arithmetical rules apply to operations over an alternate finite field a valid result will be generated. However, that result will include an n-state symbol that is different then if the galois field operation was operated with a standard finite field.
- the alternate galois field arithmetic device is applied in error correcting coding and decoding, error detection and encryption and decryption.
- alternate finite field addition, and/or subtraction and/or multiplication and/or division are applied to process a sequence of n-state symbols with n>2, n>3 and n>7.
- a sequence herein is a sequence of at least n-state symbols, if needed represented in bits.
- a sequence includes at least two words of n-state symbols.
- a processor processes in that case a word as a block.
- a processor processes a sequence of n-state symbols continuously, or in a streaming manner.
- a device such as a processor, a coder, a decoder, an encryption or decryption device applies functions of different alternate finite fields to process a sequence of n-state symbols. That is: a first n-state symbol or a first block of n-state symbols in a sequence of n-state symbols is processed by functions defined over a first finite field. A second n-state symbol or a second block of n-state symbols in a sequence of n-state symbols is processed by functions defined over a second finite field which with respect to the first finite field is an alternate finite field.
- an alternate finite field may be created by a reversible inverter as provided earlier, wherein 0 is the zero element, but one or more other elements of the inverter invert a state.
- 0 is the zero element, but one or more other elements of the inverter invert a state.
- functions additional, multiplication, division, subtraction
- functions additional, multiplication, division, subtraction
- two or more different alternate finite fields including at least one alternate finite field with a zero element not 0 are applied to process two or more n-state symbols or two or more blocks of n-state symbols.
- the 26 letters in for instance the western alphabet including capital letter, space and special characters and digits can be coded by a word of 7 bits. Each 7 bit word forms a 128-state symbol. In general one has an additional bit in the word to form a byte of 8 bits. A word of 8 bits forms a 256-state symbol.
- a sequence of k-state symbols or of blocks of k-state symbols with k ⁇ n is processed by a device such as a processor by applying a finite field GF(k) and a second finite field GF(n). In one embodiment of the present invention, both alternate finite fields have a zero element not being 0.
- k-state symbols after processing are modified to n-state symbols, for instance via a substitution table or in another way.
- a 128-state symbols can be processed by a prime field or an alternate of such a field by taking the 7 bit representation of the symbol and add a bit to make an 8-bit symbol.
- GF(137), GF(199), GF(251) could be used to generate the required alternate field.
- Assume and alternate finite field GFa(137) is applied on the k-state symbol with k 128. This will generate 137 state symbols.
- Coding may technically apply to error performance and detectability in signal transmission.
- Encryption is related to security and keeping secrecy of a message.
- Coding and encryption processes are reversible by a process named respectively decoding and decryption.
- Hashing in general refers to a (usually non-reversible) transformation process, for instance to indicate a possible change in status. Hashing can be achieved via a finite field.
- the concepts of (1) coding, (2) encryption and (3) hashing are covered herein by the name “coding” unless it is specifically named differently or it is clear from its context that either coding or encryption specifically is intended.
- decoding is therefor intended to mean both decoding and decryption unless specifically mentioned otherwise.
- Devices and methods disclosed herein in accordance with an aspect of the present invention are applied in data storage systems and storage devices enabled to store, retrieve and output data and are provided as an aspect of the present invention.
- Devices and methods disclosed herein in accordance with an aspect of the present invention are provided in data communication systems and devices enabled to either process and output data signals for transmission or to receive, to process and to present the original data. Also a communication system is provided in accordance with an aspect of the present invention, including sending and receiving processors applying methods and devices provided herein.
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Pure & Applied Mathematics (AREA)
- Computing Systems (AREA)
- Mathematical Physics (AREA)
- Mathematical Optimization (AREA)
- General Engineering & Computer Science (AREA)
- Computational Mathematics (AREA)
- Mathematical Analysis (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Algebra (AREA)
- Probability & Statistics with Applications (AREA)
- Nonlinear Science (AREA)
- Error Detection And Correction (AREA)
Abstract
Methods and apparatus for coding and decoding n-state symbols with n≧2 and n>2 and n>3 and n>4 are provided wherein at least one implementation of an addition over an alternate finite field GF(n) and an inverter defined by a multiplication over the alternate finite field GF(n) are provided. Encoders and decoders implementing a single n-state truth table that is a truth table of an addition over an alternate finite field GF(n) modified in accordance with at least one inverter defined by a multiplication over the alternate finite field GF(n) are also provided. Encoders include scramblers, Linear Feedback Shift Register (LFSR) based encoders, sequence generator based encoders, block coders, streaming cipher encoders, transposition encoders, hopping rule encoders, Feistel network based encoders, check symbol based encoders, Hamming coder, error correcting encoders, encipherment encoders, Elliptic Curve Coding encoders and all corresponding decoders. Systems applying encoders and decoders also are provided.
Description
- This application is a continuation-in-part of U.S. patent application Ser. No. 12/952,482 filed on Nov. 23, 2010 which claims the benefit of and is a continuation-in-part of U.S. patent application Ser. No. 11/555,730 filed on Nov. 2, 2006 which is incorporated herein by reference. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 11/618,986 filed on Jan. 2, 2007 which is a continuation-in-part of U.S. patent application Ser. No. 10/935,960 filed on Sep. 8, 2004 which claims the benefit of U.S. provisional patent application Ser. No. 60/547,683 filed on Feb. 25, 2004, which are all incorporated herein by reference. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 11/679,316 filed on Feb. 27, 2007 which claims the benefit of U.S. Provisional Application No. 60/779,068, filed Mar. 3, 2006, which are both incorporated herein by reference. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 11/566,725 filed on Dec. 5, 2006 which claims the benefit of U.S. Provisional Patent Application Ser. No. 60/742,831, filed Dec. 6, 2005, which are both incorporated herein by reference. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 11/680,719 filed on Mar. 1, 2007 which claims the benefit of U.S. Provisional Application No. 60/779,068, filed Mar. 3, 2006, which are both incorporated herein by reference. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 11/534,777 filed on Sep. 25, 2006 which claims the benefit of U.S. Provisional Patent Application Ser. No. 60/720,655, filed Sep. 26, 2005, which are both incorporated herein by reference. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 12/400,900 filed on Mar. 10, 2009 which is a continuation-in-part of U.S. patent application Ser. No. 11/680,719 filed on Mar. 1, 2007 which claims the benefit of U.S. Provisional Patent Application Ser. No. 60/779,068 filed on Mar. 3, 2006, which are all incorporated herein by reference in their entirety. The application U.S. patent application Ser. No. 12/400,900 filed on Mar. 10, 2009 also claims the benefit of U.S. Provisional Patent Application Ser. No. 61/035,563 filed on Mar. 11, 2008, which is incorporated herein by reference in its entirety. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 12/642,916 filed on Dec. 21, 2009 which is a continuation and claims the benefit of U.S. patent application Ser. No. 12/188,261, filed on Aug. 8, 2008, which claims the benefit of U.S. Provisional Patent Application Ser. No. 60/956,024 filed on Aug. 15, 2007 which are all incorporated herein by reference in their entirety. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 12/827,465 filed on Jun. 30, 2010 which is a continuation and claims the benefit of U.S. Non-Provisional patent application Ser. No. 12/330,255 filed on Dec. 8, 2008 which claims the benefit of U.S. Provisional Patent Application Ser. No. 61/012,548 filed on Dec. 10, 2007 and which are all incorporated herein by reference in their entirety. U.S. patent application Ser. No. 12/952,482 is also a continuation-in-part of U.S. patent application Ser. No. 12/868,874 filed on Aug. 26, 2010 which is a continuation and claims the benefit of U.S. patent application Ser. No. 12/264,728 filed on Nov. 4, 2008 which is a continuation of U.S. patent application Ser. No. 10/912,954 filed on Aug. 6, 2004 now U.S. Pat. No. 7,505,589 issued Mar. 17, 2009, and of U.S. patent application Ser. No. 10/936,181 filed Sep. 8, 2004, now U.S. Pat. No. 7,002,490 issued Feb. 21, 2006 which are incorporated herein by reference in their entirety. Both patent application Ser. No. 10/912,954 filed on Aug. 6, 2004 now U.S. Pat. No. 7,505,589 issued Mar. 17, 2009, and of U.S. patent application Ser. No. 10/936,181 filed Sep. 8, 2004 claim the benefit of U.S. Provisional Patent Application No. 60/501,335, filed on Sep. 9, 2003 which is incorporated herein by reference in its entirety. This patent application is also a continuation-in-part of U.S. patent application Ser. No. 12/980,504 filed on Dec. 29, 2010 which is incorporated herein by reference. This patent application is also a continuation-in-part of U.S. patent application Ser. No. 13/103,300 filed on May 9, 2011 which is incorporated herein by reference. This patent application is also a continuation-in-part of U.S. patent application Ser. No. 13/846,296 filed on Mar. 18, 2013 which is incorporated herein by reference.
- The present invention relates to apparatus and methods for coding and for decoding. In particular it relates to methods and apparatus for coding and for decoding that apply an implementation of at least an n-state addition over an alternate finite field GF(n) and at least one n-state inverter defined by a multiplication over the alternate finite field GF(n) or an implementation of a truth table defined by said addition and inverter, with n>2, with n>3 or with n>4.
- Finite fields GF(n), including classical extension fields are known. Presently certain type of coders apply additions and multiplications over a classical finite field GF(n). This makes certain elements of an encoder and/or decoder relatively predictable. It would make a coded signal of n-state symbols with n>2, n>3 or n>4, including certain check symbols generated as part of a code word less predictable if novel functions with attractive properties as defined in an alternate and currently unknown finite field would be used.
- Accordingly novel and improved methods and apparatus for encoding and decoding n-state symbols with functions defined over an alternate finite field are required.
- As an aspect of the present invention methods and apparatus for encoding and decoding n-state symbols with n>1, n>2, n>3 and n>4 are provided wherein a single truth table is implemented which is a truth table of an addition over an alternate finite field or a truth table of an addition over the alternate finite field that is modified in accordance with at least one inverter defined by a multiplication over an alternate finite field, wherein an alternate finite field has a neutral element that is not 0.
- In accordance with a further aspect of the present invention an apparatus is provided for encoding a first sequence of n-state symbols, each symbol being represented by a signal, comprising an input enabled to receive the first sequence of n-state symbols, a device implementing an addition over an alternate finite field GF(n) with n≧3, and an output that provides a second sequence of encoded symbols.
- In accordance with an aspect of the present invention coders, decoders, encryption devices and decryption devices are provided that process a sequence of a plurality of n-state symbols or of a plurality of blocks of n-state symbols by applying at least two different finite fields GF(p) with p≦n.
- In accordance with an aspect of the present invention one of the two finite fields GF(p) is an alternate finite field of the other finite field.
-
FIGS. 1-7 illustrate Linear Feedback Shift Registers (LFSRs) representing a minimal polynomial to generate p state symbols representing states of a field over pq; -
FIG. 8 illustrates reduction of an n-state truth table over at least one n-state inverter in accordance with an aspect of the present invention; -
FIGS. 9-10 illustrate a sequence generator in accordance with an aspect of the present invention; -
FIG. 11 illustrates a coder in accordance with an aspect of the present invention; -
FIG. 12 illustrates a coder in accordance with an aspect of the present invention; -
FIG. 13 illustrates a decoder in accordance with an aspect of the present invention; -
FIG. 14 illustrates a system that implements a truth table in accordance with an aspect of the present invention; -
FIG. 15 illustrates a scrambler in accordance with an aspect of the present invention; -
FIG. 16 illustrates a descrambler in accordance with an aspect of the present invention; -
FIG. 17 illustrates a sequence generator in accordance with an aspect of the present invention; -
FIGS. 18 and 19 illustrate a coder in accordance with an aspect of the present invention; -
FIG. 20 illustrates a decoder in accordance with an aspect of the present invention; -
FIGS. 21 and 22 illustrate coding matrices in accordance with an aspect of the present invention; -
FIG. 23 illustrates a coder in accordance with an aspect of the present invention; -
FIG. 24 illustrates another coder in accordance with an aspect of the present invention; -
FIG. 25 illustrates a device that implements a truth table in accordance with an aspect of the present invention; -
FIG. 26 illustrates another device that implements a truth table in accordance with an aspect of the present invention; -
FIG. 27 illustrates a coder in accordance with an aspect of the present invention; -
FIG. 28 illustrates a coder in reverse direction in accordance with an aspect of the present invention; -
FIG. 29 illustrates a communication system in accordance with an aspect of the present invention; -
FIG. 30 illustrates part of a data storage system in accordance with an aspect of the present invention; -
FIG. 31 illustrates another part of a data storage system in accordance with another aspect of the present invention; -
FIG. 32 illustrates a processor based system to perform coding and decoding steps in accordance with an aspect of the present invention; -
FIG. 33 illustrates a Linear Feedback Shift Register (LFSR) in accordance with an aspect of the present invention; -
FIGS. 34 and 35 illustrate a coder in accordance with an aspect of the present invention. -
FIG. 36 illustrates a method in accordance with various aspects of the present invention; -
FIG. 37 illustrates an implementation of a method in accordance with various aspects of the present invention; -
FIGS. 38 and 39 illustrate n-state truth tables in accordance with various aspects of the present invention. - The term n-valued or n-state herein is used generally as non-binary wherein n>2, unless the binary case is included. Herein also the term n-state symbol is used. An n-state symbol is a symbol that has one of n states. A symbol or an n-state symbol is a single entity. A symbol herein is being generated or processed as a signal by an apparatus. A symbol such as an n-state symbol can be represented by a single n-state signals that can have one of n states; it can also be represented and processed as a plurality of signals such as binary signals.
- Herein also the term check symbol is used. In binary applications one generally uses the term parity bit or symbol. Because the binary check function is the XOR function a check symbol generated by the XOR function is a 0 if there was an even number of 1s and a 1 if there was an odd number of 1s. Hence the name parity. The name parity has no such meaning in n-valued functions. Accordingly the name check symbols will be used.
- Parity calculation in binary error correction is the process wherein a number of bits in a codeword or sequence or block have for instance an even parity or even number of 1s, including the parity bit. Assume one has an 8 bit code word [a b c d e f g h] and a parity bit p is added. For instance a rule for determining a parity symbol could be: the number of 1s in [a b c d e f g h p] should always be even.
- This can be expressed in the equation a+b+c+d+e+f+g+h+p=0. The operation ‘+’ in this equation is the modulo-2 addition or XOR function.
- It is one aspect of the present invention to create a check symbol for a codeword comprised of k n-valued symbols by using a reversible n-valued operation sc1. In n-valued logic one may use different ways or functions to create a ‘parity’ or check symbol. One may use reversible and non-reversible operations. For instance a non-reversible parity n-valued operation is one wherein a 1 is added (modulo-n) to a sum when a symbol is not 0, and a 0 when a symbol is zero. The reversibility is related to determining the original value of the symbols of which a parity symbol is determined.
- One method as an aspect of the present invention is to apply reversible n-valued logic operations to calculate the ‘check’ or parity symbol of a sequence of n-valued symbols. The advantage of a reversible operation is that an equation can be solved. For instance two n-valued symbols x1 and x2 combined by a function sc1 will generate a symbol p1 according to the equation: x1 sc1 x2=p1.
- Assume that sc1 is self reversing and commutative. In that case (as is for instance explained in U.S. patent application Ser. No. 10/912,954 filed Aug. 6, 2004 entitled: Ternary and higher multi-value digital scramblers/descramblers, which is incorporated herein in its entirety): x1=p1 sc1 x2. For calculation and notation purposes it is sometimes preferred to write the parity symbol equations with a
result 0. In that case (x1 sc1 x2=0) can be written for instance as: (x1 sc1 x2 sc1 p1)=0. This is the result of (x1 sc 1 x2)=(p1 sc 1 0) again with sc1 assumed to be a commutative self-reversing n-valued function. - It should be clear that p1 can also be calculated in a different fashion.
- For instance by: (x1 sc1 x2)=(p1 sc2 0) so that ((x1 sc1 x2) sc3 p1)=0. Herein the function sc3 is the reverse of sc2. If sc2 is self-reversing then:
-
((x1 sc1 x2)sc2 p1)=0. - The n-valued self-reversing functions are in general not associative. This means that even though a function may be commutative, the order of variables in a multi-variable equation does matter. The expression (x1 sc1 x2 sc2 p1) should be evaluated as {(x1 sc1 x2) sc2 p1}. In words: first evaluate (x1 sc1 x2) as ‘term’ and then {term sc2 p1}. Assuming sc1 and sc2 being commutative one will get the same results by evaluation {p1 sc2 (x1 sc1 x2)} or {p1 sc2 (x2 sc1 x1)} or {(x2 sc1 x1) sc2 p1}.
- To demonstrate the above one may apply two functions: sc1 and sc2, which are self-reversing and commutative. For instance one can use two 4-valued switching functions sc1 and sc2 of which the truth tables are provided below.
-
sc1 0 1 2 3 0 3 2 1 0 1 2 1 0 3 2 1 0 3 2 3 0 3 2 1 -
sc2 0 1 2 3 0 1 0 3 2 1 0 3 2 1 2 3 2 1 0 3 2 1 0 3 - Assume x1=1 and x2=2. Then (x1 sc1 x2)=0 according to the truth table of sc1. If one wants (x1 sc1 x2)=(p1 sc1 0) then p1=3. Or (x1 sc1 x2 sc1 p1)=0. For instance (x1 sc1 p1) in this case is (1 sc1 3)=3. And (x2 sc1 3)=(2 sc1 3)=2 which is different from 0. So the expression is not associative. However the expression is reversible when one observes the order of the variables.
- For illustrative purposes the associative 4-valued function sc3 is also provided in the following truth table.
-
Sc3 0 1 2 3 0 0 1 2 3 1 1 0 3 2 2 2 3 0 1 3 3 2 1 0 - It is easy to check that (x1 sc3 x2 sc3 p1)=0 will apply if (x1 sc3 x2)=p1.
- Alternate Extension Fields
- Binary extension fields or Galois Fields represented as GF(n=2p) with p≧2 are applied in generating n-state check symbols from 2 or more n-state symbols. An n-state or n-valued symbol is a symbol which assumes one of n possible states. One may also use the term n-valued. An n-state or n-valued symbol for processing in an apparatus or a device is represented by a signal. Such a signal may be a single signal, which has one of n states. For instance a 4-state symbol has one of 4 states or values. A 4-state symbol may have the values or states 0, 1, 2 and 3. Each state is represented by a single n-valued signal. For instance the value or state of a signal may be determined by a voltage. It should be clear that it is not required that the
states - Furthermore, an n-state symbol may be represented by 2 or more signals. For instance, each possible state of a 4-state symbol may be represented by 2 binary signals. To emphasize that a value in an n-valued symbol is a distinguishing property and not a true value the term n-state symbol is preferred.
- Extension fields GF(qp) with q≧2 and p≧2 as applied in for instance error correction are in general binary extension field. These extension fields are defined by a finite (n) number of field elements, by a first operation usually called an addition, its reverse being a subtraction, by a function called a multiplication and its reverse called a division all over GF(n). The addition over GF(n=2p) is self reversing, which means that addition and subtraction over GF(n) have the same truth table. Furthermore, the addition is commutative (which means that a+b=b+a over GF(n)) and the addition is associative (which means that (a+b)+c=a+(b+c)=(a+c)+b etc. over GF(n)). The field also has an operation multiply, which is also commutative and associative. And the addition and multiplication are distributive (which means that c*(a+b)=c*a+c*b.) Furthermore there is a neutral element e or a zero element in the field so that an addition a+e=a, wherein a and e both belong to the field. There is a neutral element i (or identity or the one element) so that a*1=a wherein a and i both belong to the field. Furthermore each multiplication a has an inverse a−1 that is also part of the field (except the zero element perhaps). Addition ‘scn’ and multiplication ‘mn’ can be represented as + and *. One should keep in mind that these operations are defined by a truth table and in many cases are different from the standard addition and multiplication.
- In general elements of an extension field GF(qp) are generated by a primitive polynomial in q of order p or by a p-state LFSR expressing such a polynomial. Such polynomials are provided for the binary extension fields in for instance the earlier mentioned book of Lin and Costello in appendix A. However, there is more than one minimal polynomial for larger values of n. While there is only one minimal polynomial for GF(4), there are 2 minimal polynomials for GF(8) and 4 for GF(16).
- For instance the adder sc81 over GF(8) of paragraph [0113] is created from elements in GF(8) generated by the
binary LFSR 1400 ofFIG. 1 withbinary logic function 1401 being XOR. Assume that the initial state of the LFSR is [1 0 0]. The consecutively generated states are then: -
GF state 0 0 0 0 1 0 0 1 0 1 0 2 0 0 1 3 1 1 0 4 0 1 1 5 1 1 1 6 1 0 1 7 1 0 0 1 - The state [0 0 0] is the forbidden or degenerative state of the LFSR and represents GF(8)
state 0. By modulo-2 addition of the individual binary elements of a GF(8) state one gets the GF(8) addition result. For instance [1 0 0] XOR [0 1 0]→[1 1 0] which is GF(8)state 4 in accordance with the state diagram. One may run the LFSR with starting state [0 1 0] as initial state (which may be calledelement 1 in GF(8)). Every element in GF(8) except 0 moves up one place and [0 1 0] is GF(8) 1 and [0 0 1] is GF(8) 2. Then [0 1 0] is GF(8) 4. [0 1 0] XOR [0 0 1]→[0 1 1] which is the new representation of GF(8). So changing the initial state of the LFSR does not change the addition or the related multiplication. - Another minimal polynomial to generate elements of GF(8) is implemented by the
LFSR 1500 ofFIG. 2 . Starting with initial state [1 0 0] this LFSR generates the following states: -
GF state 0 0 0 0 1 0 0 1 0 1 0 2 0 0 1 3 1 0 1 4 1 1 1 5 1 1 0 6 0 1 1 7 1 0 0 1 - Herein the XOR addition of GF(8) states 1 and 2 is [1 0 0] XOR [0 1 0]→[1 1 0] which is GF(8)
state 6. Accordingly, a different addition over GF(8) is created. The truth table for this addition over GF(8) is provided by the following truth table: -
sc82 0 1 2 3 4 5 6 7 0 0 1 2 3 4 5 6 7 1 1 0 6 4 3 7 2 5 2 2 6 0 7 5 4 1 3 3 3 4 7 0 1 6 5 2 4 4 3 5 1 0 2 7 6 5 5 7 4 6 2 0 3 1 6 6 2 1 5 7 3 0 4 7 7 5 3 2 6 1 4 0 - This function is also self reversing and associative and is distributive with the multiplication of paragraph [0113]. Let's call the addition of paragraph [0113] sc81 and the just created addition sc82. One can create a symbol c1=a1*x1 sc81 b1*x2 by using function sc81 and a different symbol c2=a1*x2 sc82 b1*x2. For instance create the symbols c1 and c2 from x1=2 and x2=6 with a1=3 and b1=5. The two expressions then generate:
-
c1=3*2sc 81 5*6 and -
c2=3*2sc 82 5*6. - Remember that in both expressions the same multiplication m81 of paragraph [0113] is used. This will generate:
-
c1=4sc 81 3=6 and -
c2=4sc 82 3=1. - Assume that in a coder one has to determine x2 from c1 or c2 and x1.
- Using c1: c1=3*x1 sc81 b1*x2 which leads to x2=b1−1*(
c1 sc81 3*x1) wherein b1−1 is the reverse of b1. (the reverse ofmultiplier 5 is 5−1 ormultiplier 4 as one can derive from the multiplication table.) This leads to x2=4*(6sc81 3*2)=4*(6 sc81 4)=6. If one would have used the wrong function sc82 one would have as result x2=4*(6sc82 3*2)=4*(6 sc82 4)=4*7=3. - Using c2: c2=3*x1 sc82 b1*x2 which leads to x2=b1−1*(
c2 sc82 3*x1) wherein b1−1 is the reverse of b1. (the reverse ofmultiplier 5 is 5−1 ormultiplier 4 as one can derive from the multiplication table.) This leads to x2=4*(1sc82 3*2)=4*(1 sc82 4)=4*3=6. If one would have used the wrong function sc81 one would have as result x2=4*(1sc81 3*2)=4*(1 sc81 4)=4*2=5. - Accordingly, using different adder functions wherein the functions are distributive with the same multiplier. Because there is a limited number of these functions, one may try a limited number of functions to apply the correct one. To further confuse an unauthorized decoder one may create an expression using more than 2 variables and at least 2 different functions. For instance c=a1 sc81a2 sc82 a3. Herein the order of execution will become an issue. However, solving equations also may become more involved.
- One easy generation of an adder over GF(n) such as GF(8) is using consecutive binary representation and adding the elements as before by XORing all bits. This generates the following states over aGF(8) as an example wherein aGF(8) stands for alternate Galois Field.
-
aGF state 0 0 0 0 0 0 1 1 0 1 0 2 0 1 1 3 1 0 0 4 1 0 1 5 1 1 0 6 1 1 1 7 0 0 0 0 - This will create the following adder sc83 over aGF(8) (by XORing the bits of an element in aGF(8)).
-
sc83 0 1 2 3 4 5 6 7 0 0 1 2 3 4 5 6 7 1 1 0 3 2 5 4 7 6 2 2 3 0 1 6 7 4 5 3 3 2 1 0 7 6 5 4 4 4 5 6 7 0 1 2 3 5 5 4 7 6 1 0 3 2 6 6 7 4 5 2 3 0 1 7 7 6 5 4 3 2 1 0
One can apply the multiplication m81 of paragraph [0113] to the function sc83 for checking if the functions are distributive. This means checking if x1 m81 (x2 sc83 x3)=(x1 m81 x2) sc83 (x1 m81 x3). The functions sc83 is not distributive for m81. However, it turns out sc83 is distributive for a multiplication function m82 which is defined by the following truth table. -
x/ m82 0 1 2 3 4 5 6 7 0 0 0 0 0 0 0 0 0 1 0 1 2 3 4 5 6 7 2 0 2 4 6 5 7 1 3 3 0 3 6 5 1 2 7 4 4 0 4 5 1 7 3 2 6 5 0 5 7 2 3 6 4 1 6 0 6 1 7 2 4 3 5 7 0 7 3 4 6 1 5 2 - Checking if x1 m82 (x2 sc83 x3)=(x1 m82 x2) sc83 (x1 m82 x3) for all possible states of x1, x2 and x3 demonstrates that the combination of sc83 and m82 is distributive.
- There are actually several other distributive combinations of self reversing additions over aGF(n) which cannot be generated by an LFSR with multipliers which are not the multiplier m81.
- Different classes of adders over GF(n) with n>1 and GF(pq) with p>1 and q>1 wherein n, p and q are integers.
- In general a field like GF(4) or GF(8) or GF(2q) cannot be generated from modulo-4 or modulo-8 addition and modulo-4 or modulo-8 multiplication. In order to generate a finite field GF(8) one defines GF(8) as an extension field, such as GF(n=23) by using the earlier shown LFSR methods. However, especially for n>2 there are more reversing and even self-reversing two-input n-state functions than those defined by the classical LFSR methods. First of all, for values greater than 4, there are several different primitive or minimal polynomials of degree q in n=pq of which each will define an addition over GF(pq) as was shown in the case of GF(8). Each of these additions based on a primitive or minimal polynomial has the same multiplier over GF(pq) over which the operation c*(a+b) is distributive. Each of the multipliers has an inverse in the field.
-
FIGS. 3-7 are diagrams of LFSRs with a 5-stage shift register that generate a field over GF(32=25). A circle in these figures, even if not provided with a numeral indicates the same as 1401, which is a XOR function. Each field thus generated has a different 32-state addition function which is associative. Each field thus generated has the same multiplier function, which combined with the appropriate addition over GF(32) is distributive. Each individual constant multiplier herein has an inverse (or a divisor) which is also an element of the field. As n=2q becomes larger for larger values of q the number of fields or extension fields over GF(n=2q) becomes larger. - The field generated by XORing, for instance for binary words of 5-bits, over all 32 binary words ranging from [0 0 0 0 0] to [1 1 1 1 1] will create a proper 32-state addition function that is associative. However, as was already shown in the 8-state case, this 32-state addition and the ‘standard’ GF(25) combination are not distributive. In accordance with an aspect of the present invention different adders and reversible multipliers over GF(n) and especially over GF(2q) will be provided that constitute a field which allows these to be applied in n-state coders, n-state decoders, n-state sequence generators, n-state LFSRs and n-state polynomial and arithmetical circuits. Any n-state switching function herein be it an n-state function with at least two inputs and an output or an n-state inverter can be implemented in a switching device. The switching device can be a true n-state switching device wherein an n-state symbol having one of n-states is represented by an n-state signal. In the alternative an n-state switching function, be it an n-state function with at least two inputs and an output or an n-state inverter, can be implemented in a memory device, wherein the corresponding truth table of an n-state function is implemented in a memory. A memory can be a true n-state memory. It can also be a binary memory, wherein an n-state symbol is represented as a binary word, and inputted, stored and outputted as a binary word of binary signals. An analog/digital (A/D) and digital/analog (D/A) converter can be used to generate a true n-state signal from a binary word.
- The extension field GF(4) which is a traditional field is defined by the following addition and multiplication over GF(4) sc4 and m4 respectively of which the truth tables are provided in the following tables.
-
sc4 0 1 2 3 0 0 1 2 3 1 1 0 3 2 2 2 3 0 1 3 3 2 1 0 -
m4 0 1 2 3 0 0 0 0 0 1 0 1 2 3 2 0 2 3 1 3 0 3 1 2 - In this case a 4-state symbol can be represented by a 2-bit word. By adding (with XOR) the corresponding bits of two two-bits word one will get the above addition. The functions are associative and distributive. The addition is also commutative and self-reversing. The multiplication is reversible with elements of the field. It is again noted that a multiplication with a constant (or element) of the field is applying an n-state inverter with an input and an output of which the function is defined by a column or a row in the truth table of m4.
- A first alternate or not traditional addition over alternate field GF(4) is provided in the following truth table.
-
sc4 0 1 2 3 0 3 2 1 0 1 2 3 0 1 2 1 0 3 2 3 0 1 2 3 - This addition is self reversing, it has a ‘zero’ element (symbol 3) and it is commutative and associative. There is a corresponding multiplier which combined with the above adder will be distributive, which means [a m4 (b sc4 c)=(a m4 b) sc4 (a m4 c)]. The truth table of this multiplier is provided in the following table.
-
m4 0 1 2 3 0 0 1 2 3 1 1 2 0 3 2 2 0 1 3 3 3 3 3 3 - The ‘zero’ element is again 3 (any multiplication with 3 results in 3) and the ‘1’ element (multiplying a symbol ‘a’ with this element will again create ‘a’) is ‘0’. Furthermore, a division is defined within this field as each factor of multiplication ‘b’ has a reverse ‘b−1’ which is also an element of the field. (
element 0 has 0 as inverse;element 1 haselement 2 as inverse; andelement 2 haselement 1 as inverse. Furthermore,element 3 is the ‘zero’ element). - A multiplier over GF(4) in this case is actually a 4-state inversion. The inversion is indicated by [0 1 2 3]→[a b c d]. This means that the elements in the vector [0 1 2 3] are transformed into the elements of vector [a b c d] in their corresponding positions or: 0→a; 1→b; 2→c; and 3→d, wherein a, b, c and d are elements of GF(4). The
multipliers multiplier 0; [0 1 2 3]→[1 2 0 3] formultiplier 1; and [0 1 2 3]→[2 0 1 3] formultiplier 2. One can easy check that each multiplier has an inverse: 0−1=0; 1−1=2; and 2−1=1. One proof is to multiply forinstance 1*2=0 or invert [1 2 0 3] with [2 0 1 3] which will generate [0 1 2 3]. - At least one implementation of sc4 and m4 is shown in
FIG. 8 .FIG. 8 shows adevice 2101 which implements the function sc4 in 2100, which may be a memory or a switching circuit with inputs a and b and an output c which represents a 4-state symbol c. The output symbol on c which is represented by a signal is determined by the truth table of sc4 and the input symbols on a and b which are also are represented by signals. The relationship between a, b and c can be expressed by (c=a sc4 b) wherein sc4 is represents the above truth table. - In
device 2102 input ‘a’ to adevice 2100 which implements sc4 is provided with an inverter (or multiplier) inv1, which may be a multiplier which is defined by a row or column in m4. Assume that inv1 is a multiplier. The resulting symbol on d1 is then determined by {d1=(inv1(a) sc4 b)}. Assume that inv1 is theinverter representing multiplier 2. One can then write the relationship between a, b and d1 as d1=(2 m4 a) sc4 b. It is more common to name m4 as * and sc4 as +. This will create the expression d1=2*a+b, keeping in mind that * and + have a special meaning. - Assume that the top input ‘a’ to a
device 2100 determines the rows of the truth table. The truth table of 2100 (sc4) with a multiplier [2 0 1 3] at the top input can be reduced to the single truth table sc41 as provided in the following table. -
sc41 0 1 2 3 0 1 0 3 2 1 3 2 1 0 2 2 3 0 1 3 0 1 2 3 - The circuit of 2102 can thus be replaced by
equivalent circuit 2103 which implements a single truth table defined by sc41 and by an expression d1=a sc41b. It is noted that sc41 is non-commutative. - A similar approach can be taken with
circuit 2104 which has an inverter inv1 in input a and an inverter inv2 in input b and output d2 is defined by d2=inv1(a) sc4 inv2(b). Assume that inv1 ismultiplier 2 and inv2 ismultiplier 1. We can then replace the combination of 2100 with the two inverters inv1 and inv2 with theequivalent circuit 2105 with no inverters on the inputs, wherein 2105 implements the single truth table of sc42 which is provided in the following table. -
sc42 0 1 2 3 0 0 3 1 2 1 2 1 3 0 2 3 0 2 1 3 1 2 0 3 - The input b of 2100 is determined by the columns of a truth table. Accordingly, one has to modify the rows of sc4 in accordance with inv1 and the columns of that transformation in accordance with inv2 to arrive at sc42. One can also say that sc4 is modified in accordance with inv1 and inv2. In circuit 2405 the output d2 can be expressed as d2=a sc42 b, noting that if inv1 and inv2 are not identical then sc42 is non-commutative.
-
Circuit 2106 has an inverter inv3 at the output. This means that d3=inv3 (a sc4 b), which is a commutative function if sc4 is commutative. Thecircuit 2106 can be replaced by thecircuit 2107 with no inverter at the output and that implements sc43 wherein d3=a sc43 b. - The same approach is applied to reduce 2108 to 2109. One can also say that d4=inv3 (inv1(a) sc4 inv2(b)) is reduced to d3=a sc44 b, wherein sc44 is created by modifying sc4 in accordance with inv1, inv2 and inv3.
- The reduction examples have been shown for 4-state fields. These reductions of at least 2 input/1 output truth tables by their applied inverters apply to an n-state truth table with n>2 of a function in a field.
- In a further embodiment of the present invention a sequence generator for generating a sequence of n-state symbols, using implementations of the addition and multiplier or the inverter reduced form thereof is provided. In yet a further embodiment the sequence generator generates an n-state pseudo-noise or maximum length sequence of n-state symbols. An n-state sequence generator can be implemented by an n-state Linear Feedback Shift Register (LFSR), either in Galois or Fibonacci configuration. An n-state LFSR based sequence generator in Galois configuration is shown in
FIG. 9 as 2201 and 2202. The LFSR has a shift register of 3 storage elements, each element able to store and provide an n-state symbol. As common in a Galois LFSR, at least one 2-input n-state function sc is implemented between two storage element. In the illustrative example theLFSR 2201 has 3 storage elements, two functions sc (though one may apply two different functions) and three inverters inv1, inv2 and inv3. The maximum length sequence that can be generated with this n-state generator is a sequence of n3−1 n-state symbols. In an illustrative 4-state case the function sc is the above defined 4-state adder sc4 over alternate or non-traditional field GF(4). The inverters inv1, inv2 and inv3 are the 4-state inverters defined by the rows or columns of the truth table of m4 over alternate field GF(4). It should be noted that a generator may also have other functions than sc4 and inverters defined by m4 over alternate field GF(4) or have a function sc4 defined over alternate field GF(4) and n-state inverters that are not defined by m4. - The sequence generator provides a sequence ‘outg’ on an output. In one embodiment of the present invention one has to determine the actual inverters inv1, inv2 and inv3 to generate an n-state m-sequence. In the example a 4-state inverter will be selected from m4 and being [0 1 2 3] which is the identity, [1 2 0 3] and [2 0 1 3]. The inverter [3 3 3 3] is effectively a 0 inverter or open connection. (Keep in mind that ‘0’ herein is merely one of n n-state symbols. What ‘0’ does is determined by a truth table, not by the common interpretation that 0 is nothing and does nothing. The truth tables of sc4 and m4 show that the ‘0’ role is assumed by ‘3’).
- A relatively simple method to determine if a sequence is a m-sequence has been developed by the inventor of the present invention for instance in U.S. Pat. No. 7,580,472 to Lablans issued on Aug. 25, 2009 and in U.S. Pat. No. 7,725,779 to Lablans issued on May 25, 2010, which are both incorporated herein by reference. An auto-correlation graph of an n-state sequence can determine if a sequence is an m-sequence or a pseudo-noise sequence. However, the standard method of calculating an n-state auto-correlation graph will show side-peaks. Some sequences, which are not m-sequences, also have side-peaks. This sometimes makes it difficult to determine if an n-state sequence is pseudo-noise. The novel method determines a correlation value by adding a constant value to a sum if corresponding symbols in two sequences are identical and subtracting a constant or nothing when the two symbols are different. This will create a single peak correlation graph for any n-state m-sequence.
- By applying this correlation method to the
generator 2201 ofFIG. 9 one finds that inv1=[2 0 1 3] and in2 and inv3 are both [1 2 0 3]. The function sc is sc4 in the alternate field GF(4). The generator can generate a 4-state m-sequence on ‘outg’ of length 63 4-state symbols. Assume that the initial state of the LFSR is [3 2 1], then the first 10 generated 4-state symbols on ‘outg’ are [1 3 1 2 0 2 3 3 1 1]. - The two functions sc in 2201 have inv2 and inv3 respectively at an input. These functions can be reduced to scv1 and scv2 respectively by modifying the first function sc in accordance with inv2 and the second sc in accordance with inv3 in accordance with the method as was described earlier herein. Because sc is commutative, the functions scv1 and scv2 will be non-commutative.
-
FIG. 10 illustrates a 3 stage n-state sequence generator 2301 in Fibonacci configuration. It has the n-state inverters inr1, inr2 and inr3, which are inr1=[1 2 0 3]; inr2=[1 2 0 3] and inr3=[2 0 1 3]. Assume that the initial state of the LFSR of 2301 is [3 2 1], then the first 10 generated 4-state symbols on ‘outf’ are [2 2 2 1 0 0 1 0 1 3]. - The two functions sc in 2301 have inr2 and inr3 respectively at an input. The first function sc also has inr1 at an output. These functions sc can be reduced to scr1 and scr2 respectively by modifying the first sc in accordance with inr1 and inr2 and the second sc in accordance with inr3 as is shown in 2302 and according to the method as was described earlier. Because sc is commutative, the functions scr1 and scr2 will be non-commutative.
- It is noted that there are other ways to generate an m-sequence equivalent to the m-sequence generated by an LFSR based sequence generator. All states of an LFSR are deterministic. If an initial state of the 4-
state LFSR 2301 ofFIG. 10 is [a b c] then all following states of the LFSR and the generated sequence are determined by n-state (in this case 4-state) expressions. Assuming function sc4 and inverters inr1, inr2 and inr3 over the alternate field GF(4) one can provide the expression: outf=inr1{inr2(a) sc4 inr3(b) sc4 c}. In the Fibonacci configuration the content of the first shift register element is identical to the previous output symbol. Assume that at moment k the output symbol is sk. This means that at moment k the content of the shift register is [sk-1 sk-2 sk-3]. The expression that determines an output symbol can thus be written as: sk=inr1{inr2(sk-1) sc4 inr3(sk-2) sc4 sk-3} as a recursive expression. One can also express all generated symbols as a function of {a, b, c}. This approach applies to all n-state Fibonacci and Galois configuration LFSR based sequence generators as one can easily check. - A sequence generator as provided in
FIGS. 9 and 10 can be combined by a circuit as provided inFIG. 8 wherein in the combination at least one function over an alternate field GF(n) such as GF(4) is used to generate an n-state combined sequence such as an n-state Gold sequence as is disclosed in U.S. Pat. No. 7,580,472 to Lablans issued on Aug. 25, 2009 which is incorporated herein by reference. - In one embodiment of the present invention a sequence generator applying functions over an alternate field GF(n) such as alternate field GF(4), be it a Gold sequence generator or an m-sequence generator or any other sequence generator, is applied to generate a ‘known’ sequence to be applied in a scrambler in one of the configurations as shown in
FIG. 8 . Such ascrambler 2400 is illustrated inFIG. 11 . It has asequence generator 2401 to generate a known sequence which is provided on an input to ascrambling device 2402 such as provided inFIG. 8 and explained above. The input of the ‘known’ sequence todevice 2402 has an inverter ins1, which may be an identity. This inverter is preferably an inverter defined by a multiplication over an alternate field GF(n). However, the inverter ins1 may also be any reversible n-state inverter if 2402 implements an addition over an alternate field GF(n). A to be scrambled n-state sequence ‘in’ is provided on a second input of 2402 with n-state inverter ins2, which may be an identity inverter. Thedevice 2402 scrambles ‘in’ against ‘known’ and generates on an output the scrambled n-state sequence ‘out’. The output has an n-state inverter ins3 which may be an identity inverter. - It should be clear that the scrambler or coder of
FIG. 11 has a corresponding descrambler by applying the corresponding descramblers as explained related toFIG. 8 . It is to be understood that for clarity inverters ins1, ins2 and ins3 are used to explain the working of the scrambler. However, the n-state function implemented in 2402 may be reduced in accordance with ins1, in2, ins3 so that 2402 implements a single reduced truth table without having inverters at inputs or output. A further requirement for correct descrambling with a descrambler is that the sequence generator of a descrambler is synchronized with a sequence generator used by the corresponding scrambler. - LFSR based encoders such as LFSR based scramblers are known as streaming ciphers or streaming encoding as they work continuously generating a coded symbol after an input symbol has been entered.
- Yet another coder provided in accordance with an aspect of the present invention is a reversible transposition coder wherein symbols in a sequence of symbols are transposed in accordance in part at least with an n-state pseudo-noise or maximum-length sequence generated by using at least an n-state addition and one n-state inverter that are defined over an alternate finite field GF(n) as provided herein. Yet another coder is a coder with a hopping rule based on an n-state pseudo-noise or maximum-length sequence generated by using at least an n-state addition and one n-state inverter that are defined over an alternate finite field GF(n) as provided herein. How to create these transposition encoders and hopping rules and their corresponding decoders is disclosed in U.S. patent application Ser. No. 11/534,777 to Lablans filed on Sep. 25, 2006 which is incorporated herein by reference. This type of encoder can also be applied for hopping type of communication system, wherein a transposition rule determines a hopping rule.
- Another coder provided in accordance with an aspect of the present invention is an n-state LFSR based scrambler and a corresponding self synchronizing descrambler in Fibonacci configuration using at least an addition function over an alternate field GF(n) and preferably with an addition and an inverter defined by a multiplication over the alternate field GF(n). An illustration of such a
scrambler 2500 is shown inFIG. 12 . The illustrative scrambler has a 3 stage n-state shift register, each register element enabled to store and provide an n-state symbol. It is to be understood that an LFSR can have more shift register elements than 3, and also less than 3. Thescrambler 2500 has feedback taps toimplementations LFSR 2500 has anoutput 2504 and aninput 2505. Theoutput 2504 is connected to an input of animplementation 2503 of an n-state scrambling function indicated as being ‘sc’. Another input of 2503 receives a sequence of n-state symbols ‘in’ which may be inverted by an inverter ‘inv4’. The output of 2503 is connected to aninput 2505 of the LFSR, which may include an inverter ‘inv1’. The output of 2503 or (if present) the output of ‘inv1’, will generate the sequence of scrambled n-state symbols ‘scram’ resulting from ‘in’. It should be clear that an input sequence of k n-state symbols will result in k scrambled output n-state symbols. The scrambler may include additional inverters, for instance ‘inv2’ and ‘inv3’. Theimplementations - In accordance with an aspect of the present invention at least one implemented truth table to realize an n-state LFSR based scrambler is an n-state truth table of an addition over an alternate field GF(n). Preferably, such a scrambler also implements at least one n-state inverter being defined by the multiplication over the alternate field GF(n). This means that
FIG. 12 in accordance with an aspect of the present invention implements one function ‘sc’ being the addition over the alternate field GF(n) and that 2 of the functions now designated as ‘sc’ may be any n-state reversible, or even non-reversible, n-state function. - The self-reversing
descrambler 2600 corresponding to the scrambler ofFIG. 12 is shown inFIG. 13 . Thedescrambler 2600 has the same structure as the scrambler. However, the scrambled sequence ‘scram’ is provided on theinput 2605 of the LFSR of the descrambler. The inputted symbols are also inputted on 2603 which may be an implementation of sc, potentially after inversion by inverter inv1r, wherein inv1 in the scrambler and inv1r in the descrambler establish identity. The inverters inv1 and inv1r combined should establish identity. This means that a symbol inverter by both inv1 and inv1r should be un-transformed.Implementation 2603 which may be a device implementing a 2-dimensional truth table is then the descrambling device that has also one input connected tooutput 2604 of the LFSR ofFIG. 13 . An output of 2603 then outputs a descrambled symbol. If the scrambler has an inverter inv at the input of thescrambling device 2503 then 2603 should have the inverter inv4r at its output. Inverters inv4 and inv4r should establish identity. - As an example, assume that
FIGS. 12 and 13 pertain to a 4-state device, that all functions sc are the addition sc4 over the alternate finite field GF(4) as provided above and that inv1 and inv4 are identity inverters and inv2 is 4-state inverter [1 2 03] and inv3 is 4-state inverter [2 0 1 3] as defined by the multiplication over the alternate finite field GF(4). - Assume that a sequence in=[1 3 0 2 0 2 3 1 3] is inputted on the scrambler of
FIG. 12 with initial LFSR state [3 2 1]. This will create scrambled sequence scram=[1 3 3 0 2 0 0 3 1]. Assume that the descrambler ofFIG. 13 has initial LFSR state [2 1 3] and that the descrambler receives scram. This will generate dscram=[1 2 1 2 0 2 3 1 3], which only has the first 3 symbols in error due to the error in the initial setting of the LFSR of the descrambler and illustrates the self-synchronizing aspect. - It is again pointed out that any of the coders and decoders described herein may be implemented in true n-state devices, as disclosed for instance in U.S. Pat. No. 7,218,144 to Lablans issued on May 15, 2007 and U.S. Pat. No. 7,002,490 to Lablans issued on Feb. 21, 2006 and U.S. Pat. No. 7,548,092 to Lablans issued on Jun. 16, 2009 and in U.S. Pat. No. 7,643,632 to Lablans issued on Jan. 5, 2010, which are all incorporated herein by reference in their entirety. N-state memory devices are disclosed in U.S. Pat. No. 7,397,690 issued on Jul. 8, 2008 to Lablans and in U.S. Pat. No. 7,656,196 to Lablans on Feb. 2, 2010 which are incorporated herein by reference. A memory device or a dual memory device with appropriate clocking acts as a shift register element as is known to one of ordinary skill. A shift register and in particular an n-state LFSR can also be implemented in an addressable memory, which may be an addressable n-state memory as is disclosed in U.S. Patent Application Publication Ser. No. 20070088997 to Lablans published on Apr. 19, 2007 and in U.S. Patent Application Publication Ser. No. 20070098160 to Lablans published on May 3, 2007 which are all incorporated herein by reference.
- An n-state symbol with n>2 is a designation of a processing unit which is processed by an implementation of an n-state truth table with n>2. An n-state truth table can be a one dimensional truth table that defines an n-state inverter having one input and one output. It is a vector (which may be represented as a column or a row vector) that defines how each of n possible input states of an input symbol is transformed into a state of an output symbol. A reversible n-state inverter transforms one of n states of an input symbol into one of n states of an output symbol, wherein each of n input states is transformed into a unique output state. An inverter can also be non-reversible in which case n input states or transformed into less than n output states. An n-state truth table can also be 2-dimensional wherein an output n-state symbol is determined by 2 n-state input symbols.
- An implementation of a 2 dimensional n-state truth table can be an actual active switching device. It can also be a memory device. In that case an n-state output symbol may be addressed by 2 n-state input symbols. Or in other words: an n-state output symbol has an address that is determined by 2 n-state input symbols. Such an n-state truth table can be implemented as for instance a 2 by 2 matrix in a computer program running on a processor with memory such as an Intel® microprocessor with memory running a language such as MatLab® of The MathWorks, Inc. of Natick, Mass. or FreeMat, an open source computer programming language, available from <URLwww.sourceforge.net>. The following truth table of sc4 can be implemented and the function sc4 can be executed in such a processor system.
-
sc4 1 2 3 4 1 4 3 2 1 2 3 4 1 2 3 2 1 4 3 4 1 2 3 4 - The following is a listing of a program in MatLab performing all possible 4-state input combinations and the resulting output 4-state symbol of sc4.
-
% generating all possible 4-state symbols ‘out’ as result of all possible input % symbols ‘in1’ and ‘in2’ sc4=[4 3 2 1;3 4 1 2;2 1 4 3;1 2 3 4]; % this is the truth table stored in memory for in1=1:4 for in2=1:4 out=sc4(in1,in2) % the generated output end end % end program - The possible states of a 4-state symbol in this program are 1, 2, 3 and 4. Each n-state symbol in this implementation sample is represented by a plurality of binary symbols, wherein a binary symbol or a bit is represented by a binary signal. An n-state symbol is thus represented by a word of binary signals. An illustrative system that implements a truth table and transforms an input to an output is shown in
FIG. 14 . Abinary processor 2703 has an input to receive a binary word in_b. A binary word may be received as a serial sequence of bits or may be received on a plurality of parallel inputs. The binary input word may be generated from an n-state signal in_n on adevice 2701 which may be an Analog/Digital (A/D) converter which transforms a single n-state signal into a plurality of binary signals. The system may be provided with two binary words ‘word1’ and ‘word2’ in series or in parallel. In the parallel case the system may have at least two A/D converters. After having received a single, or after receiving at least two input words theprocessor 2703 will address in one embodiment of the present invention thememory 2702 with and address based on the single input word or with the two input words to find in 2702 the related output word. The memory provides the processor with the output symbol or output binary word which may be applied for further processing or will be provided on an output by the processor to provide out_b as for instance a binary word. In a further embodiment of the present invention the binary output word out_b is provided to a Digital/Analog (D/A) converter to generate an n-state signal out_n. - The following demonstrates the difference between an implementation of sc4 with an inverter [3 1 2 4] at the input that determines a row in the truth table and applying the reduced single truth table sc41 as provided in the following table.
-
sc41 1 2 3 4 1 2 1 4 3 2 4 3 2 1 3 3 4 1 2 4 1 2 3 4 - The following is a listing of a program in MatLab performing all possible 4-state input combinations and the resulting output 4-state symbol of sc4 with the inverter [3 1 2 4] at the input that determines a row in the truth table.
-
% generating all possible 4-state symbols ‘out’ as result of all possible input % symbols ‘in1’ and ‘in2’ on sc4 with inverter [3 1 2 3] at an input sc4=[4 3 2 1;3 4 1 2;2 1 4 3;1 2 3 4]; % this is the truth table stored in memory inv = [3 1 2 4]; for in1=1:4 for in2=1:4 in1= inv(in1); % this is the inversion out=sc4(in1,in2) % the generated output end end % end program - The execution takes an extra step for inversion, requiring at least an additional clock pulse.
- The following is a listing of a program in MatLab performing all possible 4-state input combinations and the resulting output 4-state symbol of sc41 which is sc4 modified in accordance with inverter [3 1 2 4] at the input that determines a row in the truth table.
-
% generating all possible 4-state symbols ‘out’ as result of all possible input % symbols ‘in1’ and ‘in2’ on sc41 sc41=[2 1 4 3;4 3 2 1;3 4 1 2;1 2 3 4]; % this is the truth table stored in memory for in1=1:4 for in2=1:4 out=sc41(in1,in2) % the generated output end end % end program - The execution of this does not require an extra step for inversion, and does not require an additional clock pulse and is faster than using an implementation of the inverter.
- A signal be it binary or n-state with n>2 may be an electric signal, an optical signal, a magnetic signal, a radiation, an magneto-optical signal, an electro-magnetic signal, a mechanical signal or a mechanical impulse, a presence of a material or a quantum-mechanical state or any other physical state of a material that will represent at least one of 2 states in one embodiment of the present invention or at least 1 of 3 states in a further embodiment of the present invention or at least 1 of 4 states in yet a further embodiment of the present invention. In yet a further embodiment an implementation of an n-state truth table, of which an example is provided in
FIG. 14 , can process n-state symbols with n>2 at a speed of at least 100 Hz (=100 symbols per second). In yet a further embodiment an implementation of an n-state truth table with n>2, of which an example is provided inFIG. 14 , can process n-state symbols at a speed of at least 1000 Hz (=1000 symbols per second). In yet a further embodiment an implementation of an n-state truth table, of which an example is provided inFIG. 14 , can process n-state symbols with n>2 at a speed of at least 100 Hz (=100 symbols per second). In yet a further embodiment an implementation of an n-state truth table, of which an example is provided inFIG. 14 , can process n-state symbols with n>2 at a speed of at least 1 MHz (=1,000,000 symbols per second). In yet a further embodiment an implementation of an n-state truth table, of which an example is provided inFIG. 14 , can process n-state symbols with n>2 at a speed of at least 100 MHz (=100,000,000 symbols per second). It should be clear that processing of n-state symbols in accordance with an n-state truth table with n>2 at the above speeds is only possible with a processor and cannot be performed mentally or with paper and pencil by a human operator. - In accordance with an embodiment of the present invention an n-state scrambler with an n-state LFSR in Galois configuration is provided and a corresponding self synchronizing descrambler. Illustrative embodiments are shown in
FIGS. 15 and 16 . Thescrambler 2800 ofFIG. 15 is based on an n-state LFSR with a 3-stage shift register with two connecting n-state functions sc and a scrambling function sc that receives the to be scrambled n-state sequence on input ‘in’. Two feedback taps contain n-state inverters inv2 and inv3 respectively. The end feedback to the output that provides the scrambled n-state sequence ‘scram’ contains an n-state inverter inv1. A correspondingdescrambler 2900 is shown inFIG. 16 . The scrambled sequence is provided on input ‘scram’. The tap from the input has n-state inverter inv1r, which combined with inverter inv1 ofFIG. 15 forms identity. Thedescrambler 2900 also has inverters inv2 and inv3. The descrambled n-state sequence is provided on ‘dscram’. All functions in the example are called ‘sc’. However, in accordance with an aspect of the present invention a ‘scrambler’ and/or a descrambler in the configuration likeFIGS. 15 and 16 only needs to have one of the devices or implementations named ‘sc’ to be an addition over alternate finite field GF(n). An inverter in a scrambler or descrambler that is like the Galois configuration inFIGS. 15 and 16 can be any n-state inverter, though preferably at least one inverter is defined by a multiplication over the alternate finite field GF(n). “Like”FIGS. 15 and 16 means a Galois configuration based scrambler with a corresponding Galois configuration shift register self synchronizing descrambler. More details of the workings of LFSR and Linear Forward Connected Shift Registers (LFCSR) in Galois configuration are disclosed in U.S. Pat. No. 7,487,194 to Lablans issued on Feb. 3, 2009 which is incorporated herein by reference. - Galois configuration means a shift register with at least two adjacent shift register elements connected through an implementation of an n-state truth table from an output of a first shift register element to an input of a directly adjacent shift register element in the signal flow direction as is shown in
FIG. 15 . Preferably, the connecting implementation is an implementation of an at least 2 dimensional n-state truth table. Fibonacci configuration means that no implementation of an at least 2-dimensional n-state truth table is placed between an output of a first shift register element to an input of a directly adjacent shift register element in the signal flow direction as is shown inFIG. 12 . - In one embodiment an LFSR is provided wherein two adjacent shift register elements are connected through an inverter as is shown in
FIG. 17 . Theshift register elements Galois LFSR 3000 inFIG. 17 is shown as a sequence generator withfunctions sc 1 and sc2 and feedback inverters inv1, inv2 and inv3 to generate an n-state sequence on output ‘seq’. By changing ‘inv4’ to one of 24 possible 4-state inverters one can generate several different 4-state m-sequences. - In accordance with a further aspect of the present invention a convolutional n-state encoder and decoder is provided for n>2, including a forward encoder, a recursive encoder and a systematic encoder and corresponding decoders. These n-state encoders and corresponding decoders are disclosed in U.S. patent application Ser. No. 11/566,725 with Lablans as named inventor and filed on Dec. 5, 2006 which is incorporated herein by reference. These encoders may be forward coders, recursive coders and systematic coders or any combination thereof and their corresponding decoders. In one embodiment of the present invention the functions and inverters applied in these coders and decoders include at least one addition and one inverter derived from a multiplication over an alternate finite field GF(n).
-
FIG. 18 illustrates aforward convolutional coder 3100 with at least two different forward coders applying a shift register (in this case of 3 stages) with functions and inverters implemented. - The
coder 3100 is shown in its twocomponent coders 3201 and 3202. Each of the coders is provided with an input sequence of n-state symbols ‘in’. Thecoders 3201 and 3202 both use a forward connected shift register. Because both shift registers are provided with the same sequence their shift register states will be identical. Coder 3201 has four taps including the start tap with inverters inv11, inv12, inv13 and inv14 respectively connected to the function ‘sc’ which for illustrative purposes will all be the addition over alternate finite field GF(n). The output sequence is inverted by inverter inv15 to create output sequence out1. All inverters herein for illustrative purposes are assumed to be derived from the multiplication over alternate finite field GF(n). - The coder 3202 is similar to 3201, but has one less tap and thus function sc and has inverters inv21, inv22, inv23 and inv24 to generate sequence out2. All inverters and functions are again defined over alternate finite field GF(n).
- The corresponding
decoders FIG. 20 . The structure of the decoders is similar to that of the corresponding coders with some directions reversed. This requires that inv15 in thedecoder 3301 is replaced by inv15−1, inv11 in thedecoder 3301 is replaced by inv11−1, that inv21 in thedecoder 3301 is replaced by inv21−1, inv24 in thedecoder 3301 is replaced by inv24−1. Because of the field properties (which include associativity and distributivity) and the self reversing properties one can easily manipulate equations that determine output symbols and state of the shift register. - To ease the burden of notation in inverters, an equation of a first n-state symbol in1 inputted on an n-state inverter that is defined by a multiplication over an alternate finite field GF(n) can be written as m1*in1, wherein m1 is the position of the column or row in the truth table of the multiplication. Accordingly, the inverter [0 1 2 3] in m4 of the alternate finite field corresponds with ‘0’; [1 2 0 3′ corresponds with ‘1’; [2 0 1 3]corresponds with ‘2’ and [3 3 3 3] corresponds with ‘3’. One should keep in mind that the ‘*’ operation then is different from the commonly used meaning of *. Furthermore, the function sc4 can be replaced with ‘+’. A function ‘sc’ with a first inverter ‘1’ provided with input n-state symbol ‘x1’ and with a second inverter ‘2’ provided with input n-state symbol ‘x2’ to generate n-state symbol y, can be expressed as: y=1*x1+2*x2.
-
FIG. 20 shows twoconvolutional decoders decoders -
x1=n1+s1+s2+s3 -
x2=n2+x1+s1+s2 -
x3=n3+x2+x1+s1 -
x1=m1+s2+s3 -
x2=m2+s1+s2 -
x3=m3+x1+s1 - Solving by substitution leads to:
-
s1=n1+m1 (1) -
s2=n1+m1+m2+n3+m3 (2) -
s3=n1+n2+n3+m3 (3) - The above equations show that, when the 3 consecutive symbols inputted into the decoders are error free, then the content of shift register is determined. The content of the shift register also reflect the 3 previous correctly generated decoded symbols. Thus if the symbols [n1 n2 n3] and [m1 m2 m3] have been preceded with symbols in error then one can correct some of these errors as is explained in detail in U.S. patent application Ser. No. 11/566,725.
- The above equations show [x1 x2 x3] and [s1 s2 s3] as unknowns, while [n1 n2 n3] and [m1 m2 m3] are known entities. This means there are 6 equations with 6 unknowns, which can be resolved with for instance Cramer's rule, wherein ‘*’ and ‘+’ have a meaning as defined by the truth tables of sc4 and m4. Furthermore a division by ‘a’ in a finite field is a multiplication with ‘a−1’. Accordingly, one can solve the above equations also when the inverters in the decoders are not identity inverters ‘0’ or [0 1 2 3].
- In a further illustrative example the inverters in
FIG. 19 are assigned as follows: all inverters as shown in 3201 are the inverter ‘2’ or [2 0 1 3] in the alternate finite field GF(4) and all inverters in 3202 are the inverter ‘1’ or [1 2 0 3] in the alternate finite field GF(4). This determines that in the correspondingdecoders - The above establish the following equations for the
decoders 3301 and 3302: - For 3301:
-
2*x1+2*s1+2*s2+s*s3=1*n1; -
2*x1+2*x2+2*s1+2*s2=1*n2; -
2*x1+2*x2+2*x3+2*s1=1*n3; - For 3302:
-
1*x1+1*s2+1*s3=2*m1; -
1*x2+1*s1+1*s2=2*m2; -
1*x1+1*x3+1*s1=2*m3. - The above equations establish 6 equations with 6 unknowns (the generated x1, x2 and x3 and the shift register state s1, s2 and s3). One can resolve the set by substitution and by Cramer's rule for instance. Cramer's rule establishes the determinant for the coefficients of the unknown and unknowns as:
-
- In calculating the corresponding value of the determinants one should keep all the rules of the alternate field GF(4) in mind. When an unknown does not have a coefficient in an equation its coefficient is actually ‘3’ which is the zero-element in the finite field. The value of D is ‘0’, which is the neutral element. The inverse of ‘0’ is also ‘0’.
- The unknown ‘s1’ for instance under Cramer's rule is then:
-
- A similar approach is applied to determine s2 and s3.
- Accordingly, after receiving a sequence of coded n-state symbols out1 and a sequence of coded n-state symbols out2, one can determine the state of the shift register [s1 s2 s3] that corresponds to these sequences. Using [s1 s2 s3] as the initial state of the shift register in
decoders - A similar approach can be applied to coders that include a recursive shift register and an encoder that includes an uncoded sequence which is usually called a systematic encoder. As an aspect of the present invention a similar approach using the functions over an alternate finite field GF(n) is applied to encoders with at least one shift register in Galois configuration as is disclosed in U.S. patent application Ser. No. 12/774,092 to Lablans filed on May 5, 2010 and which is incorporated herein by reference.
- In accordance with an aspect of the present invention an encoder is provided that creates one or more n-state check symbols from one or more n-state data symbols generated by using at least an n-state addition and one n-state inverter that are defined over an alternate finite field GF(n) as provided herein, and that in one embodiment provides an error detection capability in a sequence containing an n-state data symbol and an n-state check symbol and that in a further embodiment provides an error correction capability in a sequence containing an n-state data symbol and an n-state check symbol.
- An example is provided using the function addition and at least one inverter based on a multiplication over alternate finite field GF(n) and the following relations in a (7,4) n-state Hamming code to generate 3 n-state check symbols from 4 n-state data symbols
-
p1=(inv1(x1)sc x2)sc inv2(x3); -
p2=(x1 sc x3)sc x4; -
p3=(x2 sc x3)sc x4. - Assume that inv1 is multiplier ‘1’ in the alternate finite field GF(4) and inv2 is multiplier ‘2’. The function ‘sc’ is ‘+’ in the alternate finite field. The above equations can then be written as:
-
p1=1*x1+x2+2*x3; -
p2=x1+x3+x4; -
p3=x2+x3+x4. - The expression (1*x1+x2) in one embodiment is replaced by an implementation of a non-commutative n-state function. This aspect has been explained earlier above.
- It is assumed that only one symbol in the 7 n-state symbols is in error. One can run through all possible error situations with only one data symbol or check symbol in error. One recalculates all check symbols from the received data symbols and then compares the calculated and the received check symbols. The requirements for an n-valued (n,k) code then may be: each of the k data symbols in a n-valued Hamming codeword should be a function of at least 2 check symbols. There are (n-k) check symbols. One check symbol in error should mean just that: only one check symbol and no data symbol is in error. No check symbol in error means that no single error has occurred. What one does with a Hamming code is mapping each state of a codeword into a unique word formed by check symbols. For a (7,4) n-valued Hamming code:
- x1=p1, p2, ˜p3;
- x2=p1, ˜p2, p3;
- x3=p1, p2, p3;
- x4=˜p1, p2, p3;
- no error=˜p1, ˜p2, ˜p3;
- p1 in error=p1, ˜p2, ˜p3;
- p2 in error=˜p1, p2, ˜p3;
- p3 in error=˜p1, ˜p2, p3;
- Accordingly all 8 combinations of p1, p2 and p3 are used.
- If it is determined that x1 is in error x1 has to be reconstructed from x2, x3, x4, p1, p2 and p3 which are not in error. The equation p2=x1+x3+x4 provides that x1=p2+x3+x4 which establishes the correct value for x1. One can perform a similar calculation to determine x2, x3 and x4 when one of these symbols is in error. The check symbol can also be corrected if desired.
- The aspects of determining n-state check symbols and error detection and error correction of an n-state symbol in error based on the check symbols including an n-state Hamming code have been disclosed in U.S. patent application Ser. No. 11/680,719 to Lablans filed on Mar. 1, 2007 which is incorporated herein by reference.
- N-state check symbols can be determined from at least 2 n-state data symbols by applying an addition and at least one inverter based on a multiplication over an alternate finite field as disclosed herein. The symbols in one embodiment are arranged in a matrix to determine at least a location of an error which may be called an erasure. Errors can be located by re-calculating the check symbols. Once errors are located one can use the expressions or equations that have been used to determine the check symbols and by using check symbols and data symbols that are known to be error free to create an expression that determines a correct state of a symbol in error. To prevent that multiple errors in a column or a matrix prevent calculating a
correct state 2 check symbols can be determined by arranging data symbols in a first matrix and determine a check symbol from a row or a column and arrange data symbols in a second matrix and determine a check symbol from a row or a column from the second matrix. The equations that determine a correct state of a symbol in error are derived from the equations or expressions that generate the check symbols. - The above matrix approach is explained in U.S. patent application Ser. No. 11/969,560 to Lablans filed on Jan. 4, 2008 and in U.S. patent application Ser. No. 12/400,900 to Lablans filed on Mar. 10, 2009 which are both incorporated herein by reference.
- An illustrative example is provided using
FIG. 21 .FIG. 21 illustrates an arrangement of 4 rows and 3 columns of n-state data symbols di and mk and with two rows of check symbols pn and rn and 1 column of check symbols qj. Assume that it is determined that after re-calculation check symbols q3 and q4 and r2 and p2 are different from the received check symbols. In one embodiment a check symbol on check symbols confirms that the check symbols are not in error. It is determined that d6 and m6 are in error. There are several ways to solve the errors. For instance check symbol q3 may have been created from the expression c1*d2+c2*d6+c3*d10=q3. For instance the equations in one embodiment is implemented by using the function addition and at least one inverter based on a multiplication over alternate finite field GF(n). In this example n=4.Let 1*d2+2*d6+0*d10=q3. Assume that [d2 d6 d10]=[2 2 3]. This will create q3=2. Assume, received was [d2 d6 d10 q3]=[2 0 3 2]. It was already determined that d6 is in error. One can rephrase the check symbol expression or equation as 2*d6=1*d2+0*d10+q3. Multiplying left and right by ‘1’ will result in d6=2*d2+1*d10+1*q3. Evaluating this expression will provide d6=2 of course. - In a further embodiment also a set of equations is resolved. For instance the following equations apply:
-
r2=a1*d5+a2*m5+a3*d6+a4*m6; and - p2=b1*d5+b2*m5+b3*d6+b4*m6. Herein d6 and m6 are in error and can be resolved from the set of two equations, for instance by applying Cramer's rule. The equations in one embodiment are again implemented by using the function addition and at least one inverter based on a multiplication over alternate finite field GF(n).
- In one embodiment of the present invention at least two check symbols are generated by using the function addition and at least one inverter based on a multiplication over alternate finite field GF(n) with two expressions which have at least one n-state data symbol in common as a variable and wherein each check symbol is achieved by arranging n-state data symbols in different matrices. This embodiment is illustrated in
FIG. 22 inmatrices - It is noted that in accordance with an aspect of the invention an expression or equation (a*x1+b*x2+c*x3+ . . . m*xk) can be modified to {(x1 sc41 x2)+} wherein sc41 is an implementation of a single non-commutative n-state function which is created by modifying ‘+’ in accordance with inverters ‘a’ and ‘b’ and wherein the addition ‘+’ function and at least one inverter based on a multiplication are defined over alternate finite field GF(n).
- In one embodiment a coder is provided which is based on an n-state Linear Feedback Shift Register (LFSR) or expressions that evaluate the states and/or outputs of such an LFSR, wherein the LFSR through a function is provided with n-state data symbols and one output is a final state of the shift register as a plurality of check symbols, which can be applied to determine if an error has occurred in a sequence containing the data symbols and the final shift register content of the LFSR and wherein the LFSR and/or the expressions apply the addition ‘+’ function and at least one inverter based on a multiplication that are defined over alternate finite field GF(n). Such a coder is illustrated in
FIG. 23 with acoder 3600. At least 4 n-state data symbols in this example are entered on a function ‘+’ to be combined with a content of the last shift register element of the LFSR which has at least 2 n-state shift register elements, which is in this case an n-state LFSR in Galois configuration. A Fibonacci configuration can also be used. The LFSR also has two n-state inverters of which at least one is defined by the multiplication over the alternate finite field GF(n). As an example n=4 and inv1 is multiplier ‘1’ and inv2 is multiplier ‘2’. One can generate all codewords [x1 x2 x3 x4 s1 s2] wherein s1 and s2 represent the content of the shift register after processing. The content of the shift register at the start may be [0 0] or [3 3] or any other state. One may check that each 4-state codeword has a distance of at least 2 symbols. That means that at least one error in a codeword can be detected by recalculating the codeword. - In a further embodiment, one may take as a codeword generated by 3600 the word formed by [x1 x2 x3 x4 s1], for instance when both inv1 and inv2 are the multiplier ‘2’ over the alternate finite field GF(4). In that case the distance between all codewords is still 2, thus allowing to determine if a symbol was in error. As an example a word [1 0 3 2 0] is received. The check symbol is re-calculated from [1 0 3 2] to generate codeword [1 0 3 2 3] which is different from the received word, which indicates that an error had occurred.
- In one embodiment at least one erasure can be corrected in a coder as shown in
FIG. 23 . To explain how expressions can determine a state of an LFSR such as an n-state LFSR without actually running the LFSR the embodiment inFIG. 9 will be applied. Assume the content of the three n-state shift registers to be a, b and c. The inverters are inv1=‘1’; inv2=‘2’ and in3=‘1’ defined by the multiplication over alternate finite field GF(4) and sc is the addition over alternate finite field GF(4). The approach is the following: each element in the shift register gets its own assigned symbol. For instance the first element has content [s1 3 3]. The 3 is used because that is the ‘0’ element. The second element has as content [3 s2 3] and the final element has content [3 3 s3]. The multipliers then are expressed as inv1=[1 1 1] and inv2=[2 2 2] and inv3=[1 1 1]. The multiplication of the content of the third shift register element with inv1=[1 1 1] is [1*3 1*3 1*s3]. This approach allows to track the effects and contributions of each individual shift register element. The result of addition of inv3 times the content of the third shift register element plus the content of the second shift register element is: [{(1*3)+3} {(1*3)+s2} {(1*s3)+3}] as all operations take place on individual values. The actual final content of a shift register can be determined by adding all three components, keeping in mind that the ‘+’ herein is the addition over the alternate finite field. The following table provides the content of the individual shift register elements after staring with s1=[0 3 3]; s2=[3 0 3] and s3=[3 3 0]. -
sr1 sr2 sr3 start 0 3 3 3 0 3 3 3 0 1 3 3 1 0 3 2 3 0 1 2 3 1 2 3 2 2 0 1 3 3 1 2 3 2 2 2 1 3 2 4 2 3 0 2 2 1 3 2 1 5 3 0 2 2 1 3 2 1 0 6 0 2 1 1 3 3 1 0 1 7 2 1 2 3 3 2 0 1 2 8 1 2 0 3 2 0 1 2 1 9 2 0 2 2 0 3 2 1 1 10 0 2 2 0 3 1 1 1 2 - This approach uses the associative a distributive properties of the addition and multiplication. One may replace [0 3 3] with [0*
s1 3 3] which is of course [s1 3 3] and means that all states in the first position of a shift register content have to be multiplied with s1, etc. The table shows only the first 10 results of the content of the shift register. One can expand that to any length. It should be clear that after 63 cycles the content will return to the original initial content. The above also means that if an initial state of a shift register is known one can determine the actual content (and the generated symbol) at any time after and before the initial time without having to run the LFSR. - The following table shows the content of the shift register of the LFSR of
FIG. 23 after starting with content [3 3] and being entered with [x1 x2 x3 x4]. The input states are reflected as x1=[0 3 3 3]; x2=[3 0 3 3]; x3=[3 3 0 3] and x4=[3 3 3 0]. All shift register contents are expressed as depending on x1, x2, x3 and x4. This means that: s1=[3 3 3 3] and s2=[3 3 3 3]. The states of the two shift register elements are then: -
cycle s1 s2 0 3 3 3 3 3 3 3 3 1 2 3 3 3 2 3 3 3 2 1 2 3 3 0 2 3 3 3 2 1 2 3 0 0 2 3 4 2 2 1 2 3 0 0 2 - As was described above, the check symbol in a codeword is the content of the first shift register element after 4 cycles and thus entering x1, x2, x3 and x4. From the above one can see that after 4 cycles s1=2*x1+2*x2+1*x3+2*x4. In the earlier example it was shown that [1 0 3 2 0] was received with one symbol in error. Assume that it was decided that x2 is an erasure and that thus s1 was correct. This means that: 2*x2=2*x1+1*x3+2*x4+s1 or x2=x1+2*x3+x4+1*s1 or x2=2. This demonstrates that in one embodiment of the present invention one can determine the correct state of a symbol in error from an expression that determines a state of a check symbol. This approach can be applied for all type of expressions. However, it has here been shown to apply to a coder using at least an addition and an inverter defined by a multiplication over an alternate finite field GF(n) with n=4.
- In one embodiment of the present invention the combination of an addition and an inverter defined by a multiplication over alternate finite field GF(n) as applied in coders and decoders as shown in
FIGS. 15-20 andFIG. 23 are implemented in a single non commutative truth table. One implementation of a combination of the above addition and inverter in a further embodiment of the present invention is a single non-commutative truth table stored in a memory device. - The addition over an alternate finite field GF(n) and inverters defined over a multiplication defined over an alternate finite field GF(n) as disclosed herein can be used in any reversible coder. For instance it can be applied in a scrambler as disclosed by Kuhlman et al. in U.S. Pat. No. 7,099,469 issued on Aug. 29, 2006 which is incorporated herein by reference. The methods can also be used in for instance the S-box of Feistel ciphers or Feistel networks.
- The Feistel network is illustrated in
FIG. 24 . Herein 3721 is the coding or ciphering network and 3722 is the decoding or deciphering network. The order of use of 3721 and 3722 can the exchanged as long the one reverses the other. The working is well known to one of ordinary skill in the art, but will be briefly explained herein. Aplaintext word 3701 of 2p (with p≧1 or p>1) n-state symbols with n≧2 will be spilt into twoparts - In 3721
word 3701 is split up inword Word 3703 is modified by an n-state function 3704 against a word K0. The n-state functions implemented in 3704, 3706 and 3708 may be reversible or non-reversible. They have as input a known signal such as a key word K0, K1, . . . Kn or apply some known confusion scheme. These functions have to be applied with the same corresponding key in thecoder 3721 and in reversed order indecoder 3722. The n-state functions coder 3721 have to be reversible n-state functions and have to be applied in reversed order in their corresponding reversing function in 3722. The reversible n-state functions may be commutative or non-commutative but at least one of them is an addition over alternate finite field GF(n) or is an addition over alternate finite field GF(n) with at least one n-state inverter at an input or an output which is defined by a multiplication over the alternate finite field GF(n) or is an addition over alternate finite field GF(n) that is modified in accordance with an inverter which is defined by a multiplication over the alternate finite field GF(n) and is implemented as a single n-state truth table for instance in a memory device, wherein the truth table may be a non-commutative truth table. - Assume that
function 3709 can be represented assc 1 andfunction 3708 as sc2. Further assume that the reverse of function sc1 is function ds1. This can be illustrated by the expressions c=a sc1 b and a=c ds1 b. In general one applies the adder over GF(2n) as the reversible n-state function. This adder is self-reversing and commutative and can be implemented in a binary logic circuit or a memory device. - The last stage of 3721 can be expressed as Cn=
S sc 1 Kn and R=An sc2 Cn. The first stage of 3722 has afunction 3713 which reverses sc2 and can be called ds2. The first stage of thedecoder 3722 can be expressed as Cn=S sc1 Kn and An=R ds2 Kn. This demonstrates that thedecoder 3722 reverses thecoder 3721. One has to make sure that the generatedcodeword 3710 which is formed from 3711 and 7312 is entered in the proper way as the to be decoded codeword intodecoder 3722. - The structure of a Feistel network, wherein coding includes “rounds” of confusion and substitution are also applied in advanced codes such as Rijndael and the related Advanced Encryption Standard (AES) coding scheme. The rounds herein apply what is called herein a Feistel-like network. This means that a word of k n-state symbols (with n≧2, or n>2, or n>3) and k≧2, is split at least in two sub-words of at least one symbol and wherein at least one of the sub-words is being processed by either an implementation of an addition over an alternate finite field or by an addition over an alternate finite field and an inverter defined by a multiplication over a finite field or by an implementation of a truth table of an addition over an alternate finite field that is modified in accordance with an inverter defined by an alternate finite field. At least the reversible part of for instance DES and AES in one embodiment of the present invention apply functions and inverters defined by the alternate finite fields as defined and explained herein.
- How to generate and decode an AES code is for instance provided in U.S. Pat. No. 7,421,076 issued on Sep. 2, 2008 to Stein et al. and U.S. Pat. No. 7,383,435 to Fellerer issued on Jun. 3, 2008 which are both incorporated herein by reference.
- Feistel-like or Feistel network based encoders generally work in blocks of n-state symbols. A plurality of symbols that is received sequentially, rather than in parallel are thus considered words or blocks of symbols. These codes are generally called block codes as a coder can operate only after a block of symbols has been entered. The same applies to error correcting coders wherein check symbols are determined over a block of n-state symbols. A decoder cannot complete decoding until all symbols of a block have been entered into the decoder and can be processed.
- In accordance with an embodiment of the present invention a two input n-state function of
FIG. 24 may be represented by an n by n truth table. Such a truth table in one embodiment is implemented in a memory device. If the function is reversible a column and/or a row of the truth table have to be a reversible n-state inverter. One may modify the adder by providing n-state inverter at one or both of the inputs and/or by providing an n-state inverter at the output. An n-state inverter over GF(2q) can be implemented in binary logic for processing of words of q bits by using combinational binary circuitry, by switching outputs or by using a memory device.FIG. 38 shows in diagram an n-state switching device 3800 implementing an n-state function withinputs output 3803. - One may implement an n-state function by using a
device 3804 that implements an adder over alternate finite field GF(n) withinverters inverter 3807 at the output wherein at least one of the inverters is defined by a multiplication over the alternate finite field GF(n). An inverter may be identity, which is a direct connection, which may is called a multiplier ‘0’ in the alternate finite field GF(4) as was developed above. In one illustrative example thedevice 3804 implements the 4-state adder: -
sc4 0 1 2 3 0 3 2 1 0 1 2 3 0 1 2 1 0 3 2 3 0 1 2 3 - In a further example one of the
inverters Inverter 3805 hasinput 3802,inverter 3806 hasinput 3802 whileinverter 3807 has anoutput 3803. - Case 1:
inverter 3805 is [2 0 1 3]. The device ofFIG. 38 is reduced to the device ofFIG. 39 (assuming thatinput 3801 determines a row in the truth table and input 3802 a column) with adevice 3900 that implements a single truth table: -
sc4 0 1 2 3 0 1 0 3 2 1 3 2 1 0 2 2 3 0 1 3 0 1 2 3 - This is clearly a non-commutative truth table. However, the device of
FIG. 39 in this example does not require separate inverters at inputs or output. In one embodiment the truth table ofFIG. 39 is implemented on a processor for instance on a memory device of a processor. - Case 2: In the
second example invert 3806 is [2 0 1 3] while the other inverters are identity. This results in adevice 3900 that implements a single truth table: -
sc4 0 1 2 3 0 1 3 2 0 1 0 2 3 1 2 3 1 0 2 3 2 0 1 3 - This is also a non-commutative truth table. The device of
FIG. 39 in this example does not require separate inverters at inputs or output. In one embodiment the truth table ofFIG. 39 is implemented on a processor for instance on a memory device of a processor. - Case 3:
inverter 3807 is [2 0 1 3]. The device ofFIG. 38 is reduced to the device ofFIG. 39 with adevice 3900 that implements a single truth table: -
sc4 0 1 2 3 0 3 1 0 2 1 1 3 2 0 2 0 2 3 1 3 2 0 1 3 - This is a commutative truth table. The device of
FIG. 39 in this example does not require separate inverters at inputs or output. In one embodiment the truth table ofFIG. 39 is implemented on a processor for instance on a memory device of a processor. - Case 4:
inverter 3805 is [2 0 1 3],inverter 3806 is [1 2 0 3] andinverter 3807 is [2 0 1 3]. The device ofFIG. 38 is reduced to the device ofFIG. 39 with adevice 3900 that implements a single truth table: -
sc4 0 1 2 3 0 2 3 0 1 1 1 0 3 2 2 3 2 1 0 3 0 1 2 3 - This is again a non-commutative truth table. The device of
FIG. 39 in this example does not require separate inverters at inputs or output. In one embodiment the truth table ofFIG. 39 is implemented on a processor for instance on a memory device of a processor. - It is noted that all of the truth tables after reduction are still reversible. The reduced function can be called scnm.
- It has been noted before that in alternate finite field GF(4) that the inverse of inverters are 0→
inv 0−1; 1→inv 2−1; and 2→inv 1−1. - For instance, the function device of
FIG. 38 can be expressed as y=c*(a*x1+b*x2), wherein a, b and c are theinverters - In one embodiment of the present invention the device or implementation of
FIG. 25 or 26 can be applied in any coder which processes an n-state symbol in accordance with an n-state addition over an alternate finite field GF(n) which is modified in accordance with at least one inverter which is defined by a multiplication over the alternate finite field GF(n) or has such an inverter at an input or an output. - In one embodiment of the present invention a coding device performs a polynomial arithmetical calculation over the alternate finite field GF(n). This means that additions, multiplications and divisions are all performed over the alternate finite field GF(n). The division over such a field is the reverse of the multiplication as was explained earlier. It is believed that calculations over finite fields are known. In general one performs these calculations over the classical fields GF(2m). One reason to apply GF(2m) is that symbols over GF(2m) can be represented in binary form as binary words using mainly XOR and AND operations. By using functions over an alternate finite field GF(n) the results become less predictable and hard to analyze for an unauthorized or uninformed receiver of n-state symbols coded or generated over an alternate finite field.
- The following patents disclose n-state arithmetic over a finite or Galois field GF(n=2m). U.S. Pat. No. 4,745,568 to Onyszchuk et al. issued on May 17, 1988; U.S. Pat. No. 7,372,960 to Lambert issued on May 13, 2008; U.S. Pat. No. 7,506,015 to Graham issued on May 17, 2009; U.S. Pat. No. 7,711,763 issued on May 4, 2010 which are all incorporated herein by reference. In one embodiment these Galois field calculators apply a shift register to determine a multiplication or division of polynomials or a remainder thereof, such as in U.S. Pat. No. 4,797,848 to Walby issued on Jan. 10, 1989 and U.S. Pat. No. 5,999,959 to Weng et al. issued on Dec. 7, 1999 which are also incorporated herein by reference. While in one embodiment a calculator over an alternate finite field has an implementation of an addition and an inverter both over an alternate finite field GF(n), an implementation may also be an implementation of a single truth table which is a truth table of an addition over an alternate finite field GF(n) modified in accordance of at least inverter which is defined by a multiplication over an alternate finite field GF(n).
- Above, at least one alternate finite field GF(4) has been provided. While GF(4) has not many alternate finite fields it still has at least 3 alternate finite fields. It will be shown that for instance GF(8) has many more alternate finite fields.
- The following truth tables define two more alternate finite fields GF(4).
-
sc4a m4a 0 1 2 3 0 1 2 3 0 1 0 3 2 0 1 2 3 1 0 1 2 3 1 1 1 1 2 3 2 1 0 2 1 3 0 3 2 3 0 1 3 1 0 2 - The functions sc4a (addition) and m4a(multiplication) form a field: requirements of commutativity, associativity and distributivity are met. There is a neutral element ‘0’ in the multiplication so that 0*x=x for each element in the field. There is also a zero element (which is ‘1’) so that a+(−a)=1 and a+1=a. Furthermore the inverse of every multiplication is also in the field (0→0), (2→3) and (3→2) and 2*3=0 and 3*2=0. Furthermore, every power of an element of the field is also in the field: X2=X*X so that 2*2=3 and 3*3=2, etc.
- Yet another alternate finite field GF(4) is defined by:
-
sc4b m4b 0 1 2 3 0 1 2 3 0 2 3 0 1 0 1 2 3 1 3 2 1 0 1 3 2 0 2 0 1 2 3 2 2 2 2 3 1 0 3 2 3 0 2 1 - The functions sc4b (addition) and m4b(multiplication) form a field: requirements of commutativity, associativity and distributivity are met. There is a neutral element ‘0’ in the multiplication so that 0*x=x for each element in the field. There is also a zero element (which is ‘2’) so that a+(−a)=2 and a+2=a. Furthermore the inverse of every multiplication is also in the field (0→0), (1→3) and (3→1) and 1*3=0 and 3*1=0. Furthermore, every power of an element of the field is also in the field: X2=X*X so that 1*1=3 and 3*3=1, etc.
- As an example a multiplication of two polynomials over GF(n) defined by sc4a and m4a is provided: (2*x+3)*(3*x+2)=2*3*x2+(3*3+2*2)*x+2*3=0*x2+0*x+0. Keeping in mind that ‘0’ in this field is the neutral element. In a similar manner one may conduct a polynomial division. For instance add 0*x+0 to the above polynomial product, which will create 0*x2+0*x+0+0*x+0=0*x2+1*x+1=0*x2 as 1 is the ‘0’ element.
Dividing 0*x2 by (2*x+3) will generate 3*x+0 with aremainder 3. One can check this result by evaluating (2*x+3)*(3*x+0)+remainder which will generate 0*x2. - In one embodiment of the present invention at least one of the functions or inverters used in a coder during coding is changed from being defined in a first alternate finite field to being defined in a second alternate finite field. For instance use the scrambler and descrambler of
FIGS. 12 and 13 . In a first instance the functions and inverters are defined related to sc4a and m4a, and in a second instance to sc4b and m4b. For instance assume that inFIG. 12 sc is sc4a and the inverters inv1 and inv4 are identity and inverter inv2 ismultiplier 2 in m4a and inv3 ismultiplier 3 in m4a.FIG. 13 is the corresponding descrambler. Further assume that after coding 10 symbols the functions are changed to sc4b and m4b for coding the next 10 symbols. With the initial state of the LFSR being [0 1 3] and the inputted symbols being twenty zeros [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0] then the scrambler ofFIG. 12 will generate [1 2 3 0 3 1 2 0 2 3 2 3 1 3 3 0 2 0 2 1]. When the descrambler follows the scrambler using the same initial state then the descrambled sequence will be twenty zeros. However, if the descrambler keeps on using the same functions sc4a and m4a then the descrambled sequence will be [0 0 0 0 0 0 0 0 0 0 3 1 3 3 0 2 0 2 1 2] which is clearly not correct. Implementations of the functions herein in memory are easy to realize and easy to change. Accordingly it is not required to keep the same functions for a long period. If one so desires functions and/or inverters can be changed per coding of a single symbol. One should be careful in coding procedures wherein a plurality of symbols or a word of symbols is coded, for instance in accordance with a Galois Field. In such a case it is generally beneficial to not change functions during coding of the word. However, if one is prepared to handle the complexities of changing functions in the corresponding decoding process one may also change functions during coding of a word of n-state symbols. - We will turn our attention now to alternate finite fields for n>4. It has been shown above that one can a finite field with addition such as sc81 and sc82 and multiplication over GF(8) by a primitive polynomial for instance implemented in a 3-stage LFSR. The number of additions that establish a field combined with a standard multiplication such as above provided multiplication m81 in the n=8 case will increase for n=2m and m>3. For m=4 there are 4 generator polynomials and for m=5 there are 6 and for m=8 there are 34 generator polynomials according to Lin and Costello's Error Control Coding. Each of the additions in these polynomial fields has the ‘standard’ multiplication. The additions and inverters related to the multiplication in such finite fields can be used in coders and decoders as provided herein. It is believed to be a novel aspect that different additions as generated by primitive or minimal polynomials can be used in coders, including reversible coders that are provided herein. It is a further aspect of the present invention that coders and/or decoders provided herein apply inverters or a multiplication defined over the field, which in these cases is known as an extension field. These different additions can also be modified or provided with inverters that are not defined over the finite field.
- It has been shown above that addition sc83 is associative, it has a neutral element (0) it is commutative and it is distributive with m82 which also has a neutral element and a zero element. The addition is also self reversing. Furthermore the multiplication has for each multiplier an inverse in the field. Accordingly, sc83 and m82 form an alternate finite field GF(8) in which all of the coders and decoders as already described herein are enabled.
- The following truth tables are of combinations of additions and multiplications that establish an alternate finite field over GF(8). One such combination is:
-
sc8a m8a 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 0 1 2 3 4 5 6 7 0 0 0 0 0 0 0 0 1 1 0 5 6 7 2 3 4 0 1 2 3 4 5 6 7 2 2 5 0 7 6 1 4 3 0 2 3 5 6 7 1 4 3 3 6 7 0 5 4 2 1 0 3 5 7 1 4 2 6 4 4 7 6 5 0 3 2 1 0 4 6 1 5 2 7 3 5 5 2 1 4 3 0 7 6 0 5 7 4 2 6 3 1 6 6 3 4 2 2 7 0 5 0 6 1 2 7 3 4 5 7 7 4 3 1 1 6 5 0 0 7 4 6 3 1 5 2 - The functions sc8a and m8a establish an alternate finite field over GF(n) with n=8 and can be applied in the coders and decoders as described herein. One can see that m8a is not the traditional multiplication over GF(8).
- Another combination that defines an alternate finite field GF(n) with n=8 is:
-
sc8b m8b 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 0 1 2 3 4 5 6 7 0 0 0 0 0 0 0 0 1 1 0 7 5 6 3 4 2 0 1 2 3 4 5 6 7 2 2 7 0 4 3 6 5 1 0 2 3 5 1 6 7 4 3 3 5 4 0 2 1 7 6 0 3 5 6 2 7 4 1 4 4 6 3 2 0 7 1 5 0 4 1 2 7 3 5 6 5 5 3 6 1 7 0 2 4 0 5 6 7 3 4 1 2 6 6 4 5 7 1 2 0 3 0 6 7 4 5 1 2 3 7 7 2 1 6 5 4 3 0 0 7 4 1 6 2 3 5 - The functions sc8b and m8b establish an alternate finite field over GF(n) with n=8 and can be applied in the coders and decoders as described herein. One can see that m8b is not the traditional multiplication over GF(8) and is also different from m8a.
- All neutral elements in the above addition are ‘0’ (a+(−a)=0) and in the multiplication is 1 (a*1=a).
- There are several ways to find the appropriate addition and corresponding multiplication functions by using the required properties of the functions. For instance, one may require that the addition is self reversing. In that case each column and row in the truth table of the addition is a self reversing n-state inverter. Furthermore, one may require that all additions have the
field characteristic 2 or that (a+(−a))=e, wherein e is the zero element. A requirement of a field is the existence of e so that a+e=a. This means that at least one column and row are the identity. Communitivity also limits the construction. For each row selected in a truth table the next row selection becomes more restricted as the rows and columns are symmetric around the diagonal of the truth table. - Once one has selected the rows or columns and arrange them in a commutative table, the next check is associativity. After finding a proper addition, a next step is to find a corresponding multiplication. One can limit a search for appropriate rows or columns in a multiplication truth table by first limiting all to be considered n-state inverters to the reversible inverters that are distributive with the addition. The multiplication is also commutative further limiting a search for appropriate n-state inverters. A further limitation is that none of the inverters that are considered for an addition or multiplication should have an identical symbol in an identical position.
- The earlier provided examples of alternate finite fields over GF(n) with n=8 have as neutral element ‘0’. In the 4-state case it was already shown that one can also generate an alternate finite field with neutral element ‘3’ or ‘2’ or ‘1’. The same applies for other alternate finite fields, for instance for n=8. For instance, one can construct at least one alternate finite field over GF(8) with
neutral element 5. The truth tables of the addition and multiplication that define this field are provided next. -
sc8c m8c 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 5 3 7 1 6 0 4 2 0 1 2 3 4 5 6 7 1 3 5 4 0 2 1 7 6 1 2 3 4 6 5 7 0 2 7 4 5 6 1 2 3 0 2 3 4 6 7 5 0 1 3 1 0 6 5 7 3 2 4 3 4 6 7 0 5 1 2 4 6 2 1 7 5 4 0 3 4 6 7 0 1 5 2 3 5 0 1 2 3 4 5 6 7 5 5 5 5 5 5 5 5 6 4 7 3 2 0 6 5 1 6 7 0 1 2 5 3 4 7 2 6 0 4 3 7 1 5 7 0 1 2 3 5 4 6 - The following illustrative example shows the truth tables of the addition and multiplication that define an alternate finite field GF(8) with neutral element ‘7’.
-
sc8d m8d 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 7 3 6 1 5 4 2 0 0 1 2 3 4 5 6 7 1 3 7 4 0 2 6 5 1 1 2 3 4 5 6 0 7 2 6 4 7 5 1 3 0 2 2 3 4 5 6 0 1 7 3 1 0 5 7 6 2 4 3 3 4 5 6 0 1 2 7 4 5 2 1 6 7 0 3 4 4 5 6 0 1 2 3 7 5 4 6 3 2 0 7 1 5 5 6 0 1 2 3 4 7 6 2 5 0 4 3 1 7 6 6 0 1 2 3 4 5 7 7 0 1 2 3 4 5 6 7 7 7 7 7 7 7 7 7 - The following illustrative example shows the truth tables of the addition and multiplication that define an alternate finite field GF(8) with neutral element ‘3’.
-
sc8e m8e 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 3 2 1 0 5 4 7 6 0 1 2 3 4 5 6 7 1 2 3 0 1 6 7 4 5 1 4 6 3 5 7 0 2 2 1 0 3 2 7 6 5 4 2 6 5 3 0 1 7 4 3 0 1 2 3 4 5 6 7 3 3 3 3 3 3 3 3 4 5 6 7 4 3 0 1 2 4 5 0 3 7 2 1 6 5 4 7 6 5 0 3 2 1 5 7 1 3 2 6 4 0 6 7 4 5 6 1 2 3 0 6 0 7 3 1 4 2 5 7 6 5 4 7 2 1 0 3 7 2 4 3 6 0 5 1 - The following illustrative example shows the truth tables of the addition and multiplication that define another alternate finite field GF(8) with neutral element ‘3’.
-
sc8e2 m8e2 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 3 2 1 0 6 7 4 5 0 1 2 3 4 5 6 7 1 2 3 0 1 5 4 7 6 1 4 5 3 2 7 0 6 2 1 0 3 2 7 6 5 4 2 5 6 3 7 0 4 1 3 0 1 2 3 4 5 6 7 3 3 3 3 3 3 3 3 4 6 5 7 4 3 1 0 2 4 2 7 3 5 6 1 0 5 7 4 6 5 1 3 2 0 5 7 0 3 6 1 2 4 6 4 7 5 6 0 2 3 1 6 0 4 3 1 2 7 5 7 5 6 4 7 2 0 1 3 7 6 1 3 0 4 5 2 - The above shows that there are different alternate fields based on the same addition but with different multiplications.
- In accordance with an aspect of the present invention a decoder is provided to a Reed Solomon coder that is enabled to detect at least one n-state symbol in error. A diagram of an
illustrative encoder 4000 is shown inFIG. 27 . The n-state encoder 4000 has an n-state Linear Feedback Shift Register, in this example with 2 shift register elements s1 and s2. As is known in the art this encoder can generate two n-state symbols, which is the content of the shift register after all n-state data symbols x=[x1 x2 . . . xk] have been entered into 4000. The encoder implements two n-state additions, which in this case are assumes to be identical additions over alternate finite field GF(n). The two functions may be different functions, but for illustrative purposes they are assumed to be the same. Furthermore, an inverter inv2 is included in a feedback tap and an inverter inv1 is included in the tap into the first shift register element. At least one of inv1 and inv2 is defined by a multiplication over alternate finite field GF(n). - Assume that the sequence of n-state symbols contains 4 n-state symbols [x1 x2 x3 x4], though more symbols may be entered. The shift register starts with an initial content [s1 s2]. Assume that sc is an addition ‘+’ over an alternate finite field GF(n) and inverters inv1 and inv2 are constant multipliers ‘a’ and ‘b’ in the alternate finite field. This means that all functions are associate, distributive and commutative and the ‘+’ herein is self reversing. The following table shows the calculated states of the shift register starting with [s1 s2] as x1 and x2 are entered, as developed by executing the functions that are implemented in the coder.
-
return sr1 sr2 in s1 s2 x1 + s2 a * (x1 + s2) a * (x1 + s2) b * (x1 + s2) + s1 b * (x1 + s2)+ s1 + x2 a * {b * (x1 + a * {b * (x1 + b * {b * (x1 + s2) + s1 + s2) + s1 + s2) + s1 + x2} x2) x2) + a * (x1 + s2) - One can see that the expressions in each state as the LFSR advances in processing greatly accumulate in terms. One can take at least two approaches in showing the individual states of the LFSR at each clock cycle: show the evaluated state by performing the expressions for each cycle. However, this requires the actual states of symbols. In an embodiment of the present invention one provides the coefficients of the dependent terms like s1, s2, x1, x2, x3 and x4 etc. The coefficient of a term containing for instance s1 does not depend on any other term, but only on the functions such as additions and multiplications. The end state of the shift register is then dependent on s1, s2, x1, x2, x3 and x4 and can be expressed as c1*s1+c2*s2+c3*x1+c4*x2+c5*x3+c6*x4 and can be represented as [c1 c2 c3 c4 c5 c6]. During processing a term c5*x3 can be achieved by composite processing. As an illustrative example c5*x3=(t1*x3+t2*x3)*t4. Because of properties of the functions in the alternate finite field one can simply apply multiplication and addition to calculate c5=t4*(t1+t2).
- The simplest way to represent the states of the shift register is to represent each shift register as dependent upon the variables s1, s2, x1, x2, x3 and x4. For instance the initial content of the first shift register in
FIG. 27 is s1 and does not depend on other variables. One can then represent this content as [s1 z z z z z] wherein z is the zero state. The second shift register has initial content [z s2 z z z z]. The first symbol x1 to be entered in the LFSR is then [z z x1 z z z] and so on. In the example field GF(8) with sc8e2 and m8e2 the zero element is 3. To provide a general representation of the states one can use the neutral identity state for the state of s1, s2 etc. To determine an actual state one then substitutes this actual state for the identity state. In the example field the neutral state is 0. (0*x1=x1 for instance). One can then represent s1=[0 3 3 3 3 3]; s2=[3 0 3 3 3 3]; x1=[3 3 0 3 3 3]; x2=[3 3 3 0 3 3]; x3=[3 3 3 3 0 3] and x4=[3 3 3 3 3 0]. Assume that inv2=[4 2 7 3 5 6 1 0] or b=4 and inv1=[1 4 5 3 2 7 0 6] or a=1. Starting the LFSR in initial state [0 0] and with x=[0 0 0 0] the consecutive states of the LFSR as a consequence of entering the 4 symbols is provided in the following table. -
sr element 1sr element 2s1 s2 x1 x2 x3 x4 s1 s2 x1 x2 x3 x4 initial 3 3 3 3 3 3 3 3 3 3 3 3 t = 1 3 3 1 3 3 3 3 3 4 3 3 3 t = 2 3 3 2 1 3 3 3 3 4 4 3 3 t = 3 3 3 2 2 1 3 3 3 6 4 4 3 t = 4 3 3 0 2 2 1 3 3 0 6 4 4 - The end state of the first shift register element is determined by: 3*s1+3*s2+0*x1+2*x2+2*x3+1*x4. So, if the shift register's initial state was [3 3] and x=[0 1 2 3] then the end state of the first shift register element is [3*3+3*3+0*1+2*1+2*2+1*3]=[3+3+1+5+6+3]=0.
- As a further aspect of the present invention a coder such as provided in
FIG. 27 is reversed, starting from an end state and entering the symbols of x=[x1 x2 x3 x4] in reverse order. This is shown inFIG. 28 in acoder 4100. The change compared toFIG. 27 is the reversed direction of the flow of symbols. All functions are the same (because the function sc8e2 is self reversing) and inv2 is the same as inFIG. 27 . Only the last inverter which was inv1=a is now reversed and should be inv−1 or a−1. The reverse of 1 is 6 in this field. In reverse direction the shift register starts with initial end content [s1e s2e] wherein s1e and s2e can be determined from the above step. The end state can be represented as: [s1e 3 3 3 3 3] and [3s2e 3 3 3 3] or as [0 3 3 3 3 3] and [3 0 3 3 3 3]. The symbols entered are x4=[3 3 3 3 3 x1]; x3=[3 3 3 3 x3 3]; x2=[3 3 3x2 3 3] and x1=[3 3x1 3 3 3] wherein the state of x1, x2, x3 and x4 can be set to theidentity state 0. The following table shows the states of the shift register at each clock stage in reverse order (starting from end state to t=1). -
sr element 1sr element 2s1 s2 x1 x2 x3 x4 s1 s2 x1 x2 x3 x4 t = 1 2 2 3 0 1 0 4 6 0 3 6 0 t = 2 2 0 3 3 0 1 6 0 3 0 3 6 t = 3 0 1 3 3 3 0 0 6 3 3 0 3 t = 4 1 0 3 3 3 3 6 3 3 3 3 0 end state 0 3 3 3 3 3 3 0 3 3 3 3 - All the steps as described above can easily be performed by a processor. If one performs the reverse steps (or down direction) starting with the states as determined in the forward direction (or up direction) then one will arrive at initial shift register state [3 3 3 3 3 3] and [3 3 3 3 3 3] as is to be expected.
- If no errors have occurred, all the shift register states going up have to be identical to the shift register states going down or in reverse. As a further aspect of the present invention corresponding states going up and down are compared. Because addition in the alternate finite field is identical to subtraction one may add corresponding states. The sum of corresponding states then has to be the all zero elements or [3 3 3 3 3 3]. The sum (or subtraction) of all corresponding states is shown in the following table.
-
comparative state sr1 comparative state sr2 s1 s2 x1 x2 x3 x4 s1 s2 x1 x2 x3 x4 t = 1 2 2 3 0 1 0 4 6 0 3 6 0 t = 2 2 0 1 3 0 1 6 0 4 0 3 6 t = 3 0 1 2 4 3 0 0 6 4 2 0 3 t = 4 1 0 2 5 5 3 6 3 6 2 7 0 end state 0 3 0 5 6 3 3 0 0 0 7 3 - Because it is known that all comparative states are the zero state (or
state 3 in this case) one can now determine if a received symbol was in error. One can see that each comparative state has at least one component that is instate 3. This means that no matter what state that component is, the comparative state is not influenced by the state of such component. For instance comparative state of sr1 at t=1 the comparative state is [2 2 3 0 1 0] and the symbol x1 contributes 3, so it does not depend upon x1. This also means that if x1 is received in error, then the comparative state of sr1 will still be 3 if all other symbols were correct. - As an illustrative example assume that what is received is [s1 s2 x1 x2 x3 x4]=[1 7 0 1 2 3]. Entering these states in the comparative table and evaluating the expressions will lead to:
-
evaluated comparative states sr1 sr2 t = 1 3 3 t = 2 3 3 t = 3 3 3 t = 4 3 3 end state 3 3 - One may conclude that if only one error can occur, then based on this evaluation no error has occurred.
- Assume that what is received is [s1 s2 x1 x2 x3 x4]=[1 7 7 1 2 3]. Entering these states in the comparative table and evaluating the expressions will lead to:
-
evaluated comparative states sr1 sr2 t = 1 3 5 t = 2 7 6 t = 3 0 6 t = 4 0 2 end state 5 5 - Because there are comparative states that are not 3 there is a symbol in error. Because sr1 at t=1 is
state 3 it can be determined that x1 as received is in error. - As only x1 is in error, the end state of sr1 is not in error. Recall that [s1 s2 x1 x2 x3 x4]=[1 7 7 1 2 3] was received. Thus for instance comparative state sr1 at t=4 should be 3 or: 0*s1+3*s2+0*x1+5*x2+6*x3+3*x3=3. Or: 0*x1=0*1+3*7+5*1+6*2+3*3=1+3+7+4+3=0, which was the correct state of x1.
- The outcome of the comparative states depends on the selected inverters. In one embodiment of the present invention one creates a computer program, for instance in Matlab® of The Mathworks of Natick, Mass. that implements the up and down version of an LFSR and determines the comparative states based on different inverters. Preferably at least one inverter is defined by a multiplication over the alternate finite field GF(n) and at least one function sc is defined by the alternate finite field. Based on a selected inverter one can review the comparative states and determine which configuration is most convenient to determine at least one symbol in error.
- In accordance with a further aspect of the present invention an LFSR with at least three (3) shift register elements is created to determine three check symbols and send a word of a plurality of data symbols and the at least three check symbols to a receiving device that implements the comparative states calculations as explained herein. This allows the receiving device to determine at least 2 symbols in error. How detectable symbols in error are distributed over a codeword depends on the selected inverters.
- In accordance with a further aspect of the present invention a very long sequence, much longer than the number of shift register elements, can be coded this way into a word with only two or more shift register elements. The number of comparative states will increase. However, the method as provided herein will still identify a symbol in error. At least for a small number of errors that appear in a burst of consecutive errors, the herein provided methods can be arranged to provide a fast way to determine an error location and resolve the symbols in error, for instance as compared to standard Reed Solomon methods. This is especially true for detecting one or more consecutive errors in a long sequence or even a very long sequence of symbols.
- In one embodiment of the present invention the up/down approach is applied to a sequence of binary symbols. For instance, a coder as illustrated in
FIG. 23 is a binary coder with inv1 and inv2 being identity and the ‘+’ being an implementation of a XOR function. The following table shows the comparative state table for this coder with an input of a sequence of 4 bits and an initial shift register state [0 0]. -
comparative state sr1 comparative state sr2 s1 s2 x1 x2 x3 x4 s1 s2 x1 x2 x3 x4 t = 1 1 1 0 1 1 0 1 0 1 0 1 1 t = 2 1 0 1 0 1 1 0 1 1 1 0 1 t = 3 0 1 1 1 0 1 1 1 0 1 1 0 t = 4 1 1 0 1 1 0 1 0 1 0 1 1 end state 1 0 1 0 1 1 0 1 1 1 0 1 - One is reminded that 0 herein means that that symbol does not contribute to the state and 1 means it does. For t=1 one can thus express the two comparative states as sr1→(s1≠s2≠x2≠x3) and sr2→(s1≠x1≠x3≠x4). This means that if bit x1 is in error sr1 will be 0 but sr2 will be 1.
- A similar result can be achieved for binary coders with 3 or more shift registers and with binary coders wherein at least one implementation of an EQUAL (=) function or an XOR function with an inverter [1 0] is used.
- The above methods for error location and error correction also apply to alternate finite fields for n is smaller than 8. One example is n=4. The following provides an addition and a multiplication over an alternate finite field GF(4).
-
sc4 0 1 2 3 m4 0 1 2 3 0 3 2 1 0 0 1 2 3 1 2 3 0 1 1 2 0 3 2 1 0 3 2 2 0 1 3 3 0 1 2 3 3 3 3 3 - Using the configurations of
FIGS. 27 and 28 and inv1=[2 0 1 3] or a=2 and inv2=[0 1 2 3] or b=0 and a−1=1, will provide the following comparative states. -
comparative states sr1 comparative states sr1 s1 s2 x1 x2 x3 x4 s1 s2 x1 x2 x3 x4 t = 1 3 0 3 0 1 0 1 1 0 3 1 2 t = 2 0 0 2 3 0 1 1 2 0 0 3 1 t = 3 0 1 2 2 3 0 2 1 1 0 0 3 t = 4 1 0 0 2 2 3 1 3 0 1 0 0 end state 0 3 2 0 2 2 3 0 3 0 1 0 - The state corresponding to t=1 is the initial state. In an example this state should be [3 3]. Assume that a word [s1 s2 x1 x2 x3 x4]=[1 2 3 1 2 0] was received. The evaluated comparative states based on the received word are:
-
evaluated comparative states sr1 sr2 t = 1 3 2 t = 2 1 2 t = 3 1 0 t = 4 2 2 end state 1 3 - From the earlier individual components based comparative states one can see that for t=1 (wherein the comparative state of sr1 is 3) that comparative state sr1 does not depend upon x1, while the other comparative states do. As a check one can also see that the same is the case for the end state of sr2. Accordingly x1 is in error. And one can solve, as before, x1 by solving for instance the expression that determines the comparative end state for sr1. The expression is 0*s1+3*s2+2*x1+0*x2+2*x3+2*×4=3. Or 2*x1=0*s1+3*s2+0*x2+2*x3+2*x4. The word [1 2 3 1 2 0] was received or: 2*x1=0*1+3*2+0*1+2*2+0*0=1+3+1+1+1=3. Or x1=2−1*3=3. Thus x1=3.
- In the above alternate finite fields of order n=2p have been disclosed. As illustrative examples self reversing additions over such fields have been provided. As is known to one of ordinary skill a field can also be over n is an odd number. In particular prime fields wherein n is prime or Zn are of interest. These and other fields are of interest in certain coders such as Elliptic Curve Coders. In many of these cases the ‘normal’ field is usually defined by using the modulo-n addition and the modulo-n multiplication. In accordance with an aspect of the present invention an alternate finite field is created over GF(n) wherein n is prime. As an example an alternate finite field over GF(5) is provided that is defined by the following addition and multiplication.
-
sc5a 0 1 2 3 4 m5a 0 1 2 3 4 0 1 2 3 4 0 0 1 2 3 4 1 2 3 4 0 1 1 3 0 2 4 2 3 4 0 1 2 2 0 3 1 4 3 4 0 1 2 3 3 2 1 0 4 4 0 1 2 3 4 4 4 4 4 4 - The functions sc5a is commutative, associative, it has a ‘0’ element (4) so that “
x sc5a 4=x” and it is distributive with m5a which has a zeroelement 4 and a neutral element ‘0’ and which function is also commutative and associative. Furthermore, each multiplier has an inverse that is also in the alternate finite field: 0 has itself as inverse, the inverse of 1 is 2, the inverse of 2 is 1, and the inverse of 3 is 3. - The following table provides an addition and multiplication that establish an alternate finite field GF(5).
-
sc5b 0 1 2 3 4 m5b 0 1 2 3 4 0 2 3 4 0 1 0 1 2 3 4 1 3 4 0 1 2 1 0 4 3 2 2 4 0 1 2 3 2 4 1 3 0 3 0 1 2 3 4 3 3 3 3 3 4 1 2 3 4 0 4 2 0 3 1 - Each multiplier has an inverse in the field: 0 is the identity; 1 is self reversing; 2 has 4 as inverse and 4 has 2 as inverse.
- Other alternate finite fields over GF(5) can also be constructed with 0 as identity element and 1 or 2 as the neutral element.
- The following tables provides additions and multiplications that establish an alternate finite field over GF(7).
-
sc7a 0 1 2 3 4 5 6 m7a 0 1 2 3 4 5 6 0 1 2 3 4 5 6 0 0 1 2 3 4 5 6 1 2 3 4 5 6 0 1 1 3 5 0 2 4 6 2 3 4 5 6 0 1 2 2 5 1 4 0 3 6 3 4 5 6 0 1 2 3 3 0 4 1 5 2 6 4 5 6 0 1 2 3 4 4 2 0 5 3 1 6 5 6 0 1 2 3 4 5 5 4 3 2 1 0 6 6 0 1 2 3 4 5 6 6 6 6 6 6 6 6 - All multipliers are also in the alternate finite field.
- The following tables also establish an alternate finite field GF(7).
-
sc7b 0 1 2 3 4 5 6 m7b 0 1 2 3 4 5 6 0 6 0 1 2 3 4 5 0 1 2 3 4 5 6 1 0 1 2 3 4 5 6 1 1 1 1 1 1 1 2 1 2 3 4 5 6 0 2 1 0 6 5 4 3 3 2 3 4 5 6 0 1 3 1 6 4 2 0 5 4 3 4 5 6 0 1 2 4 1 5 2 6 3 0 5 4 5 6 0 1 2 3 5 1 4 0 3 6 2 6 5 6 0 1 2 3 4 6 1 3 5 0 2 4 - Again, all multipliers not being the zero element have an inverse in the field. The following 3-valued or ternary function establishes a standard finite field GF(3).
-
sc3 0 1 2 m3 0 1 2 0 0 1 2 0 0 0 1 1 2 0 0 1 2 2 2 0 1 0 2 1 - One can easily check that the following 3-valued or ternary functions also establish an alternate finite field.
-
sc3a 0 1 2 m3a 0 1 2 0 1 2 0 0 1 2 1 2 0 1 1 0 2 2 0 1 2 2 2 2 -
sc3b 0 1 2 m3b 0 1 2 0 2 0 1 0 1 2 1 0 1 2 1 1 1 2 1 2 0 2 1 0 - One can generate the states for an n-state extension field with n=32 with a 2-state LFSR with one of the above 3-state additions and an inverter being one of the inverters in the field in a sequence generator as shown in
FIG. 32 . For instance with sc being sc3b and inv1 is [0 1 2] and inv2=[2 1 0] as defined by m3b. The following table shows the addition and multiplication over GF(9) that can be generated from this. -
sc9 0 1 2 3 4 5 6 7 8 m9 0 1 2 3 4 5 6 7 8 0 0 1 2 3 4 5 6 7 8 0 0 0 0 0 0 0 0 0 1 1 5 8 4 6 0 3 2 7 0 1 2 3 4 5 6 7 8 2 2 8 6 1 5 7 0 4 3 0 2 3 4 5 6 7 8 1 3 3 4 1 7 2 6 8 0 5 0 3 4 5 6 7 8 1 2 4 4 6 5 2 8 3 7 1 0 0 4 5 6 7 8 1 2 3 5 5 0 7 6 3 1 4 8 2 0 5 6 7 8 1 2 3 4 6 6 3 0 8 7 4 2 5 1 0 6 7 8 1 2 3 4 5 7 7 2 4 0 1 8 5 3 6 0 7 8 1 2 3 4 5 6 8 8 7 3 5 0 2 1 6 4 0 8 1 2 3 4 5 6 7 - One way to generate an alternate field over GF(9) is to for instance determine that the new ‘zero’ or neutral element of the alternate field is 5. This means that ‘a+5=a’ or: the row and column corresponding to
element 5 should be [0 1 2 3 4 5 6 7 8]. A way to achieve that is to invert the whole truth table of sc9 with the inverse of the column or row ofelement 5 because 5−1(5)=e. This means that the new column ofelement 5 in the inverted truth table should be [5 0 7 6 3 1 4 8 2]−1=[1 5 8 4 6 0 3 2 7]. The functions sc9a generated by inverting sc9 with the above inverter will create: -
sc9a 0 1 2 3 4 5 6 7 8 m9a 0 1 2 3 4 5 6 7 8 0 1 5 8 4 6 0 3 2 7 0 1 2 3 4 5 6 7 8 1 5 0 7 6 3 1 4 8 2 1 0 3 2 7 5 8 4 6 2 8 7 3 5 0 2 1 6 4 2 3 1 0 8 5 4 6 7 3 4 6 5 2 8 3 7 1 0 3 2 0 1 6 5 7 8 4 4 6 3 0 8 7 4 2 5 1 4 7 8 6 2 5 0 3 1 5 0 1 2 3 4 5 6 7 8 5 5 5 5 5 5 5 5 5 6 3 4 1 7 2 6 8 0 5 6 8 4 7 0 5 3 1 2 7 2 8 6 1 5 7 0 4 3 7 4 6 8 3 5 1 2 0 8 7 2 4 0 1 8 5 3 6 8 6 7 4 1 5 2 0 3 - One should first check if sc9a is associative. One can create m9a by first setting column and row of 5 to all 5 (as this is now the neutral element). Furthermore, one can determine all reversible 9-state inverters that are distributive with sc9a and construct the truth table m9a from the compliant inverters. A simple computer program will demonstrate that sc9a and m9a are distributive. There is a zero element, the multiplication has an identity (0), all non-zero elements in the field have an inverse that is also in the field, the functions are commutative. Accordingly, sc9a and m9a establish an alternate finite field GF(9). Other alternate finite fields can be constructed in a similar way.
- Galois Field (or finite field) arithmetic is widely used in cryptography. The applied fields can be for instance a field GF(p) with p being prime, or extension fields GF(pm) with p being prime and m>1, wherein p preferably is 2, or composite fields GF((pm)r) with p being prime and m and r>1, or a prime field such as a Mersenne prime field GF(n) with n≈pm and preferably n≈2m. For instance Odd Characteristic Extension Fields including Optimal Extension Fields are known that are defined over GF(n)=GF(2m±c) as disclosed for instance in U.S. Pat. No. 7,069,287 issued on Jun. 27, 2006 to Paar et al. which is incorporated herein by references. One application of finite field arithmetic is in Elliptic Curve cryptography, wherein product symbols based on an elliptic curve over a finite field is generated from the to be coded symbols and random numbers. How to apply a Galois Field in elliptic curve cryptography is also disclosed in U.S. Pat. No. 5,351,297 issued on Sep. 27, 1994 to Miyaji et al. which is incorporated herein by reference. The use of binary fields or binary extension fields in elliptic curve cryptography is disclosed in U.S. Pat. No. 6,721,771 issued on Apr. 13, 2004 to Chang which is incorporated herein by reference. It has been shown already above that alternate finite fields exists for binary, binary extension fields and prime fields and prime extension finite fields. Any field (if it is a traditional or an alternate field) as is known in the art has a minimal set of common properties. However, where at least one class of alternate finite fields differ from traditional finite fields is that the neutral or ‘zero’ element is not 0. Name the neutral element ‘e’ and ‘a’ is any element in a finite field not being ‘e’ then ‘e’ is defined as ‘a+e=a’ with ‘+’ being the addition over the field and wherein the neutral element ‘e’ is not 0 in at least one class of alternate finite fields. A parallel definition in the alternate finite field is related to the multiplication “*” over the finite field. Herein ‘e*a=e’ for all states of ‘a’ including all states not being ‘e’ and wherein ‘e’ is not ‘0’. As the same field properties to traditional finite fields apply to alternate finite fields one may define an elliptic curve over an alternate finite field and develop the cryptography over that elliptic curve in a similar way as in the traditional finite field but now by applying the alternate finite field. In general one applies finite field arithmetic by using a modulo-polynomial calculation. However, a much faster way is to either store the truth table or calculate the elements of the truth table from a known inversion as was explained above. This allows for very fast calculations in binary logic if one so desires. Thus an embodiment is provided of an elliptic curve encoder and a corresponding decoder that applies addition and multiplication (and division when required) over an alternate finite field.
- An encoder is provided that modifies the statistical distribution of symbols in a coded message as disclosed in U.S. Pat. No. 7,659,838 issued on Feb. 9, 2010 to Lablans, which is incorporated herein by reference. In one embodiment of the present invention as illustrated in
FIG. 34 acoder 3400 with acorresponding decoder 3401 is provided. Theencoder 3400 in one embodiment of the present invention has afirst coding stage 3402 in accordance with an encoding method as herein provided an using at least an implementation of an addition over an alternate finite field and preferably an addition over an alternate finite field and an inverter defined by a multiplication over an alternate finite field with an input sequence of symbols In, that generates a sequence Int of symbols. Sequence Int is provided to anencoding state 3403 which modifies the statistical distribution of symbols without changing the number of symbols to generate sequence Outc. For decoding by a decoder 3401 a received sequence Outc is provided ondecoding stage 3404 which reverses 3403 to generate Int with the previous statistical distribution of symbols which is provided todecoding stage 3405 which reversesencoder 3402 to generate original sequence In. An encoding step may be preceded or succeeded by signal processing including modulation, demodulation, detection, amplification or other signal processing as is known in the art.FIG. 35 illustrates anencoder 3500 wherein 3502 performs modification of statistical distribution of symbols and 3503 performs an encoding process in accordance with a method as provided herein using at least an implementation of an addition over an alternate finite field and preferably an addition over an alternate finite field and an inverter defined by a multiplication over an alternate finite field.FIG. 35 also illustrates adecoder 3501 with 3504 reversing 3503 and 3505 reversing 3502. - The above approaches also apply to the generation of other classes of alternate fields GF(qp) with q≧2 and p≧1 or p≧2.
- An alternate finite field GF(n) is not a classical finite field. The existing literature in Field Theory uses in general 0 as the neutral element or as the zero element ‘e’ of a field so that ‘a+e=e’. At least one class of an alternate finite field GF(n) herein is defined as the field GF(n) defined by the addition scn wherein an element not represented by the
field element 0 is the neutral element and by a corresponding multiplication. It is noted that a field can be defined by a single addition and one of a plurality of possible multiplications. - In accordance with an aspect of the present invention an implementation of at least one addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>3 is applied in an encoder as provided herein.
- In accordance with an aspect of the present invention an implementation of at least one addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>3 is applied in an encoder as provided herein.
- In accordance with an aspect of the present invention an implementation of at least one addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>4 is applied in an encoder as provided herein.
- In accordance with an aspect of the present invention an implementation of at least one n-state function which is defined by a truth table that is a reduction of an addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n≧3 is applied in an encoder as provided herein.
- In accordance with an aspect of the present invention an implementation of at least one n-state function which is defined by a truth table that is a reduction of an addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n≧3 is applied in an encoder as provided herein.
- In accordance with an aspect of the present invention an implementation of at least one n-state function which is defined by a truth table that is a reduction of an addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>3 is applied in an encoder as provided herein.
- In accordance with an aspect of the present invention an implementation of at least one n-state function which is defined by a truth table that is a reduction of an addition over an alternate finite field GF(n) and at least one inverter defined by a multiplication over an alternate finite field GF(n) with n>4 is applied in an encoder as provided herein.
- In accordance with an aspect of the present invention an alternate binary finite field is defined by an addition being the EQUAL (or =) function and a multiplication being the NAND function. Extension fields created from the EQUAL and the NAND function from primitive or minimal polynomials may also be called alternate finite fields. However, they may also be considered as a different type of alternate finite field compared to those that cannot be generated from primitive or minimal polynomials only.
- In accordance with an aspect of the present invention an encoder that is provided in accordance with an aspect of the present invention is provided with a corresponding decoder.
- In accordance with an embodiment of the present invention an encoder and a corresponding decoder use at least an implementation of an addition over an alternate finite field GF(n). In such an embodiment inverters may be used or the addition may be modified in accordance with an inverter. In a further embodiment an inverter defined by a multiplication defining the alternate finite field GF(n) is required or an implementation of an addition in accordance with an inverter over the alternate finite field is required.
- In some cases only illustrative examples of a 4-state or an 8-state or an n-state encoder and or decoder is provided. It is fully contemplated that similar encoders and decoders in any of the alternate finite fields GF(n) can easily be constructed by one of ordinary skill without undue experimentation. Any additional effort may come from the increased number of states of GF(n>n1) if n1 is greater than n and not from different principles.
- In accordance with a further aspect of the present invention the here provided methods of encoding and decoding are used in a system, such as a communication system. Such a communication system may be a wired system or a wireless system. Such a system may be used for data transmission, telephony, video or any other type of transfer of information. A diagram of such a system is provided in
FIG. 29 . Herein 1101 is a source of information. The information is provided to acoder 1102. The information provided to acoder 1102 may already be in a digital form. It may also be converted into digital form by thecoder 1102. Thecoder 1102 creates the coded symbols in a signal. The codewords are organized in such a way that up to a number of symbols in error can be identified as such. The thus created codewords may be provided directly to atransmission medium 1103 for transmission. They may also be provided to a modulator/transmitter 1106 that will modify the digital coded signal provided by 1102 to a form that is appropriate for the medium 1103. Forinstance 1106 may create an optical signal or an electrical signal.Modulator 1106 may also be a radio transmitter, which will modulate the signal on for instance a carrier signal, and wherein 1103 is a radio connection. - At the receiving side a
receiver 1107 may receive, amplify, and demodulate the signal coming from 1103 and provide a digital signal to adecoder 1104. Thedecoder 1104 applies the methods provided herein to decode symbols including correcting symbols in error. A decoded and/or error corrected signal is then provided to atarget 1105. Such a target may be a radio, a phone, a computer, a tv set or any other device that can be a target for an information signal. Acoder 1102 may also provide additional coding means, for instance to form a concatenated or combined code. Additional information, such as synchronization or ID information, may be inserted during the transmission and/or coding process. - In accordance with another aspect of the present invention the here provided methods and apparatus for coding including error correcting coding and decoding including error correcting decoding of signals can also be applied for systems and apparatus for storage of information. For instance data stored on a CD, a DVD, a magnetic tape or disk or in mass memory in general may benefit from error correcting coding. A system for storing symbols coded in accordance with an aspect of the present invention is shown in diagram in
FIG. 30 . Asource 1201 provides the information to be coded. This may be audio, video or any information data. The data may already be presented in n-valued symbols by 1201 or may be coded in such a form by 1202.Unit 1202 may create code words of a plurality of data symbols with added check symbols as described herein as another aspect of the present invention. The thus created coded symbols may be provided directly to achannel 1204 for transmission to aninformation carrier 1205. Theinformation carrier 1205 may be an optical disk, an electro-optical disk, a magnetic disk, a magnetic tape, a flash memory device or any other device or medium that can store information. In general a modulator/data writer 1203 will be required to write a signal to acarrier 1205. For instance the channel may require optical signals, electrical signals or it may require magnetic or electro-magnetic or electro-optical signals. Modulator/data writer 1203 will create a signal that can be written viachannel 1204 to acarrier 1205. Additional information such as for ID and/or synchronization may be added to the data. -
FIG. 31 shows a diagram for decoding information read from acarrier 1305. The information is read through a channel 1304 (such as an optical channel or electrical or magnetic or electro-magnetic or electro-optical channel) and provided in general to adetector 1303 that will receive and may amplify and/or demodulate the signal. The signal is then provided to adecoder 1302. The information signal, possibly readied for presentation as an audio or video signal or any other form is then provided to a target. The target may be a video screen, a compute, a radio or any other device that can use the decoded signal. - The methods and apparatus here provided can be implemented using a general processor, a dedicated signal processor or customized logic. N-valued symbols may be processed as binary words, being created from n-valued symbols by Analog/Digital converters. After being processed n-valued signals may be created from binary words by applying Digital/Analog converters. Switching functions may be created as customized n-valued circuits. For instance U.S. Pat. No. 6,133,754 by Olson, issued Oct. 17, 2000 entitled “Multiple-valued logic circuit architecture; supplementary symmetrical logic circuit structure (SUS-LOC)” discloses embodiments of n-valued CMOS switches. In U.S. patent application Ser. No. 11/000,218 filed Nov. 30, 2004 entitled “Single and composite binary and multi-valued logic functions from gates and inverters” which is incorporated herein by reference in its entirety, it is shown how n-valued logic circuits can be created. N-state logic embodiments, for instance using look-up tables are also contemplated.
- It has been shown in for instance U.S. Published Patent Publication Ser. No. 2007009160 to Lablans published on May 3, 2007 which is incorporated herein by reference in its entirety that an LFSR, with may be part of a scrambler or a descrambler is implemented in an addressable memory and using an implementation of an n-state switching function. In one embodiment of the present invention an LFSR implemented with an addressable memory applies an implementation of an addition over an alternate finite field, or an implementation of an addition over an alternate finite field and an inverter defined by a multiplication over an alternate finite field, or an implementation of a single truth table of an addition over an alternate finite field modified by an inverter defined by a multiplication over an alternate finite field.
- In some encipherment applications security comes from large finite fields GF(n), preferably with n being prime and in certain cases with n≈2P to facilitate binary execution. Elliptic Curve Coding coders and AES coders are an example of that. In accordance with an aspect of the present invention instead of n being a large prime, n can be a much smaller integer but with many different alternate finite fields are used. For instance n=251 (which can be represented by 8 bits) has hundreds of alternate finite fields. Furthermore, there are different alternate finite fields having the same addition but different multiplications as was shown herein. In a coder and a decoder instead of one large finite field or one large alternate finite field many different smaller alternate finite fields are applied. And rather than calculating a state in a finite field by applying complex Galois field or polynomial arithmetic the states are stored in an addressable memory, which makes processing much faster. Additional security is introduced by determining which alternate finite field to apply for instance based on a key or a pseudo-random sequence of symbols. In a further embodiment of the present invention, the order of alternate finite fields is changed per message, per time period or by any other pre-determined parameter that can be synchronized between sender and receiver.
-
FIG. 32 illustrates a processor in accordance with an aspect of the present invention. Aprocessing unit 50000 is provided to process at least binary words that represent an n-state symbol. The processing unit may also implement circuitry that implements n-state logic tables. The processing unit has at least one input/control port to provide the processing units directly with input and/or control signals. The processing unit may also have a communication port to receive external data. While the processing unit may have its own internal memory, preferably it is bi-directionally connected to amemory 50001 to store and retrieve data and instructions. The memory may work in binary mode or as a non-binary memory. If the memory is a binary memory then if non-binary symbols are provided as non-binary signals a converter such as an A/D 50002 converts non-binary signals to binary words that are stored in 50001. The processing unit process the n-state symbols in accordance with the herein provided encoding and/or decoding methods over an alternate finite field GF(n) and provides the result on an output. If the processing unit operates on binary words a converter such as a D/A converter 50003 generates non-binary signals from the binary words. - It is again noted that a finite field and an alternate finite field are defined by an addition and a multiplication. In one embodiment of the present invention it is a requirement that an encoder or a corresponding decoder applies at least an implementation of an addition over an alternate finite field. This automatically requires that a multiplication over the alternate finite field also exists, even if such multiplication or an inverter defined by such multiplication is not used. This means that an addition over a classical field GF(6) does not exist. Such an addition conceivably would be a modulo-6 addition. However, no set of multiplications in combination with the modulo-6 addition exists to create a finite field. Accordingly, an addition over a finite field, be it a classical field or a class of alternate fields, requires a corresponding multiplication.
- As an example of a small alternate finite field that defines a group over an elliptic curve an illustrative example will be provided for n=8 which will be applied to an example as provided on the website of Certicom® of Mississauga, Canada with URL of pages <URLwww.certicom.com/index.php/44-quiz-3> and <URLwww.certicom.com/index.php/44-quiz-3—solutions>. The page defines a field GF(8) defined by the polynomial x3+x+1 and provides an elliptic curve y2+xy=x3+g2x2+g6. Rather than working in binary represented states, the truth table of classical addition and multiplication over this field can be provided as follows:
-
sc8clas 0 1 2 3 4 5 6 7 m8clas 0 1 2 3 4 5 6 7 0 0 1 2 3 4 5 6 7 0 0 0 0 0 0 0 0 1 1 0 4 7 2 6 5 3 0 1 2 3 4 5 6 7 2 2 4 0 5 1 3 7 6 0 2 3 4 5 6 7 1 3 3 7 5 0 6 2 4 1 0 3 4 5 6 7 1 2 4 4 2 1 6 0 7 3 5 0 4 5 6 7 1 2 3 5 5 6 3 2 7 0 1 4 0 5 6 7 1 2 3 4 6 6 5 7 4 3 1 0 2 0 6 7 1 2 3 4 5 7 7 3 6 1 5 4 2 0 0 7 1 2 3 4 5 6 - The curve then should be written as y2+xy=x3+3x2+7. One can easily check that the following points in the field lie on the curve: (2,0) and (2,2), (4,5) and (4,7) and (0,4) as was provided in the Certicom® example. The points (1,0) and (1,1), (6,0) and (6,6) among others also lie on the curve. The coordinates of 2P of P=(4,1) can be determined as (5,2). As the correct solution for developing 2P one should apply the formula yR=s(xP+xR)+xR+yP, which leads to 2P=(5,2).
- In an alternate scenario one uses the alternate finite field defined by:
-
sc8e2 0 1 2 3 4 5 6 7 m8e2 0 1 2 3 4 5 6 7 0 3 2 1 0 6 7 4 5 0 1 2 3 4 5 6 7 1 2 3 0 1 5 4 7 6 1 4 5 3 2 7 0 6 2 1 0 3 2 7 6 5 4 2 5 6 3 7 0 4 1 3 0 1 2 3 4 5 6 7 3 3 3 3 3 3 3 3 4 6 5 7 4 3 1 0 2 4 2 7 3 5 6 1 0 5 7 4 6 5 1 3 2 0 5 7 0 3 6 1 2 4 6 4 7 5 6 0 2 3 1 6 0 4 3 1 2 7 5 7 5 6 4 7 2 0 1 3 7 6 1 3 0 4 5 2 - One curve is defined as y2+xy=x3+x2+4. The terms without coefficient actually have coefficient 0 in accordance with the field and the curve over the alternate finite field is 0*y2+0*xy=0*x3+0*x2+4. Points in the alternate finite field that lie on the curve are: (0,5) and (0,7); (1,0) and (1,2); (4,1) and (4,5) and (3,1). These points are generated by evaluating all points of the finite field and checking if they are one the curve. One can easily check that for all generated points on the curve (−P)=(xP, xP+yP) when P=(xP, yP) wherein ‘+’ is sc8e2. Determining 2P when P is (4,1) using the proper addition and multiplication rules over the alternate finite field will lead to: 2P=(0,6). Accordingly, it has been shown that the calculations as required for elliptic curve coding in a finite field can also be performed in an alternate finite field.
- In one embodiment of the present invention an encoder or a decoder includes an implementation of a multiplication over an alternate finite field. If a constant multiplier or an equivalent inverter is required one can provide a constant input symbol on at least one input of such a multiplication which then in effect implements a constant multiplier.
- It has been provided above that alternate finite fields with zero-elements not being 0 can be applied for instance in coding, decoding, encryption and decryption purposes in accordance with one or more aspects of the present invention. A test for an alternate finite field GFa(n) is to check the existence of a zero-element z, so that z+i=i and z*i=z, for each element i of the alternate finite field and a neutral element e exits so that e+e=z and e*i=e for each element of the alternate finite field and all associative and distributive properties apply in the alternate finite field. For instance (i1+i2)+i3=(i1+i3)+i2; (i1*i2)*i3=(i1*i3)*i2; and i3*(i1+i2)=i3*i1+i3*i2, wherein ‘+’ and ‘*’ are the addition and the multiplication over the alternate finite field.
- It would be beneficial if a large number of alternate finite fields can be generated at will. This allows for instance n-state symbols to be generated in a code or for encryption to apply one of different alternate finite fields. Correct decoding and/or decryption then requires application of the same alternate finite field, which contributes to security of a code or encryption. It is noted that alternate finite fields are isomorphic to the finite fields that are for instance extension fields or composite fields. By having a different zero element in different alternate finite fields, there is no clear bijection between field elements. In other words, one cannot simply try different field element substitutions to find an alternate finite field.
- In accordance with an aspect of the present invention a method is provided to create a plurality of different alternate finite fields from a given finite field. The steps of such a method are illustrated in
FIG. 36 . One uses an n-state reversible inverter ‘inv1’. For instance a finite field over GF(8) can be modified to an alternate finite field GFa(8). - The inverter ‘rinv1’ that inverts ‘inv1’ back to identity must also be determined. For instance one can generate all 8-state 40320 reversible inverters, including identity. Select one inverter ‘inv1’ for instance inv1=[5 7 1 2 4 3 0 6] as illustrated in
step 3601. Determine the reversing 8-state inverter ‘rinv1’ from ‘inv1’ as illustrated instep 3603. The inversion of the above example is rinv1=[6 2 3 5 4 0 7 1]. - In accordance with
steps - The steps are further illustrated by
FIG. 37 . A function ‘fn’ which can be the addition or the multiplication over GF(n) are implemented in acircuit 3701, which can be a memory. The circuit has two inputs, 3703 and 3705 which each include the inverter ‘inv1’. The signals i1 and i2 are provided the inputs. The signals i1 and i2 represent a symbol in GF(n). A resulting signal representing a symbol is output onoutput 3707 which is inverted by inverter ‘rinv1’ and is for instance stored on amemory 3709. Other implementations are possible. The output symbol is associated with input (i1,i2), so that the stored data represents the addition or multiplication over GFa(n) depending on what ‘fn’ was stored on 3701. The system ofFIG. 37 runs through all n2 possible combinations of (i1,i2). - An example is illustrated in
FIGS. 38 and 39 .FIG. 38 illustrates a truth table of an addition and multiplication over GF(8). The truth tables of the addition and multiplication over an alternate finite field GFa(8) in accordance with 8-state inverter inv1=[5 7 1 2 4 3 0 6] and related inverted inverter invr=[6 2 3 5 4 0 7 1] are illustrated inFIG. 39 and are derived from the truth tables provided inFIG. 38 . - There are thus 40,319 different alternate finite fields that can be generated from a single finite field over GF(8). The number of possible reversible n-state inverters depends on n! (n factorial). That means that for GF(256) one can find over 10100 or over a googol of alternate finite fields. In accordance with an aspect of the present invention a first n-state symbol is generated or transformed using an addition and a multiplication over a first alternate finite field GFa(n) and a second n-state symbol is generated or transformed using an addition and a multiplication over a second alternate finite field GFa(n). A receiver is familiar with which alternate fields are applied and applies or recovers the first and the second n-state symbols. In accordance with an aspect of the present invention at least one alternate finite field has a zero element not being zero. In accordance with an aspect of the present invention at least both alternate finite fields have a zero element not being zero.
- In accordance with one or more aspects of the present invention, the addition and multiplication over an alternate finite field GFa(n) with n>2 are applied in one or more of the applications, inventions or embodiments enclosed herein or incorporated herein by reference, including but not limited to n-state methods and devices with n>3 or with n>7: scramblers and descramblers, shift register based scramblers and descramblers, LFSRs, sequence generators, Gold sequence generators, sequence detectors, correlation circuits, convolutional coders and decoders, Reed-Solomon coders or any other error-correcting coder and decoder, encryption and decryption devices and Galois Field arithmetical methods and devices.
- In one embodiment of the present invention, an addition and a multiplication over an n-state alternate finite field GFa(n) are generated from an addition and multiplication of a given finite field GF(n). A given finite field may be an extension field, such as a binary extension field indicated by GF(n=2k). Elements of such an extension fields and their order can be determined by using a binary LFSR of k shift register elements determined by a primitive polynomial of degree k. The addition of two elements over such an extension field can be determined by individual XORing of the bits in the binary representation of two n-state elements. The multiplication can be determined by shifting (n−1) elements as shown in the multiplication table of
FIG. 38 . Such a finite field may be called a given or standard finite field. A multiplication of such a given finite field may also be derived from a true binary multiplication. - In one embodiment of the present invention the alternate finite field is determined relative to the given finite field by the method depicted in
FIG. 36 and the apparatus ofFIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity. - In one embodiment of the present invention the alternate finite field is determined relative to the given finite field by the method depicted in
FIG. 36 and the apparatus ofFIG. 37 wherein an inverter inv1 is a multiplication over the given field except the n-state inverter being the identity. - In one embodiment of the present invention the alternate finite field is determined relative to the given finite field by the method depicted in
FIG. 36 and the apparatus ofFIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity and except any n-state inverter that inverts 0 to 0. - In one embodiment of the present invention the alternate finite field is determined relative to the given finite field by the method depicted in
FIG. 36 and the apparatus ofFIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity and except any n-state inverter that inverts any of the n-states into the same n-state. - In one embodiment of the present invention the alternate finite field is determined relative to the given finite field by the method depicted in
FIG. 36 and the apparatus ofFIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity and except any n-state self reversing inverter. - In one embodiment of the present invention the alternate finite field is determined relative to the given finite field by the method depicted in
FIG. 36 and the apparatus ofFIG. 37 wherein an inverter inv1 is an n-state self-reversing inverter except the n-state inverter being the identity. - In one embodiment of the present invention the alternate finite field is determined relative to the given finite field by the method depicted in
FIG. 36 and the apparatus ofFIG. 37 wherein an inverter inv1 is any of the n-state reversible inverters except the n-state inverter being the identity and the n-state inverter that inverts 0 to 0 but are not a multiplication over the given finite field. - The inventor has provided in earlier cited U.S. patent application Ser. No. 13/846,296 a novel type of shift register based coders, scramblers and decoders and descramblers that are provided with a second sequence of external data, as a key sequence. In another embodiment thereof, the scramblers can be operated in a public and a private mode. In accordance with an aspect of the present invention the shift register based devices and methods are implemented using at least one addition and one multiplication over an alternate finite field GFa(n).
- It is noted that all n-state finite fields are isomorphic. It is common to define a binary extension field based on the XOR or modulo-2 addition. For reference purposes a given finite field may (but is not required) to be related to a modulo-n addition if n is prime or to a modulo-p addition if n=pk or if n is a composite field wherein n is factorized in p. All modulo-k additions (and multiplications) have 0 as the zero-element. This is useful to distinguish between a given finite field and an alternate finite field. One should be aware that there are thus alternate fields with the zero element being 0, but wherein no relation or no direct relation exists with modulo-n or modulo-p addition.
- Finite field functions are presently implemented in XOR functions. In accordance with an aspect of the present invention one or more functions over an alternate finite field, be it an addition, a multiplication or a multiplier modified addition are retrievably stored in a physical memory device, wherein each element in a table can be addressed and retrieved. A memory device can be an electrical device, an optical device, a magnetic device or any other device that is configured to store an n-state truth table and wherein each n-state symbol can be stored, addressed and retrieved.
- A division over a finite field is the reverse of a multiplication over that field. It has been show earlier and it can be easily checked that a constant multiplier over a finite field can be represented by its equivalent n-state inverter, for instance represented by the corresponding column or row in the truth table of the multiplication. A division is a reversal of a multiplication. A constant division can also be represented by its equivalent n-state inverter, for instance represented by the corresponding column or row in the truth table of the multiplication. That is: the reversing inverter of a multiplication is also a row or a column in the truth table of the multiplication. Accordingly, a multiplication over a finite field also defines a division over a finite field. Similarly, an addition over a finite field also defines a subtraction over the finite field.
- Many coders and encryption devices, including processors configured to perform coding and encryption as well as decoding and decryption, apply finite field arithmetic, which is also known as galois field arithmetic. In accordance with an aspect of an aspect of the present invention an alternate galois field arithmetic device is provided that performs a galois field addition and a multiplication, or a galois field addition and a division, or a galois field subtraction and a multiplication, or a galois field subtraction and a division over an alternate finite field wherein a zero element is not 0. Because all finite field arithmetical rules apply to operations over an alternate finite field a valid result will be generated. However, that result will include an n-state symbol that is different then if the galois field operation was operated with a standard finite field.
- In a further embodiment of the present invention the alternate galois field arithmetic device is applied in error correcting coding and decoding, error detection and encryption and decryption.
- In one embodiment of the present invention alternate finite field addition, and/or subtraction and/or multiplication and/or division are applied to process a sequence of n-state symbols with n>2, n>3 and n>7. A sequence herein is a sequence of at least n-state symbols, if needed represented in bits. In one embodiment of the present invention, a sequence includes at least two words of n-state symbols. A processor processes in that case a word as a block. In one embodiment of the present invention a processor processes a sequence of n-state symbols continuously, or in a streaming manner.
- In accordance with an aspect of the present invention a device such as a processor, a coder, a decoder, an encryption or decryption device applies functions of different alternate finite fields to process a sequence of n-state symbols. That is: a first n-state symbol or a first block of n-state symbols in a sequence of n-state symbols is processed by functions defined over a first finite field. A second n-state symbol or a second block of n-state symbols in a sequence of n-state symbols is processed by functions defined over a second finite field which with respect to the first finite field is an alternate finite field.
- In one embodiment of the present invention an alternate finite field may be created by a reversible inverter as provided earlier, wherein 0 is the zero element, but one or more other elements of the inverter invert a state. One can thus apply different alternate finite fields with zero
element 0, which still make correct decoding or decryption very difficult unless the details of the alternate finite field are known. - In one embodiment of the present invention functions (addition, multiplication, division, subtraction) of two or more different alternate finite fields including at least one alternate finite field with a zero element not 0 are applied to process two or more n-state symbols or two or more blocks of n-state symbols. When sufficient unpredictable changes for an uninformed party takes place to switch between a plurality of alternate finite fields, then code breaking or cryptanalysis of the received sequence of n-state symbols processed in the above manner will become highly unlikely.
- The 26 letters in for instance the western alphabet including capital letter, space and special characters and digits can be coded by a word of 7 bits. Each 7 bit word forms a 128-state symbol. In general one has an additional bit in the word to form a byte of 8 bits. A word of 8 bits forms a 256-state symbol. In accordance with an aspect of the present invention a sequence of k-state symbols or of blocks of k-state symbols with k<n is processed by a device such as a processor by applying a finite field GF(k) and a second finite field GF(n). In one embodiment of the present invention, both alternate finite fields have a zero element not being 0.
- One problem would be that processing of k-state symbols over a field GF(k) will generate k-state symbols while processing of k-state symbols over a field GF(n) will generate n-state symbols giving away information about the applied field. In accordance with an aspect of the present invention the k-state symbols after processing are modified to n-state symbols, for instance via a substitution table or in another way. For instance a 128-state symbols can be processed by a prime field or an alternate of such a field by taking the 7 bit representation of the symbol and add a bit to make an 8-bit symbol. One can then use the decimal value of the 8-bit word with an addition and multiplication over a field GF(p with k<p). For instance GF(137), GF(199), GF(251) could be used to generate the required alternate field. Assume and alternate finite field GFa(137) is applied on the k-state symbol with k=128. This will generate 137 state symbols. One can generate from the 137 state symbols 256 state symbols by using a relevant substitution method. For instance a substitution table or by applying a 256-state LFSR scrambler.
- There is a distinction in the art between the concepts of (1) coding, (2) encryption and (3) hashing, Coding may technically apply to error performance and detectability in signal transmission. Encryption is related to security and keeping secrecy of a message. Coding and encryption processes are reversible by a process named respectively decoding and decryption. Hashing in general refers to a (usually non-reversible) transformation process, for instance to indicate a possible change in status. Hashing can be achieved via a finite field. The concepts of (1) coding, (2) encryption and (3) hashing are covered herein by the name “coding” unless it is specifically named differently or it is clear from its context that either coding or encryption specifically is intended. The term decoding is therefor intended to mean both decoding and decryption unless specifically mentioned otherwise.
- The following patent applications, including the specifications, claims and drawings, are hereby incorporated by reference herein, as if they were fully set forth herein: (1) U.S. Non-Provisional patent application Ser. No. 10/935,960, filed on Sep. 8, 2004, entitled TERNARY AND MULTI-VALUE DIGITAL SCRAMBLERS, DESCRAMBLERS AND SEQUENCE GENERATORS; (2) U.S. Pat. No. 7,002,490 by Lablans, issued Feb. 21, 2006, entitled TERNARY AND HIGHER MULTI-VALUE SCRAMBLERS/DESCRAMBLERS; (3) U.S. patent application Ser. No. 11/000,218, filed Nov. 30, 2004, entitled SINGLE AND COMPOSITE BINARY AND MULTI-VALUED LOGIC FUNCTIONS FROM GATES AND INVERTERS; (4) U.S. Provisional Patent Application No. 60/599,781, filed Aug. 7, 2004, entitled MULTI-VALUED DIGITAL INFORMATION RETAINING ELEMENTS AND MEMORY DEVICES; and (5) U.S. patent application Ser. No. 11/566,725 filed Dec. 5, 2006, entitled ERROR CORRECTING DECODING FOR CONVOLUTIONAL AND RECURSIVE SYSTEMATIC CONVOLUTIONAL ENCODED SEQUENCES.
- Devices and methods disclosed herein in accordance with an aspect of the present invention are applied in data storage systems and storage devices enabled to store, retrieve and output data and are provided as an aspect of the present invention.
- Devices and methods disclosed herein in accordance with an aspect of the present invention are provided in data communication systems and devices enabled to either process and output data signals for transmission or to receive, to process and to present the original data. Also a communication system is provided in accordance with an aspect of the present invention, including sending and receiving processors applying methods and devices provided herein.
- While there have been shown, described and pointed out fundamental novel features of the invention as applied to preferred embodiments thereof, it will be understood that various omissions and substitutions and changes in the form and details of the device illustrated and in its operation may be made by those skilled in the art without departing from the spirit of the invention. It is the intention, therefore, to be limited only as indicated by the scope of the claims appended hereto.
Claims (20)
1. An apparatus for encoding a first plurality of n-state symbols with n equal to or greater than 3, each symbol being represented by a signal, comprising:
an input enabled to receive the first plurality of n-state symbols;
a device implementing an n-state switching function that is an addition over an alternate finite field GF(n) modified with a multiplication over an alternate finite field GF(n), wherein the alternate finite field GF(n) is a finite field defined by the addition and the multiplication, wherein
a zero element which is a neutral element of the addition is not 0; and wherein
the apparatus is part of the group consisting of a communication system and a data storage system; and
an output enabled to provide a second plurality of symbols based on the first plurality of symbols.
2. The apparatus of claim 1 , wherein n>4.
3. The apparatus of claim 1 , further comprising:
an implementation of at least one n-state inverter defined by the multiplication over the alternate finite field GF(n).
4. The apparatus of claim 1 , wherein n>7.
5. The apparatus of claim 1 , wherein the second plurality of n-state symbols is applied in symbol error correction.
6. The apparatus of claim 1 , wherein the device is part of a Feistel-like network.
7. The apparatus of claim 1 , wherein the apparatus is an Advanced Encryption Standard (AES) encoder.
8. The apparatus of claim 1 , wherein the apparatus is an Elliptic Curve Coding encoder.
9. The apparatus of claim 1 , wherein the apparatus modifies a statistical distribution of symbols in the first plurality of symbols compared to the second plurality of symbols.
10. The apparatus of claim 1 , further comprising a corresponding apparatus to decode the second plurality of symbols into the first plurality of symbols.
11. The apparatus of claim 1 , wherein the second plurality of symbols includes at least one check symbol.
12. The apparatus of claim 1 , wherein n is a prime number.
13. The apparatus of claim 1 , wherein n=2m with m>1.
14. The apparatus of claim 1 , wherein the apparatus is a transposition encoder.
15. The apparatus of claim 1 , wherein the apparatus performs a Galois arithmetical operation for encoding.
16. The apparatus of claim 1 , wherein the apparatus includes a shift register with at least two shift register elements each enabled to store an n-state symbol.
17. The apparatus of claim 1 , wherein an n-state symbol is represented by a plurality of binary signals.
18. An apparatus for encoding a first sequence of n-state symbols, each symbol being represented by a signal, comprising:
an input of a device enabled to receive the first sequence of n-state symbols;
a memory device storing a single truth table that is a truth table of a modified addition over an alternate finite field GF(n), wherein the alternate finite field GF(n) is a finite field defined by the addition and a multiplication and a neutral element of the addition, wherein
the neutral element of the addition is not 0 and the modified addition over the alternate finite field GF(n) is the addition over the alternate finite field GF(n) that is modified by at least one n-state inverter defined by the multiplication over the alternate finite field GF(n) with n an integer greater than 4 and wherein
the apparatus is part of the group consisting of a communication system and a data storage system; and
an output that provides a second sequence of symbols based on the first sequence of symbols.
19. The apparatus of claim 18 , wherein the apparatus is one of the group consisting of: a scrambler, a convolutional coder, a Reed-Solomon coder, a Hamming coder, a check-symbol based error correcting coder, a transposition coders, a hopping rule coder, a Linear Feedback Shift Register based coder, a Feistel-like network based coder, an Elliptic Curve Coding coder, a symbol statistical distribution modifying coder, a Galois Field arithmetic based coder, a sequence generator based encoder, a streaming coder, a block coder and an Advanced Encryption Standard (AES) coder.
20. A method for decoding a sequence of n-state symbols with n>4, each symbol being represented by a signal, comprising:
providing a plurality of signals representing the sequence of n-state symbols on an input of a processor;
the processor processing the plurality of signals representing the sequence of n-state symbols by an implementation of an addition and a multiplication over an alternate finite field, wherein the addition and the multiplication over the alternate finite field define the alternate finite field wherein a zero element of the alternate finite field which is a neutral element of the addition over the alternate finite field is not 0, wherein truth tables of the addition and the multiplication over the alternate finite field are retrievably stored in a memory device;
providing a plurality of signals representing a decoded sequence of symbols on an output; and wherein
the sequence of n-state symbols was generated by an encoder in the group consisting of a convolutional encoder, a Reed-Solomon encoder, a Hamming coder, a check-symbol based error correcting encoder, a transposition encoder, a hopping rule encoder, a streaming cipher encoder, a block coder, a Feistel-like network based encoder, an Elliptic Curve Coding encoder, a symbol statistical distribution modifying encoder, a Galois Field arithmetic based encoder and an Advanced Encryption Standard (AES) encoder.
Priority Applications (7)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/064,089 US20140055290A1 (en) | 2003-09-09 | 2013-10-25 | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders |
US14/622,860 US9218158B2 (en) | 2003-09-09 | 2015-02-14 | N-valued shift registers with inverter reduced feedback logic functions |
US14/975,841 US20160112069A1 (en) | 2003-09-09 | 2015-12-20 | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders |
US15/442,556 US10515567B2 (en) | 2010-06-01 | 2017-02-24 | Cryptographic machines with N-state lab-transformed switching devices |
US15/499,849 US10375252B2 (en) | 2010-06-01 | 2017-04-27 | Method and apparatus for wirelessly activating a remote mechanism |
US16/172,584 US11093213B1 (en) | 2010-12-29 | 2018-10-26 | Cryptographic computer machines with novel switching devices |
US16/717,691 US11336425B1 (en) | 2010-06-01 | 2019-12-17 | Cryptographic machines characterized by a Finite Lab-Transform (FLT) |
Applications Claiming Priority (31)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US50133503P | 2003-09-09 | 2003-09-09 | |
US54768304P | 2004-02-25 | 2004-02-25 | |
US10/912,954 US7505589B2 (en) | 2003-09-09 | 2004-08-06 | Ternary and higher multi-value digital scramblers/descramblers |
US10/935,960 US7643632B2 (en) | 2004-02-25 | 2004-09-08 | Ternary and multi-value digital signal scramblers, descramblers and sequence generators |
US10/936,181 US7002490B2 (en) | 2003-09-09 | 2004-09-08 | Ternary and higher multi-value digital scramblers/descramblers |
US72065505P | 2005-09-26 | 2005-09-26 | |
US73330805P | 2005-11-03 | 2005-11-03 | |
US74283105P | 2005-12-06 | 2005-12-06 | |
US77906806P | 2006-03-03 | 2006-03-03 | |
US11/534,777 US7930331B2 (en) | 2005-09-26 | 2006-09-25 | Encipherment of digital sequences by reversible transposition methods |
US11/555,730 US20070098160A1 (en) | 2005-11-03 | 2006-11-02 | SCRAMBLING AND SELF-SYNCHRONIZING DESCRAMBLING METHODS FOR BINARY AND NON-BINARY DIGITAL SIGNALS NOT USING LFSRs |
US11/566,725 US7877670B2 (en) | 2005-12-06 | 2006-12-05 | Error correcting decoding for convolutional and recursive systematic convolutional encoded sequences |
US11/618,986 US20070110229A1 (en) | 2004-02-25 | 2007-01-02 | Ternary and Multi-Value Digital Signal Scramblers, Descramblers and Sequence of Generators |
US11/679,316 US7865806B2 (en) | 2006-03-03 | 2007-02-27 | Methods and apparatus in finite field polynomial implementations |
US11/680,719 US7865807B2 (en) | 2004-02-25 | 2007-03-01 | Multi-valued check symbol calculation in error detection and correction |
US95602407P | 2007-08-15 | 2007-08-15 | |
US1254807P | 2007-12-10 | 2007-12-10 | |
US3556308P | 2008-03-11 | 2008-03-11 | |
US12/188,261 US7659839B2 (en) | 2007-08-15 | 2008-08-08 | Methods and systems for modifying the statistical distribution of symbols in a coded message |
US12/264,728 US20090060202A1 (en) | 2003-09-09 | 2008-11-04 | Ternary and Higher Multi-Value Digital Scramblers/Descramblers |
US12/330,255 US7772999B2 (en) | 2007-12-10 | 2008-12-08 | N-state ripple adder scheme coding with corresponding n-state ripple adder scheme decoding |
US12/400,900 US8832523B2 (en) | 2006-03-03 | 2009-03-10 | Multi-state symbol error correction in matrix based codes |
US12/642,916 US7864087B2 (en) | 2007-08-15 | 2009-12-21 | Methods and systems for modifying the statistical distribution of symbols in a coded message |
US33297410P | 2010-05-10 | 2010-05-10 | |
US12/827,465 US7924176B2 (en) | 2007-12-10 | 2010-06-30 | N-state ripple adder scheme coding with corresponding N-state ripple adder scheme decoding |
US12/868,874 US7864079B1 (en) | 2003-09-09 | 2010-08-26 | Ternary and higher multi-value digital scramblers/descramblers |
US12/952,482 US20110064214A1 (en) | 2003-09-09 | 2010-11-23 | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders |
US12/980,504 US8577026B2 (en) | 2010-12-29 | 2010-12-29 | Methods and apparatus in alternate finite field based coders and decoders |
US13/103,300 US8645803B2 (en) | 2010-05-10 | 2011-05-09 | Methods and systems for rapid error correction by forward and reverse determination of coding states |
US13/846,296 US20130230172A1 (en) | 2007-11-26 | 2013-03-18 | Novel binary and n-state Linear Feedback Shift Registers (LFSRs) |
US14/064,089 US20140055290A1 (en) | 2003-09-09 | 2013-10-25 | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders |
Related Parent Applications (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/952,482 Continuation-In-Part US20110064214A1 (en) | 2003-09-09 | 2010-11-23 | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders |
US12/980,504 Continuation-In-Part US8577026B2 (en) | 2003-09-09 | 2010-12-29 | Methods and apparatus in alternate finite field based coders and decoders |
US15/442,556 Continuation-In-Part US10515567B2 (en) | 2010-06-01 | 2017-02-24 | Cryptographic machines with N-state lab-transformed switching devices |
US16/172,584 Continuation-In-Part US11093213B1 (en) | 2010-06-01 | 2018-10-26 | Cryptographic computer machines with novel switching devices |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/622,860 Continuation US9218158B2 (en) | 2003-09-09 | 2015-02-14 | N-valued shift registers with inverter reduced feedback logic functions |
Publications (1)
Publication Number | Publication Date |
---|---|
US20140055290A1 true US20140055290A1 (en) | 2014-02-27 |
Family
ID=50150940
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/064,089 Abandoned US20140055290A1 (en) | 2003-09-09 | 2013-10-25 | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders |
US14/622,860 Expired - Fee Related US9218158B2 (en) | 2003-09-09 | 2015-02-14 | N-valued shift registers with inverter reduced feedback logic functions |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/622,860 Expired - Fee Related US9218158B2 (en) | 2003-09-09 | 2015-02-14 | N-valued shift registers with inverter reduced feedback logic functions |
Country Status (1)
Country | Link |
---|---|
US (2) | US20140055290A1 (en) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8798380B1 (en) * | 2012-08-08 | 2014-08-05 | Google Inc. | Techniques for generating customized two-dimensional barcodes |
US20150280906A1 (en) * | 2014-03-27 | 2015-10-01 | Samsung Israel Research Corporation | Algebraic manipulation detection codes from algebraic curves |
US9177238B2 (en) | 2012-08-08 | 2015-11-03 | Google Inc. | Techniques for generating customized two-dimensional barcodes |
CN106982116A (en) * | 2017-04-26 | 2017-07-25 | 南通大学 | A kind of local file encryption method of the AES based on reversible logic circuits |
EP3512153A1 (en) * | 2018-01-16 | 2019-07-17 | Proton World International N.V. | Cryptographic function and authentication of replaceable component for printer |
CN112840543A (en) * | 2018-08-21 | 2021-05-25 | 德克萨斯仪器股份有限公司 | Spectrum shaping of spread spectrum clock/frequency by post-processing |
US20220294468A1 (en) * | 2019-11-21 | 2022-09-15 | Huawei Technologies Co., Ltd. | Multiplier and operator circuit |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
RU2614370C1 (en) * | 2015-10-12 | 2017-03-24 | федеральное государственное автономное образовательное учреждение высшего образования "Северо-Кавказский федеральный университет" | Multi-input adder by module two |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060149962A1 (en) * | 2003-07-11 | 2006-07-06 | Ingrian Networks, Inc. | Network attached encryption |
US20070110229A1 (en) * | 2004-02-25 | 2007-05-17 | Ternarylogic, Llc | Ternary and Multi-Value Digital Signal Scramblers, Descramblers and Sequence of Generators |
US8577026B2 (en) * | 2010-12-29 | 2013-11-05 | Ternarylogic Llc | Methods and apparatus in alternate finite field based coders and decoders |
Family Cites Families (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3515805A (en) | 1967-02-06 | 1970-06-02 | Bell Telephone Labor Inc | Data scrambler |
GB1500132A (en) * | 1974-03-07 | 1978-02-08 | Standard Telephones Cables Ltd | Multi-level data scramblers and descramblers |
NL8302214A (en) | 1983-06-22 | 1985-01-16 | Philips Nv | DECODER FOR DECODING CODEWORDS PROTECTED BLOCK-PROOF FROM A REED-SOLOMON CODE AGAINST MULTIPLE SYMBOL ERRORS PER BLOCK, AND READING DEVICE FOR OPTICALLY READABLE STORES FOR AN INDICATOR. |
US4703485A (en) | 1986-02-10 | 1987-10-27 | International Business Machines Corporation | Method and apparatus for computing and implementing error detection check bytes |
US5812438A (en) | 1995-10-12 | 1998-09-22 | Adaptec, Inc. | Arithmetic logic unit and method for numerical computations in galois fields |
US5768168A (en) | 1996-05-30 | 1998-06-16 | Lg Semicon Co., Ltd. | Universal galois field multiplier |
US6473779B1 (en) | 1996-10-03 | 2002-10-29 | Texas Instruments Incorporated | Combinatorial polynomial multiplier for galois field 256 arithmetic |
US6003057A (en) | 1997-12-24 | 1999-12-14 | Motorola, Inc. | Galois field arithmetic logic unit circuit |
US6141786A (en) | 1998-06-04 | 2000-10-31 | Intenational Business Machines Corporation | Method and apparatus for performing arithmetic operations on Galois fields and their extensions |
CN1249473A (en) | 1998-09-30 | 2000-04-05 | 朗迅科技公司 | Arithmetic code without multiplication |
JP2000124813A (en) | 1998-10-20 | 2000-04-28 | Texas Instr Japan Ltd | Device and method for reed solomon encoding and decoding |
US6760742B1 (en) | 2000-02-18 | 2004-07-06 | Texas Instruments Incorporated | Multi-dimensional galois field multiplier |
JP4371520B2 (en) | 2000-03-06 | 2009-11-25 | 三菱電機株式会社 | CRC arithmetic unit |
DE10061315A1 (en) | 2000-12-08 | 2002-06-13 | T Mobile Deutschland Gmbh | Method and device for generating a pseudo random sequence |
US6587864B2 (en) | 2001-11-30 | 2003-07-01 | Analog Devices, Inc. | Galois field linear transformer |
WO2003071766A1 (en) * | 2002-02-20 | 2003-08-28 | Xtremespectrum, Inc. | M-ary orthagonal coded communications method and system |
US7089276B2 (en) | 2002-10-18 | 2006-08-08 | Lockheed Martin Corp. | Modular Galois-field subfield-power integrated inverter-multiplier circuit for Galois-field division over GF(256) |
US7865806B2 (en) * | 2006-03-03 | 2011-01-04 | Peter Lablans | Methods and apparatus in finite field polynomial implementations |
US7512647B2 (en) | 2004-11-22 | 2009-03-31 | Analog Devices, Inc. | Condensed Galois field computing system |
-
2013
- 2013-10-25 US US14/064,089 patent/US20140055290A1/en not_active Abandoned
-
2015
- 2015-02-14 US US14/622,860 patent/US9218158B2/en not_active Expired - Fee Related
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060149962A1 (en) * | 2003-07-11 | 2006-07-06 | Ingrian Networks, Inc. | Network attached encryption |
US20070110229A1 (en) * | 2004-02-25 | 2007-05-17 | Ternarylogic, Llc | Ternary and Multi-Value Digital Signal Scramblers, Descramblers and Sequence of Generators |
US8577026B2 (en) * | 2010-12-29 | 2013-11-05 | Ternarylogic Llc | Methods and apparatus in alternate finite field based coders and decoders |
Cited By (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9665817B2 (en) * | 2012-08-08 | 2017-05-30 | Google Inc. | Techniques for generating customized two-dimensional barcodes |
US8798380B1 (en) * | 2012-08-08 | 2014-08-05 | Google Inc. | Techniques for generating customized two-dimensional barcodes |
US9177238B2 (en) | 2012-08-08 | 2015-11-03 | Google Inc. | Techniques for generating customized two-dimensional barcodes |
US9208420B2 (en) | 2012-08-08 | 2015-12-08 | Google Inc. | Techniques for generating customized two-dimensional barcodes |
US20160189016A1 (en) * | 2012-08-08 | 2016-06-30 | Google Inc. | Techniques for generating customized two-dimensional barcodes |
US9425952B2 (en) * | 2014-03-27 | 2016-08-23 | Samsung Israel Research Corporation | Algebraic manipulation detection codes from algebraic curves |
US20150280906A1 (en) * | 2014-03-27 | 2015-10-01 | Samsung Israel Research Corporation | Algebraic manipulation detection codes from algebraic curves |
CN106982116A (en) * | 2017-04-26 | 2017-07-25 | 南通大学 | A kind of local file encryption method of the AES based on reversible logic circuits |
EP3512153A1 (en) * | 2018-01-16 | 2019-07-17 | Proton World International N.V. | Cryptographic function and authentication of replaceable component for printer |
FR3076925A1 (en) * | 2018-01-16 | 2019-07-19 | Proton World International N.V. | CRYPTOGRAPHIC FUNCTION |
WO2019141542A1 (en) * | 2018-01-16 | 2019-07-25 | Proton World International N.V. | Cryptographic function and authentication of replaceable component for printer |
US11025426B2 (en) | 2018-01-16 | 2021-06-01 | Proton World International N.V. | Encryption function and authentication of a replaceable printer component |
CN112840543A (en) * | 2018-08-21 | 2021-05-25 | 德克萨斯仪器股份有限公司 | Spectrum shaping of spread spectrum clock/frequency by post-processing |
US20220294468A1 (en) * | 2019-11-21 | 2022-09-15 | Huawei Technologies Co., Ltd. | Multiplier and operator circuit |
US11855661B2 (en) * | 2019-11-21 | 2023-12-26 | Huawei Technologies Co., Ltd. | Multiplier and operator circuit |
Also Published As
Publication number | Publication date |
---|---|
US9218158B2 (en) | 2015-12-22 |
US20150160922A1 (en) | 2015-06-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8577026B2 (en) | Methods and apparatus in alternate finite field based coders and decoders | |
US20140055290A1 (en) | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders | |
Carlet | Boolean functions for cryptography and coding theory | |
KR101246490B1 (en) | A closed galois field cryptographic system | |
US20110064214A1 (en) | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders | |
US9203436B2 (en) | Error correction in multi-valued (p,k) codes | |
US20160112069A1 (en) | Methods and Apparatus in Alternate Finite Field Based Coders and Decoders | |
GB2549981A (en) | A public key cryptosystem based on the partitioning of elements of vectors | |
US20090092250A1 (en) | Methods and Systems for N-State Signal Processing with Binary Devices | |
EP0011615A1 (en) | Method and device for encryption and decryption of data. | |
US8149143B2 (en) | Data encryption and decryption with a key by an N-state inverter modified switching function | |
US8103943B2 (en) | Symbol reconstruction in Reed-Solomon codes | |
US7865806B2 (en) | Methods and apparatus in finite field polynomial implementations | |
Seo et al. | A lower bound on the linear span of an FCSR | |
US20130230172A1 (en) | Novel binary and n-state Linear Feedback Shift Registers (LFSRs) | |
US20130145237A1 (en) | Methods and Systems for Rapid Error Location in Reed-Solomon Codes | |
US7865807B2 (en) | Multi-valued check symbol calculation in error detection and correction | |
US8645803B2 (en) | Methods and systems for rapid error correction by forward and reverse determination of coding states | |
Carter | Aspects of local linear complexity | |
RU2188513C2 (en) | Method for cryptographic conversion of l-bit digital-data input blocks into l-bit output blocks | |
US20100299579A1 (en) | Methods and Systems for Error-Correction in Convolutional and Systematic Convolutional Decoders in Galois Configuration | |
JPH1152850A (en) | Device and method for cipher conversion | |
RU2140709C1 (en) | Process of cryptographic conversion of blocks of digital data | |
Bennenni et al. | Contemporary Mathematics Volume 785, 2023 | |
RU2024209C1 (en) | Binary information coding device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |