The invention relates generally to computer instructions, and more specifically to an “OR” bit matrix multiply vector instruction.
Most general purpose computer systems are built around a general-purpose processor, which is typically an integrated circuit operable to perform a wide variety of operations useful for executing a wide variety of software. The processor is able to perform a fixed set of instructions, which collectively are known as the instruction set for the processor. A typical instruction set includes a variety of types of instructions, including arithmetic, logic, and data instructions.
Arithmetic instructions include common math functions such as add and multiply. Logic instructions include logical operators such as AND, NOT, and invert, and are used to perform logical operations on data. Data instructions include instructions such as load, store, and move, which are used to handle data within the processor.
Data instructions can be used to load data into registers from memory, to move data from registers back to memory, and to perform other data management functions. Data loaded into the processor from memory is stored in registers, which are small pieces of memory typically capable of holding only a single word of data. Arithmetic and logical instructions operate on the data stored in the registers, such as adding the data in one register to the data in another register, and storing the result in one of the two registers.
A variety of data types and instructions are typically supported in sophisticated processors, such as operations on integer data, floating point data, and other types of data in the computer system. Because the various data types are encoded into the data words stored in the computer in different ways, adding the numbers represented by two different words stored in two different registers involves different operations for integer data, floating point data, and other types of data.
For these and other reasons, it is desirable to carefully consider the data types and instructions supported in a processor's register and instruction set.
One example embodiment of the invention comprises a processor operable to execute a bit matrix multiply instruction. In further examples, the processor is operable to perform a vector bit matrix multiply instruction, and is a part of a computerized system.
In the following detailed description of example embodiments of the invention, reference is made to specific example embodiments of the invention by way of drawings and illustrations. These examples are described in sufficient detail to enable those skilled in the art to practice the invention, and serve to illustrate how the invention may be applied to various purposes or embodiments. Other embodiments of the invention exist and are within the scope of the invention, and logical, mechanical, electrical, and other changes may be made without departing from the subject or scope of the present invention. Features or limitations of various embodiments of the invention described herein, however essential to the example embodiments in which they are incorporated, do not limit other embodiments of the invention or the invention as a whole, and any reference to the invention, its elements, operation, and application do not limit the invention as a whole but serve only to define these example embodiments. The following detailed description does not, therefore, limit the scope of the invention, which is defined only by the appended claims.
Sophisticated computer systems often use more than one processor to perform a variety of tasks in parallel, use vector processors operable to perform a specified function on multiple data elements at the same time, or use a combination of these methods. Vector processors and parallel processing are commonly found in scientific computing applications, where complex operations on large sets of data benefit from the ability to perform more than one operation on one piece of data at the same time. Vector operations specifically can perform a single function on large sets of data with a single instruction rather than using a separate instruction for each data word or pair of words, making coding and execution more straightforward. Similarly, address decoding and fetching each data word or pair of data words is typically less efficient than operating on an entire data set with a vector operation, giving vector processing a significant performance advantage when performing an operation on a large set of data.
The actual operations or instructions are performed in various functional units within the processor. A floating point add function, for example, is typically built in to the processor hardware of a floating point arithmetic logic unit, or floating point ALU functional unit of the processor. Similarly, vector operations are typically embodied in a vector unit hardware element in the processor which includes the ability to execute instructions on a group of data elements or pairs of elements. The vector unit typically also works with a vector address decoder and other support circuitry so that the data elements can be efficiently loaded into vector registers in the proper sequence and the results can be returned to the correct location in memory.
Instructions that are not available in the hardware instruction set of a processor can be performed by using the instructions that are available to achieve the same result, typically with some cost in performance. For example, multiplying two numbers together is typically supported in hardware, and is relatively fast. If a multiply instruction were not a part of a processor's instruction set, available instructions such as shift and add can be used as a part of the software program executing on the processor to compute a multiplication, but will typically be significantly slower than performing the same function in hardware.
One example embodiment of the invention seeks to speed up operation of a certain type of vector function by incorporating hardware support for an instruction to perform the function in the instruction set, extending vector instruction capability to include use of the OR function in a bit matrix functional unit. This instruction works on bit matrix data on a bit-by-bit basis, which in some embodiments is stored in a special bit matrix register or registers in the processor. This enables testing for the equality or inequality of bits in two different input bit matrices, such as to compare whether two sequences of bit-encoded data are the same.
The bit matrix vector OR function in the hardware of the vector unit is available as a bit matrix vector OR instruction in some embodiments. In other embodiments, the bit matrix vector OR function is implemented as a Vector Bit Matrix Compare, or “VBMC” instruction. The instruction is referred to as a compare function in this example because the OR function can be used to compare the contents of bits in two different bit matrices.
In a more detailed example shown in
The equations used to compare the rows of matrix A to the columns of transposed matrix B are also shown in
In some further embodiments, matrix arrays of a given capacity are used to store matrices of a smaller value.
The bit matrix compare functions described herein can be implemented into the hardware functional units of a processor, such as by use of hardware logic gate networks or microcode designed to implement logic such as the equations shown in
This functionality has a variety of applications, such as searching for similarities or differences in genomes or other biological sequences, compressing or encrypting data, and searching large volumes of data for specific sequences. The bit matrix compare instructions implemented in hardware in processors therefore enable users of such processors to perform these functions significantly faster than was previously possible in software, meaning that a result can be achieved faster or a greater number of results can be achieved in the same amount of time.
Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement that achieve the same purpose, structure, or function may be substituted for the specific embodiments shown. This application is intended to cover any adaptations or variations of the example embodiments of the invention described herein. It is intended that this invention be limited only by the claims, and the full scope of equivalents thereof.
This application is a Continuation-in Part of and claims the benefit of priority under 35 U.S.C. §120 to U.S. patent application Ser. No. 11/750,928, filed on May 18, 2007, and to U.S. patent Application Ser. No. 12/814,101, filed on Jun. 11, 2010, which claims the benefit of priority under 35 U.S.C. §119(e) to U.S. Provisional Patent Application Ser. No. 61/186,810, filed on Jun. 12, 2009, the benefit of priority of each of which is claimed hereby, and each of which are incorporated by reference herein in their entirety.
The U.S. Government has a paid-up license in this invention and the right in limited circumstances to require the patent owner to license others on reasonable terms as provided for by the terms of Contact No. MDA904-02-3-0052, awarded by the Maryland Procurement Office.
Number | Date | Country | |
---|---|---|---|
61186810 | Jun 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11750928 | May 2007 | US |
Child | 13020358 | US | |
Parent | 12814101 | Jun 2010 | US |
Child | 11750928 | US |