KR100756137B1 - 제산 및 제곱근 연산 유닛 - Google Patents
제산 및 제곱근 연산 유닛 Download PDFInfo
- Publication number
- KR100756137B1 KR100756137B1 KR1020050123009A KR20050123009A KR100756137B1 KR 100756137 B1 KR100756137 B1 KR 100756137B1 KR 1020050123009 A KR1020050123009 A KR 1020050123009A KR 20050123009 A KR20050123009 A KR 20050123009A KR 100756137 B1 KR100756137 B1 KR 100756137B1
- Authority
- KR
- South Korea
- Prior art keywords
- square root
- data
- bits
- remainder
- division
- Prior art date
Links
- 230000000295 complement effect Effects 0.000 claims abstract description 114
- 238000004364 calculation method Methods 0.000 claims abstract description 25
- 238000000034 method Methods 0.000 claims description 13
- 238000006243 chemical reaction Methods 0.000 claims description 10
- 230000014759 maintenance of location Effects 0.000 claims description 3
- 238000004422 calculation algorithm Methods 0.000 description 10
- 238000010586 diagram Methods 0.000 description 3
- 230000014509 gene expression Effects 0.000 description 3
- 238000004321 preservation Methods 0.000 description 3
- 230000008569 process Effects 0.000 description 3
- 238000007667 floating Methods 0.000 description 2
- 238000011084 recovery Methods 0.000 description 2
- 230000000717 retained effect Effects 0.000 description 2
- 230000015556 catabolic process Effects 0.000 description 1
- 238000006731 degradation reaction Methods 0.000 description 1
- 230000000593 degrading effect Effects 0.000 description 1
- 230000006866 deterioration Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000000605 extraction Methods 0.000 description 1
- 238000010606 normalization Methods 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 238000000926 separation method Methods 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
- 230000001131 transforming effect Effects 0.000 description 1
- 238000012800 visualization Methods 0.000 description 1
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 description 1
Images
Classifications
-
- 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/491—Computations with decimal numbers radix 12 or 20.
- G06F7/492—Computations with decimal numbers radix 12 or 20. using a binary weighted representation within each denomination
- G06F7/493—Computations with decimal numbers radix 12 or 20. using a binary weighted representation within each denomination the representation being the natural binary coded representation, i.e. 8421-code
- G06F7/496—Multiplying; Dividing
-
- 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/544—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 for evaluating functions by calculation
- G06F7/552—Powers or roots, e.g. Pythagorean sums
- G06F7/5525—Roots or inverse roots of single operands
-
- 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/4824—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 using signed-digit representation
-
- 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/4873—Dividing
-
- 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/544—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 for evaluating functions by calculation
- G06F7/552—Powers or roots, e.g. Pythagorean sums
Landscapes
- Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Mathematical Analysis (AREA)
- Pure & Applied Mathematics (AREA)
- Computational Mathematics (AREA)
- Mathematical Optimization (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Nonlinear Science (AREA)
- Complex Calculations (AREA)
- Executing Machine-Instructions (AREA)
Abstract
Description
Claims (3)
- 고기수의 제산 연산과 저기수의 제곱근 풀이 연산을 수행하기 위한 제산 및 제곱근 연산 유닛에 있어서,스케일링에 사용될 승산 계수를 생성하는 스케일링 계수 생성기와;53비트의 입력된 피제수와 6비트의 입력된 제수를, 상기 스케일링 계수 생성기로부터 제공된 승산 계수로 각각 승산하고, 승산 결과를 출력하는 한 쌍의 승산기와;상기 승산기의 출력을 3배로 하여 제수의 3배수를 생성하여 출력하는 3배 제수 생성기와;부분 나머지의 상위 비트를 2의 보수 표현으로 유지하는 부분 나머지 상위 레지스터 및 상기 부분 나머지의 상위 비트를 제외한 하위 비트를 용장 2진수 표현으로 유지하는 부분 나머지 하위 레지스터와;상기 부분 나머지의 상위 레지스터에 의해 2보수 표현으로 유지되는 상기 부분 나머지의 상위 비트를 참조하는 것에 의해 몫을 생성하는 몫 생성기와;연산의 종류에 따라 제수와 부분적으로 구해진 제곱근 중 하나를 유지하는 제수-부분 제곱근 레지스터와;상기 몫 생성기에 의해 생성된 몫에 기초하여 상기 제수-부분 제곱근 레지스터로부터 상기 제수 및 상기 부분적으로 구해진 제곱근 중 하나를 선택하는 3배 제수-부분 제곱근 선택기와;상기 용장 2진수 표현의 상기 부분 나머지의 하위 비트와 상기 제수-부분 제곱근 선택기의 출력을 입력받고 입력된 데이터를 가산하는 캐리 보존 가산기와;2의 보수 표현의 상기 부분 나머지의 상위 비트와, 용장 2진수 표현의 상기 부분 나머지의 하위 비트와, 상기 제수-부분 제곱근 선택기의 출력 및 상기 캐리 보존 가산기로부터의 캐리 신호를 입력받고 입력된 데이터를 가산하는 캐리 전파 가산기와;상기 캐리 보존 가산기의 출력의 상위 비트로부터, 기수에 의해 결정된 소정 비트수의 비트 데이터 및 상기 캐리 전파 가산기의 출력을 입력받고, 입력된 데이터를 2의 보수 표현의 데이터로 변환하고, 상기 2의 보수 표현의 데이터를 연산의 기수에 기초하여 결정된 소정의 비트수만큼 시프트하여 다음 단계에서의 다른 부분 나머지를 얻는 2의 보수 변환 및 시프트 장치와;상기 몫 생성기에서 생성된 몫 디지트와 부분적으로 구해진 제곱근을 연결하기 위한 처리 비트 정보를 유지하는 위치 레지스터와;상기 몫 생성과 병행하여, 용장 2진수 표현의 데이타를 2의 보수 표현의 부분 제곱근 정데이터를 생성하는 온더플라이 몫 정생성기와;상기 몫 생성과 병행하여, 용장 2진수 표현의 데이터를 2의 보수 표현의 데이터로 변환하고 그에 따라 부분 제곱근의 부데이터를 생성하는 온더플라이 몫 부 생성기를 포함하는 것을 특징으로 하는 제산 및 제곱근 연산 유닛.
- 제 1항에 있어서,상기 2의 보수 변환 및 시프트 장치는:상기 캐리 보존 가산기의 출력의 상위 비트로부터, 고기수에 기초하여 결정된 소정 비트수의 비트 데이터 및 상기 캐리 전파 가산기의 출력을 입력받고, 상기 입력된 데이터를 2의 보수 표현의 데이터로 변환하는 제 1의 2의 보수 변환기와;상기 캐리 보존 가산기의 출력의 상위 비트로부터, 저기수에 기초하여 결정된 소정 비트수의 비트 데이터 및 상기 캐리 전파 가산기의 출력을 입력받고, 상기 입력 데이터를 2의 보수 표현의 데이터로 변환하는 제 2의 2의 보수 변환기와;제산 연산에서는 상기 제 1의 2의 보수 변환기를 선택하고 제곱근 풀이 연산에서는 상기 제 2의 2의 보수 변환기를 선택하는 선택기; 및상기 선택기의 출력을, 제산 연산에서 고기수에 기초하여 결정된 제 1의 비트수 시프트하고 제곱근 풀이 연산에서는 저기수에 기초하여 결정된 제 2의 비트수 시프트하여, 다음 단계에서의 다른 부분 나머지를 얻는 시프터를 포함하는 것을 특징으로 하는 제산 및 제곱근 연산 유닛.
- 제 1항에 있어서,상기 2의 보수 변환 및 시프트 장치는:2의 보수 표현의 상기 부분 나머지의 상위 비트를, 제산 연산과 제곱근 풀이 연산의 기수 사이의 차이에 의해 결정되는 소정의 비트수만큼 오른쪽으로 시프트하고, 시프트된 데이터를 상기 캐리 보존 가산기로 전송하는 제 1의 시프터와;용장 2진수 표현의 상기 부분 나머지의 하위 비트를, 제산 연산과 제곱근 풀이 연산의 기수 사이의 차이에 의해 결정되는 소정의 비트수만큼 오른쪽으로 시프트하고, 시프트된 데이터를 상기 캐리 전파 가산기로 전송하는 제 2의 시프터와;상기 캐리 보존 가산기의 결과의 상위 비트로부터 제산 연산의 고기수의 비트수에서 구해진 데이터와 상기 캐리 전파 가산기의 결과를 입력받고, 상기 입력된 데이터를 2의 보수 표현의 데이터로 변환하는 2의 보수 변환기; 및상기 고기수에 기초하여 결정된 소정의 비트수만큼 상기 2의 보수 변환기의 출력을 시프트하여 다음 단계에서의 다른 부분 나머지를 얻는 제 3의 시프터를 포함하는 것을 특징으로 하는 제산 및 제곱근 연산 유닛.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2004362300A JP4273071B2 (ja) | 2004-12-15 | 2004-12-15 | 除算・開平演算器 |
JPJP-P-2004-00362300 | 2004-12-15 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20060067874A KR20060067874A (ko) | 2006-06-20 |
KR100756137B1 true KR100756137B1 (ko) | 2007-09-05 |
Family
ID=35999596
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020050123009A KR100756137B1 (ko) | 2004-12-15 | 2005-12-14 | 제산 및 제곱근 연산 유닛 |
Country Status (9)
Country | Link |
---|---|
US (1) | US7921149B2 (ko) |
EP (1) | EP1672481B1 (ko) |
JP (1) | JP4273071B2 (ko) |
KR (1) | KR100756137B1 (ko) |
AU (1) | AU2005256094A1 (ko) |
CA (1) | CA2530015C (ko) |
DE (1) | DE602005011742D1 (ko) |
DK (1) | DK1672481T3 (ko) |
SG (1) | SG123731A1 (ko) |
Families Citing this family (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7509365B2 (en) * | 2005-02-11 | 2009-03-24 | International Business Machines Corporation | Inverting data on result bus to prepare for instruction in the next cycle for high frequency execution units |
EP2341425A1 (en) * | 2009-12-30 | 2011-07-06 | STMicroelectronics (Grenoble 2) SAS | control of electric machines involving calculating a square root |
US8819098B2 (en) | 2010-11-23 | 2014-08-26 | International Business Machines Corporation | Computation of a remainder by division using pseudo-remainders |
US8868633B2 (en) * | 2012-03-30 | 2014-10-21 | Advanced Micro Devices, Inc. | Method and circuitry for square root determination |
RU2510072C1 (ru) * | 2012-10-25 | 2014-03-20 | Открытое акционерное общество "Российская корпорация ракетно-космического приборостроения и информационных систем" (ОАО "Российские космические системы") | Устройство деления и извлечения квадратного корня |
US9348796B2 (en) | 2013-09-19 | 2016-05-24 | International Business Machines Corporation | Arithmetic operation in a data processing system |
US9785407B2 (en) * | 2014-11-21 | 2017-10-10 | Arm Limited | Data processing apparatus having combined divide-square root circuitry |
US10209957B2 (en) * | 2015-05-04 | 2019-02-19 | Samsung Electronics Co., Ltd. | Partial remainder/divisor table split implementation |
US10209959B2 (en) | 2016-11-03 | 2019-02-19 | Samsung Electronics Co., Ltd. | High radix 16 square root estimate |
JP7131627B2 (ja) * | 2018-10-31 | 2022-09-06 | 富士通株式会社 | 演算処理装置 |
US11281428B2 (en) * | 2019-03-12 | 2022-03-22 | Arm Limited | Conversion circuitry |
US11119731B2 (en) | 2019-03-12 | 2021-09-14 | Arm Limited | Apparatus and method for rounding |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4939686A (en) * | 1987-05-18 | 1990-07-03 | Weitek Corporation | Method and apparatus for shared radix 4 division and radix 4 square root |
US6847986B2 (en) * | 2000-02-07 | 2005-01-25 | Nec Corporation | Divider |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5023827A (en) * | 1988-08-18 | 1991-06-11 | Digital Equipment Corporation | Radix-16 divider using overlapped quotient bit selection and concurrent quotient rounding and correction |
US5128891A (en) | 1990-04-02 | 1992-07-07 | Advanced Micro Devices, Inc. | High speed divider with square root capability |
US5386376A (en) * | 1992-08-31 | 1995-01-31 | Intel Corporation | Method and apparatus for overriding quotient prediction in floating point divider information processing systems |
US5687106A (en) * | 1995-03-31 | 1997-11-11 | International Business Machines Corporation | Implementation of binary floating point using hexadecimal floating point unit |
US5787030A (en) * | 1995-07-05 | 1998-07-28 | Sun Microsystems, Inc. | Correct and efficient sticky bit calculation for exact floating point divide/square root results |
JP3514566B2 (ja) | 1995-12-13 | 2004-03-31 | 株式会社ルネサステクノロジ | 除算/開平回路 |
JPH10187420A (ja) | 1996-12-26 | 1998-07-21 | Hitachi Ltd | 除算・開平演算器 |
US6490607B1 (en) * | 1998-01-28 | 2002-12-03 | Advanced Micro Devices, Inc. | Shared FP and SIMD 3D multiplier |
US6108682A (en) | 1998-05-14 | 2000-08-22 | Arm Limited | Division and/or square root calculating circuit |
JP3517162B2 (ja) | 1999-09-22 | 2004-04-05 | 株式会社東芝 | 除算・開平演算装置 |
WO2002029546A1 (fr) * | 2000-09-26 | 2002-04-11 | Hitachi, Ltd. | Unite de calcul et dispositif de circuit electronique utilisant cette unite |
US7016930B2 (en) * | 2002-10-25 | 2006-03-21 | Arm Limited | Apparatus and method for performing operations implemented by iterative execution of a recurrence equation |
-
2004
- 2004-12-15 JP JP2004362300A patent/JP4273071B2/ja not_active Expired - Lifetime
-
2005
- 2005-12-13 CA CA002530015A patent/CA2530015C/en not_active Expired - Fee Related
- 2005-12-13 US US11/299,697 patent/US7921149B2/en active Active
- 2005-12-14 AU AU2005256094A patent/AU2005256094A1/en not_active Abandoned
- 2005-12-14 EP EP05027390A patent/EP1672481B1/en not_active Not-in-force
- 2005-12-14 KR KR1020050123009A patent/KR100756137B1/ko not_active IP Right Cessation
- 2005-12-14 DE DE602005011742T patent/DE602005011742D1/de not_active Expired - Fee Related
- 2005-12-14 DK DK05027390T patent/DK1672481T3/da active
- 2005-12-15 SG SG200508127A patent/SG123731A1/en unknown
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4939686A (en) * | 1987-05-18 | 1990-07-03 | Weitek Corporation | Method and apparatus for shared radix 4 division and radix 4 square root |
US6847986B2 (en) * | 2000-02-07 | 2005-01-25 | Nec Corporation | Divider |
Also Published As
Publication number | Publication date |
---|---|
SG123731A1 (en) | 2006-07-26 |
DK1672481T3 (da) | 2009-03-16 |
CA2530015A1 (en) | 2006-06-15 |
JP2006172035A (ja) | 2006-06-29 |
EP1672481B1 (en) | 2008-12-17 |
DE602005011742D1 (de) | 2009-01-29 |
US20060129623A1 (en) | 2006-06-15 |
JP4273071B2 (ja) | 2009-06-03 |
CA2530015C (en) | 2010-01-05 |
US7921149B2 (en) | 2011-04-05 |
KR20060067874A (ko) | 2006-06-20 |
EP1672481A1 (en) | 2006-06-21 |
AU2005256094A1 (en) | 2006-06-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Mohan et al. | Residue number systems | |
US8639737B2 (en) | Method to compute an approximation to the reciprocal of the square root of a floating point number in IEEE format | |
KR100756137B1 (ko) | 제산 및 제곱근 연산 유닛 | |
JPH04227535A (ja) | 除算を行なう装置 | |
KR940008615B1 (ko) | 고기수제산기 | |
CN113467750A (zh) | 用于基数为4的srt算法的大整数位宽除法电路及方法 | |
US6847986B2 (en) | Divider | |
CN109298848A (zh) | 双模式浮点除法平方根的电路 | |
US5289399A (en) | Multiplier for processing multi-valued data | |
US5777916A (en) | Method for the production of an error correction parameter associated with the implementation of modular operations according to the montgomery method | |
JP3660075B2 (ja) | 除算装置 | |
CN115658005A (zh) | 一种基于冗余的高精度低延时大整数除法加速装置 | |
JPH086766A (ja) | 正弦余弦演算装置 | |
Chandu et al. | Design and implementation of high efficiency square root circuit using Vedic mathematics | |
Zhao et al. | An efficient signed digit montgomery modular multiplication algorithm | |
Mohan et al. | Implementation of Quaternary Signed Adder System | |
US7266578B2 (en) | Method and hardware for computing reciprocal square root and program for the same | |
AU2020424575B2 (en) | Secure square root computation system, secure normalization system, methods therefor, secure computation apparatus, and program | |
JP2000010763A (ja) | 除算回路 | |
AU2020423805B2 (en) | Secure selective product computation system, secure selective product computation method, secure computation apparatus, and program | |
JP2795253B2 (ja) | 除算器 | |
Rajkumar et al. | VLSI Implementation of Signed Multiplier using Quaternary Signed Digit Number System | |
Villalba-Moreno et al. | Floating point square root under HUB format | |
US11157594B2 (en) | Matrix multiplication in hardware using modular math | |
JPS6155691B2 (ko) |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A201 | Request for examination | ||
PA0109 | Patent application |
Patent event code: PA01091R01D Comment text: Patent Application Patent event date: 20051214 |
|
PA0201 | Request for examination | ||
PG1501 | Laying open of application | ||
E902 | Notification of reason for refusal | ||
PE0902 | Notice of grounds for rejection |
Comment text: Notification of reason for refusal Patent event date: 20061130 Patent event code: PE09021S01D |
|
E701 | Decision to grant or registration of patent right | ||
PE0701 | Decision of registration |
Patent event code: PE07011S01D Comment text: Decision to Grant Registration Patent event date: 20070629 |
|
GRNT | Written decision to grant | ||
PR0701 | Registration of establishment |
Comment text: Registration of Establishment Patent event date: 20070830 Patent event code: PR07011E01D |
|
PR1002 | Payment of registration fee |
Payment date: 20070829 End annual number: 3 Start annual number: 1 |
|
PG1601 | Publication of registration | ||
LAPS | Lapse due to unpaid annual fee | ||
PC1903 | Unpaid annual fee |