Approximate computation in digital systems using bit partitioning
US-11914447-B1 · Feb 27, 2024 · US
US12141548B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-12141548-B2 |
| Application number | US-202318204872-A |
| Country | US |
| Kind code | B2 |
| Filing date | Jun 1, 2023 |
| Priority date | Sep 10, 2015 |
| Publication date | Nov 12, 2024 |
| Grant date | Nov 12, 2024 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
Official abstract text for this publication.
Methods and leading zero anticipators for estimating the number of leading zeros in a result of a fixed point arithmetic operation which is accurate to within one bit for any signed fixed point numbers. The leading zero anticipator includes an input encoding circuit which generates an encoded input string from the fixed point numbers; a window-based surrogate string generation circuit which generates a surrogate string whose leading one is an estimate of the leading one in the result of the arithmetic operation by examining consecutive windows of the encoded input string and setting corresponding bits of the surrogate string based on the examinations; and a counter circuit configured to estimate the number of leading zeros in the result of the arithmetic operation based on the leading one in the surrogate string.
Opening claim text (preview).
What is claimed is: 1. An anticipator circuit configured to estimate a number of leading or trailing digits in a result of an arithmetic operation, the anticipator circuit comprising: a surrogate string generation circuit configured to generate a surrogate string whose leading or trailing digit is an estimate of a leading or trailing digit in the result of the arithmetic operation by examining consecutive windows of an encoded input string; and an output configured to provide an estimate of the number of leading or trailing digits in the result of the arithmetic operation based on the leading or trailing digit in the surrogate string. 2. The anticipator circuit of claim 1 , wherein a window of the encoded input string comprises a predetermined number of consecutive positions of the encoded input string. 3. The anticipator circuit of claim 2 , wherein the predetermined number is greater than or equal to three. 4. The anticipator circuit of claim 2 , wherein the surrogate string generation circuit is configured to generate a selected bit of the surrogate string based on a corresponding window of the encoded input string, the corresponding window comprising the predetermined number of consecutive positions of the encoded input string starting with and including a corresponding bit position of the encoded input string. 5. The anticipator circuit of claim 1 , wherein the input encoding circuit is configured to set a selected position of the encoded input string to one of a z, p or g based on how many of the corresponding bits of two or more fixed point numbers in the arithmetic operation are the predetermined value. 6. The anticipator circuit of claim 5 , wherein there are two fixed point numbers and the input encoding circuit is configured to: set the selected position of the encoded input string to a z when both of the corresponding bits of the fixed point numbers are a first value; set the selected position of the encoded input string to a p when only one of the corresponding bits of the fixed point numbers is a second value; and set the selected position of the encoded input string to a g when both of the corresponding bits of the fixed point numbers are the second value. 7. The anticipator circuit of claim 5 , wherein a window of the encoded input string comprises three consecutive positions of the encoded input string and the surrogate string generation circuit is configured to set a selected bit of the surrogate string to the predetermined value when the corresponding window of the encoded input string comprises ggz, gpg, gpp, gpz, gzg, pgg, pzz, zgz, zpg, zpp, zpz or zzg and the surrogate string generation circuit is configured to set the selected bit of the surrogate string to a different predetermined value when the corresponding window of the encoded input string comprises ggg, ggp, gzp, gzz, pgp, pgz, ppg, ppp, ppz, pzg, pzp, zgg, zgp, zzp, or zzz. 8. The anticipator circuit of claim 5 , wherein the surrogate string generation circuit is configured to set a selected bit of the surrogate string, e_y, according to the following formula: e _ y i =( p ι ∨( p i−1 ∧( g i−1 ∧z i−2 )∨( z i−1 ∧g i−2 )))∨( p i ∧(( z i−1 ∧z i−2 )∨( g i−1 ∧g i−2 ))) 9. The anticipator circuit of claim 5 , wherein the surrogate string generation circuit is configured to set a selected bit of a negated surrogate string, e_y, according to the following formula: e _ y ι =( p ι ∧(( z i−1 ∧ g ι−2 )∨( g i−1 ∧ z ι−2 )))∨( p i ∧(( z i−1 ∧ g ι−2 )∨( g i−1 ∧ z i−2 ))) 10. A method of estimating a number of leading or trailing digits in a result of an arithmetic operation performed, the method comprising: generating, using a surrogate string generation circuit, a surrogate string whose leading or trailing digit is an estimate of a leading or trailing digit in the result of the arithmetic operation by examining consecutive windows of an encoded input string; and outputting an estimate of the number of leading or trailing digits in the result of the arithmetic operation based on the leading or trailing digit in the surrogate string. 11. The method of claim 10 , wherein a window of the encoded input string comprises a predetermined number of consecutive positions of the encoded input string and the predetermined number is greater than or equal to three. 12. The method of claim 11 , wherein generating the surrogate string comprises setting a selected bit of the surrogate string based on a corresponding window of the encoded input string, the corresponding window comprising the predetermined number of consecutive positions of the encoded input string starting with and including a corresponding bit position of the encoded input string. 13. The method of claim 10 , wherein generating the encoded input string comprises setting a selected position of the encoded input string to one of z, p or g based on how many of the corresponding bits of two or more fixed point numbers in the arithmetic operation are the predetermined value. 14. The method of claim 13 , wherein there are two fixed point numbers and generating the encoded input string comprises: setting the selected position of the encoded input string to a z when both of the corresponding bits of the fixed point numbers are a first value; setting the selected position of the encoded input string to a p when only one of the corresponding bits of the fixed point numbers is a second value; and setting the selected position of the encoded input string to a g when both of the corresponding bits of the fixed point numbers are the second value. 15. The method of claim 13 , wherein a window of the encoded input string comprises three consecutive positions of the encoded input string and generating the surrogate string comprises setting a selected bit of the surrogate string to the predetermined value when the corresponding window of the encoded input string comprises ggz, gpg, gpp, gpz, gzg, pgg, pzz, zgz, zpg, zpp, zpz or zzg and setting the selected bit of the surrogate string to a different predetermined value when the corresponding window of the encoded input string comprises ggg, ggp, gzp, gzz, pgp, pgz, ppg, ppp, ppz, pzg, pzp, zgg, zgp, zzp, or zzz. 16. The method of claim 13 , wherein generating the surrogate string comprises setting a selected bit of the surrogate string, e_y, according to the following formula: e _ y i =( p ι ∧( p i−1 ∨( g i−1 ∧z i−2 )∨( z i−1 ∧g i−2 )))∨( p i ∧(( z i−1 ∧z i−2 )∨( g i−1 ∧g i−2 ))) 17. The method of claim 13 , wherein generating the surrogate string comprises setting a selected bit of a negated surrogate string, e_y, according to the following formula: e _ y ι =( p ι ∧(( z i−1 ∧ g ι−2 )∨( g i−1 ∧ z ι−2 )))∨( p i ∧(( z i−1 ∧ g ι−2 )∨( g i−1 ∧ z i−2 ))) 18. A non-transitory computer readable storage medium having stored thereon a computer readable dataset description of an integrated circuit that, when processed in an integrated circuit manufacturing system, causes the integrated circuit manufacturing system to manufacture the anticipator circuit configured to estimate a number of leading or trailing digits in a result of an arithmetic operation, the anticipator circuit comprising: a surrogate string generation circuit configured to: generate a surrogate string whose leading or trailing digit is an estimate of a leading or trailing digit in the result of the arithmetic operation by examining consecutive windows of an encoded input string;
in floating-point computations · CPC title
Basic arithmetic logic units, i.e. devices selectable to perform either addition, subtraction or one of several logical operations, using, at least partially, the same circuitry · CPC title
Selecting or encoding within a word the position of one or more bits having a specified value, e.g. most or least significant one or zero detection, priority encoders {(with shifting G06F5/01)} · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.