US 6275587 B1 Abstract A computer system includes a processor and a computer readable medium storing a computer program product for encoding a serial bit stream of digital data. The product includes instructions for causing the processor to place a first number of bits from the input bit stream into bit positions of an encoded output unit in accordance with a first value, the first number of bits aligned to a bit position in the encoded output unit in accordance with a second value and insert bits of arbitrary value into remaining, bit positions of the unit of the encoded output unit. In addition, the computer program product includes instructions that cause a processor to select significant bits from a unit of the encoded bit stream in accordance with the first value and the second value to place the selected bits in a decoded bit stream.
Claims(54) 1. A method of encoding a serial bit stream of digital data, the method comprises:
placing a first portion of bits from the input bit stream into bit positions of an encoded output unit in accordance with a first value, said first number of bits aligned to a bit position in the encoded output unit in accordance with a second value and inserting bits of arbitrary value into remaining bit positions of the unit of the encoded output unit;
placing a remaining portion of bits from the input bit stream into bit positions of a second encoded output unit in accordance with a different, first value, said remaining portion of bits aligned to a bit position in the second encoded output unit in accordance with a different, second value and inserting bits of arbitrary value into remaining bit positions of the second unit of the encoded output unit; and
wherein the bits of arbitrary value are noise bits.
2. A method of encoding a serial bit stream of digital data, the method comprises:
placing a first portion of bits from the input bit stream into bit positions of an encoded output unit in accordance with a first value, said first number of bits aligned to a bit position in the encoded output unit in accordance with a second value and inserting bits of arbitrary value into remaining bit positions of the unit of the encoded output unit;
placing a remaining portion of bits from the input bit stream into bit positions of a second encoded output unit in accordance with a different, first value, said remaining portion of bits aligned to a bit position in the second encoded output unit in accordance with a different, second value and inserting bits of arbitrary value into remaining bit positions of the second unit of the encoded output unit; and
iteratively generating subsequent first values and subsequent second values for the actions of placing, and for each subsequent action of placing, placing a variable number of bits, as determined by the subsequent first values from the input bit stream into subsequent encoded output units.
3. The method of claim
2 wherein generating the first value and the second value uses a deterministic non-trivial algorithm to select the first value and second value.4. The method of claim
3 wherein the deterministic non-trivial algorithm comprisesdetermining pairs of generated values from a first prime number and a second prime number, where the first prime number is a primitive root of the second prime number.
5. The method of claim
4 wherein pairs of generated values based on the first and second prime numbers are used to determine the first and second values.6. The method of claim
2 wherein the unit of encoded data is a byte, word, long word or quad word.7. The method of claim
2 wherein the unit of data is a byte.8. The method of claim
2 wherein placing further comprises modifying the selected input bits in the encoded bit stream in accordance with whether a third value corresponds to a logic 0 or a logic 1.9. The method of claim
2 further comprising supplying the encoded bit stream with a header that identifies values of the two prime numbers to produce the generated values.10. The method of claim
9 wherein the header is encrypted.11. The method of claim
5 wherein the values of the two prime numbers to produce the generated values are in a software application that uses the encoding method.12. The method of claim
5 wherein values of the two prime numbers to produce the generated values are user supplied.13. The method of claim
2 wherein placing further comprises applying a transformation to the selected bits and noise.14. The method of claim
2 wherein the first value is defined as b(k) and the second value is defined as r(k) and are given by:b(k)=v(2*k)=p ^{2*k }mod q mod(n+1) r(k)=v(2*k+1)=p ^{2*k+1 }mod q mod(n+1−b). 15. The method of claim
2 wherein the first value is defined as b(k) and the second value is defined as r(k) and are given by:b(k)=v(i+(2+w)*k)mod(n+1) r(k)=(v(i+(2+w)*k+1)mod(9−b(k)) t(k)=(v(i+3*k+2)mod z)mod 2. 16. The method of claim
2 wherein placing bits into the encoded output unit further comprises inverting a unit of the encoded bit stream in accordance with whether a third value corresponds to a logic 0 or a logic 1.17. A method of decoding an encoded serial bit stream, the method comprising:
selecting significant bits from a unit of the encoded bit stream in accordance with a number of bits value and a bit alignment value to place the selected bits in a decoded bit streams;
gathering values of two prime numbers to produce generated values;
generating the generated values based on the gathered values of the two prime numbers; and
producing the number of bits value and the bit alignment value from the generated values.
18. The method of claim
17 further comprising iteratively repeating the generating, producing and selecting actions until all bits of the encoded bit stream have been placed in the decoded bit stream.19. The method of claim
17 wherein the encoded unit is a byte, word, long word or quad word.20. The method of claim
17 wherein the encoded unit is a byte.21. The method of claim
20 wherein generating provides said generated values in accordance with a primitive root algorithm.22. The method of claim
17 wherein selecting identifies the number of bits in the encoded bit stream and the bit position in the encoded bit stream.23. The method of claim
20 further comprising:gathering a third value and wherein said third value determines a filter function to apply to the selected bits.
24. The method of claim
23 wherein said third value determines whether or not the selected bits in the encoded bit stream unit are inverted to provided the decoded bit stream.25. The method of claim
20 wherein gathering further comprises decrypting values to find the two prime numbers.26. The method of claim
20 wherein gathering further comprises retrieving the values of the two prime numbers from an application program.27. The method of claim
20 wherein gathering further comprises retrieving user supplied values of the two prime numbers.28. The method of claim
20 wherein gathering further comprises retrieving the values of the two prime numbers from a header that accompanies the encoded bit stream.29. A computer program product residing on a computer readable medium for encoding a serial bit stream of digital data, the product comprising instructions for causing a processor to:
place a first portion of bits from the input bit stream into bit positions of an encoded output unit in accordance with a first value, said first number of bits aligned to a bit position in the encoded output unit in accordance with a second value and insert bits of arbitrary value into remaining, bit positions of the unit of the encoded output unit; and
place a remaining portion of bits from the input bit stream into bit positions of a second encoded output unit in accordance with a different, first value, said remaining portion of bits aligned to a bit position in the second encoded output unit in accordance with a different, second value and insert bits of arbitrary value into remaining bit positions of the second unit of the encoded output unit; and
iteratively generate subsequent first values and subsequent second values to place a variable number of bits determined by the subsequent first values from the input bit stream into subsequent encoded output units.
30. The computer program product of claim
29 wherein instructions that cause the processor to generate the first value and the second value use a deterministic non-trivial algorithm to select the first value and second value.31. The computer program product of claim
30 wherein the deterministic non-trivial algorithm comprises instructions that cause the processor todetermine pairs of generated values from a first prime number and a second prime number, where the first prime number is a primitive root of the second prime number.
32. The computer program product of claim
31 wherein pairs of generated values based on the first and second prime numbers are used to determine the first and second values.33. The computer program product of claim
29 wherein the unit of encoded data is a byte, word, long word or quad word.34. The computer program product of claim
29 wherein the unit of data is a byte.35. The computer program product of claim
29 wherein instructions that cause the processor to place further comprise instructions that cause the processor to modify the selected input bits in the encoded bit stream in accordance with whether a third value corresponds to a logic 0 or a logic 1.36. The computer program product of claim
31 further comprising a header that identifies values of the two prime numbers to produce the generated values.37. The computer program product of claim
36 wherein the header is encrypted.38. The computer program product of claim
31 wherein the values of the two prime numbers to produce the generated values are in a software application that uses the encoding computer program product.39. The computer program product of claim
31 wherein values of the two prime numbers to produce the generated values are user supplied.40. The computer program product of claim
29 wherein instructions that cause the processor to place bits further comprise instructions that cause the processor to apply a transformation to the selected bits and noise.41. The computer program product of claim
29 wherein the first value is defined as b(k) and the second value is defined as r(k) and are given by:b(k)=v(2*k)=p ^{2*k }mod q mod(n+1) r(k)=v(2*k+1)=p ^{2*k+1 }mod q mod(n+1−b). 42. The computer program product of claim
29 wherein the first value is defined as b(k) and the second value is defined as r(k) and are given by:b(k)=v(i+(2+w)*k)mod(n+1) r(k)=(v(i+(2+w)*k+1)mod(9−b(k)) t(k)=(v(i+3*k+2)mod z)mod 2. 43. A computer program product residing on a computer readable medium for decoding an encoded serial bit stream, the computer program product comprising instructions that cause a processor to:
select significant bits from a unit of the encoded bit stream in accordance with a number of bits value and a bit alignment value to place the selected bits in a decoded bit stream;
gather values of two prime numbers to produce generated values;
generate the generated values based on the gathered values of the two prime numbers; and
produce the number of bits value and the bit alignment value from the generated values.
44. The computer program product of claim
43 further comprising instructions that cause a processor to:iteratively repeat the generate, produce and select instructions until all bits of the encoded bit stream have been placed in the decoded bit stream.
45. The computer program product of claim
43 wherein the encoded unit is a byte, word, long word or quad word.46. The computer program product of claim
43 wherein the encoded unit is a byte.47. The computer program product of claim
43 wherein instructions that cause a processor to generate generated values provides said generated values in accordance with a primitive root algorithm.48. The computer program product of claim
47 wherein instructions that cause a processor to select significant bits further comprises instructions that cause the processor to identify the number of bits in the encoded bit stream and the bit position in the encoded bit stream.49. The computer program product of claim
43 further comprising instructions that cause a processor to gather a third value and wherein said third value determines a filter function to apply to the selected bits.50. The computer program product of claim
49 wherein said third value determines whether or not the selected bits in the encoded bit stream unit are inverted to provided the decoded bit stream.51. The computer program product of claim
43 wherein instructions that cause a processor to gather further comprises instructions that cause a processor to de-encrypt values to find the two prime numbers.52. The computer program product of claim
43 wherein instructions that cause a processor to gather further comprises instructions that cause a processor to retrieve the values of the two prime numbers from an application program.53. The computer program product of claim
43 wherein instructions that cause a processor to gather further comprises instructions that cause a processor to retrieve user supplied values of the two prime numbers.54. The computer program product of claim
43 wherein instructions that cause a processor to gather further comprise instructions that cause a processor to retrieve the values of the two prime numbers from a header that accompanies the encoded bit stream.Description This invention relates to secure communication techniques. It is often desirable to transmit digital data from a source to one or more intended recipients in such a manner that the digital data can be recognized only by its intended recipients. Examples of instances where this is desirable include transmission of sensitive data (e.g., financial data, technical data, policy data) or software such as downloading an application program from the Internet, or retrieving a program or other data from a disk (e.g., optical or magnetic). There are known techniques for secure data communication. Most of these techniques are classified as encryption/decryption techniques. In general, encryption techniques convert from one system of data formats to another sometimes by use of the source data to vary the conversion process. This conversion is performed in such a manner that given encryption information reconversion into the original form is possible by decryption. A cryptographic transformation function takes data, e.g., symbols comprising a message in its original form, known as plaintext or plaintext symbols, and performs mathematical manipulations on the numerical representation of the message (either on a block or stream basis), transforming the message into ciphertext or cipertext symbols. Ciphertext is a representation of the original message which is unreadable, typically appearing as garbled text. Three types of cryptographic transformation functions which are used to convert plaintext to ciphertext are: secret key functions, public key functions, and hash functions. Secret key functions employ directional encryption algorithms. A user selects a secret key which, along with the message to be encrypted, are the inputs to an algorithm. The resulting ciphertext is sent to a recipient where the recipient may be a person or a computer. To read the encrypted message, the recipient must know the user's secret key. Using the user's secret key and the ciphertext, as inputs to the same algorithm used to encrypt the message, the recipient is able to decrypt the message into plaintext and thus read the message sent by the user. Encryption may also be accomplished by using a public key function. A public key function requires two keys, a public key and a private key for each user of the system. The public key for an individual user may be known by all other users of the system. The private key for the individual user should be known only by the individual user. Hash functions unlike secret or public key are one-way encryption functions. In the stream cipher technique, the symbols of the plaintext message are serially flowed through a stream ciphering system. The stream cipher system typically operates on the plaintext symbols using a key or random data to form a modulo sum. According to an aspect of the invention, a method includes encoding a serial bit stream of digital data by inserting bits of arbitrary value into bit positions of an encoded output unit along with a first number of bits from the serial bit stream. The method can also include decoding an encoded serial bit stream by selecting significant bits from a unit of the encoded bit stream that includes bits of arbitrary value. According to a further aspect of the invention, a computer storage medium stores an encoded bit stream of digital data. The encoded bit stream include a header portion including encoding values used by a decoder to decode the encoded serial bit stream, a first set of portions of the encoded bit stream including bits of arbitrary value; and a second set of portions of the encoded bit stream including bits representative of an original input data stream. According to a still further aspect of the invention, a method of encoding a serial bit stream of digital data, includes placing a first number of bits from the input bit stream into bit positions of an encoded output unit in accordance with a first value, said first number of bits aligned to a bit position in the encoded output unit in accordance with a second value and inserting bits of arbitrary value into remaining bit positions of the unit of the encoded output unit. The bits of arbitrary value can be noise bits or bits from a second data stream. The bits can also be bits from a tail end of the serial bit data stream. The method iteratively generating a subsequent first value and subsequent second value for each action of placing a subsequent number of bits from the input bit stream into a subsequent encoded output unit. Generating the first value and the second value uses a deterministic non-trivial algorithm to select the first value and second value. The deterministic non-trivial algorithm can include determining pairs of generated values from a first prime number and a second prime number, where the first prime number is a primitive root of the second prime number. According to a still further aspect of the invention, a method of decoding an encoded serial bit stream includes selecting significant bits from a unit of the encoded bit stream in accordance with a number of bits value and a bit alignment value to place the selected bits in a decoded bit stream. The method gathers values of two prime numbers to produce generated values and generates the generated values based on the gathered values of the two prime numbers. The method produces the number of bits value and the bit alignment value from the generated values. The method iteratively generates values, produces the bit and alignment values and selects bits from the encoded bit stream until all bits of the encoded bit stream have been placed in the decoded bit stream. According to a still further aspect of the invention, a computer program product resides on a computer readable medium. The product encodes a serial bit stream of digital data and includes instructions for causing a processor to place a first number of bits from the input bit stream into bit positions of an encoded output unit in accordance with a first value. The first number of bits are aligned to a bit position in the encoded output unit in accordance with a second value. The product also includes instructions to cause a computer to insert bits of arbitrary value into remaining, bit positions of the unit of the encoded output unit. According to a still further aspect of the invention, a computer program product resides on a computer readable medium. The product can decode an encoded serial bit stream and includes instructions that cause a processor to select significant bits from a unit of the encoded bit stream in accordance with a number of bits value and a bit alignment value to place the selected bits in a decoded bit stream. According to a still further aspect of the invention, a computer system includes a processor and a computer readable medium storing a computer program product for encoding a serial bit stream of digital data. The product includes instructions for causing the processor to place a first number of bits from the input bit stream into bit positions of an encoded output unit in accordance with a first value, said first number of bits aligned to a bit position in the encoded output unit in accordance with a second value and insert bits of arbitrary value into remaining, bit positions of the unit of the encoded output unit. According to a still further aspect of the invention, a computer system includes a processor and a computer readable medium storing a computer program product for decoding an encoded serial bit stream. The computer program product includes instructions that cause a processor to select significant bits from a unit of the encoded bit stream in accordance with a number of bits value and a bit alignment value to place the selected bits in a decoded bit stream. One or more of the following advantages may be provided by one or more of the aspects of the invention. The encoded bit stream has the original data inserted into random positions in the encoded output unit to obfuscate the original bits from the input bit stream. The encoded bit stream can have the input bit stream intermingled with useless data, e.g., random data or noise. Alternatively, the encoded bit stream can have the input data stream intermingled with useful data. The encoded output can be transformed by a transformation function or filter to further obfuscate the input stream. The output unit can have various sizes. Moreover, the output unit size can be fixed or variable. FIG. 1 is a block diagram of a computer system that encodes and decodes digital data. FIG. 2 is a block diagram of the encoder/decoder used in FIG. FIG. 2A is a block diagram of an alternate encoder/decoder. FIG. 3 is a flow chart of an encoder for the encoder/decoder system. FIG. 3A is a diagram showing a relationship between an input bit stream and an encoded bit stream. FIG. 4 is a flow chart of a decoder for the encoder/decoder system. FIG. 4A is a diagram showing a relationship between part of the encoded bit stream of FIG. 3A and a decoded bit stream. FIG. 5 is a block diagram of an alternate encoder. FIG. 5A is a diagram showing the effect of a transformation applied to an encoded data stream. FIG. 6 is a block diagram of an alternate decoder. Referring now to FIG. 1, a computer system Referring now to FIG. 2, the program Optionally, the encoded output unit is transformed by a transformation function or filter to add additional security. The encoded bit stream Typically, the output unit of the output bit stream comprises a byte or 8 bits of data. However, the output unit can have various sizes. For example, the output unit could be a word of 16 bits of data, a long word of 32 bits of data, or a quad word of 64 bits of data. In addition, the output unit size does not have to equal the unit size of the input data stream. Moreover, the output unit size can be fixed or variable, as will be described below. In addition, the entire output bit stream can be a single output unit. The encoded bit stream Referring now to FIG. 2A, the program At some point, the encoded output stream As described above, the encoder Referring now to FIG. 3, the encoder The scheme can also be used to generate first and second values for the encoder One preferred technique to produce b(k) and r(k) is based on the notion of primitive roots, as will be described below. Suffice it here to say that the encoder selects The encoding algorithm determines This can be illustrated, for example, by reference to FIG. 3A which shows an input stream comprising three bytes, BYTE After inserting selected bits from the input bit stream based on the values of b( Thus, as shown in FIG. 3A, for b( After inserting selected bits from the input bit stream based on the value of b( Thus, as shown in FIG. 3A, for b( After inserting selected bits from the input bit stream based on the value of b( This process continues until all of the remaining bits in the input bit stream have been placed in subsequent units of the encoded bit stream. At that point the encoder determines Also, bits or units of the encoded bit stream can be returned, as they are completed, particularly if pipelining techniques are used to implement encoding. Referring now to FIG. 4, the decoder The decoder The selected bits are placed into sequential bit positions the decoded bit stream The encoding process needs to know where the end of the input bit stream is. This is accomplished by including the number of bits in the stream and testing if there are any bits remaining Several placements of b(k) bits can be allowed within an output unit. One way that this is accomplished is by using v values to determine a partitioning of an output unit, and selecting r values to align the bit positions. For example, suppose the output units are 16 bits wide. The encoder Another advantage of this encoding technique is that b(k) and r(k) values can be represented by separate pairs of p and q values. That is, a first pair of primitive roots, p, q can be used to generate b(k) values, and a second, different pair of p, q primitive roots can be used to generate r(k) values. One approach for noise insertion in obfuscated encoding requires a deterministic, non-trivial algorithm to select appropriate values of b(k) and r(k) such that both encoding and decoding can be deterministically performed. An approach for computing values of b(k) and r(k) should have the values appear to be random so that decoding of the encoded output stream is difficult without the information used to generate b(k) and r(k). Non-deterministic algorithms may be used to generate values of b(k) and r(k) in certain applications where some loss can be tolerated. One technique for deterministically generating b(k) and r(k) is based on the mathematical notion of a primitive root. Simply stated, a prime number “p” is considered to be a primitive root of a prime number “q,” if certain requirements are satisfied. These requirements are that both the number “p” and the number “q” are prime numbers, and the value of the number “p” is less than the value of the number “q.” Another condition is that for an integer “k” that takes on the values from 0 to q−2 inclusive, the set of integers produced by evaluating the mathematical function given by Equation 1,
for all defined values of “k,” produces a set of integers containing all of the integers from 1 to q−1. If all these conditions are satisfied, then the prime number “p” is said to be a primitive root of the prime number “q.” As used above, “mod” refers to modulo arithmetic. The expression “p As an example of a primitive root consider p=2 and q=5. The expression p
The number 2 is thus considered to be a primitive root of 5 since both p=2 and q=5 are prime numbers, p<q and the expression, p
As shown in Table 2, the sequence repeats for values of k>3. This feature of primitive roots can be used to generate a series of generated values “v(k)” as given by Equation 2.
The function “v(k)” generates values in the range of 1 to q−1 when operating on (p, q) combinations in which a primitive root relationship exists. This algorithm is circular, as illustrated by the example above, in that for values of k greater than q−2, the function v(k) produces results modulo in the range of 1 to q−1 inclusive. This occurs because v(k+c*(q−1))=v(k) for any non-negative integer c. Therefore, if
for some value of i where i is 0≦i≦q−2, then
Equations 3 and 4 show that this algorithm will produce a set of values of v as {v(i), v(i+1), v(i+2), . . . v(i+q−2)} (Equation 4) that are equivalent to the set {v(0), v(1), v(2), . . . v(q−2)} produced by (Equation 2). This property can be used to provide a further embodiment, as will be described in FIGS. 5 and 6. Equation
where n=number of bits in the encoded unit (typically 8) and b is the number of bits selected by b(k) for a particular r(k). Other techniques can be used to provide b(k) and r(k) from the generated v values. In the generated sequence, b(k) and r(k) values each use one of the values generated by the generated sequence v(k). A sample listing of some primitive roots is contained as Appendix A attached hereto and incorporated by reference. Referring now to FIG. 5, an alternate embodiment As mentioned above, the primitive root process is circular in that for values of k greater than q−2, the function v(k) produces the same value modulo in the range of 1 to q−1 inclusive. Therefore, the encoder also generates p(k) and r(k) based on a value “s” that corresponds to a starting value of a sequence of values generated by the “p” and “q” values. The value “s” enables encoder The encoder As above, the values of b(k) and r(k), along with s(k) and t(k) are specified. The b and r values each require one number from the generated v values sequence. The t value may require 0 or more generated values from the v(k) sequence. If w represents count of numbers required by the t function, then the total count required for each k index for the b(k), r(k), and t(k) functions is 2+w. Therefore, the numbers generated by the v function can be assigned as follows:
t(k) uses either none or, if w>0, then uses:
If between 0 and n (where 1≦n≦8) bits are to be taken from the source stream at a time for processing, then b(k) is a number in the range of 0 to n, inclusive. This can be accomplished by taking the v number for b(k) mod (n+1) as:
The placement of these bits in the output stream is limited according to the number of bits placed. For example, consider an output unit of a byte. If 8 bits are selected a full byte, then the bits must occupy the full byte and, therefore, the right-most bit is at location If b(k) is 0, then the value of r(k) is not used and the computation can be skipped. The generated value v may either be skipped or reused for the next b value to be computed. No matter which is done, the same choice is made for encoding and decoding so that the process remains deterministic. The encoder
The encoder A transformation routine could, for instance, modify the current output unit e.g., a byte to perform some transformation on the byte using the t values that are active any initial state value such as p, q, s and z and return the transformed byte. After the input bit stream bits and random data have been placed into an output unit, this data may be transformed by a process “t.” This process can use any of the p, q, s, b, r and v values mentioned above. In addition, additional values “z” may be used by the “t” process, and are provided by the encoding process to specify additional options (e.g., transformations, dual bit stream encoding, folding or tail-end encoding, etc.) and may be required by the decoding process. One example of a transformation as mentioned above, inverts all the bits of the byte and returns the inverted bits in accordance with the computed values of t. This will provide an additional degree of security to the encoded bit stream. Other examples of transformation processes include adjusting the output unit by a fixed or variable amount. On approach could add a fixed value to each output unit in the encoding process and remove the fixed value in the decoding process. Others are possible. For example, the output unit bit order can be reversed or the output unit can be adjusted by an amount that is determined by use of the next generated value “v.” The transformation “t” function can use or not use the “v” function values. In addition, the transformation “t” function may use any initial z values. As an example, assume that the transformation “t” function uses one v function value and relies on a z value as well. In this example, the transformation “t” function determines if the bits in a byte are to be inverted using Equation 9:
where if t(k) is 0, do nothing, and if t(k) is 1, invert the bits within the output byte. There are simple iterative equivalents for the b(k), r(k), and t(k) computations based on: That is, (assuming the t function uses one value as in the example): Start with h=s and n=8; The values b( b( Let h=p*h mod q r( Let h=p*h mod q t( Let h=p*h mod q, The values b( b( Let h=p*h mod q r( Let h=p*h mod q t( Let h=p*h mod q These values are determined in accordance with the following equations:
where h is initialized to “s,” k is initialized to 0, and 9 corresponds to the output unit size plus 1. An example of a code sequence to produce values that can be used for b(k), r(k) and t(k) is shown in Appendix B along with two examples, one for s=1 and one for s=13 which demonstrates the cyclic, random-appearing nature of the encoder information. Referring now to FIG. 5A, an example of an inversion transformation routine is shown where encoded bytes EBYTE Referring now to FIG. 6, a decoder
The decoder The invention can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them. Apparatus of the invention can be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a programmable processor. Method steps of the invention can be performed by a programmable processor executing a program of instructions to perform functions of the invention by operating on input data and generating output. The invention can advantageously be implemented in one or more computer programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. Each computer program can be implemented in a high-level procedural or object-oriented programming language, or in assembly or machine language if desired. In any case, the language can be a compiled or interpreted language. Suitable processors include, by way of example, both general and special-purpose microprocessors. Generally, a processor will receive instructions and data from a read-only memory and/or a random access memory. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM disks. Any of the foregoing can be supplemented by, or incorporated in, ASICs (application-specific integrated circuits). It is to be understood that while the invention has been described in conjunction with the detailed description thereof, the foregoing description is intended to illustrate and not limit the scope of the invention, which is defined by the scope of the appended claims. Other aspects, advantages, and modifications are within the scope of the following claims. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |