Computer arithmetic is the practice of performing mathematical operations in a computer. Originally proposed in 1945 by John von Neumann, an arithmetic logic unit (ALU) is a digital circuit that performs integer arithmetic and logical operations. The ALU is a fundamental building block of the central processing unit of a computer. Data is provided as input to the ALU, an external control unit tells the ALU what operation to perform on that data, and then the ALU transforms the input data into an output. The input data are called the operands, and the output of the ALU is called the result. Each operation that the ALU is capable of performing may produce a different result for the same set of operands.
In modern computers, the integer operands are typically encoded into digital signals using well-known formats like two's complement or binary coded decimal. An ALU may also calculate with non-integer formats, but these types of ALU are usually given a more specific name. For example, an ALU that performs operations on floating point operands is typically called a floating point unit (FPU). In applicant's U.S. Pat. No. 7,949,700 entitled “Modal Interval Processor,” incorporated herein by reference, an ALU taking modal interval operands as input, performing a modal interval operation specified by a selector signal, and then producing a modal interval result is called a modal interval processing unit (MIPU).
Regardless of the formats that any particular type of ALU may calculate with, it is common in many ALU designs to also take as input or produce as output a set of condition codes. These codes may be used to indicate cases such as carry-in, carry-out, zero, parity, etc. However, another common use for these codes is to indicate the presence or absence of exceptional conditions.
An exception is a particular state that may occur in an ALU when an operation is performed on a specific set of operands. For example, the IEEE Standard for Floating Point Arithmetic (IEEE Std 754-2008 In IEEE Std 754-2008, Aug. 29, 2008, pp. 1-58), incorporated herein by reference, defines exactly five (5) exceptions known as Invalid Operation, Division by Zero, Overflow, Underflow and inexact. In the event any operation conforming to the standard reaches a state characterized by one of these five exceptional conditions, certain mechanisms are specified which allow a user to detect the exceptional condition. One mechanism specified by the standard is to require that a designated exception flag is set. Another mechanism requires the operation to encode a special non-numeric value known as a Na (Not-a-Number) in the result. In the thriller case, a user may determine if an exception occurred during an operation by checking to see if the designated exception flag is set. In the latter case, the user may determine if an exception occurred by checking to see if the operation result is a NaN.
Similarly, applicant's U.S. Pat. No. 8,204,926 entitled “Reliable and Efficient Computation of Modal interval Arithmetic Operations,” incorporated herein by reference, discloses a set of digital circuits that allow certain exceptional conditions to be detected in various modal interval arithmetic operations. If an exception is detected, methods similar to those specified in IEEE 754-2008 may allow a user to determine if an exception occurred.
The focus of the present invention is an improved system and method of detecting exceptions in modal interval arithmetic operations (which includes but is not limited to the so-called. “classical” interval arithmetic, a distinction made and discussed in applicant's previously referenced patents). As shown in applicant's white paper entitled “Decorations as State Machine,” prior art methods of detecting exceptional conditions in interval operations lack several important properties that allow a user to detect certain types of exceptions or else have the potential to lose information about exceptions that may have occurred in prior operations. In the worst case, some prior art methods can under certain circumstances actually provide misleading information or even be totally incorrect. So there is still yet a need for a new and improved system and method to detect exceptional conditions in interval operations that overcome these limitations of prior art methods.
Apparatus calculates a first result modal interval dependent on a first modal interval. Each modal interval is defined by first and second endpoints. Each endpoint comprises sign, fraction and exponent bit fields.
The apparatus broadly comprises a first operand register for holding the first and second endpoints, and for providing a first operand signal specifying the contents of the first modal interval endpoints' fields.
The apparatus also includes a first analysis element that receives the first operand signal, that creates first and second truth tables dependent on the first operand signal, and that encodes the first and second truth tables in a first truth tables signal.
The apparatus further includes a first logic array receiving the first operand signal and the first truth tables signal. This first logic array provides a first “empty” bit value signal dependent on the sign, fraction, and exponent field contents of the first and second endpoints.
Lastly, in this broad version, the apparatus also includes a first computational element receiving the first operand signal and the “empty” bit value signal. The first computational element then performs a computation associated with the first computational element using the data encoded in the first operand signal and the “empty” bit value signal. The result of that computation is provided in a first result signal encoding the result of the computation by the first computational element. Such computations may include inverse, transcendental computations, squares, square roots, etc.
In a further version of this invention, the first analysis element creates the first and second truth tables dependent on a preselected exponent field bit configuration in each of the first and second endpoints, and on a preselected fraction field configuration in each of the first and second endpoints.
The broad version of the invention described above may be adapted for calculating a second result modal interval dependent on the first modal interval and on a second modal interval having the same structure as the first modal interval. This version is suitable for modal interval calculations involving two operands such as multiplication, division, adding, and subtracting,
Such a version includes a second operand register for holding the second modal interval, and for providing a second operand signal specifying the contents of the second modal interval's endpoints' fields.
This version includes a second analysis element that receives the second operand signal, that creates third and fourth truth tables dependent on the second operand signal, and that encodes the third and fourth truth tables in a second truth tables signal.
This two operand version also has a second logic array receiving the second operand signal and the second truth tables signal, and providing a second “empty” bit value signal dependent on the sign, exponent, and fraction values in the third and fourth endpoints. A third logic array receives the first and second truth tables signals and generates first and second multiplexer control signals based on the first and second truth tables signals.
This version also includes at least first and second multiplexers each having a control terminal and first and second input terminals. These first and second multiplexers receive respectively the first and second multiplexer control signals at the control terminals thereof. Each multiplexer has first and second data terminals, and each multiplexer gates data present at the one of the first and second data input terminals as selected by the multiplexer control signal to create a multiplexer output signal at an output terminal of the multiplexer involved, that encodes the bit values present at the selected input terminal.
Connections provide to the first multiplexer's first and second data terminals respectively, the values of selected bits in the first and second endpoints' fraction fields.
Other connections provide to the second multiplexer's first and second data terminals respectively the values of selected bits in the third and fourth endpoints' fraction fields.
A second computational element in this version receives the first and second operands signals, the first and second “empty” bit value signals, and the first and second multiplexer output terminal signals. The second computational element then performs a computation associated with the second computational element using the data encoded in the first and second operand signals, the “empty” bit value signals, and the first and second multiplexer output signals. The second computational element provides a second result signal encoding the second result modal interval as a result of the computation by the second computational element.
The apparatus may be further adapted to process at least one of an EIN signal and a GAP signal. Such apparatus comprises third and fourth multiplexers each with the structure of the first and second multiplexers. The third and fourth multiplexers receive the first and second multiplexers' output signals respectively at the first input terminals of the third and fourth multiplexers, and one of the EIN signal and the GAP signal at the second input terminals of the third and fourth multiplexers. The third and fourth multiplexers receive at the control terminals thereof third and fourth multiplexer control signals respectively, and provide at the respective third and fourth multiplexers' output terminals the signal at the respective input terminal specified by the control signal at the respective control terminal.
A fourth logic array receives the first and second truth tables signals and generates therefrom the third and fourth multiplexer control signals.
A further version of this apparatus comprises a comparator receiving the output signals of the first and second multiplexers at first and second input terminals respectively. The comparator provides a comparator output signal having a first value responsive to the value encoded in the first multiplexer's output signal numerically exceeding the value encoded in the second multiplexer's output signal, and a second value otherwise.
This version includes a fifth multiplexer with the structure of the first and second multiplexers. The fifth multiplexer at the first and second input terminals receives the second endpoints recorded in the first and second operand registers, and the comparator output signal at the control terminal. A sixth multiplexer also has the structure of the first and second multiplexers. The sixth multiplexer at the first and second input terminals receives the first endpoints recorded in the first and second operand registers, and the comparator output signal at the control terminal
The second computational element includes a first sub-element providing as a result of the computation by the second computational element and responsive to a first configuration of the first and second “empty” bit value signals, the data forming the fifth and sixth multiplexer output signals as the first and second endpoints of the result modal interval encoded in the second result signal.
A second sub-element of the second computational element, as a result of the computation by the second computational element and responsive to a second configuration of the first and second “empty” bit value signals different from the first configuration thereof, provides as the second result modal interval encoded in the second result signal, the first and second endpoints recorded in the first operand register as the second and first endpoints of the second result modal interval.
A third sub-element of the second computational element, as a result of the computation by the second computational element and responsive to a third configuration of the first and second “empty” bit value signals different from the first and second configurations thereof, provides as the second result modal interval encoded in the second result signal, the first and second endpoints recorded in the second operand register as the second and first endpoints of the second result modal interval; and
A fourth sub-element of the second computational element, as a result of the computation by the second computational element and responsive to a fourth configuration of the first and second “empty” bit value signals different from the first through third configurations thereof, provides as the second result modal interval encoded in the second result signal, the results of a selected modal interval calculation.
In furtherance of disclosing important features of the present invention and distinguishing it from the references of prior art, a preliminary overview of related concepts and prior art work is in order.
In the realm of pure mathematics, operations on real numbers are functions that have a natural domain. For example, the square root of a negative real number is not defined, so the natural domain of the square root operation is the set of all non-negative real numbers. Division by zero is also not defined, so the natural domain of the reciprocal operation is the set of all non-zero real numbers. And so on for each contemplated operation. In other words, whenever the input to an operation is not an element of the natural domain of the operation, the operation is not defined.
Continuity is another important property of functions of real numbers. Formal definitions of a continuous function are well-known in the prior art and can be given in terms of sequences or limits of the function. Informally, if a function is continuous then any time a sequence converges in the domain, the image of the sequence in the range also converges. In other words, one could either take the limit first, and then apply the function, or apply the function first, and then take the limits.
Even more particularly, if ƒ: Rn→R is a function that maps n-dimensional real vectors Rn to real numbers R and Dƒ⊆Rn is the natural domain of ƒ, then for any X⊆Dƒ, the property of continuity may be further defined in terms of the restriction ƒ on X. In this case, the only relevant aspect of the continuity property is with respect to the portions of the function ƒ that are restricted to the domain X, wherein X is a subset of the natural domain Dƒ of the function.
For example, consider the function floor(x) R→R depicted in
The restriction of a function to X can be continuous if and only if X is also a subset of the natural domain of the function. For example, the natural domain of the square root operation is the set of all non-negative real numbers. So the restriction of the square root operation to X=[−16, 4] cannot be continuous because there are elements of X=[−16, 4] which do not belong to the natural domain of the operation and for which the operation is not defined. In other words, X in this case is not a subset of the natural domain of the operation.
Because the empty set (Ø) is a subset of every set, it is also a subset of all natural domains of all functions. The restriction of a function to the empty set must therefore be contemplated. As it turns out, the restriction of any function to the empty set X=Ø is always defined and continuous. This is perhaps a little counterintuitive, but nonetheless mathematically correct. Formal mathematical reasoning to prove this is well known in the prior art.
The present invention is concerned with modal interval arithmetic and modal interval analysis. In particular, the present invention is concerned with an improved system and method of detecting exceptional conditions in modal interval operations. The prior notions of a real function, the natural domain of a real function, and the restriction of a real function to a subset of the natural domain of the function arc therefore lifted into the topic of modal intervals.
For the purposes of the present invention, a modal interval is defined as an ordered pair [a,b] such that a and b arc real numbers or signed infinities. However, the two pairs [−∞, −∞] and [+∞, +∞] are excluded. Note that no restriction a≤b is required.
The set-theoretic interpretation of a modal interval is defined as
Set([a, b])={x∈ R: min(a, b)≤x≤max(a, b)},
and the notation x ∈ [a, b] may be used as an abbreviation for x ∈ Set([a, b]). The empty set (Ø) is not a modal interval, however Sct(Ø)=Ø.
A closed interval includes all of its limit points. Every modal interval [a, b] is a closed interval. If both a and b arc real numbers, the modal interval is bounded. If a modal interval is not bounded, then at least one of the endpoints is −∞ or +∞ and the modal interval still contains all of its limit points but not all of its endpoints. Modal intervals of the form
are therefore understood to be unbounded. Despite the use of square brackets, infinity is never an element of any modal interval, and
are by definition not modal intervals.
A modal interval [a, b] is called proper if a≤b. The modal interval is called improper if a≥b. It is called a point or a point-wise modal interval if a=b. Note that a point-wise modal interval is also a proper and an improper modal interval at the same time.
The set of all bounded modal intervals can be visualized as points in the R2 plane, where canonical abscissa and ordinate are defined respectively as the left and right bound of a modal interval [a, b], i. c.,
λ([a, b])=a and p([a, b])=b.
As of this date, the subset of bounded and unbounded proper modal intervals is the set of intervals supported in the working draft of the IEEE Standard for Interval Arithmetic. That standard is currently under development by the P1788 Working Group committee at the time of this writing and does not provide any provision for bounded or unbounded improper intervals. The present vention therefore contemplates the broadest set of “intervals” as it is the only one that consists of a set wherein each element of the set ay be bounded or unbounded, proper or improper.
A predicate is a Boolean function, and a proposition is a predicate, wherein each variable is universally (∀) or existentially (∃) quantified.
The modal quantifier Q of a modal interval [a, b] quantifies a real variable x by the definition
Q(x, [a, b])=if a≤b then ∀x∈ Set([a, b]) else ∃x∈ Set([a, b]).
The modal operators are
and the corresponding modal quantifiers D, E and U are defined as
With the modal quantifiers Q, D, E and U it is possible to form propositions with modal intervals. For example, if A and B are modal intervals then the inclusion (⊆) relation is
A⊆B⇔D(a, A)Q(b, B): a=b,
and the less-or-equal (≤) relation is
A≤B⇔U(a, A)E(b, B): a≤b and U(b, B)E(a, A): a≤b.
If x is a real number, the rounding operators ∇(x) and Δ(x) are digital approximations of x such that the relations
∇(x)≤x and Δ(x)≥x
are always true. For any modal interval [a, b],
Inn([a, b])=[Δ(a), ∇(b)] and Out([a, b])=[∇(a), Δ(b)]
are the “inner” and “outer” digital roundings, respectively of [a, b].
The inner and outer digital roundings are universally possible for any digital scale and satisfy the property.
Inn([a, b])⊆[a, b]⊆Out([a, b])
such that the equivalence
Inn([a, b])=Dual(Out(Dual([a, b])))
makes unnecessary the implementation of the inner rounding.
Decorations and Proper Tracking
A decoration is a mathematical property of a real function restricted to the domain of its modal interval inputs. Decorations provide a framework for detecting exceptional conditions such as out-of-domain arguments or non-continuous functions.
Looking at the syntactic tree for a real function, where the nodes are operators, the leaves are variables, and branches define the domain of each operator, the real function can be operationally extended to a modal interval expression by using the computational program implicitly defined by the syntactic tree of the real function. This is accomplished by transforming all of the real operators into their modal interval extension and all of the real variables into modal interval variables.
ƒ(x, y)=y/sqrt((1−x)*(1+x))
implicitly defines a modal interval expression. Real operators and variables 12 are respectively transformed into their modal interval counterparts 15. Evaluation of the expression begins at the leafs of the tree, where variables are propagated up the branches to the operations. The operations accept the variables as operands, perform an operation and generate a result. The result of each operation is then propagated up the branches into other operations until all nodes in the tree have been evaluated and a final result is propagated to the root of the tree.
The present invention makes a distinction between two types of decorations. A static decoration is the absolute mathematical truth about the restriction of an individual operation to the domain of its modal interval inputs. A tracking decoration, on the other hand, is a mathematical implication that is obtained for a modal interval expression by propagating static decorations in the expression tree up the branches and to the root. The method used to propagate static decorations through an expression tree in order to obtain a tracking decoration is called property tracking.
TABLE 1 in
Note that EIN is a subset of all tracking decorations and GAP is a superset of all tracking decorations.
For example, if ƒ is the square root operator and X=[1, 4] then for this particular (ƒ, X) pair the restriction of ƒ on X is defined and continuous. Since X is not empty, the (ƒ, X) pair cannot be an element of EIN. Additionally, the (ƒ, X) pair cannot be an element of NDF because in this case ƒ(X) is not empty, either. However, if X is the empty set then the (ƒ, X) pair is an element of EIN, and since EIN is a subset of all tracking decorations the (ƒ, X) pair is also an element of DAC, DEF, GAP and NDF.
An important note should be made regarding the prior art as it pertains to decorations. A draft of the IEEE Standard for Interval Arithmetic, which is under development at the time of this writing, contains a decoration system that was at least partially conceived by the applicant of the present invention. That decoration system has some common characteristics to the decoration system of the present invention, such as DEF and DAC decorations. However, there are some important differences, namely the absence of an E IN decoration as well as the inclusion of several other decorations not defined in the present invention such as ILL (ill-formed), COM (a common interval) and BND (a bounded interval). Applicant's white paper entitled “Decorations as State Machine” provides rationale why these competing decoration systems are unnecessary or insufficient for reliable interval computations and how the unique decoration system of the present invention overcomes those issues.
TABLE 2 in
For any (ƒ, X) pair, the notation S(ƒ, X) indicates which static decoration the (ƒ, X) pair is an element of as a function of TABLE 2. If ƒ has n operands, the notation S(ƒ, X) is shorthand for S(ƒ, X1, X2, . . . Xn).
If ƒ: Rn→R is a real function and Dƒ⊆Rn is the natural domain of ƒ, and if X is an n-dimensional modal interval box, then TABLE 3 in
For example, if ƒ is the square root operation and X1=[2, 4], X2=[−1, 1] and X=[−4, −2] then S(ƒ, X1)=dac because Set(X1) is a nonempty subset of Dƒ and the restriction of ƒ on X1 is continuous; S(ƒ, X2)=gap because Set(X2) is not a subset of Dƒ but the intersection of Set(X2) and Dƒ is nonempty; and S(ƒ, X3)=ndf because X3 is not empty but the intersection of Set(X3) and Dƒ is empty.
Property tracking is the method used to propagate static decorations through an expression tree in order to obtain a tracking decoration. To facilitate this method, the notion of a decorated interval is contemplated. A decorated interval is a pair (X, D) that consists of a modal interval X and a tracking decoration D. The empty set is not an interval, however the notion of a decorated empty set (Ø, D) is also contemplated.
The method of property tracking begins with initialization. Each modal interval variable X1, X2, . . . Xn in the leafs of the expression tree is promoted to a decorated interval (X1, DAC), (X2, DAC), . . . (Xn, DAC). If any variable in a leaf of the expression tree is an empty set, then the empty variable is promoted to a decorated empty set (Ø, EIN). Similarly, if any variable in a leaf of the expression tree is [+∞, +∞] or [−∞, −∞], then the variable is promoted, respectively, to ([+∞, +∞], GAP) or ([−∞, −∞], GAP)
The decorated variables are then propagated up the branches of the expression tree to the operations. The operations accept the decorated variables as operands, perform an operation and generate a decorated result. For each operation, if ƒ: Rn→R is the real function and
(Xi, Di)=((X1, D1), (X2, D2), . . . , (Xn, Dn))
are the decorated inters operands of ƒ, then the decorated result of the operation has the tracking decoration
T(ƒ, (Xi, Di))=min{S(ƒ, X1, X2, . . . , Xn), D1, D2, . . . , Dn}.
In other words, the decorated result of the operation has a tracking decoration which is the minimum element of a set formed by the union of the static decoration S(ƒ, X1, X2, . . . , Xn) of the operation and the decorations D1, D2, . . . , Dn of the operands.
For the sake of determining the minimum element of a set of decorations, the decorations are linearly ordered
The decorated result of each operation is then propagated up the branches into other operations. The procedure is repeated until all nodes in the tree have been evaluated and a final decorated result is propagated to the root of the tree.
Digital Encodings of Modal Intervals and Decorations
Inside a computer, the endpoints of a modal interval may be represented by elements of a digital scale. In a preferred embodiment of the present invention, the digital scale conforms to the binary64 interchange format encoding of IEEE 754-2008. For the sake of discourse, only the binary64 encoding will be explained or considered in the rest of this document. However, the use of other digital scales or interchange format encodings as it pertains to the present invention should be obvious.
A binary64 floating-point datum is 64 bits of information partitioned into sign, exponent and fraction fields as shown in register 20 of
A binary64 datum may be associated with a truth table 23 consisting of a set of classification bits as depicted in
If x is a floating-point datum, then S(x), N(x), I(x) and Z(x) arc notations used in this document to represent the respective values of the Sign, NaN. Infinity and Zero classification bits of truth table 23.
If bit 51 of a NaN is set to 1, then the NaN is quiet (QNaN); otherwise the NaN is signaling (SNaN). If the NaN is signaling, at least one other fraction bit of the NaN must be set to 1 to distinguish the NaN from an infinity. The difference between a quiet and signaling NaN is for the sake of compatibility with IEEE 754-2008 standard interchange format encoding. However, the present invention does not require signaling NaN operations.
Bits 0 to 50 are the NaN “payload.” All bits of the payload may be set to any value so long as the entire fraction field of a NaN does not become zero. The preferred embodiment of the present invention may use bits 49 to 50 of a NaN payload as a NaN decoration field to encode a representation of a tracking decoration.
If x is a NaN, then T(x) is the representation of a tracking decoration encoded within the NaN decoration field of x as depicted in TABLE 4 of
If n is the representation of a tracking decoration, then NaN(n), QNaN(n) and SNaN(n) are notations used in this document to represent the respective encodings of a NaN, quiet NaN or signaling NaN when the bits of the decoration field are set to the corresponding value of n as depicted in TABLE 4 of
A modal interval datum [a1, a2] may be encoded into 128 bits as two binary64 datums a1 and a2 as illustrated in register 27 of
All non-interval data is an encoding of a decorated empty set.
If a1 and a2 are binary64 datums that do not represent a NaN, and if n is a representation of one of the tracking decorations DAC, DEF, GAP or NDF (see TABLE 1 in
Any such encoding of a decorated empty set (Ø, n) ay be provided as input to an operation of the present invention, and a canonical encoding
may be provided as a result of an operation which produces a decorated empty set as output.
Non-interval data of the form
is an encoding of the decorated empty set (Ø, EIN) and non-interval data of the form
is an encoding of the decorated empty set (Ø, GAP).
The Empty bit in
Decoration is a representation of the NaN decoration field from a2; otherwise the Tracking Decoration is EIN. Strictly speaking, the Tracking Decoration has no meaning unless the Empty bit is set to 1. If the Empty bit is 0, the modal interval datum is a hounded or unbounded modal interval and the Tracking Decoration is not used.
If [a1, a2] is a modal interval datum, then E(a1, a2) and T(a1, a2) are notations used in this document to represent the respective values of the Empty bit and the Tracking Decoration.
Modal interval Operations with Decorations
The present invention provides an improved system and method for reliable and efficient modal interval operations using decorations. The preferred embodiment of the present invention is an arithmetic functional unit (AFU) as depicted in applicant's U.S. Pat. No. 7,949,700 entitled “Modal Interval Processor.” Modal interval operand and result signals for the AFU are digitally encoded using the methods described in the previous section of this document entitled “Digital Encodings of Modal Intervals and Decorations.”
As will be shown subsequently for select modal interval operations, the result of a modal interval operation is typically obtained by performing a floating-point calculation on select endpoints of the modal interval operands. Because floating-point calculations are often inexact, the present invention requires the rounding operators ∇(x) and Δ(x) to ensure modal interval results obey the “outer” digital rounding of modal intervals.
(−∞)(−0)=(−0)(−∞)=+0
(−∞)(+0)=(+0)(−∞)=−0
(+∞)(−0)=(−0)(+∞)=−0
(+∞)(+0)=(+0)(+∞)=+0
according to applicant's U.S. Pat. No. 8,204,926 entitled “Reliable and Efficient Modal Interval Arithmetic Operations.” The modal interval multiplication operation is therefore always defined so long as the operands [a1, a2], and [b1, b2] are bounded or unbounded modal intervals.
This is a continuation of application Ser. No. 15/419,215, filed Jan. 30, 2017, now U.S. Pat. No. 9,934,198 (Apr. 3, 2018), which is a continuation of application Ser. No. 14/421/272, filed Feb. 12, 2015, now U.S. Pat. No. 9,558,155, which is a USC § 371 national phase entry of international application PCT/US2013/055162 filed Aug. 15, 2013, which is an international application filed under 35 U.S.C. § 363 claiming priority, under 35 U.S.C. § 119(e)(1), of provisional application Ser. No. 61/683,456, previously filed Aug. 15, 2012, under 35 U.S.C. § 111(b).
Number | Date | Country | |
---|---|---|---|
61683456 | Aug 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15939433 | Mar 2018 | US |
Child | 16423924 | US | |
Parent | 15419215 | Jan 2017 | US |
Child | 15939433 | US | |
Parent | 14421272 | Feb 2015 | US |
Child | 15419215 | US |