JPH0371331A - Multiplier - Google Patents
MultiplierInfo
- Publication number
- JPH0371331A JPH0371331A JP20935989A JP20935989A JPH0371331A JP H0371331 A JPH0371331 A JP H0371331A JP 20935989 A JP20935989 A JP 20935989A JP 20935989 A JP20935989 A JP 20935989A JP H0371331 A JPH0371331 A JP H0371331A
- Authority
- JP
- Japan
- Prior art keywords
- multiplier
- multiplicand
- multiplication
- digit
- bits
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000010586 diagram Methods 0.000 description 12
- 238000007792 addition Methods 0.000 description 11
- 238000007796 conventional method Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000000034 method Methods 0.000 description 2
- 238000006243 chemical reaction Methods 0.000 description 1
Landscapes
- Complex Calculations (AREA)
Abstract
Description
【発明の詳細な説明】
〔発明の技術分野〕
本発明は、ディジタル乗算器に関し、特に、同一のハー
ドウェアで、(1)実数の乗算を高精度で実行する、(
2)低精度ではあるが複素数の乗算(1つの複素数乗算
は4つの実数乗算と等価)を高速で実行する、という2
つの機能を合わせ持った乗算器に関する。DETAILED DESCRIPTION OF THE INVENTION [Technical Field of the Invention] The present invention relates to a digital multiplier, and in particular, the present invention relates to a digital multiplier that (1) performs multiplication of real numbers with high precision using the same hardware;
2) Perform complex number multiplications (one complex number multiplication is equivalent to four real number multiplications) at high speed, albeit with low precision.
This article concerns a multiplier that has two functions.
従来の通常の乗算器では、取り扱う演算精度は一義的に
決まっており、例えば32ビツト乗算器では32ビツト
の被乗数と32ビツトの乗数から64ビツトの乗算結果
を得るものであった。In conventional ordinary multipliers, the processing precision is uniquely determined; for example, a 32-bit multiplier obtains a 64-bit multiplication result from a 32-bit multiplicand and a 32-bit multiplier.
したがって、例えば、入力が被乗数も乗数も共に16ビ
ツトの場合のように、32ビツト以下のデータの場合で
あっても32ビツト乗算と同じ演算時間を必要としてい
た。Therefore, even if the input is data of 32 bits or less, such as when both the multiplicand and the multiplier are 16 bits, the same calculation time as 32-bit multiplication is required.
これに対して、B経エレクトロニクス1986年上1月
17日号の197頁に記載されている乗算器は、本来は
32ビツト乗算器であるが、16ビツト入力の場合には
、2つの16ビツト乗算を並列に実行できる構成とする
ことにより、2倍の速度を実現することが出来るもので
ある。On the other hand, the multiplier described on page 197 of the January 17, 1986 issue of B Kei Electronics is originally a 32-bit multiplier, but in the case of a 16-bit input, two 16-bit multipliers are used. By adopting a configuration that allows multiplication to be executed in parallel, it is possible to achieve twice the speed.
上記の乗算器は1乗算器のセルアレイを4つのサブアレ
イに分割し、16ビツトモードの際には、このうちの2
つのサブアレイを用いて、(1)被乗数の下位と乗数の
下位の乗算と、(2)被乗数の上位と乗数の上位の乗算
と、の2つを並列に実行し、その出力を同時に得るもの
である。The above multiplier divides the cell array of one multiplier into four subarrays, and in 16-bit mode, two of these
This method uses two subarrays to perform two operations in parallel: (1) multiplication of the lower part of the multiplicand and lower part of the multiplier, and (2) multiplication of the upper part of the multiplicand and the higher part of the multiplier, and obtains the outputs at the same time. be.
また、32ビツト乗算を実行する場合には、4つのサブ
アレイをすべて使って乗算を実行する。Also, when performing a 32-bit multiplication, all four subarrays are used to perform the multiplication.
このようにして、同一ハードウェアで、32ビツトの高
精度乗算を1回実行することも出来るし。In this way, 32-bit high-precision multiplication can be performed once with the same hardware.
16ビツトの低精度乗算を2回実行することも出来る、
という柔軟性を持たせたものである。It is also possible to perform two 16-bit low-precision multiplications.
It provides flexibility.
上記の乗算器においては、同一ハードウェアで、高精度
乗算(32ビツト)を1回実行するか、或いは低精度乗
算(16ビツト)を2回実行することが出来る、という
利点がある。しかし、上記の方式では、低精度演算モー
ドの際に、4つのサブアレイのうちの2つの乗算結果し
か利用しておらず、残りの2つのサブアレイでの乗算結
果、すなわち、被乗数の下位と乗数の上位の乗算結果と
、被乗数の上位と乗数の下位の乗算結果とを全く利用し
ていないので、その部分の構成が無駄になる、という問
題があった。The advantage of the multiplier described above is that high precision multiplication (32 bits) can be performed once or low precision multiplication (16 bits) can be performed twice with the same hardware. However, in the above method, only the multiplication results of two of the four subarrays are used in the low-precision arithmetic mode, and the multiplication results of the remaining two subarrays are used, that is, the lower order of the multiplicand and the multiplier. Since the upper multiplication result and the multiplication result between the upper multiplicand and the lower multiplier are not used at all, there is a problem in that the configuration of that part is wasted.
本発明は、上記のごとき従来技術の問題を解決するため
になされたものであり、上記の無駄になっていた部分を
生かすことによって、さらに高速演算を可能にした乗算
器を提供することを目的とする。The present invention was made in order to solve the problems of the prior art as described above, and an object of the present invention is to provide a multiplier that enables even higher-speed calculation by making use of the above-mentioned wasted portions. shall be.
上記の目的を達成するため、本発明においては。 In order to achieve the above object, in the present invention.
特許請求の範囲に記載するように構成している。The invention is constructed as described in the claims.
すなわち1本発明においては、被乗数の上位桁と乗数の
上位桁、被乗数の上位桁と乗数の下位桁、被乗数の下位
桁と乗数の上位桁、被乗数の下位桁と乗数の下位桁の4
つの部分積を求め、それら4つの部分積結果から、高精
度(例えば32ビツト)の実数乗算結果と、低精度(例
えば16ビツト)の複素数乗算結果とを一度に求め、そ
れらの何れかを選択して出力するように構成したもので
ある。That is, in the present invention, the upper digits of the multiplicand and the upper digits of the multiplier, the upper digits of the multiplicand and the lower digits of the multiplier, the lower digits of the multiplicand and the upper digits of the multiplier, the lower digits of the multiplicand and the lower digits of the multiplier.
From these four partial product results, find a high-precision (e.g., 32-bit) real number multiplication result and a low-precision (e.g., 16-bit) complex number multiplication result at the same time, and select one of them. It is configured to output as follows.
第1図は本発明の原理を示す図である。FIG. 1 is a diagram showing the principle of the present invention.
第1図において、
XH=被乗数の上位桁
Xム=被乗数の下位桁
Yo=乗数の上位桁
YL=乗数の下位桁
ZH=乗算結果の上位桁
ZL=乗算結果の下位桁
である、また、部分積生成手段l〜4は、4つの部分積
XHX Y)1. XoX Yt、、 XI、X YH
,Xl、X YLを生成する手段、加算手段5は上記4
つの部分積から高精度の乗算結果ZH2Lを求める手段
である。In FIG. 1, The product generating means 1 to 4 generate four partial products XHXY)1. XoX Yt,, XI,X YH
, Xl, X YL, the addition means 5 is
This is a means for obtaining a highly accurate multiplication result ZH2L from two partial products.
また、加減算手段6は上記4つの部分積を用いて次の2
つの加減算を実行する。Further, the addition/subtraction means 6 uses the above four partial products to obtain the following two
Perform two additions and subtractions.
ZH=XllXYH−XLXYL −(1)Z+、=
XoXYし+XbXYu −(2)従って、入力デー
タを、それぞれ
X o + j X L ・・・(3)Y o +
j Y L ・・・(4)という複素数とみなせ
ば1.上記の加減算結果ZH,ZLは、それぞれ複素数
乗算結果の実部・虚部に等しい。このことは下記(5)
式からも明白である。ZH=XllXYH−XLXYL −(1) Z+,=
XoXY + XbXYu - (2) Therefore, the input data are respectively X o + j
j Y L ... (4) If it is considered as a complex number, then 1. The above addition/subtraction results ZH and ZL are respectively equal to the real part and imaginary part of the complex multiplication result. This is explained below (5)
It is clear from the formula.
(X H+ j X L )・(Yo+jYt、)=X
H−Y)I−XL−Yb+j(Xu−YL+XL−Yo
)=ZH+jZt、 ・・・(5
)したがって加減算手段6により、低精度(高精度の実
数乗算のビット数の172のビット数)ではあるが、複
素数乗算を一度に実行することが出来る。(X H+ j X L)・(Yo+jYt,)=X
H-Y)I-XL-Yb+j(Xu-YL+XL-Yo
)=ZH+jZt, ...(5
) Therefore, the addition/subtraction means 6 can perform complex number multiplication at once, albeit with low precision (the number of bits is 172, which is the number of bits of high precision real number multiplication).
また、選択手段7および8は、上記のようにして求めた
高精度実数乗算結果と低精度複素数乗算結果との何れか
一方を選択して出力する。なお、選択手段の切り換えは
、外部から制御信号を与えることによって任意に行なう
ことが出来る。Further, the selection means 7 and 8 select and output either the high precision real number multiplication result or the low precision complex number multiplication result obtained as described above. Note that switching of the selection means can be performed arbitrarily by applying a control signal from the outside.
上記のようにして、同一時間内に、高精度実数乗算か低
精度複素数乗算かの何れかの結果を得ることが出来る。In the above manner, either high-precision real number multiplication or low-precision complex number multiplication can be obtained within the same time.
上記のように、本発明においては5低精度の演算におい
て従来は演算されながら利用されなかった2つのサブア
レイでの乗算結果(被乗数の下位と乗数の上位の乗算結
果と、被乗数の上位と乗数の下位の乗算結果)も全て利
用することにより、低精度の演算を一度に4つ実行させ
ることによって演算速度を4倍にし、それによって低精
度の複素数乗算を一度に実行可能にしたものである。As described above, in the present invention, the multiplication results in two subarrays that were conventionally calculated but not used in low-precision calculations (the multiplication results for the lower multiplicand and the upper multiplier, and the multiplication results for the lower multiplicand and the upper multiplier) By using all the low-order multiplication results), the calculation speed is quadrupled by executing four low-precision operations at once, thereby making it possible to execute low-precision complex number multiplications at once.
このようにして従来の4倍の性能を引きだすことができ
れば、複素数の乗算(実数乗算4回に相当)を同一ハー
ドウェアを用いて同一サイクルで実行することが出来る
ので、ディジタル信珍処理の分野で用いられるフーリエ
変換などのように複素数演算を多用する処理の高速化を
図ることが出来る。If we can extract four times the performance of conventional methods in this way, we can execute complex number multiplications (equivalent to four real number multiplications) in the same cycle using the same hardware, which will be useful in the field of digital processing. It is possible to speed up processing that uses a lot of complex number operations, such as the Fourier transform used in
第2図は、本発明の一実施例図である。 FIG. 2 is a diagram showing an embodiment of the present invention.
第2図において、部分積生成器11〜工4は、前記第1
図の部分積生成手段■〜4に対応するものであり、具体
的には、通常の乗算器から加算部分を除いた構成を有す
る。In FIG. 2, the partial product generators 11 to 4 are connected to the first
It corresponds to the partial product generating means (1) to (4) shown in the figure, and specifically has a configuration in which the addition part is removed from a normal multiplier.
また、加算器15および16は、前記第1図の加算手段
5に相当し、減算器17と加算器18とは同じく加減算
手段6に相当する。Further, the adders 15 and 16 correspond to the adding means 5 in FIG.
また、選択器19は第1図の選択手段7に、選択器20
は同じく選択手段8に相当する。Further, the selector 19 is connected to the selector 20 in the selection means 7 in FIG.
also corresponds to the selection means 8.
本実施例においては、まず、部分積生成器】−]−で被
乗数の上位桁Xiと乗数の上位桁Yllの部分積XH−
YHを求め1部分積生成器13で被乗数の上位桁XHと
乗数の下位桁Yしの部分積X H・Yl、を求め、部分
積生成器13で被乗数の下位桁X r、と乗数の上位桁
Yl(との部分積XL−YHを求め5部分積生成器14
で被乗数の下位桁Xt、と乗数の下位桁YLとの部分積
XL’YLを求める。In this embodiment, first, a partial product generator ]-]- is used to generate a partial product XH- of the high-order digit Xi of the multiplicand and the high-order digit Yll of the multiplier.
The partial product generator 13 calculates the partial product XH·Yl between the high-order digit XH of the multiplicand and the low-order digit Y of the multiplier. Calculate the partial product XL-YH of the digit Yl (5-part product generator 14
Find the partial product XL'YL of the lower digit Xt of the multiplicand and the lower digit YL of the multiplier.
次に、加算器15と16で、上記の各部分積結果から高
精度実数乗算用の加算を実行する。Next, adders 15 and 16 perform addition for high-precision real number multiplication from the above partial product results.
また、減算器17と加算器上8で、上記の各部分積結果
から複素数乗算用の加減算を実行する。Further, the subtracter 17 and the adder 8 perform addition and subtraction for complex number multiplication from each of the above partial product results.
そして以上の結果の何れか一方を、選択器7および8で
切り替えて、所望の値を出力する。Then, one of the above results is switched by selectors 7 and 8 to output a desired value.
第3図は、上記第2図の実施例において高精度実数乗算
を実行する際のデータの流れを示す図であり、また、第
4図は低精度複素数乗算を実行する際のデータの流れを
示す図である。FIG. 3 is a diagram showing the data flow when performing high-precision real number multiplication in the embodiment shown in FIG. 2, and FIG. 4 is a diagram showing the data flow when performing low-precision complex number multiplication. FIG.
次に、第5図は本発明の他の実施例図である。Next, FIG. 5 is a diagram showing another embodiment of the present invention.
第5図において、部分積生成器1工〜14は前記第2図
と同じである。また、前記第1図の加算手段5.加減算
手段6、選択手段7,8の部分は、加算器21.22.
27.289選択器24.25.26、符号反転器23
およびANDゲート29で構成している。In FIG. 5, partial product generators 1 to 14 are the same as those in FIG. 2 above. Furthermore, the adding means 5 in FIG. The addition/subtraction means 6 and the selection means 7, 8 are comprised of adders 21, 22, .
27.289 selector 24.25.26, sign inverter 23
and an AND gate 29.
また、第6図は、第5図の実施例において高精度実数乗
算を実行する際めデータの流れを示す図。Further, FIG. 6 is a diagram showing the flow of data when performing high-precision real number multiplication in the embodiment of FIG. 5.
第7図は低精度複素数乗算を実行する際のデータの流れ
を示す図である。FIG. 7 is a diagram showing the flow of data when performing low-precision complex number multiplication.
以上説明したように本発明によれば、制御信号を与えて
選択手段を切り替えるだけで、同一ハードウェアで、高
精度実数乗算と低精度複素数乗算とのいずれかを回−時
間で実行することが可能となる。また、演算速度を従来
の4倍にしたことによって複素数の乗算(実数乗算4回
に相当)を同一ハードウェアを用いて同一サイクルで実
行することが出来るので、ディジタル信号処理の分野で
用いられるフーリエ変換などのように複素数演算を多用
する処理の高速化を図ることが出来る、等の優れた効果
が得られる。As explained above, according to the present invention, it is possible to execute either high-precision real number multiplication or low-precision complex number multiplication in one cycle time using the same hardware simply by applying a control signal and switching the selection means. It becomes possible. In addition, by increasing the calculation speed by four times compared to conventional methods, complex number multiplications (equivalent to four real number multiplications) can be executed in the same cycle using the same hardware. Excellent effects such as speeding up processing that uses a lot of complex number operations such as conversion can be obtained.
第1図は本発明の原理図、第2図は本発明の一実施例図
、第3図および第4図は第2図の実施例におけるデータ
の流れを示す図、第5図は本発明の他の実施N図、第6
図および第7図は第5図の実施例におけるデータの流れ
を示す図である。
く符号の説明〉
(,2,3,4・・・部分積生成手段
5・・・加算手段
6・・・加減算手段
7.8・・・選択手段
11.12,13.14・・・部分積生成器15.16
.18・・・加算器
17・・・減算器
19.20・・・選択器
23・・・符号反転器
24.25.26・・・選択器
27.28・・・加算器
29・・・ANDゲートFIG. 1 is a diagram showing the principle of the present invention, FIG. 2 is a diagram showing an embodiment of the present invention, FIGS. 3 and 4 are diagrams showing the flow of data in the embodiment of FIG. 2, and FIG. 5 is a diagram showing the embodiment of the present invention. Another implementation N figure, 6th
7 and 7 are diagrams showing the flow of data in the embodiment of FIG. 5. Explanation of codes> (, 2, 3, 4...partial product generation means 5...addition means 6...addition/subtraction means 7.8...selection means 11.12, 13.14...partial Product generator 15.16
.. 18...Adder 17...Subtractor 19.20...Selector 23...Sign inverter 24.25.26...Selector 27.28...Adder 29...AND Gate
Claims (1)
の下位桁、被乗数の下位桁と乗数の上位桁、被乗数の下
位桁と乗数の下位桁の4つの部分積を出力する部分積生
成手段と、上記部分積生成手段の4つの部分積出力から
、上位桁のビット数と下位桁のビット数とを加算したビ
ット数を有する高精度の実数乗算結果を求める加算手段
と、 被乗数および乗数の上位を実部、下位を虚部とする複素
数とみなした場合に、上記部分積生成手段の4つの部分
積出力から、上位桁のビット数と下位桁のビット数とを
加算したビット数の1/2のビット数を有する低精度の
複素数乗算結果を求める加減算手段と、 上記加算手段の出力と上記加減算手段の出力との何れか
一方を選択して出力する選択手段と、を備えたことを特
徴とする乗算器。[Claims] Four partial products of the upper digits of the multiplicand and the upper digits of the multiplier, the upper digits of the multiplicand and the lower digits of the multiplier, the lower digits of the multiplicand and the upper digits of the multiplier, the lower digits of the multiplicand and the lower digits of the multiplier. and addition to obtain a high-precision real number multiplication result having the number of bits obtained by adding the number of bits of the upper digit and the number of bits of the lower digit from the four partial product outputs of the partial product generating means. When the multiplicand and the multiplier are regarded as complex numbers with the upper part as the real part and the lower part as the imaginary part, from the four partial product outputs of the above partial product generation means, the number of bits in the upper digit and the number of bits in the lower digit are calculated. an addition/subtraction means for obtaining a low-precision complex number multiplication result having a number of bits that is 1/2 of the number of bits added together; and a selection means for selecting and outputting either the output of the addition means or the output of the addition/subtraction means. A multiplier comprising:
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP20935989A JPH0371331A (en) | 1989-08-11 | 1989-08-11 | Multiplier |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP20935989A JPH0371331A (en) | 1989-08-11 | 1989-08-11 | Multiplier |
Publications (1)
Publication Number | Publication Date |
---|---|
JPH0371331A true JPH0371331A (en) | 1991-03-27 |
Family
ID=16571639
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP20935989A Pending JPH0371331A (en) | 1989-08-11 | 1989-08-11 | Multiplier |
Country Status (1)
Country | Link |
---|---|
JP (1) | JPH0371331A (en) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100420410B1 (en) * | 2001-05-02 | 2004-03-04 | 주식회사 하이닉스반도체 | Real-complex multiplier using redudant binary operation |
KR100433627B1 (en) * | 2001-12-11 | 2004-05-31 | 한국전자통신연구원 | Low power multiplier for complex numbers |
JP2009048532A (en) * | 2007-08-22 | 2009-03-05 | Nec Electronics Corp | Microprocessor |
CN103677735A (en) * | 2012-09-19 | 2014-03-26 | 北京中科晶上科技有限公司 | Data processing device and digital signal processor |
-
1989
- 1989-08-11 JP JP20935989A patent/JPH0371331A/en active Pending
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100420410B1 (en) * | 2001-05-02 | 2004-03-04 | 주식회사 하이닉스반도체 | Real-complex multiplier using redudant binary operation |
KR100433627B1 (en) * | 2001-12-11 | 2004-05-31 | 한국전자통신연구원 | Low power multiplier for complex numbers |
JP2009048532A (en) * | 2007-08-22 | 2009-03-05 | Nec Electronics Corp | Microprocessor |
CN103677735A (en) * | 2012-09-19 | 2014-03-26 | 北京中科晶上科技有限公司 | Data processing device and digital signal processor |
CN103677735B (en) * | 2012-09-19 | 2017-08-04 | 北京中科晶上科技股份有限公司 | A kind of data processing equipment and digital signal processor |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JPH0612229A (en) | Multiplication and accumulation circuit | |
JPH0375901B2 (en) | ||
KR940001147B1 (en) | OPERATING METHOD AND APPARATUS FOR GF(2m) | |
JPH0368416B2 (en) | ||
JPS54159831A (en) | Adder and subtractor for numbers different in data length using counter circuit | |
JPH0371331A (en) | Multiplier | |
JPH0464091B2 (en) | ||
JPH10111791A (en) | Division device | |
JP2737933B2 (en) | Division device | |
JPS6259828B2 (en) | ||
JPH0251732A (en) | Floating point computing element | |
JPS63254525A (en) | Dividing device | |
SU972517A1 (en) | Device for performing rapid fourier transform | |
JP2512801B2 (en) | Multiplier | |
JPH0784762A (en) | Multiplication circuit | |
SU640290A1 (en) | Square rooting arrangement | |
SU922760A2 (en) | Digital function generator | |
JPH04195523A (en) | Square root calculating device | |
SU868767A1 (en) | Device for computing polynomials | |
JPH0468435A (en) | Multiplier | |
JPS62147526A (en) | Multiplier | |
Tickle et al. | Developing the basic building blocks of mathematics to be employed in practical embedded systems | |
JPH0371332A (en) | Remainder multiplying circuit and remainder multiplying method | |
JPH1124893A (en) | Inverse square root arithmetic unit | |
JPH04287220A (en) | Multiplier circuit |