JPH06204888A - データ圧縮伸張装置 - Google Patents
データ圧縮伸張装置Info
- Publication number
- JPH06204888A JPH06204888A JP36089092A JP36089092A JPH06204888A JP H06204888 A JPH06204888 A JP H06204888A JP 36089092 A JP36089092 A JP 36089092A JP 36089092 A JP36089092 A JP 36089092A JP H06204888 A JPH06204888 A JP H06204888A
- Authority
- JP
- Japan
- Prior art keywords
- data
- output
- serial
- adder
- arithmetic
- 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.)
- Granted
Links
Landscapes
- Compression Or Coding Systems Of Tv Signals (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
- Image Processing (AREA)
Abstract
(57)【要約】
【目的】 小さな回路規模で高速にデータの圧縮伸張を
行なうことが可能なデータ圧縮伸張装置を実現する。 【構成】 データ圧縮伸張装置のデータ変換演算装置9
0は、DCT演算係数を簡単な整数比に変えた形のシリ
アル回路により構成するとともに、odd側については
演算式をそのままハードウェア化したシリアル回路10
0を含んで構成し、パラレル−シリアル変換装装置11
から出力されたデータに対して一次元のDCT演算をシ
リアル演算の形で施す。また、シリアル回路100は、
DCT演算式を展開して得られた各入力b0〜b3に共通
な係数を2のべきにある数値をかけた形で表現した場合
の該数値の部分を作成するシリアル回路101と、この
シリアル回路101により計算された係数出力に対して
式の横方向に符号分を含めた加減算を行なって出力x0
〜x3として出力するシリアル回路102により構成し
て演算式をそのままハードウェア化する。
行なうことが可能なデータ圧縮伸張装置を実現する。 【構成】 データ圧縮伸張装置のデータ変換演算装置9
0は、DCT演算係数を簡単な整数比に変えた形のシリ
アル回路により構成するとともに、odd側については
演算式をそのままハードウェア化したシリアル回路10
0を含んで構成し、パラレル−シリアル変換装装置11
から出力されたデータに対して一次元のDCT演算をシ
リアル演算の形で施す。また、シリアル回路100は、
DCT演算式を展開して得られた各入力b0〜b3に共通
な係数を2のべきにある数値をかけた形で表現した場合
の該数値の部分を作成するシリアル回路101と、この
シリアル回路101により計算された係数出力に対して
式の横方向に符号分を含めた加減算を行なって出力x0
〜x3として出力するシリアル回路102により構成し
て演算式をそのままハードウェア化する。
Description
【0001】
【産業上の利用分野】本発明は、画像データの圧縮処理
等に用いられるデータ圧縮伸張装置に係り、詳細には小
さな回路規模でデータ圧縮を行うことが可能なデータ圧
縮伸張装置に関する。
等に用いられるデータ圧縮伸張装置に係り、詳細には小
さな回路規模でデータ圧縮を行うことが可能なデータ圧
縮伸張装置に関する。
【0002】
【従来の技術】ISDNやCD−ROMを前提とした画
像の高能率符号化技術において、DCT(Discrete Cos
ine Transform:離散コサイン変換)が高能率符号化技
術の主流になりつつある。このDCTに限らず、高能率
符号化して画素当りの平均ビット数を減らすと、画像の
品質は落ち、圧縮率を上げると、画質の劣化を引き起こ
す。例えば、現行の標準テレビ信号を1.5Mビット/
秒に圧縮した場合に問題となるのは、輪郭部分の劣化と
DCTで処理するブロック単位(例えば8×8画素)に
発生するブロック歪である。逆変換して画素を再生する
ときに、ブロック内のDCT出力をすべて線形和するこ
とになるが、8×8画素から成るブロックのDCT出力
64個のうち、一つでも情報損失があると、ブロック内
全体の再生画素に劣化が生じる。
像の高能率符号化技術において、DCT(Discrete Cos
ine Transform:離散コサイン変換)が高能率符号化技
術の主流になりつつある。このDCTに限らず、高能率
符号化して画素当りの平均ビット数を減らすと、画像の
品質は落ち、圧縮率を上げると、画質の劣化を引き起こ
す。例えば、現行の標準テレビ信号を1.5Mビット/
秒に圧縮した場合に問題となるのは、輪郭部分の劣化と
DCTで処理するブロック単位(例えば8×8画素)に
発生するブロック歪である。逆変換して画素を再生する
ときに、ブロック内のDCT出力をすべて線形和するこ
とになるが、8×8画素から成るブロックのDCT出力
64個のうち、一つでも情報損失があると、ブロック内
全体の再生画素に劣化が生じる。
【0003】ここで、DCT変換は、直交変換の一つで
あり、カールネン・レーベ変換と並んでエネルギの集中
度の最も高い変換法といわれるものである。
あり、カールネン・レーベ変換と並んでエネルギの集中
度の最も高い変換法といわれるものである。
【0004】いま、信号f(j) (j=0、1、…、
N−1)の一次元のDCT変換による結果F(u)
(u=0、1、…、N−1)は数1で定義される。
N−1)の一次元のDCT変換による結果F(u)
(u=0、1、…、N−1)は数1で定義される。
【0005】
【数1】 また、逆DCT変換は、数2で定義される。
【0006】
【数2】 このようなDCT変換を画像に対して施すことにより、
エネルギ集中が得られることから、エネルギの多い成分
のみを符号化することが可能となり、これにより画像デ
ータの圧縮を行なうようにしている。
エネルギ集中が得られることから、エネルギの多い成分
のみを符号化することが可能となり、これにより画像デ
ータの圧縮を行なうようにしている。
【0007】ところで、上記DCTを有するデータ圧縮
伸張装置に限らず、通常のデータ圧縮伸張装置では、数
値列に対し、データ変換(FFT,DCT等)を施し、
その後に量子化を行っている。
伸張装置に限らず、通常のデータ圧縮伸張装置では、数
値列に対し、データ変換(FFT,DCT等)を施し、
その後に量子化を行っている。
【0008】図11は従来のデータ圧縮伸張装置のブロ
ック図である。10はデータ記憶装置であり、データ記
憶装置10には圧縮を施そうとする2次元データがパラ
レルデータの形で蓄えられている。データ記憶装置10
に蓄えられているデータ(例えば、画像データ)はパラ
レル−シリアル変換装置11に入力され、パラレル−シ
リアル変換装置11はデータ記憶装置10から読み込ん
だパラレルデータをシリアルデータに変換してデータ変
換演算装置12に出力する。データ変換演算装置12は
パラレル−シリアル変換装置11から出力されたデータ
に対して一次元のDCT演算をシリアル演算の形で施
す。シリアルDCT演算されたデータはシリアル−パラ
レル変換装置13に出力され、シリアル−パラレル変換
装置13はデータ変換演算装置12から出力されたシリ
アルデータをパラレルデータに変換してデータ記憶装置
10に書き込む。上記の例は一次元の場合であり、画像
等の二次元の場合には図12に示すように上述した処理
を縦横(順不同)二次元に施す。また、量子化装置14
は、データ記憶装置10に蓄えられたデータ変換演算後
のデータに対して、例えば図13に示すような量子化テ
ーブルの値で除算をする(あるいは、逆数の乗算)こと
によって量子化演算を行なう。上記各部の動作はデータ
圧縮伸張装置の全体を制御する制御装置15によって制
御される。
ック図である。10はデータ記憶装置であり、データ記
憶装置10には圧縮を施そうとする2次元データがパラ
レルデータの形で蓄えられている。データ記憶装置10
に蓄えられているデータ(例えば、画像データ)はパラ
レル−シリアル変換装置11に入力され、パラレル−シ
リアル変換装置11はデータ記憶装置10から読み込ん
だパラレルデータをシリアルデータに変換してデータ変
換演算装置12に出力する。データ変換演算装置12は
パラレル−シリアル変換装置11から出力されたデータ
に対して一次元のDCT演算をシリアル演算の形で施
す。シリアルDCT演算されたデータはシリアル−パラ
レル変換装置13に出力され、シリアル−パラレル変換
装置13はデータ変換演算装置12から出力されたシリ
アルデータをパラレルデータに変換してデータ記憶装置
10に書き込む。上記の例は一次元の場合であり、画像
等の二次元の場合には図12に示すように上述した処理
を縦横(順不同)二次元に施す。また、量子化装置14
は、データ記憶装置10に蓄えられたデータ変換演算後
のデータに対して、例えば図13に示すような量子化テ
ーブルの値で除算をする(あるいは、逆数の乗算)こと
によって量子化演算を行なう。上記各部の動作はデータ
圧縮伸張装置の全体を制御する制御装置15によって制
御される。
【0009】上記データ変換演算装置12により実行さ
れるシリアルDCT演算を以下に説明するシリアル演算
によって行なう。
れるシリアルDCT演算を以下に説明するシリアル演算
によって行なう。
【0010】先ず、基本的な考え方としてCOS係数の値
を、数3に示すように2のべき(すなわち、2のn乗)
の和又は差で表すようにする。数3に示すように数値を
2のべきで表現する理由はシリアルの回路による演算を
実現するためである。すなわち、図14において、符号
21は、クロック入力信号に応答し、入力信号を1クロ
ック遅れた出力とするFF(フリップフロップ)からな
る1タイムディレイユニットを表すものとすると、1タ
イムディレイユニット21を通って出てくる出力と1タ
イムディレイユニット21を通らずに直接出てくる出力
とを比較すると前者が後者より1クロック分遅い。ここ
で、1タイムディレイユニット21はシフトレジスタが
並んだようなものであり、例えばLSB側から順にデー
タが入力されているものとすると、1クロック遅く出て
くるということは2倍されたことを意味する。同様に、
8倍しようとする場合には上記1タイムディレイユニッ
ト21を図15に示すように3つ並べて3クロック遅ら
せるようにすれば23で8倍となる。本実施例では上記
ユニットを組み合わせて加減算を行なうことでシリアル
演算回路を実現する。
を、数3に示すように2のべき(すなわち、2のn乗)
の和又は差で表すようにする。数3に示すように数値を
2のべきで表現する理由はシリアルの回路による演算を
実現するためである。すなわち、図14において、符号
21は、クロック入力信号に応答し、入力信号を1クロ
ック遅れた出力とするFF(フリップフロップ)からな
る1タイムディレイユニットを表すものとすると、1タ
イムディレイユニット21を通って出てくる出力と1タ
イムディレイユニット21を通らずに直接出てくる出力
とを比較すると前者が後者より1クロック分遅い。ここ
で、1タイムディレイユニット21はシフトレジスタが
並んだようなものであり、例えばLSB側から順にデー
タが入力されているものとすると、1クロック遅く出て
くるということは2倍されたことを意味する。同様に、
8倍しようとする場合には上記1タイムディレイユニッ
ト21を図15に示すように3つ並べて3クロック遅ら
せるようにすれば23で8倍となる。本実施例では上記
ユニットを組み合わせて加減算を行なうことでシリアル
演算回路を実現する。
【0011】図16は乗算部のシリアル演算構成を示し
たものであり、図16は入力データを38倍する場合の
例である。先ず、38を数4の形に分解する。
たものであり、図16は入力データを38倍する場合の
例である。先ず、38を数4の形に分解する。
【0012】数4において、ある数値xを32倍すると
いうことは、xを左(MBS方向)へ5回シフトするこ
とであり、図16では、5段の1タイムディレイユニッ
ト271を通過させることによって実現される。また、
数4で示される2×(2+1)は、実際には、6である
から、4+2と表してもよい。しかし、図16のフルア
ダー22が1タイムディレイユニットを持っており、入
力データを2倍するため、2×(2+1)という表現形
式が採用できる。この図16のユニット自体の出力は7
6倍となるが、次段の取り込みタイミングを1クロック
遅らせることにより38倍を実現している。
いうことは、xを左(MBS方向)へ5回シフトするこ
とであり、図16では、5段の1タイムディレイユニッ
ト271を通過させることによって実現される。また、
数4で示される2×(2+1)は、実際には、6である
から、4+2と表してもよい。しかし、図16のフルア
ダー22が1タイムディレイユニットを持っており、入
力データを2倍するため、2×(2+1)という表現形
式が採用できる。この図16のユニット自体の出力は7
6倍となるが、次段の取り込みタイミングを1クロック
遅らせることにより38倍を実現している。
【0013】以下、データ圧縮伸張装置を図面に従い説
明する。
明する。
【0014】図17は、上記シリアルDCT演算を実行
するためのデータ変換演算装置12の回路構成を示す図
であり、I〜IVの各ステージから構成される。
するためのデータ変換演算装置12の回路構成を示す図
であり、I〜IVの各ステージから構成される。
【0015】図17において、31はステージIの演算
回路、32はステージIIの演算回路、33はステージII
Iの演算回路、34はステージIVの演算回路であり、こ
れらのステージI〜IVの演算回路31〜34はそれぞれ
スイッチ35〜39を介して直列に接続するように構成
されている。この場合、DCT演算処理では、図17に
示すように演算回路31〜34の順で直列接続され、ま
た逆DCT演算の処理では、スイッチ35〜39の切換
え動作により演算回路34〜31の順で直接接続される
ようになっている。そして、入力端子40に与えられる
入力データに対するDCTまたは逆DCT演算結果は出
力端子41から出力されるようになる。この場合、入力
データは、シリアル8系統よりなっている。
回路、32はステージIIの演算回路、33はステージII
Iの演算回路、34はステージIVの演算回路であり、こ
れらのステージI〜IVの演算回路31〜34はそれぞれ
スイッチ35〜39を介して直列に接続するように構成
されている。この場合、DCT演算処理では、図17に
示すように演算回路31〜34の順で直列接続され、ま
た逆DCT演算の処理では、スイッチ35〜39の切換
え動作により演算回路34〜31の順で直接接続される
ようになっている。そして、入力端子40に与えられる
入力データに対するDCTまたは逆DCT演算結果は出
力端子41から出力されるようになる。この場合、入力
データは、シリアル8系統よりなっている。
【0016】図18は、ステージIの演算回路31の回
路構成を示す図である。演算回路31は上述したシリア
ル演算を実行するものであり、加算器1a、1b、1
c、1dと減算器1e、1f、1g、1hから構成され
ている。
路構成を示す図である。演算回路31は上述したシリア
ル演算を実行するものであり、加算器1a、1b、1
c、1dと減算器1e、1f、1g、1hから構成され
ている。
【0017】図19は、ステージIIの演算回路32の回
路構成を示す図である。演算回路32は上述したシリア
ル演算を実行するものであり、シフタ2a〜2fと、CO
S(4/16)π演算(数1参照)を行なうCOS(4/16)π演算器
2g、2hから構成されている。ここで、上記シフタ2
a〜2fは、それぞれ10個のフリップフロップを直列
接続したものであり、入力されたデータを所定時間遅延
して出力するようになっている。また、上記COS(4/16)
π演算器2gは、COS(N/16)πのN=4の場合の近似式1
81=(16-1)×(2+1)×4+1の演算を実現したものであり、
加算器2g1、この加算器2g1の出力をシフトする4個
のフリップフロップからなるシフタ2g2、このシフタ
2g2の出力より加算器2g1からの出力を減算する減算
器2g3、この減算器2g3の出力をシフトする1個のフ
リップフロップからなるシフタ2g4、このシフタ2g4
の出力と上記減算器2g3の出力を加算する加算器2g
5、この加算器2g5の出力と上記加算器2g1の出力を
加算する加算器2g6から構成されている。また、上記C
OS(4/16)π演算器2hもCOS(N/16)πのN=4の場合の
近似式181=(16-1)×(2+1)×4+1の演算を実現したもので
あり、減算器2h1、この減算器2h1の出力をシフトす
る4個のフリップフロップからなるシフタ2h2、この
シフタ2h2の出力より減算器2h1の出力を減算する減
算器2h3、この減算器2h3の出力をシフトする1個の
フリップフロップからなるシフタ2h4、このシフタ2
h4の出力と減算器2h3の出力を加算する加算器2h
5、この加算器2h5の出力と減算器2h1の出力を加算
する加算器2h6から構成されている。
路構成を示す図である。演算回路32は上述したシリア
ル演算を実行するものであり、シフタ2a〜2fと、CO
S(4/16)π演算(数1参照)を行なうCOS(4/16)π演算器
2g、2hから構成されている。ここで、上記シフタ2
a〜2fは、それぞれ10個のフリップフロップを直列
接続したものであり、入力されたデータを所定時間遅延
して出力するようになっている。また、上記COS(4/16)
π演算器2gは、COS(N/16)πのN=4の場合の近似式1
81=(16-1)×(2+1)×4+1の演算を実現したものであり、
加算器2g1、この加算器2g1の出力をシフトする4個
のフリップフロップからなるシフタ2g2、このシフタ
2g2の出力より加算器2g1からの出力を減算する減算
器2g3、この減算器2g3の出力をシフトする1個のフ
リップフロップからなるシフタ2g4、このシフタ2g4
の出力と上記減算器2g3の出力を加算する加算器2g
5、この加算器2g5の出力と上記加算器2g1の出力を
加算する加算器2g6から構成されている。また、上記C
OS(4/16)π演算器2hもCOS(N/16)πのN=4の場合の
近似式181=(16-1)×(2+1)×4+1の演算を実現したもので
あり、減算器2h1、この減算器2h1の出力をシフトす
る4個のフリップフロップからなるシフタ2h2、この
シフタ2h2の出力より減算器2h1の出力を減算する減
算器2h3、この減算器2h3の出力をシフトする1個の
フリップフロップからなるシフタ2h4、このシフタ2
h4の出力と減算器2h3の出力を加算する加算器2h
5、この加算器2h5の出力と減算器2h1の出力を加算
する加算器2h6から構成されている。
【0018】図20は、ステージIIIの演算回路33の
回路構成を示す図である。演算回路33は上述したシリ
アル演算を実行するものであり、加算器3a,3b、減
算器3c,3dおよび加算器3e,3f、減算器3g,
3hから構成されている。
回路構成を示す図である。演算回路33は上述したシリ
アル演算を実行するものであり、加算器3a,3b、減
算器3c,3dおよび加算器3e,3f、減算器3g,
3hから構成されている。
【0019】図21は、ステージIVの演算回路34の回
路構成を示す図である。演算回路34は上述したシリア
ル演算を実行するものであり、各COS係数演算を行なうC
OS(4/16)π演算器4a,4b、COS(2/16)πおよびCOS(6
/16)π演算器4c,4d、COS(1/16)πおよびCOS(7/16)
π演算器4e,4f、COS(3/16)πおよびCOS(5/16)π演
算器4g,4hから構成されている。この場合、上記CO
S(4/16)π演算器4a,4bは、上述したステージIIの
演算回路32のCOS(4/16)π演算器2g,2hと同様で
あり、ここでは添字2を4に代えて同符号を付すること
で説明は省略する。
路構成を示す図である。演算回路34は上述したシリア
ル演算を実行するものであり、各COS係数演算を行なうC
OS(4/16)π演算器4a,4b、COS(2/16)πおよびCOS(6
/16)π演算器4c,4d、COS(1/16)πおよびCOS(7/16)
π演算器4e,4f、COS(3/16)πおよびCOS(5/16)π演
算器4g,4hから構成されている。この場合、上記CO
S(4/16)π演算器4a,4bは、上述したステージIIの
演算回路32のCOS(4/16)π演算器2g,2hと同様で
あり、ここでは添字2を4に代えて同符号を付すること
で説明は省略する。
【0020】また、上記COS(2/16)πおよびCOS(6/16)π
演算器4cは、COS(N/16)πのN=2の場合の近似式23
6.5=4×(64-4-1)+1/2およびN=6の場合の98=2×(32+1
6+1)の演算を実現するもので、このうちCOS(2/16)πの
演算を実現するものは、7個のフリップフロップからな
るシフタ4c1、シフタ4c1の出力からシフタ4c1の
第3番目のフリップフロップの出力を減算する減算器4
c2、減算器4c2の出力からシフタ4c1の第2番目の
フリップフロップの出力を減算する減算器4c3、減算
器4c3の出力と加算器3aの出力を加算する加算器4
c4からなり、また、COS(6/16)π演算を実現するもの
は、シフタ4c1の第6番目のフリップフロップの出力
とシフタ4c1の第5番目のフリップフロップの出力を
加算する加算器4c5、加算器4c5の出力とシフタ4c
1の第2番目のフリップフロップの出力を加算する加算
器4c6からなっている。一方、上記COS(2/16)πおよび
COS(6/16)π演算器4dは、上述した演算回路4cと同
様であり、ここでは添字cをdに代えて同符号を付する
ことで説明は省略する。そして、加算器4c4と加算器
4d6の出力を加算器4c7で加算し、また、加算器4c
6の出力から加算器4d4の出力を減算器4d7で減算す
るようにしている。
演算器4cは、COS(N/16)πのN=2の場合の近似式23
6.5=4×(64-4-1)+1/2およびN=6の場合の98=2×(32+1
6+1)の演算を実現するもので、このうちCOS(2/16)πの
演算を実現するものは、7個のフリップフロップからな
るシフタ4c1、シフタ4c1の出力からシフタ4c1の
第3番目のフリップフロップの出力を減算する減算器4
c2、減算器4c2の出力からシフタ4c1の第2番目の
フリップフロップの出力を減算する減算器4c3、減算
器4c3の出力と加算器3aの出力を加算する加算器4
c4からなり、また、COS(6/16)π演算を実現するもの
は、シフタ4c1の第6番目のフリップフロップの出力
とシフタ4c1の第5番目のフリップフロップの出力を
加算する加算器4c5、加算器4c5の出力とシフタ4c
1の第2番目のフリップフロップの出力を加算する加算
器4c6からなっている。一方、上記COS(2/16)πおよび
COS(6/16)π演算器4dは、上述した演算回路4cと同
様であり、ここでは添字cをdに代えて同符号を付する
ことで説明は省略する。そして、加算器4c4と加算器
4d6の出力を加算器4c7で加算し、また、加算器4c
6の出力から加算器4d4の出力を減算器4d7で減算す
るようにしている。
【0021】一方、上記COS(1/16)πおよびCOS(7/16)π
演算器4eは、COS(N/16)πのN=1の場合の近似式251
=(128-2)×2-1およびN=7の場合の50=2×(16+8+1)の
演算を実現するもので、このうちCOS(1/16)πの演算を
実現するものは、7個のフリップフロップからなるシフ
タ4e1、シフタ4e1の出力からシフタの第1番目のフ
リップフロップの出力を減算する減算器4e2、減算器
4e2の出力からステージIIIの演算回路33の加算器3
eの出力を減算する減算器4e3からなり、COS(7/16)π
演算を実現するもので、シフタ4e1の第3番目と第4
番目のフリップフロップの出力を加算する加算器4e
4、加算器4e4、の出力とシフタ4e1の第1番目のフ
リップフロップの出力を加算する加算器4e5からなっ
ている。また、COS(1/16)πおよびCOS(7/16)π演算器4
fは、上述した演算器4eと同様であり、ここでは添字
eをfに代えて同符号を付することで説明は省略する。
そして、減算器4e3と加算器4f5の出力を加算器4e
6で加算し、この加算器4e6の出力をシフタ4e7を介
して発生する。また加算器4e5の出力から減算器4f3
の出力を減算器4f6で減算し、シフタ4f7を介して発
生するようにしている。また、上記COS(5/16)πおよびC
OS(3/16)π演算器4gは、COS(N/16)πのN=5の場合
の近似式142=2×(64+8-1)およびN=3の場合の近似式2
13=(2+1)×(64+8-1)の演算を実現するもので、このうち
COS(5/16)πの演算を実現するものは、5個のフリップ
フロップからなるシフタ4g1、シフタ4g1の出力とシ
フタ4g1の第2番目のフリップフロップの出力を加算
する加算器4g2、加算器4g2の出力からステージIII
の演算回路3の減算器3gの出力を減算する減算器4g
3、減算器4g3の出力をシフトする2個のフリップフロ
ップからなるシフタ4g4からなり、COS(3/16)πの演算
を実現するものは、上述の構成に加えて減算器4g3と
シフタ4g4の第1番目のフリップフロップの出力を加
算する加算器4g5からなっている。また、COS(5/16)π
およびCOS(3/16)π演算器4hは、上述した演算器4g
と同様であり、ここでは添字gをhに代えて同符号を付
することで説明は省略する。そして、シフタ4g4と加
算器4h5の出力を加算器4g6で加算し、また、加算器
4g5の出力からシフタ4h4の出力を減算器4h6で減
算するようにしている。
演算器4eは、COS(N/16)πのN=1の場合の近似式251
=(128-2)×2-1およびN=7の場合の50=2×(16+8+1)の
演算を実現するもので、このうちCOS(1/16)πの演算を
実現するものは、7個のフリップフロップからなるシフ
タ4e1、シフタ4e1の出力からシフタの第1番目のフ
リップフロップの出力を減算する減算器4e2、減算器
4e2の出力からステージIIIの演算回路33の加算器3
eの出力を減算する減算器4e3からなり、COS(7/16)π
演算を実現するもので、シフタ4e1の第3番目と第4
番目のフリップフロップの出力を加算する加算器4e
4、加算器4e4、の出力とシフタ4e1の第1番目のフ
リップフロップの出力を加算する加算器4e5からなっ
ている。また、COS(1/16)πおよびCOS(7/16)π演算器4
fは、上述した演算器4eと同様であり、ここでは添字
eをfに代えて同符号を付することで説明は省略する。
そして、減算器4e3と加算器4f5の出力を加算器4e
6で加算し、この加算器4e6の出力をシフタ4e7を介
して発生する。また加算器4e5の出力から減算器4f3
の出力を減算器4f6で減算し、シフタ4f7を介して発
生するようにしている。また、上記COS(5/16)πおよびC
OS(3/16)π演算器4gは、COS(N/16)πのN=5の場合
の近似式142=2×(64+8-1)およびN=3の場合の近似式2
13=(2+1)×(64+8-1)の演算を実現するもので、このうち
COS(5/16)πの演算を実現するものは、5個のフリップ
フロップからなるシフタ4g1、シフタ4g1の出力とシ
フタ4g1の第2番目のフリップフロップの出力を加算
する加算器4g2、加算器4g2の出力からステージIII
の演算回路3の減算器3gの出力を減算する減算器4g
3、減算器4g3の出力をシフトする2個のフリップフロ
ップからなるシフタ4g4からなり、COS(3/16)πの演算
を実現するものは、上述の構成に加えて減算器4g3と
シフタ4g4の第1番目のフリップフロップの出力を加
算する加算器4g5からなっている。また、COS(5/16)π
およびCOS(3/16)π演算器4hは、上述した演算器4g
と同様であり、ここでは添字gをhに代えて同符号を付
することで説明は省略する。そして、シフタ4g4と加
算器4h5の出力を加算器4g6で加算し、また、加算器
4g5の出力からシフタ4h4の出力を減算器4h6で減
算するようにしている。
【0022】このように構成された図18〜図21に示
すステージI〜IVの演算回路31〜34は、DCT演算
処理の場合、図22に示すように接続される。また、図
23〜図25は図22中の各ユニットを示す図であり、
図23はFFからなる1タイムディレイユニット21
を、図24は加算(a+b)を行なう1タイムディレイ
ユニットフルアダー(内部Carry Type)22を、図25
は減算(a−b)を行なう1タイムディレイユニットフ
ルサブトラクタ(内部Borrow type)23をそれぞれ示
している。
すステージI〜IVの演算回路31〜34は、DCT演算
処理の場合、図22に示すように接続される。また、図
23〜図25は図22中の各ユニットを示す図であり、
図23はFFからなる1タイムディレイユニット21
を、図24は加算(a+b)を行なう1タイムディレイ
ユニットフルアダー(内部Carry Type)22を、図25
は減算(a−b)を行なう1タイムディレイユニットフ
ルサブトラクタ(内部Borrow type)23をそれぞれ示
している。
【0023】次に、このように構成したデータ変換演算
装置12の動作を説明する。
装置12の動作を説明する。
【0024】まず、DCT演算処理の場合を述べると、
ここでは、ステージIの演算回路31において加算器1
aに入力データf(0)とf(7)、加算器1bに入力
データf(3)、f(4)、加算器1cに入力データf
(1)、f(6)、加算器1dに入力データf(2)、
f(5)、減算器1eに入力データf(0)、f
(7)、減算器1fに入力データf(3)、f(4)、
減算器1gに入力データf(1)、f(6)、減算器1
hに入力データf(2)、f(5)が入力される。これ
により加算器1aは入力データf(0)とf(7)の加
算結果を出力し、加算器1bは入力データf(3)とf
(4)の加算結果を出力し、加算器1cは入力データf
(1)とf(6)の加算結果f(1)+f(6)を出力
し、加算器1dは入力データf(2)とf(5)の加算
結果を出力するようになる。また、減算器1eは入力デ
ータf(0)とf(7)の減算結果を出力し、減算器1
fは入力データf(3)とf(4)の減算結果を出力
し、減算器1gは入力データf(1)とf(6)の減算
結果を出力し、減算器1hは入力データf(2)とf
(5)の減算結果を出力するようになる。この場合の入
力データは、図26に示すように7bitと1bitのサイン
ビットの8bitのデータからなっている。また、出力デ
ータは、図26のIに示すように7+1bitと1bitのサ
インビットからなっている。ここで、出力データが7+
1bitになるのは、加算器1a〜1dでの加算結果を考
慮したからである。
ここでは、ステージIの演算回路31において加算器1
aに入力データf(0)とf(7)、加算器1bに入力
データf(3)、f(4)、加算器1cに入力データf
(1)、f(6)、加算器1dに入力データf(2)、
f(5)、減算器1eに入力データf(0)、f
(7)、減算器1fに入力データf(3)、f(4)、
減算器1gに入力データf(1)、f(6)、減算器1
hに入力データf(2)、f(5)が入力される。これ
により加算器1aは入力データf(0)とf(7)の加
算結果を出力し、加算器1bは入力データf(3)とf
(4)の加算結果を出力し、加算器1cは入力データf
(1)とf(6)の加算結果f(1)+f(6)を出力
し、加算器1dは入力データf(2)とf(5)の加算
結果を出力するようになる。また、減算器1eは入力デ
ータf(0)とf(7)の減算結果を出力し、減算器1
fは入力データf(3)とf(4)の減算結果を出力
し、減算器1gは入力データf(1)とf(6)の減算
結果を出力し、減算器1hは入力データf(2)とf
(5)の減算結果を出力するようになる。この場合の入
力データは、図26に示すように7bitと1bitのサイン
ビットの8bitのデータからなっている。また、出力デ
ータは、図26のIに示すように7+1bitと1bitのサ
インビットからなっている。ここで、出力データが7+
1bitになるのは、加算器1a〜1dでの加算結果を考
慮したからである。
【0025】次いで、ステージIIの演算回路32に進
む。この演算回路32では、ステージIの演算回路31
の加算器1aの出力がシフタ2aに与えられ、以下、同
様にして加算器1bの出力がシフタ2c、加算器1cの
出力がシフタ2b、加算器1dの出力がシフタ2d、減
算器1eの出力がシフタ2e、減算器1fの出力がシフ
タ2f、減算器1g、1hの出力が加算器2g1および
減算器2h1にそれぞれ与えられる。この場合、図26
の入力に示す入力データに対しシフタ2a〜2eからは
同図IIに示すように10個のフリップフロップの動作だ
け遅れて出力データを発生する。つまり、シフタ2aは
加算器1aの出力を、シフタ2bは加算器1cの出力
を、シフタ2cは加算器1bの出力を、シフタ2dは加
算器1dの出力を、シフタ2eは加算器1eの出力を、
シフタ2fは加算器1fの出力を、それぞれ所定時間遅
延して出力するようになる。
む。この演算回路32では、ステージIの演算回路31
の加算器1aの出力がシフタ2aに与えられ、以下、同
様にして加算器1bの出力がシフタ2c、加算器1cの
出力がシフタ2b、加算器1dの出力がシフタ2d、減
算器1eの出力がシフタ2e、減算器1fの出力がシフ
タ2f、減算器1g、1hの出力が加算器2g1および
減算器2h1にそれぞれ与えられる。この場合、図26
の入力に示す入力データに対しシフタ2a〜2eからは
同図IIに示すように10個のフリップフロップの動作だ
け遅れて出力データを発生する。つまり、シフタ2aは
加算器1aの出力を、シフタ2bは加算器1cの出力
を、シフタ2cは加算器1bの出力を、シフタ2dは加
算器1dの出力を、シフタ2eは加算器1eの出力を、
シフタ2fは加算器1fの出力を、それぞれ所定時間遅
延して出力するようになる。
【0026】一方、上記COS(4/16)π演算器2g、2h
では、COS(N/16)πのN=4の場合の近似式181=(16-1)
×(2+1)×4+1の演算を実行する。この場合、演算器2g
には、減算器1g、1hの出力が入力データとして与え
られ、加算器2g1で、これら入力データを加算する。
そして、この加算器2g1の出力をシフタ2g2に与え、
シフタ2g2より得られた出力より加算器2g1の出力を
減算器2g3で減算すると(16-1)が求められ、次いで、
減算器2g3の出力とシフタ2g4の出力を加算器2g5
で加算することで(16-1)×(2+1)が求められる。そし
て、この加算器2g5の出力と加算器2g1の出力を加算
器2g6で加算することによりCOS(N/16)πのN=4の場
合の近似値(16-1)×(2+1)×4+1が求められることにな
る。この場合、図26の入力に示す入力データに対して
COS(4/16)π演算器2gでは、同図IIに示すタイミング
で上述の演算結果を出力データとして発生するようにな
る。
では、COS(N/16)πのN=4の場合の近似式181=(16-1)
×(2+1)×4+1の演算を実行する。この場合、演算器2g
には、減算器1g、1hの出力が入力データとして与え
られ、加算器2g1で、これら入力データを加算する。
そして、この加算器2g1の出力をシフタ2g2に与え、
シフタ2g2より得られた出力より加算器2g1の出力を
減算器2g3で減算すると(16-1)が求められ、次いで、
減算器2g3の出力とシフタ2g4の出力を加算器2g5
で加算することで(16-1)×(2+1)が求められる。そし
て、この加算器2g5の出力と加算器2g1の出力を加算
器2g6で加算することによりCOS(N/16)πのN=4の場
合の近似値(16-1)×(2+1)×4+1が求められることにな
る。この場合、図26の入力に示す入力データに対して
COS(4/16)π演算器2gでは、同図IIに示すタイミング
で上述の演算結果を出力データとして発生するようにな
る。
【0027】次いで、ステージIIIの演算回路33に進
む。この演算回路33では、ステージIIの演算回路32
のシフタ2a、2cの出力が加算器3aおよび減算器3
cに与えられ、同様にしてシフタ2b、2dの出力が加
算器3bおよび減算器3dに与えられ、さらにシフタ2
eとCOS(4/16)π演算部2gの出力が加算器3eおよび
減算器3gに、シフタ2fとCOS(4/16)π演算器2hの
出力が加算器3fおよび減算器3hに与えられる。これ
により、加算器3aは、ステージIIの演算回路32のシ
フタ2aと2cの出力を加算した結果を出力し、加算器
3bはステージIIの演算回路32のシフタ2bと2dの
出力を加算した結果を出力し、減算器3cはステージII
の演算回路32のシフタ2aの出力からシフタ2cの出
力を減算した結果を出力し、減算器3dはステージIIの
演算回路32のシフタ2bの出力からシフタ2dの出力
を減算した結果を出力するようになる。また、加算器3
eはステージIIの演算回路2のシフタ2eと演算器2g
の出力を加算した結果を出力し、加算器3fはステージ
IIの演算回路2のシフタ2fと加算器2hの出力を加算
した結果を出力し、加算器3gはステージIIの演算回路
32のシフタ2eの出力から演算器2gの出力を減算し
た結果を出力し、減算器3hはステージIIの演算回路3
2のシフタ2fの出力から演算器2hの出力を減算した
結果を出力するようになる。この場合、図26の入力デ
ータに対して各加算器3a、3b、3e、3fおよび減
算器3c、3d、3g、3hでは、同図IVに示すタイミ
ングで、それぞれの演算結果を出力するようになる。
む。この演算回路33では、ステージIIの演算回路32
のシフタ2a、2cの出力が加算器3aおよび減算器3
cに与えられ、同様にしてシフタ2b、2dの出力が加
算器3bおよび減算器3dに与えられ、さらにシフタ2
eとCOS(4/16)π演算部2gの出力が加算器3eおよび
減算器3gに、シフタ2fとCOS(4/16)π演算器2hの
出力が加算器3fおよび減算器3hに与えられる。これ
により、加算器3aは、ステージIIの演算回路32のシ
フタ2aと2cの出力を加算した結果を出力し、加算器
3bはステージIIの演算回路32のシフタ2bと2dの
出力を加算した結果を出力し、減算器3cはステージII
の演算回路32のシフタ2aの出力からシフタ2cの出
力を減算した結果を出力し、減算器3dはステージIIの
演算回路32のシフタ2bの出力からシフタ2dの出力
を減算した結果を出力するようになる。また、加算器3
eはステージIIの演算回路2のシフタ2eと演算器2g
の出力を加算した結果を出力し、加算器3fはステージ
IIの演算回路2のシフタ2fと加算器2hの出力を加算
した結果を出力し、加算器3gはステージIIの演算回路
32のシフタ2eの出力から演算器2gの出力を減算し
た結果を出力し、減算器3hはステージIIの演算回路3
2のシフタ2fの出力から演算器2hの出力を減算した
結果を出力するようになる。この場合、図26の入力デ
ータに対して各加算器3a、3b、3e、3fおよび減
算器3c、3d、3g、3hでは、同図IVに示すタイミ
ングで、それぞれの演算結果を出力するようになる。
【0028】次いで、ステージIVの演算回路34に進
む。この演算回路34では、ステージIIIの演算回路3
3の加算器3a、3bの出力がCOS(4/16)π演算器4
a、4bに与えられ、同様にして減算器3c、3dがCO
S(2/16)πおよびCOS(6/16)π演算器4c、4dに各別に
与えられ、加算器3e、3fの出力がCOS(1/16)πおよ
びCOS(7/16)π演算器4e、4fに各別に与えられ、減
算器3g、3hの出力がCOS(5/16)πおよびCOS(3/16)π
演算器4g、4hに各別に与えられる。この場合、図2
6の入力データに対してCOS(4/16)π演算器4a、4b
では、COS(N/16)πのN=4の場合の近似値(6-1)×(2+
1)×4+1の演算を実行し、同図IVに示すタイミングで、
その演算結果を出力データF(0)、F(4)として発
生する。同様にして、COS(2/16)πおよびCOS(6/16)π演
算器4c、4dについてもCOS(N/16)πN=2の場合の
近似値4×(64-4-1)+1/2およびCOS(N/16)πのN=6の場
合の近似値2×(32+16+1)の演算を実行し、同図IVに示す
タイミングで、その演算結果を出力データF(2)、F
(6)として発生し、COS(1/16)πおよびCOS(7/16)π演
算器4e、4fについてもCOS(N/16)πのN=1の場合
の近似値251=(128-2)×2-1 およびCOS(N/16)πのN=7
の場合の近似値2×(16+8+1)の演算を実行し、同図IVに
示すタイミングで、その演算結果を出力データF
(1)、F(7)として発生し、さらに、COS(5/16)π
およびCOS(3/16)π演算器4g、4hについてもCOS(N/1
6)πのN=5の場合の近似値2×(64+8-1)およびCOS(N/1
6)πのN=3の場合の近似値(2+1)×(64+8-1)の演算を
実行し、同図IVに示すタイミングで、その演算結果を出
力データF(5)、F(3)として発生するようにな
る。
む。この演算回路34では、ステージIIIの演算回路3
3の加算器3a、3bの出力がCOS(4/16)π演算器4
a、4bに与えられ、同様にして減算器3c、3dがCO
S(2/16)πおよびCOS(6/16)π演算器4c、4dに各別に
与えられ、加算器3e、3fの出力がCOS(1/16)πおよ
びCOS(7/16)π演算器4e、4fに各別に与えられ、減
算器3g、3hの出力がCOS(5/16)πおよびCOS(3/16)π
演算器4g、4hに各別に与えられる。この場合、図2
6の入力データに対してCOS(4/16)π演算器4a、4b
では、COS(N/16)πのN=4の場合の近似値(6-1)×(2+
1)×4+1の演算を実行し、同図IVに示すタイミングで、
その演算結果を出力データF(0)、F(4)として発
生する。同様にして、COS(2/16)πおよびCOS(6/16)π演
算器4c、4dについてもCOS(N/16)πN=2の場合の
近似値4×(64-4-1)+1/2およびCOS(N/16)πのN=6の場
合の近似値2×(32+16+1)の演算を実行し、同図IVに示す
タイミングで、その演算結果を出力データF(2)、F
(6)として発生し、COS(1/16)πおよびCOS(7/16)π演
算器4e、4fについてもCOS(N/16)πのN=1の場合
の近似値251=(128-2)×2-1 およびCOS(N/16)πのN=7
の場合の近似値2×(16+8+1)の演算を実行し、同図IVに
示すタイミングで、その演算結果を出力データF
(1)、F(7)として発生し、さらに、COS(5/16)π
およびCOS(3/16)π演算器4g、4hについてもCOS(N/1
6)πのN=5の場合の近似値2×(64+8-1)およびCOS(N/1
6)πのN=3の場合の近似値(2+1)×(64+8-1)の演算を
実行し、同図IVに示すタイミングで、その演算結果を出
力データF(5)、F(3)として発生するようにな
る。
【0029】以上の説明は、DCT演算処理の場合であ
るが、逆DCT演算処理の場合も上述したと同様であ
る。
るが、逆DCT演算処理の場合も上述したと同様であ
る。
【0030】この場合は入力データがステージIVの演算
回路34〜ステージIの演算回路31の順で与えられる
ようになる。
回路34〜ステージIの演算回路31の順で与えられる
ようになる。
【0031】図26は、データ変換演算装置12の入力
から出力までのタイミングチャートであり、ステージI
の演算回路31〜ステージIVの演算回路34の動作を総
合した場合のタイミングチャートを示している。同図
中、I、II、III、IVは図22における各ステージI、I
I、III、IVの出力を示している。図26では、次データ
との処理の重なりを避けるように考慮してあり全体とし
て8bitのデータを入力した場合、1ライン当りの処理
周期は28クロック必要とする。この場合の処理は、入
力データ8bitのDCT処理の場合であるが、入力デー
タのビット数が異なる場合や逆DCT処理の場合は、1
データ当りの処理周期も変化するようになる。
から出力までのタイミングチャートであり、ステージI
の演算回路31〜ステージIVの演算回路34の動作を総
合した場合のタイミングチャートを示している。同図
中、I、II、III、IVは図22における各ステージI、I
I、III、IVの出力を示している。図26では、次データ
との処理の重なりを避けるように考慮してあり全体とし
て8bitのデータを入力した場合、1ライン当りの処理
周期は28クロック必要とする。この場合の処理は、入
力データ8bitのDCT処理の場合であるが、入力デー
タのビット数が異なる場合や逆DCT処理の場合は、1
データ当りの処理周期も変化するようになる。
【0032】このように、ステージI〜ステージIVから
なるフローグラフに基づいてディスクリートコサイン変
換処理を実行するものにおいて、各ステージをシリアル
処理するように構成することにより、入力データが各ス
テージの演算回路により順次シリアル処理されるように
なり、従来のメモリに対してレジスタ、シフタおよび加
減算器からなる演算部を並列的に設けたものに比べ、回
路規模を小さくすることができるとともに、高速処理を
実現することができる。
なるフローグラフに基づいてディスクリートコサイン変
換処理を実行するものにおいて、各ステージをシリアル
処理するように構成することにより、入力データが各ス
テージの演算回路により順次シリアル処理されるように
なり、従来のメモリに対してレジスタ、シフタおよび加
減算器からなる演算部を並列的に設けたものに比べ、回
路規模を小さくすることができるとともに、高速処理を
実現することができる。
【0033】
【発明が解決しようとする課題】しかしながら、このよ
うなシリアルDCT演算処理を行なうデータ圧縮伸張装
置にあっては、DCT演算式をそのままシリアル処理回
路上で実現する構成となっていたため、DCT演算を並
列的に行なうDCT演算装置に比べて回路規模は大幅に
小さくすることはできるものの、図16に示すようにフ
リップフロップ(FF)で126個、演算器を構成する
1bit Add(Sub)unitが 62個必要となり、未だ回路規
模が大きいという欠点があった。また、FF等を1段通
るごとに1クロック分遅延するので演算段数を短くする
ようにして高速化を図りたいという要望がある。
うなシリアルDCT演算処理を行なうデータ圧縮伸張装
置にあっては、DCT演算式をそのままシリアル処理回
路上で実現する構成となっていたため、DCT演算を並
列的に行なうDCT演算装置に比べて回路規模は大幅に
小さくすることはできるものの、図16に示すようにフ
リップフロップ(FF)で126個、演算器を構成する
1bit Add(Sub)unitが 62個必要となり、未だ回路規
模が大きいという欠点があった。また、FF等を1段通
るごとに1クロック分遅延するので演算段数を短くする
ようにして高速化を図りたいという要望がある。
【0034】そこで本発明は、小さな回路規模で高速に
データの圧縮を行なうことが可能なデータ圧縮伸張装置
を提供することを目的としている。
データの圧縮を行なうことが可能なデータ圧縮伸張装置
を提供することを目的としている。
【0035】
【課題を解決するための手段】請求項1記載の発明は、
上記目的達成のため、所定のデータを記憶するデータ記
憶手段と、前記データ記憶手段から出力されたデータに
対して所定の係数に基づいてシリアル演算によりデータ
変換演算を実行するデータ変換演算手段と、前記データ
変換演算手段によるデータ変換後のデータに対して量子
化演算を実行する量子化手段と、前記データ記憶手段、
前記データ変換演算手段及び前記量子化手段を制御をす
る制御手段とを備えたデータ圧縮伸張装置であって、前
記データ変換演算手段のデータ変換演算式を展開し、展
開した式に従って前記データ変換演算手段を構成するよ
うにしている。
上記目的達成のため、所定のデータを記憶するデータ記
憶手段と、前記データ記憶手段から出力されたデータに
対して所定の係数に基づいてシリアル演算によりデータ
変換演算を実行するデータ変換演算手段と、前記データ
変換演算手段によるデータ変換後のデータに対して量子
化演算を実行する量子化手段と、前記データ記憶手段、
前記データ変換演算手段及び前記量子化手段を制御をす
る制御手段とを備えたデータ圧縮伸張装置であって、前
記データ変換演算手段のデータ変換演算式を展開し、展
開した式に従って前記データ変換演算手段を構成するよ
うにしている。
【0036】請求項2記載の発明は、所定のデータを記
憶するデータ記憶手段と、前記データ記憶手段から出力
されたデータに対して所定の係数に基づいてシリアル演
算によりデータ変換演算を実行するデータ変換演算手段
と、前記データ変換演算手段によるデータ変換後のデー
タに対して量子化演算を実行する量子化手段と、前記デ
ータ記憶手段、前記データ変換演算手段及び前記量子化
手段を制御をする制御手段とを備えたデータ圧縮伸張装
置であって、前記データ変換演算手段の係数を整数の比
に置き換え、該整数の比に置き換えることにより生じた
ゲインの変化を、前記量子化手段により調整するように
するとともに、データ変換演算式を展開し、展開した式
に従って前記データ変換演算手段を構成するようにして
いる。
憶するデータ記憶手段と、前記データ記憶手段から出力
されたデータに対して所定の係数に基づいてシリアル演
算によりデータ変換演算を実行するデータ変換演算手段
と、前記データ変換演算手段によるデータ変換後のデー
タに対して量子化演算を実行する量子化手段と、前記デ
ータ記憶手段、前記データ変換演算手段及び前記量子化
手段を制御をする制御手段とを備えたデータ圧縮伸張装
置であって、前記データ変換演算手段の係数を整数の比
に置き換え、該整数の比に置き換えることにより生じた
ゲインの変化を、前記量子化手段により調整するように
するとともに、データ変換演算式を展開し、展開した式
に従って前記データ変換演算手段を構成するようにして
いる。
【0037】請求項3記載の発明は所定のデータを記憶
するデータ記憶手段と、前記データ記憶手段のデータを
パラレルデータからシリアルデータに変換するパラレル
−シリアル変換手段と、前記パラレル−シリアル変換手
段から出力されたデータに対して所定の係数に基づいて
シリアル演算によりデータ変換演算を実行するデータ変
換演算手段と、前記データ変換手段から出力されるシリ
アルデータをパラレルデータに変換し、前記データ記憶
手段に書き込むシリアル−パラレル変換手段と、前記デ
ータ変換演算手段によるデータ変換後のデータに対して
量子化演算を実行する量子化手段と、前記データ記憶手
段、前記パラレル−シリアル変換手段、前記データ変換
演算手段、前記シリアル−パラレル変換手段及び前記量
子化手段を制御をする制御手段とを備えたデータ圧縮伸
張装置であって、前記データ変換演算手段の係数を整数
の比に置き換え、該整数の比に置き換えることにより生
じたゲインの変化を、前記量子化手段により調整するよ
うにするとともに、データ変換演算式を展開し、展開し
た式に従って前記データ変換演算手段を構成するように
している。
するデータ記憶手段と、前記データ記憶手段のデータを
パラレルデータからシリアルデータに変換するパラレル
−シリアル変換手段と、前記パラレル−シリアル変換手
段から出力されたデータに対して所定の係数に基づいて
シリアル演算によりデータ変換演算を実行するデータ変
換演算手段と、前記データ変換手段から出力されるシリ
アルデータをパラレルデータに変換し、前記データ記憶
手段に書き込むシリアル−パラレル変換手段と、前記デ
ータ変換演算手段によるデータ変換後のデータに対して
量子化演算を実行する量子化手段と、前記データ記憶手
段、前記パラレル−シリアル変換手段、前記データ変換
演算手段、前記シリアル−パラレル変換手段及び前記量
子化手段を制御をする制御手段とを備えたデータ圧縮伸
張装置であって、前記データ変換演算手段の係数を整数
の比に置き換え、該整数の比に置き換えることにより生
じたゲインの変化を、前記量子化手段により調整するよ
うにするとともに、データ変換演算式を展開し、展開し
た式に従って前記データ変換演算手段を構成するように
している。
【0038】請求項4記載の発明は、所定のデータを記
憶するデータ記憶手段と、前記データ記憶手段から出力
されたデータに対して所定の係数に基づいてシリアル演
算によりデータ変換演算を実行するデータ変換演算手段
と、前記データ変換演算手段によるデータ変換後のデー
タに対して量子化演算を実行する量子化手段と、前記デ
ータ記憶手段、前記データ変換演算手段及び前記量子化
手段を制御をする制御手段とを備えたデータ圧縮伸張装
置であって、前記データ変換演算手段のデータ変換演算
式の係数の値を2のべきで表現するとともに、該係数の
値を2のべきで表現するとき所定以上ビット数が大きく
なる部分については該係数を整数の比に置き換え、該整
数の比に置き換えることにより生じたゲインの変化を、
前記量子化手段により調整するようにするとともに、デ
ータ変換演算式を展開し、展開した式に従って前記デー
タ変換演算手段を構成するようにしている。
憶するデータ記憶手段と、前記データ記憶手段から出力
されたデータに対して所定の係数に基づいてシリアル演
算によりデータ変換演算を実行するデータ変換演算手段
と、前記データ変換演算手段によるデータ変換後のデー
タに対して量子化演算を実行する量子化手段と、前記デ
ータ記憶手段、前記データ変換演算手段及び前記量子化
手段を制御をする制御手段とを備えたデータ圧縮伸張装
置であって、前記データ変換演算手段のデータ変換演算
式の係数の値を2のべきで表現するとともに、該係数の
値を2のべきで表現するとき所定以上ビット数が大きく
なる部分については該係数を整数の比に置き換え、該整
数の比に置き換えることにより生じたゲインの変化を、
前記量子化手段により調整するようにするとともに、デ
ータ変換演算式を展開し、展開した式に従って前記デー
タ変換演算手段を構成するようにしている。
【0039】前記データ変換演算手段は、例えば請求項
5に記載されているように、各入力に所定の係数が表れ
るようにデータ変換演算式を展開し、該展開したデータ
変換演算式の係数部分をシリアル演算する第1のシリア
ル演算部と、該第1のシリアル演算部の出力を加減算し
て該展開したデータ変換演算式の演算を実行する第2の
シリアル演算部とにより構成するようにしてもよく、前
記第1のシリアル演算部は、例えば請求項6に記載され
ているように、前記展開したデータ変換演算式の係数を
2のべきに数値をかけた形で表現するとともに、該係数
を2のべきに数値をかけた形で表現した場合の数値部分
をシリアル演算するシリアル回路により構成するように
してもよく、前記第2のシリアル演算部は、例えば請求
項7に記載されているように、前記第1のシリアル演算
部から出力された数値を加減算して出力する複数の加減
算器により構成され、前記展開したデータ変換演算式の
係数を2のべきに数値をかけた形で表現した場合の2の
べき部分を各加減算器への入力位置により調整するよう
にしてもよい。
5に記載されているように、各入力に所定の係数が表れ
るようにデータ変換演算式を展開し、該展開したデータ
変換演算式の係数部分をシリアル演算する第1のシリア
ル演算部と、該第1のシリアル演算部の出力を加減算し
て該展開したデータ変換演算式の演算を実行する第2の
シリアル演算部とにより構成するようにしてもよく、前
記第1のシリアル演算部は、例えば請求項6に記載され
ているように、前記展開したデータ変換演算式の係数を
2のべきに数値をかけた形で表現するとともに、該係数
を2のべきに数値をかけた形で表現した場合の数値部分
をシリアル演算するシリアル回路により構成するように
してもよく、前記第2のシリアル演算部は、例えば請求
項7に記載されているように、前記第1のシリアル演算
部から出力された数値を加減算して出力する複数の加減
算器により構成され、前記展開したデータ変換演算式の
係数を2のべきに数値をかけた形で表現した場合の2の
べき部分を各加減算器への入力位置により調整するよう
にしてもよい。
【0040】また、前記データ変換演算手段は、例えば
請求項8に記載されているように、データに対してシリ
アル演算により直交変換を実行する直交変換手段であっ
てもよく、前記データ変換演算手段は、例えば請求項9
に記載されているように、データに対してシリアル演算
により離散コサイン変換(DCT)を実行する離散コサ
イン変換手段であってもよい。また、前記データ変換演
算手段は、例えば請求項10に記載されているように、
入力されたデータを所定のクロックに応答して順次移動
させるシリアル演算器を含んで構成されてもよく、前記
データ変換演算手段は、例えば請求項11に記載されて
いるように、データ変換演算式の係数の値を2のべきで
表現したシリアル回路により構成し、該シリアル回路に
よるシリアル演算によりデータ変換演算を実行するよう
にしてもよく、さらには、前記データ変換演算手段は、
例えば請求項12に記載されているように、データ変換
演算式の係数の値を2のべきで表現するとともに、該係
数の値を2のべきで表現するとき所定以上ビット数が大
きくなる部分については該係数を整数の比に置き換えた
シリアル回路により構成し、該シリアル回路によるシリ
アル演算によりデータ変換演算を実行するようにしても
よい。
請求項8に記載されているように、データに対してシリ
アル演算により直交変換を実行する直交変換手段であっ
てもよく、前記データ変換演算手段は、例えば請求項9
に記載されているように、データに対してシリアル演算
により離散コサイン変換(DCT)を実行する離散コサ
イン変換手段であってもよい。また、前記データ変換演
算手段は、例えば請求項10に記載されているように、
入力されたデータを所定のクロックに応答して順次移動
させるシリアル演算器を含んで構成されてもよく、前記
データ変換演算手段は、例えば請求項11に記載されて
いるように、データ変換演算式の係数の値を2のべきで
表現したシリアル回路により構成し、該シリアル回路に
よるシリアル演算によりデータ変換演算を実行するよう
にしてもよく、さらには、前記データ変換演算手段は、
例えば請求項12に記載されているように、データ変換
演算式の係数の値を2のべきで表現するとともに、該係
数の値を2のべきで表現するとき所定以上ビット数が大
きくなる部分については該係数を整数の比に置き換えた
シリアル回路により構成し、該シリアル回路によるシリ
アル演算によりデータ変換演算を実行するようにしても
よい。
【0041】また、前記データ変換演算手段で用いられ
るデータ変換演算式は、例えば請求項13に記載されて
いるように、該データ変換演算式の係数を、前記量子化
手段の量子化演算に用いる量子化係数に含ませるように
作成してもよく、前記量子化手段によるゲインの調整
は、例えば請求項14に記載されているように、前記デ
ータ変換演算手段の係数を整数の比に変えることにより
生じたゲイン変化分を吸収させるように構成された量子
化テーブルにより行なわれるものであってもよい。さら
に、前記データ変換演算手段の係数の整数の比への置き
換えは、例えば請求項15に記載されているように、該
係数を整数値に置き換えることにより行なうようにする
ものであってもよい。
るデータ変換演算式は、例えば請求項13に記載されて
いるように、該データ変換演算式の係数を、前記量子化
手段の量子化演算に用いる量子化係数に含ませるように
作成してもよく、前記量子化手段によるゲインの調整
は、例えば請求項14に記載されているように、前記デ
ータ変換演算手段の係数を整数の比に変えることにより
生じたゲイン変化分を吸収させるように構成された量子
化テーブルにより行なわれるものであってもよい。さら
に、前記データ変換演算手段の係数の整数の比への置き
換えは、例えば請求項15に記載されているように、該
係数を整数値に置き換えることにより行なうようにする
ものであってもよい。
【0042】
【作用】本発明の手段はの作用は次の通りである。
【0043】請求項1記載の発明では、データ変換演算
手段のデータ変換演算式を各項毎に展開し、展開した式
に従ってシリアル回路を構成するようにしている。この
場合、展開した式に従って構成されるシリアル回路は、
例えば各入力に共通な係数が表れるようにデータ変換演
算式を展開したときに該係数部分をシリアル演算する第
1のシリアル演算部と、このシリアル演算部の出力を加
減算して展開したデータ変換演算式の演算を実行する第
2のシリアル演算部とにより構成され、各入力がこのシ
リアル回路に入力されると第1のシリアル演算部により
各入力をシリアル演算して係数分を求めておき、このよ
うにして作成された係数に対して第2のシリアル演算部
が加減算を行なって展開したデータ変換演算式の演算が
実行される。
手段のデータ変換演算式を各項毎に展開し、展開した式
に従ってシリアル回路を構成するようにしている。この
場合、展開した式に従って構成されるシリアル回路は、
例えば各入力に共通な係数が表れるようにデータ変換演
算式を展開したときに該係数部分をシリアル演算する第
1のシリアル演算部と、このシリアル演算部の出力を加
減算して展開したデータ変換演算式の演算を実行する第
2のシリアル演算部とにより構成され、各入力がこのシ
リアル回路に入力されると第1のシリアル演算部により
各入力をシリアル演算して係数分を求めておき、このよ
うにして作成された係数に対して第2のシリアル演算部
が加減算を行なって展開したデータ変換演算式の演算が
実行される。
【0044】従って、展開したデータ変換演算式に従っ
てシリアル回路を構成することによりシフトレジスタ等
のシリアル回路の段数を減少させてクロック数を減らす
ことができ、処理速度を向上させることができる。
てシリアル回路を構成することによりシフトレジスタ等
のシリアル回路の段数を減少させてクロック数を減らす
ことができ、処理速度を向上させることができる。
【0045】請求項2、3、4、5、6、7、8、9、
10、11、12、13、14及び15記載の発明で
は、データ変換演算手段の係数が整数の比に置き換えら
れ、そのゲインの変化は量子化手段により調整されると
ともに、データ変換演算式を展開し、展開した式に従っ
てシリアル回路を構成するようにしている。この場合、
シリアル回路は、例えば展開したデータ変換演算式の係
数を2のべきに数値をかけた形で表現した場合の数値部
分をシリアル演算する第1のシリアル演算部と、このシ
リアル演算部から出力された数値を加減算して出力する
複数の加減算器からなる第2のシリアル演算部とにより
構成され、各入力がこのシリアル回路に入力されると第
1のシリアル演算部により各入力をシリアル演算して係
数分を求め、このようにして作成された係数に対して第
2のシリアル演算部が加減算を行なって展開したデータ
変換演算式の演算が実行される。このとき、展開したデ
ータ変換演算式の係数を2のべきに数値をかけた形で表
現した場合の2のべき部分は各加減算器への入力位置に
より調整される。
10、11、12、13、14及び15記載の発明で
は、データ変換演算手段の係数が整数の比に置き換えら
れ、そのゲインの変化は量子化手段により調整されると
ともに、データ変換演算式を展開し、展開した式に従っ
てシリアル回路を構成するようにしている。この場合、
シリアル回路は、例えば展開したデータ変換演算式の係
数を2のべきに数値をかけた形で表現した場合の数値部
分をシリアル演算する第1のシリアル演算部と、このシ
リアル演算部から出力された数値を加減算して出力する
複数の加減算器からなる第2のシリアル演算部とにより
構成され、各入力がこのシリアル回路に入力されると第
1のシリアル演算部により各入力をシリアル演算して係
数分を求め、このようにして作成された係数に対して第
2のシリアル演算部が加減算を行なって展開したデータ
変換演算式の演算が実行される。このとき、展開したデ
ータ変換演算式の係数を2のべきに数値をかけた形で表
現した場合の2のべき部分は各加減算器への入力位置に
より調整される。
【0046】また、データ変換演算式の係数が、量子化
演算に用いる量子化係数に含まれるようにデータ変換演
算式を作成しておき、このようにして作成されたデータ
変換演算式の係数の値を2のべきで表現してシリアル回
路が構成される。このとき、該係数の値を2のべきで表
現しようとすれば所定以上ビット数が大きくなる部分に
ついては該係数が整数の比に置き換えられ、該整数の比
に置き換えられることにより生じたゲインの変化は量子
化手段により調整される。
演算に用いる量子化係数に含まれるようにデータ変換演
算式を作成しておき、このようにして作成されたデータ
変換演算式の係数の値を2のべきで表現してシリアル回
路が構成される。このとき、該係数の値を2のべきで表
現しようとすれば所定以上ビット数が大きくなる部分に
ついては該係数が整数の比に置き換えられ、該整数の比
に置き換えられることにより生じたゲインの変化は量子
化手段により調整される。
【0047】従って、単にシリアル回路を実現していた
場合に比べ、回路規模を大幅に小さくすることができる
とともに、シフトレジスタ等のシリアル回路の段数を減
少させてクロック数を減らすことができ、処理速度を向
上させることができ、画像等のデータ圧縮に利用するこ
とができる。
場合に比べ、回路規模を大幅に小さくすることができる
とともに、シフトレジスタ等のシリアル回路の段数を減
少させてクロック数を減らすことができ、処理速度を向
上させることができ、画像等のデータ圧縮に利用するこ
とができる。
【0048】
【実施例】以下、本発明を図面に基づいて説明する。
【0049】原理説明 (I)先ず、本実施例の基本的な考え方を説明する。図
11に示した従来のデータ圧縮伸張装置では、シリアル
演算によるDCT演算を実現するためバタフライ演算を
そのままシリアル回路上に表わしていた。具体的には、
COS係数値を2のべきで表わすことによって図22に示
すようなシリアルDCT演算回路を実現していたため、
DCT演算式の係数をすべて2のべきで表現しようとす
るとビット数が大きなものとなり、したがって、シリア
ル回路を構成するFF等の段数が大きくなってしまって
いた。
11に示した従来のデータ圧縮伸張装置では、シリアル
演算によるDCT演算を実現するためバタフライ演算を
そのままシリアル回路上に表わしていた。具体的には、
COS係数値を2のべきで表わすことによって図22に示
すようなシリアルDCT演算回路を実現していたため、
DCT演算式の係数をすべて2のべきで表現しようとす
るとビット数が大きなものとなり、したがって、シリア
ル回路を構成するFF等の段数が大きくなってしまって
いた。
【0050】ところで、DCT演算された画像データは
後段の量子化部(例えば、図11の量子化装置14)に
おいて量子化されることになる。
後段の量子化部(例えば、図11の量子化装置14)に
おいて量子化されることになる。
【0051】本発明者はこの点に着目して、2のべきで
表現できる部分はべきで表現して取り込みに用いる一方
で、べきで表現しようとすればビット数が大きくなって
しまう部分については敢えてべきにより表現しようとし
ないで2のべきにとらわれずにDCTの演算係数を整数
比(あるいは、整数値)に置き換え、そのゲイン変化分
を量子化部によって吸収するようにする。これによって
2のべきによりシリアル回路を実現していた場合に比
べ、回路規模を大幅に小さくすることができるととも
に、シリアルの段数を減少させて処理速度を向上させる
ことができる。
表現できる部分はべきで表現して取り込みに用いる一方
で、べきで表現しようとすればビット数が大きくなって
しまう部分については敢えてべきにより表現しようとし
ないで2のべきにとらわれずにDCTの演算係数を整数
比(あるいは、整数値)に置き換え、そのゲイン変化分
を量子化部によって吸収するようにする。これによって
2のべきによりシリアル回路を実現していた場合に比
べ、回路規模を大幅に小さくすることができるととも
に、シリアルの段数を減少させて処理速度を向上させる
ことができる。
【0052】(II)さらに、上述したDCT演算式をシ
リアル回路により構成する場合においてもDCT演算式
を加減算及びバタフライ演算を用いて実現していたた
め、FF等の段数をある程度以上減らすのは困難であ
り、速度向上のためには一層のFF等の段数の削減が求
められていた。
リアル回路により構成する場合においてもDCT演算式
を加減算及びバタフライ演算を用いて実現していたた
め、FF等の段数をある程度以上減らすのは困難であ
り、速度向上のためには一層のFF等の段数の削減が求
められていた。
【0053】そこで本実施例では、DCT演算式を展開
することによって各入力に共通な係数(必ずしも共通で
なくてもよい)が表れるように係数を分割し、このよう
に展開したDCT演算式をバタフライ演算にとらわれず
にそのままハードウェア化する。このため、先ず、前段
のシリアル回路で各入力に用いる係数分の計算をしてお
き、続く後段のシリアル回路で計算された係数出力に対
して出力方向に符号分を含めた加減算を行なうようにし
てDCT演算式をそのままハードウェア化する。これに
よってFF等の段数を減らすことができ、クロック数
(時間)を短縮することができる。
することによって各入力に共通な係数(必ずしも共通で
なくてもよい)が表れるように係数を分割し、このよう
に展開したDCT演算式をバタフライ演算にとらわれず
にそのままハードウェア化する。このため、先ず、前段
のシリアル回路で各入力に用いる係数分の計算をしてお
き、続く後段のシリアル回路で計算された係数出力に対
して出力方向に符号分を含めた加減算を行なうようにし
てDCT演算式をそのままハードウェア化する。これに
よってFF等の段数を減らすことができ、クロック数
(時間)を短縮することができる。
【0054】例えば、図1に示すようにDCT演算式を
展開して各入力に共通な係数17、85、48、72が
得られたとすると、先ず、前段のシリアル回路でDCT
演算式の係数に相当する部分を作成するようにする。こ
の場合、上記係数17、85、48、72を2のべきに
ある数値をかけた形で表現し、この数値の部分(図1の
破線内の数値参照)をシリアル回路で構成する。そし
て、2のべきの部分は後段のシリアル回路への入力位置
により調整するようにする。すなわち、図1に示すよう
に後段のシリアル回路はアダー(サブトラクタも含む)
が複数個つながるように構成されており、各アダーを1
段通る度に×2が入る構成となっていて、上記係数のう
ち2のべきで表現された部分は各アダーへの接続方法に
より調整する。ここで、上記係数17、85、48、7
2のうち、基本的に奇数のもの(係数17、85)につ
いての加算を先に行なうようにするがこれは以下の理由
からである。すなわち、1度加算する度に1クロック遅
れるというシリアル回路の構造上、奇数の係数を作るの
が大変であり、奇数の係数を作るために1を足すという
動作が必要となる。このため、先ず手間のかかる奇数の
係数同士を事前に足してしまうようにする。図1では、
係数85は42×21+1、係数17は16+1と考え
てこれら奇数の係数の1同士を事前に1回足してしまう
ようにする。これにより1クロック遅れて×2倍とな
る。その次に、その他の部分を足しておいたものに上記
奇数の1同士を足したものを加えるようにするためもう
1クロック必要となり全体では×4倍となる。つまり、
奇数の係数が2個以上ある場合には2回のアダーを通す
必要があり×4が最小の形となる。なお、奇数をなくす
ようにすると演算精度が落ちることになる。
展開して各入力に共通な係数17、85、48、72が
得られたとすると、先ず、前段のシリアル回路でDCT
演算式の係数に相当する部分を作成するようにする。こ
の場合、上記係数17、85、48、72を2のべきに
ある数値をかけた形で表現し、この数値の部分(図1の
破線内の数値参照)をシリアル回路で構成する。そし
て、2のべきの部分は後段のシリアル回路への入力位置
により調整するようにする。すなわち、図1に示すよう
に後段のシリアル回路はアダー(サブトラクタも含む)
が複数個つながるように構成されており、各アダーを1
段通る度に×2が入る構成となっていて、上記係数のう
ち2のべきで表現された部分は各アダーへの接続方法に
より調整する。ここで、上記係数17、85、48、7
2のうち、基本的に奇数のもの(係数17、85)につ
いての加算を先に行なうようにするがこれは以下の理由
からである。すなわち、1度加算する度に1クロック遅
れるというシリアル回路の構造上、奇数の係数を作るの
が大変であり、奇数の係数を作るために1を足すという
動作が必要となる。このため、先ず手間のかかる奇数の
係数同士を事前に足してしまうようにする。図1では、
係数85は42×21+1、係数17は16+1と考え
てこれら奇数の係数の1同士を事前に1回足してしまう
ようにする。これにより1クロック遅れて×2倍とな
る。その次に、その他の部分を足しておいたものに上記
奇数の1同士を足したものを加えるようにするためもう
1クロック必要となり全体では×4倍となる。つまり、
奇数の係数が2個以上ある場合には2回のアダーを通す
必要があり×4が最小の形となる。なお、奇数をなくす
ようにすると演算精度が落ちることになる。
【0055】また、図1では、係数17は2×23+
1、係数48は6×23で表わされ、2のべきが同じ23
であるからこの部分を1段目のアダーにより足してしま
う。以後、アダーを1段通る度に2倍されるので3段目
のアダーでこの係数の加算結果が揃うことになる。ま
た、係数72は18×22、係数85は42×21+1で
表わされるから2のべきに着目して係数72の18を2
番目のアダーに、係数85の42は3番目のアダーに入
力される。
1、係数48は6×23で表わされ、2のべきが同じ23
であるからこの部分を1段目のアダーにより足してしま
う。以後、アダーを1段通る度に2倍されるので3段目
のアダーでこの係数の加算結果が揃うことになる。ま
た、係数72は18×22、係数85は42×21+1で
表わされるから2のべきに着目して係数72の18を2
番目のアダーに、係数85の42は3番目のアダーに入
力される。
【0056】このようにDCT演算式をそのままハード
ウェア化することによってFF等の段数を減らすことが
でき、クロック数(時間)を短縮することができる。
ウェア化することによってFF等の段数を減らすことが
でき、クロック数(時間)を短縮することができる。
【0057】実施例 図2〜図10は上記基本原理に基づくデータ圧縮伸張装
置の実施例を示す図であり、図2〜図5は上記基本原理
(I)に基づくデータ圧縮伸張装置を、図6〜図10は
上記基本原理(II)に基づくデータ圧縮伸張装置を説明
するための図である。
置の実施例を示す図であり、図2〜図5は上記基本原理
(I)に基づくデータ圧縮伸張装置を、図6〜図10は
上記基本原理(II)に基づくデータ圧縮伸張装置を説明
するための図である。
【0058】先ず、上記基本原理(I)に基づくデータ
圧縮伸張装置の構成を説明する。
圧縮伸張装置の構成を説明する。
【0059】図2はデータ圧縮伸張装置のブロック図で
あり、前記図11のデータ圧縮伸張装置に対応する図で
ある。なお、従来例と同一構成部分には同一番号を付し
ている。図2において、データ圧縮伸張装置は、圧縮を
施そうとする2次元データ及びデータ変換演算後のデー
タをパラレルデータの形で蓄えるデータ記憶装置10
と、データ記憶装置10から読み込んだパラレルデータ
をシリアルデータに変換するパラレル−シリアル変換装
置11と、DCT演算係数を簡単な整数比(あるいは、
整数値)に変えた形のシリアル回路により構成され、パ
ラレル−シリアル変換装置11から出力されたデータに
対して一次元のDCT演算をシリアル演算の形で施すデ
ータ変換演算装置50と、シリアルDCT演算されたシ
リアルデータをパラレルデータに変換してデータ記憶装
置10に書き込むシリアル−パラレル変換装置13と、
データ記憶装置10に蓄えられたデータ変換演算後のデ
ータに対して、DCT演算係数を整数比に変えることに
より生じたゲイン変化分を吸収させるようにした量子化
テーブルの値で除算する(あるいは、逆数の乗算を行な
う)ことによって量子化演算を行なう量子化装置51
と、上記各部の動作をデータ圧縮伸張装置の全体を制御
する制御装置52により構成されている。
あり、前記図11のデータ圧縮伸張装置に対応する図で
ある。なお、従来例と同一構成部分には同一番号を付し
ている。図2において、データ圧縮伸張装置は、圧縮を
施そうとする2次元データ及びデータ変換演算後のデー
タをパラレルデータの形で蓄えるデータ記憶装置10
と、データ記憶装置10から読み込んだパラレルデータ
をシリアルデータに変換するパラレル−シリアル変換装
置11と、DCT演算係数を簡単な整数比(あるいは、
整数値)に変えた形のシリアル回路により構成され、パ
ラレル−シリアル変換装置11から出力されたデータに
対して一次元のDCT演算をシリアル演算の形で施すデ
ータ変換演算装置50と、シリアルDCT演算されたシ
リアルデータをパラレルデータに変換してデータ記憶装
置10に書き込むシリアル−パラレル変換装置13と、
データ記憶装置10に蓄えられたデータ変換演算後のデ
ータに対して、DCT演算係数を整数比に変えることに
より生じたゲイン変化分を吸収させるようにした量子化
テーブルの値で除算する(あるいは、逆数の乗算を行な
う)ことによって量子化演算を行なう量子化装置51
と、上記各部の動作をデータ圧縮伸張装置の全体を制御
する制御装置52により構成されている。
【0060】図3は、上記シリアルDCT演算を実行す
るためのデータ変換演算装置50の回路構成を示す図で
あり、I〜IVの各ステージから構成される。
るためのデータ変換演算装置50の回路構成を示す図で
あり、I〜IVの各ステージから構成される。
【0061】図3において、61はステージIの演算回
路、62はステージIIの演算回路、63はステージIII
の演算回路、64はステージIVの演算回路であり、これ
らのステージI〜IVの演算回路61〜64はそれぞれス
イッチ65〜69を介して直列に接続するように構成さ
れている。この場合、DCT演算処理では、図2に示す
ように演算回路61〜64の順で直列接続され、また逆
DCT演算の処理では、スイッチ65〜69の切換え動
作により演算回路64〜61の順で直接接続されるよう
になっている。そして、入力端子70に与えられる入力
データに対するDCTまたは逆DCT演算結果は出力端
子71から出力されるようになる。この場合、入力デー
タは、シリアル8系統よりなっている。
路、62はステージIIの演算回路、63はステージIII
の演算回路、64はステージIVの演算回路であり、これ
らのステージI〜IVの演算回路61〜64はそれぞれス
イッチ65〜69を介して直列に接続するように構成さ
れている。この場合、DCT演算処理では、図2に示す
ように演算回路61〜64の順で直列接続され、また逆
DCT演算の処理では、スイッチ65〜69の切換え動
作により演算回路64〜61の順で直接接続されるよう
になっている。そして、入力端子70に与えられる入力
データに対するDCTまたは逆DCT演算結果は出力端
子71から出力されるようになる。この場合、入力デー
タは、シリアル8系統よりなっている。
【0062】図4は前記基本原理(I)に基づくデータ
圧縮伸張装置のデータ変換演算装置50の回路構成図で
あり、前記図16に示す従来のデータ変換演算装置12
に対応する図である。
圧縮伸張装置のデータ変換演算装置50の回路構成図で
あり、前記図16に示す従来のデータ変換演算装置12
に対応する図である。
【0063】図4において、ステージIの演算回路61
は上述したシリアル演算を実行するものであり、加算器
81a、81b、81c、81dと減算器81e、81
f、81g、81hから構成されている。このステージ
Iの演算回路61の構成は従来例と同様であるが、入力
データf0〜f7の入力は異なっている。
は上述したシリアル演算を実行するものであり、加算器
81a、81b、81c、81dと減算器81e、81
f、81g、81hから構成されている。このステージ
Iの演算回路61の構成は従来例と同様であるが、入力
データf0〜f7の入力は異なっている。
【0064】また、ステージIIの演算回路62は、原理
説明(I)で述べたシリアル演算を実行するものであ
り、係数を簡単な整数比に近似した場合のDCTシリア
ル演算を行なうシリアル演算器82a〜82hから構成
されている。ここで、上記演算器82aは、加算器81
aの出力と加算器81dの出力とを加算する加算器82
a1、この加算器82a1の出力をシフトする3個のフリ
ップフロップ(FF)からなるシフタ82a2から構成
されている。また、上記演算器82bは、加算器81b
の出力と加算器81cの出力とを加算する加算器82b
1、この加算器82b1の出力をシフトする3個のフリッ
プフロップ(FF)からなるシフタ82b2から構成さ
れている。また、上記演算器82cは、加算器81bの
出力から加算器81cの出力を減算する減算器82c
1、この減算器82c1の出力をシフトする3個のフリッ
プフロップからなるシフタ82c2、このシフタ82c2
の第1番目のフリップフロップの出力とシフタ82c2
の出力を加算する加算器82c3、シフタ82c2の第2
番目のフリップフロップの出力と加算器82c3の出力
を加算する加算器82c4から構成されている。同様
に、上記演算器82dは、加算器81aの出力から加算
器81dの出力を減算する減算器82d1、この減算器
82d1の出力をシフトする3個のフリップフロップか
らなるシフタ82d2、このシフタ82d2の第1番目の
フリップフロップの出力とシフタ82d2の出力を加算
する加算器82d3、シフタ82d2の第2番目のフリッ
プフロップの出力と加算器82d3の出力を加算する加
算器82d4から構成されている。
説明(I)で述べたシリアル演算を実行するものであ
り、係数を簡単な整数比に近似した場合のDCTシリア
ル演算を行なうシリアル演算器82a〜82hから構成
されている。ここで、上記演算器82aは、加算器81
aの出力と加算器81dの出力とを加算する加算器82
a1、この加算器82a1の出力をシフトする3個のフリ
ップフロップ(FF)からなるシフタ82a2から構成
されている。また、上記演算器82bは、加算器81b
の出力と加算器81cの出力とを加算する加算器82b
1、この加算器82b1の出力をシフトする3個のフリッ
プフロップ(FF)からなるシフタ82b2から構成さ
れている。また、上記演算器82cは、加算器81bの
出力から加算器81cの出力を減算する減算器82c
1、この減算器82c1の出力をシフトする3個のフリッ
プフロップからなるシフタ82c2、このシフタ82c2
の第1番目のフリップフロップの出力とシフタ82c2
の出力を加算する加算器82c3、シフタ82c2の第2
番目のフリップフロップの出力と加算器82c3の出力
を加算する加算器82c4から構成されている。同様
に、上記演算器82dは、加算器81aの出力から加算
器81dの出力を減算する減算器82d1、この減算器
82d1の出力をシフトする3個のフリップフロップか
らなるシフタ82d2、このシフタ82d2の第1番目の
フリップフロップの出力とシフタ82d2の出力を加算
する加算器82d3、シフタ82d2の第2番目のフリッ
プフロップの出力と加算器82d3の出力を加算する加
算器82d4から構成されている。
【0065】上記演算器82eは、減算器81eの出力
をシフトする5個のフリップフロップからなるシフタ8
2e1、このシフタ82e1の第3番目のフリップフロッ
プの出力と第4番目のフリップフロップの出力を加算す
る加算器82e2、加算器82e2の出力をシフトするシ
フタ82e3、シフタ82e1の第1番目のフリップフロ
ップの出力と第5番目のフリップフロップの出力を加算
する加算器82e4から構成されている。また、上記演
算器82fは、減算器81gの出力から減算器81fの
出力を減算する減算器82f1、この減算器82f1の出
力をシフトする4個のフリップフロップからなるシフタ
82f2、このシフタ82f2の第2番目のフリップフロ
ップの出力と第3番目のフリップフロップの出力を加算
する加算器82f3、減算器82f1の出力とシフタ82
f2の出力を加算する加算器82f4から構成されてい
る。また、上記演算器82gは、減算器81fの出力と
減算器81gの出力を加算する加算器82g1、この加
算器82g1の出力をシフトする4個のフリップフロッ
プからなるシフタ82g2、このシフタ82g2の第2番
目のフリップフロップの出力と第3番目のフリップフロ
ップの出力を加算する加算器82g3、加算器82g1の
出力とシフタ82g2の出力を加算する加算器82g4か
ら構成されている。また、上記演算器82hは、減算器
81hの出力をシフトする5個のフリップフロップから
なるシフタ82h1、このシフタ82h1の第3番目のフ
リップフロップの出力と第4番目のフリップフロップの
出力を加算する加算器82h2、加算器82h2の出力を
シフトするシフタ82h3、シフタ82h1の第1番目の
フリップフロップの出力と第5番目のフリップフロップ
の出力を加算する加算器82h4から構成されている。
をシフトする5個のフリップフロップからなるシフタ8
2e1、このシフタ82e1の第3番目のフリップフロッ
プの出力と第4番目のフリップフロップの出力を加算す
る加算器82e2、加算器82e2の出力をシフトするシ
フタ82e3、シフタ82e1の第1番目のフリップフロ
ップの出力と第5番目のフリップフロップの出力を加算
する加算器82e4から構成されている。また、上記演
算器82fは、減算器81gの出力から減算器81fの
出力を減算する減算器82f1、この減算器82f1の出
力をシフトする4個のフリップフロップからなるシフタ
82f2、このシフタ82f2の第2番目のフリップフロ
ップの出力と第3番目のフリップフロップの出力を加算
する加算器82f3、減算器82f1の出力とシフタ82
f2の出力を加算する加算器82f4から構成されてい
る。また、上記演算器82gは、減算器81fの出力と
減算器81gの出力を加算する加算器82g1、この加
算器82g1の出力をシフトする4個のフリップフロッ
プからなるシフタ82g2、このシフタ82g2の第2番
目のフリップフロップの出力と第3番目のフリップフロ
ップの出力を加算する加算器82g3、加算器82g1の
出力とシフタ82g2の出力を加算する加算器82g4か
ら構成されている。また、上記演算器82hは、減算器
81hの出力をシフトする5個のフリップフロップから
なるシフタ82h1、このシフタ82h1の第3番目のフ
リップフロップの出力と第4番目のフリップフロップの
出力を加算する加算器82h2、加算器82h2の出力を
シフトするシフタ82h3、シフタ82h1の第1番目の
フリップフロップの出力と第5番目のフリップフロップ
の出力を加算する加算器82h4から構成されている。
【0066】また、ステージIIIの演算回路63は、原
理説明(I)で述べたシリアル演算を実行するものであ
り、演算器82aの出力と演算器82b2の出力を加算
する加算器83a、減算器82aの出力から演算器82
bの出力を減算する減算器83b、演算器82dの加算
器82d3の出力から演算器82cの加算器82c4の出
力を減算する減算器83c、演算器82cの加算器82
c3の出力と演算器82dの加算器82d4の出力を加算
する加算器83d、演算器82eの加算器82e4の出
力と演算器82fの加算器82f3の出力を加算する加
算器83e、演算器82eのシフタ82e3の出力から
演算器82fの加算器82f4の出力を減算する減算器
83f、演算器82hの加算器82h3の出力から演算
器82gの加算器82f4の出力を減算する減算器83
g、演算器82gの加算器82g3の出力と演算器82
hの加算器82h4の出力を加算する加算器83hから
構成されている。
理説明(I)で述べたシリアル演算を実行するものであ
り、演算器82aの出力と演算器82b2の出力を加算
する加算器83a、減算器82aの出力から演算器82
bの出力を減算する減算器83b、演算器82dの加算
器82d3の出力から演算器82cの加算器82c4の出
力を減算する減算器83c、演算器82cの加算器82
c3の出力と演算器82dの加算器82d4の出力を加算
する加算器83d、演算器82eの加算器82e4の出
力と演算器82fの加算器82f3の出力を加算する加
算器83e、演算器82eのシフタ82e3の出力から
演算器82fの加算器82f4の出力を減算する減算器
83f、演算器82hの加算器82h3の出力から演算
器82gの加算器82f4の出力を減算する減算器83
g、演算器82gの加算器82g3の出力と演算器82
hの加算器82h4の出力を加算する加算器83hから
構成されている。
【0067】また、ステージIVの演算回路64は、原理
説明(I)で述べたシリアル演算を実行するものであ
り、係数を簡単な整数比に近似した場合のDCTシリア
ル演算を行なうシリアル演算器84a〜84hから構成
されている。ここで、上記演算器84aは、加算器83
aの出力をシフトする6個のフリップフロップからなる
シフタ84a1、このシフタ84a1の第5番目のフリッ
プフロップの出力と第6番目のフリップフロップの出力
を加算する加算器84a2、加算器84a2の出力からシ
フタ84a1の第3番目のフリップフロップの出力を減
算して出力データF0として出力する減算器84a3から
構成されている。また、上記演算器84bは、減算器8
3bの出力をシフトする6個のフリップフロップからな
るシフタ84b1、このシフタ84b1の第5番目のフリ
ップフロップの出力と第6番目のフリップフロップの出
力を加算する加算器84b2、加算器84b2の出力から
シフタ84b1の第3番目のフリップフロップの出力を
減算して出力データF4として出力する減算器84b3か
ら構成されている。また、上記演算器84cは、減算器
83cの出力をシフトする5個のフリップフロップから
なるシフタ84c1、このシフタ84c1の第3番目のフ
リップフロップの出力と第5番目のフリップフロップの
出力を加算して出力データF6として出力する加算器8
4c2から構成されている。また、上記演算器84d
は、加算器83dの出力をシフトする5個のフリップフ
ロップからなるシフタ84d1、このシフタ84d1の第
3番目のフリップフロップの出力と第5番目のフリップ
フロップの出力を加算して出力データF2として出力す
る加算器84d2から構成されている。
説明(I)で述べたシリアル演算を実行するものであ
り、係数を簡単な整数比に近似した場合のDCTシリア
ル演算を行なうシリアル演算器84a〜84hから構成
されている。ここで、上記演算器84aは、加算器83
aの出力をシフトする6個のフリップフロップからなる
シフタ84a1、このシフタ84a1の第5番目のフリッ
プフロップの出力と第6番目のフリップフロップの出力
を加算する加算器84a2、加算器84a2の出力からシ
フタ84a1の第3番目のフリップフロップの出力を減
算して出力データF0として出力する減算器84a3から
構成されている。また、上記演算器84bは、減算器8
3bの出力をシフトする6個のフリップフロップからな
るシフタ84b1、このシフタ84b1の第5番目のフリ
ップフロップの出力と第6番目のフリップフロップの出
力を加算する加算器84b2、加算器84b2の出力から
シフタ84b1の第3番目のフリップフロップの出力を
減算して出力データF4として出力する減算器84b3か
ら構成されている。また、上記演算器84cは、減算器
83cの出力をシフトする5個のフリップフロップから
なるシフタ84c1、このシフタ84c1の第3番目のフ
リップフロップの出力と第5番目のフリップフロップの
出力を加算して出力データF6として出力する加算器8
4c2から構成されている。また、上記演算器84d
は、加算器83dの出力をシフトする5個のフリップフ
ロップからなるシフタ84d1、このシフタ84d1の第
3番目のフリップフロップの出力と第5番目のフリップ
フロップの出力を加算して出力データF2として出力す
る加算器84d2から構成されている。
【0068】上記演算器84eは、加算器83eの出力
をシフトする2個のフリップフロップからなるシフタ8
4e1、加算器83eの出力とシフタ84e1の出力を加
算して出力する加算器84e2、後述するシフタ84h1
の第1番目のフリップフロップの出力からこの加算器8
4e2の出力を減算する減算器84e3、減算器84e3
の出力をシフトする2個のフリップフロップからなるシ
フタ84e4、このシフタ84e4の出力から減算器84
e3の出力を減算して出力データF7として出力する減算
器84e5から構成されている。また、上記演算器84
fは、減算器83fの出力をシフトする2個のフリップ
フロップからなるシフタ84f1、減算器83fの出力
とシフタ84f1の第1番目のフリップフロップの出力
を加算する加算器84f2、後述する加算器g2の出力か
らこのシフタ84f1の出力を減算する減算器84f3、
減算器84f3の出力をシフトする2個のフリップフロ
ップからなるシフタ84f4、減算器84f3の出力から
シフタ84f4の出力を減算して出力データF3として出
力する減算器84f5から構成されている。また、上記
演算器84gは、減算器83gの出力をシフトする2個
のフリップフロップからなるシフタ84g1、減算器8
3gの出力とシフタ84g1の第1番目のフリップフロ
ップの出力を加算する加算器84g2、上記加算器f2の
出力とシフタ84g1の出力を加算する加算器84g3、
加算器84g3の出力をシフトする2個のフリップフロ
ップからなるシフタ84g4、シフタ84g4の出力から
加算器84g3の出力を減算して出力データF5として出
力する減算器84g5から構成されている。また、上記
演算器84hは、加算器83hの出力をシフトする2個
のフリップフロップからなるシフタ84h1、加算器8
3hの出力とシフタ84h1の出力を加算して出力する
加算器84h2、上記シフタ84e1の第1番目のフリッ
プフロップの出力と加算器84h2の出力を加算する加
算器84h3、加算器84h3の出力をシフトする2個の
フリップフロップからなるシフタ84h4、シフタ84
h4の出力から加算器84h3の出力を減算して出力デー
タF1として出力する減算器84h5から構成されてい
る。
をシフトする2個のフリップフロップからなるシフタ8
4e1、加算器83eの出力とシフタ84e1の出力を加
算して出力する加算器84e2、後述するシフタ84h1
の第1番目のフリップフロップの出力からこの加算器8
4e2の出力を減算する減算器84e3、減算器84e3
の出力をシフトする2個のフリップフロップからなるシ
フタ84e4、このシフタ84e4の出力から減算器84
e3の出力を減算して出力データF7として出力する減算
器84e5から構成されている。また、上記演算器84
fは、減算器83fの出力をシフトする2個のフリップ
フロップからなるシフタ84f1、減算器83fの出力
とシフタ84f1の第1番目のフリップフロップの出力
を加算する加算器84f2、後述する加算器g2の出力か
らこのシフタ84f1の出力を減算する減算器84f3、
減算器84f3の出力をシフトする2個のフリップフロ
ップからなるシフタ84f4、減算器84f3の出力から
シフタ84f4の出力を減算して出力データF3として出
力する減算器84f5から構成されている。また、上記
演算器84gは、減算器83gの出力をシフトする2個
のフリップフロップからなるシフタ84g1、減算器8
3gの出力とシフタ84g1の第1番目のフリップフロ
ップの出力を加算する加算器84g2、上記加算器f2の
出力とシフタ84g1の出力を加算する加算器84g3、
加算器84g3の出力をシフトする2個のフリップフロ
ップからなるシフタ84g4、シフタ84g4の出力から
加算器84g3の出力を減算して出力データF5として出
力する減算器84g5から構成されている。また、上記
演算器84hは、加算器83hの出力をシフトする2個
のフリップフロップからなるシフタ84h1、加算器8
3hの出力とシフタ84h1の出力を加算して出力する
加算器84h2、上記シフタ84e1の第1番目のフリッ
プフロップの出力と加算器84h2の出力を加算する加
算器84h3、加算器84h3の出力をシフトする2個の
フリップフロップからなるシフタ84h4、シフタ84
h4の出力から加算器84h3の出力を減算して出力デー
タF1として出力する減算器84h5から構成されてい
る。
【0069】次に、図6〜図8により前記基本原理(I
I)に基づくデータ圧縮伸張装置の構成を説明する。
I)に基づくデータ圧縮伸張装置の構成を説明する。
【0070】上記図4のデータ変換演算装置50に前記
基本原理(II)の考え方を適用することを考える。図4
のデータ変換演算装置50の各ステージI〜IVの構造を
みた場合、ステージIの構造はシンプルな形であり、ま
たステージIVの出力側の最終段も加減算のみのシンプル
な形であり簡略化は困難である。これに対しステージI
I、III、IVはバタフライ演算部を有し構造が複雑である
ばかりかステージIVのeven(偶数)側にはタイミン
グ合わせのFFが存在する。特に、odd(奇数)側の
ステージII、III、IVには2段のバタフライ演算部が存
在し、このodd側のバタフライ演算部を簡略化するこ
とによってデータ変換演算装置50全体の演算実行速度
を向上させることができる。本実施例では、データ変換
演算装置50のodd側に前記基本原理(II)の考え方
を適用する。
基本原理(II)の考え方を適用することを考える。図4
のデータ変換演算装置50の各ステージI〜IVの構造を
みた場合、ステージIの構造はシンプルな形であり、ま
たステージIVの出力側の最終段も加減算のみのシンプル
な形であり簡略化は困難である。これに対しステージI
I、III、IVはバタフライ演算部を有し構造が複雑である
ばかりかステージIVのeven(偶数)側にはタイミン
グ合わせのFFが存在する。特に、odd(奇数)側の
ステージII、III、IVには2段のバタフライ演算部が存
在し、このodd側のバタフライ演算部を簡略化するこ
とによってデータ変換演算装置50全体の演算実行速度
を向上させることができる。本実施例では、データ変換
演算装置50のodd側に前記基本原理(II)の考え方
を適用する。
【0071】図6はデータ圧縮伸張装置のデータ変換演
算装置50の回路構成図であり、前記図4に示すデータ
変換演算装置50と同じものである。また、図10は7
bitデータが入力された場合のデータ変換演算装置50
の入力から出力までのタイミングチャートである。図6
において、構造を簡略化するのが困難なデータ変換演算
装置50のodd側に着目し、同図破線に示すようにデ
ータ変換演算装置50のodd側のステージII、III及
びステージIVのバタフライ演算部を一纏めにし、この部
分に前記基本原理(II)の考え方を適用して簡略化す
る。
算装置50の回路構成図であり、前記図4に示すデータ
変換演算装置50と同じものである。また、図10は7
bitデータが入力された場合のデータ変換演算装置50
の入力から出力までのタイミングチャートである。図6
において、構造を簡略化するのが困難なデータ変換演算
装置50のodd側に着目し、同図破線に示すようにデ
ータ変換演算装置50のodd側のステージII、III及
びステージIVのバタフライ演算部を一纏めにし、この部
分に前記基本原理(II)の考え方を適用して簡略化す
る。
【0072】図7は前記基本原理(II)に基づくデータ
圧縮伸張装置のデータ変換演算装置90の回路構成図で
あり、前記図6に示すデータ変換演算装置50に対応す
る図である。図7に示すデータ変換演算装置90は、前
記図6の破線内を図8に示すように構成することによっ
てデータ変換演算装置90全体の速度向上を図るように
したものである。なお、図7及び図8の説明に当たり図
4と同一構成部分には同一番号を付している。
圧縮伸張装置のデータ変換演算装置90の回路構成図で
あり、前記図6に示すデータ変換演算装置50に対応す
る図である。図7に示すデータ変換演算装置90は、前
記図6の破線内を図8に示すように構成することによっ
てデータ変換演算装置90全体の速度向上を図るように
したものである。なお、図7及び図8の説明に当たり図
4と同一構成部分には同一番号を付している。
【0073】図7において、データ変換演算装置90は
I〜IIIの各ステージから構成され、ステージIの演算
回路91はシリアル演算を実行する加算器81a、81
b、81c、81dと減算器81e、81f、81g、
81hから構成されている。
I〜IIIの各ステージから構成され、ステージIの演算
回路91はシリアル演算を実行する加算器81a、81
b、81c、81dと減算器81e、81f、81g、
81hから構成されている。
【0074】また、ステージIIの演算回路92は、原理
説明(I)で述べたシリアル演算を、原理説明(II)で
述べたDCT演算式をそのままハードウェア化したシリ
アル回路上で実行するものであり、even側は係数を
簡単な整数比に近似してDCTシリアル演算を行なうシ
リアル演算器92a〜92dから構成され、odd側は
DCT演算式をそのままハードウェア化したシリアル回
路100(図8)から構成されている。
説明(I)で述べたシリアル演算を、原理説明(II)で
述べたDCT演算式をそのままハードウェア化したシリ
アル回路上で実行するものであり、even側は係数を
簡単な整数比に近似してDCTシリアル演算を行なうシ
リアル演算器92a〜92dから構成され、odd側は
DCT演算式をそのままハードウェア化したシリアル回
路100(図8)から構成されている。
【0075】また、上記シリアル演算器92a〜92d
の前段は、DCTシリアル演算を行なうシリアル演算器
82a〜82dと、これら演算器82a〜82dの出力
をバタフライ演算により加減算する加減算器83a〜8
3dにより構成され、前記図4のeven側のステージ
IIとステージIIIを合わせたものに相当する。ここで、
上記演算器82aは、加算器81aの出力と加算器81
dの出力とを加算する加算器82a1、この加算器82
a1の出力をシフトする3個のフリップフロップ(F
F)からなるシフタ82a2から構成され、また、上記
演算器82bは、加算器81bの出力と加算器81cの
出力とを加算する加算器82b1、この加算器82b1の
出力をシフトする3個のフリップフロップ(FF)から
なるシフタ82b2から構成されている。また、上記演
算器82cは、加算器81bの出力から加算器81cの
出力を減算する減算器82c1、この減算器82c1の出
力をシフトする3個のフリップフロップからなるシフタ
82c2、このシフタ82c2の第1番目のフリップフロ
ップの出力とシフタ82c2の出力を加算する加算器8
2c3、シフタ82c2の第2番目のフリップフロップの
出力と加算器82c3の出力を加算する加算器82c4か
ら構成されている。同様に、上記演算器82dは、加算
器81aの出力から加算器81dの出力を減算する減算
器82d1、この減算器82d1の出力をシフトする3個
のフリップフロップからなるシフタ82d2、このシフ
タ82d2の第1番目のフリップフロップの出力とシフ
タ82d2の出力を加算する加算器82d3、シフタ82
d2の第2番目のフリップフロップの出力と加算器82
d3の出力を加算する加算器82d4から構成されてい
る。また、上記シリアル演算器92a〜92dの後段
は、原理説明(I)で述べたシリアル演算を実行するも
のであり、演算器82aの出力と演算器82b2の出力
を加算する加算器83a、演算器82aの出力から演算
器82bの出力を減算する減算器83b、演算器82c
の加算器82c4の出力から演算器82dの加算器82
d3の出力を減算する減算器83c、演算器82cの加
算器82c3の出力と演算器82dの加算器82d4の出
力を加算する加算器83dから構成されている。
の前段は、DCTシリアル演算を行なうシリアル演算器
82a〜82dと、これら演算器82a〜82dの出力
をバタフライ演算により加減算する加減算器83a〜8
3dにより構成され、前記図4のeven側のステージ
IIとステージIIIを合わせたものに相当する。ここで、
上記演算器82aは、加算器81aの出力と加算器81
dの出力とを加算する加算器82a1、この加算器82
a1の出力をシフトする3個のフリップフロップ(F
F)からなるシフタ82a2から構成され、また、上記
演算器82bは、加算器81bの出力と加算器81cの
出力とを加算する加算器82b1、この加算器82b1の
出力をシフトする3個のフリップフロップ(FF)から
なるシフタ82b2から構成されている。また、上記演
算器82cは、加算器81bの出力から加算器81cの
出力を減算する減算器82c1、この減算器82c1の出
力をシフトする3個のフリップフロップからなるシフタ
82c2、このシフタ82c2の第1番目のフリップフロ
ップの出力とシフタ82c2の出力を加算する加算器8
2c3、シフタ82c2の第2番目のフリップフロップの
出力と加算器82c3の出力を加算する加算器82c4か
ら構成されている。同様に、上記演算器82dは、加算
器81aの出力から加算器81dの出力を減算する減算
器82d1、この減算器82d1の出力をシフトする3個
のフリップフロップからなるシフタ82d2、このシフ
タ82d2の第1番目のフリップフロップの出力とシフ
タ82d2の出力を加算する加算器82d3、シフタ82
d2の第2番目のフリップフロップの出力と加算器82
d3の出力を加算する加算器82d4から構成されてい
る。また、上記シリアル演算器92a〜92dの後段
は、原理説明(I)で述べたシリアル演算を実行するも
のであり、演算器82aの出力と演算器82b2の出力
を加算する加算器83a、演算器82aの出力から演算
器82bの出力を減算する減算器83b、演算器82c
の加算器82c4の出力から演算器82dの加算器82
d3の出力を減算する減算器83c、演算器82cの加
算器82c3の出力と演算器82dの加算器82d4の出
力を加算する加算器83dから構成されている。
【0076】また、ステージIIの演算回路92のodd
側のシリアル回路100の構成については図8により後
述する。
側のシリアル回路100の構成については図8により後
述する。
【0077】また、ステージIIIの演算回路93は、原
理説明(I)で述べたシリアル演算を実行するものであ
り、係数を簡単な整数比に近似した場合のDCTシリア
ル演算を行なうシリアル演算器93a〜93hから構成
されている。
理説明(I)で述べたシリアル演算を実行するものであ
り、係数を簡単な整数比に近似した場合のDCTシリア
ル演算を行なうシリアル演算器93a〜93hから構成
されている。
【0078】ここで、上記演算器93aは、加算器83
aの出力をシフトする3個のフリップフロップからなる
シフタ93a1、このシフタ93a1の第2番目のフリッ
プフロップの出力と第3番目のフリップフロップの出力
を加算する加算器84a2、加算器84a2の出力から加
算器83aの出力を減算して出力データF0として出力
する減算器84a3から構成されている。また、上記演
算器93bは、減算器83bの出力をシフトする3個の
フリップフロップからなるシフタ93b1、このシフタ
93b1の第2番目のフリップフロップの出力と第3番
目のフリップフロップの出力を加算する加算器84b
2、加算器84b2の出力から減算器83bの出力を減算
して出力データF4として出力する減算器84b3から構
成されている。また、上記演算器93cは、減算器83
cの出力をシフトする2個のフリップフロップからなる
シフタ93c1、このシフタ93c1の第2番目のフリッ
プフロップの出力と減算器83cの出力を加算して出力
データF6として出力する加算器84c2から構成されて
いる。また、上記演算器93dは、加算器83dの出力
をシフトする2個のフリップフロップからなるシフタ9
3d1、このシフタ93d1の第2番目のフリップフロッ
プの出力と加算器83dの出力を加算して出力データF
2として出力する加算器84d2から構成されている。
aの出力をシフトする3個のフリップフロップからなる
シフタ93a1、このシフタ93a1の第2番目のフリッ
プフロップの出力と第3番目のフリップフロップの出力
を加算する加算器84a2、加算器84a2の出力から加
算器83aの出力を減算して出力データF0として出力
する減算器84a3から構成されている。また、上記演
算器93bは、減算器83bの出力をシフトする3個の
フリップフロップからなるシフタ93b1、このシフタ
93b1の第2番目のフリップフロップの出力と第3番
目のフリップフロップの出力を加算する加算器84b
2、加算器84b2の出力から減算器83bの出力を減算
して出力データF4として出力する減算器84b3から構
成されている。また、上記演算器93cは、減算器83
cの出力をシフトする2個のフリップフロップからなる
シフタ93c1、このシフタ93c1の第2番目のフリッ
プフロップの出力と減算器83cの出力を加算して出力
データF6として出力する加算器84c2から構成されて
いる。また、上記演算器93dは、加算器83dの出力
をシフトする2個のフリップフロップからなるシフタ9
3d1、このシフタ93d1の第2番目のフリップフロッ
プの出力と加算器83dの出力を加算して出力データF
2として出力する加算器84d2から構成されている。
【0079】また、上記演算器93eは、シリアル回路
100の出力x0をシフトする2個のフリップフロップ
からなるシフタ84e4、このシフタ84e4の出力から
減算器84e3の出力を減算して出力データF7として出
力する減算器84e5から構成され、上記演算器93f
は、シリアル回路100の出力x1をシフトする2個の
フリップフロップからなるシフタ84f4、減算器84
f3の出力からシフタ84f4の出力を減算して出力デー
タF3として出力する減算器84f5から構成されてい
る。また、上記演算器93gは、シリアル回路100の
出力x2をシフトする2個のフリップフロップからなる
シフタ84g4、シフタ84g4の出力から加算器84g
3の出力を減算して出力データF5として出力する減算器
84g5から構成され、上記演算器93hは、シリアル
回路100の出力x3をシフトする2個のフリップフロ
ップからなるシフタ84h4、加算器84h3の出力から
シフタ84h4の出力を減算して出力データF1として出
力する減算器84h5から構成されている。
100の出力x0をシフトする2個のフリップフロップ
からなるシフタ84e4、このシフタ84e4の出力から
減算器84e3の出力を減算して出力データF7として出
力する減算器84e5から構成され、上記演算器93f
は、シリアル回路100の出力x1をシフトする2個の
フリップフロップからなるシフタ84f4、減算器84
f3の出力からシフタ84f4の出力を減算して出力デー
タF3として出力する減算器84f5から構成されてい
る。また、上記演算器93gは、シリアル回路100の
出力x2をシフトする2個のフリップフロップからなる
シフタ84g4、シフタ84g4の出力から加算器84g
3の出力を減算して出力データF5として出力する減算器
84g5から構成され、上記演算器93hは、シリアル
回路100の出力x3をシフトする2個のフリップフロ
ップからなるシフタ84h4、加算器84h3の出力から
シフタ84h4の出力を減算して出力データF1として出
力する減算器84h5から構成されている。
【0080】このように、ステージIIIのeven側の
シリアル演算器93a〜93dは、前記図4のステージ
IVのシリアル演算器84a〜84dのシフタ84a1〜
84d1から3段のフリップフロップ(FF)を取り去
った構成となっており、また、テージIIIのodd側の
シリアル演算器93e〜93hは、前記図4のステージ
IVの演算器84e〜84hからバタフライ演算部分(例
えば、演算器84eにおいては、シフタ84e1、加算
器84e2及び減算器84e3、演算器84fにおいて
は、シフタ84f1、加算器84f2及び減算器84f
3、演算器84gにおいては、シフタ84g1、加算器8
4g2及び加算器84g3、演算器84hにおいては、シ
フタ84h1、加算器84h2及び加算器84h3)を取
り去った構成となっている。
シリアル演算器93a〜93dは、前記図4のステージ
IVのシリアル演算器84a〜84dのシフタ84a1〜
84d1から3段のフリップフロップ(FF)を取り去
った構成となっており、また、テージIIIのodd側の
シリアル演算器93e〜93hは、前記図4のステージ
IVの演算器84e〜84hからバタフライ演算部分(例
えば、演算器84eにおいては、シフタ84e1、加算
器84e2及び減算器84e3、演算器84fにおいて
は、シフタ84f1、加算器84f2及び減算器84f
3、演算器84gにおいては、シフタ84g1、加算器8
4g2及び加算器84g3、演算器84hにおいては、シ
フタ84h1、加算器84h2及び加算器84h3)を取
り去った構成となっている。
【0081】図8はDCT演算式をそのままハードウェ
ア化したシリアル回路100の回路構成図である。シリ
アル回路100は、前述したように前記図6の破線に示
す部分に前記基本原理(II)の考え方を適用することに
より構成されている。
ア化したシリアル回路100の回路構成図である。シリ
アル回路100は、前述したように前記図6の破線に示
す部分に前記基本原理(II)の考え方を適用することに
より構成されている。
【0082】図6の破線内の演算について、入力をb0
〜b3、出力をx0〜x3とすると、シリアル回路100
は、DCT演算式を展開して得られた各入力b0〜b3に
共通な係数を2のべきにある数値をかけた形で表現した
場合の該数値の部分を作成する前段のシリアル回路10
1と、このシリアル回路101により計算された係数出
力に対して出力方向(DCT演算式の横方向)に符号分
を含めた加減算を行なって出力x0〜x3として出力する
後段のシリアル回路102により構成されている。すな
わち、上記シリアル回路101は、入力b0について各
入力b0〜b3に共通な係数(本実施例では、17、8
5、48、72)を2のべきにある数値(本実施例で
は、2、42、6、18)をかけた形で表現した場合に
該数値の部分を作成するシリアル演算器101e、入力
b1について各入力b0〜b3に共通な係数を2のべきに
ある数値をかけた形で表現した場合に該数値の部分を作
成するシリアル演算器101f、入力b2について各入
力b0〜b3に共通な係数を2のべきにある数値をかけた
形で表現した場合に該数値の部分を作成するシリアル演
算器101g、入力b3について各入力b0〜b3に共通
な係数を2のべきにある数値をかけた形で表現した場合
に該数値の部分を作成するシリアル演算器101hから
構成されている。具体的には、シリアル演算器101e
は、入力b0をシフトする3個のフリップフロップから
なるシフタ101e1、入力b0とシフタ101e1の第
1番目のフリップフロップの出力を加算して出力する加
算器101e2、入力b0とシフタ101e1の出力を加
算して出力する加算器101e3、シフタ101e1の第
1番目のフリップフロップの出力とシフタ101e1の
出力を加算して出力する加算器101e4、入力b0と加
算器101e4の出力を加算して出力する加算器101
e5から構成されている。同様に、シリアル演算器10
1fは、入力b1をシフトする3個のフリップフロップ
からなるシフタ101f1、入力b0とシフタ101f1
の第1番目のフリップフロップの出力を加算して出力す
る加算器101f2、入力b0とシフタ101f1の出力
を加算して出力する加算器101f3、シフタ101f1
の第1番目のフリップフロップの出力とシフタ101f
1の出力を加算して出力する加算器101f4、入力b0
と加算器101f4の出力を加算して出力する加算器1
01f5から構成されている。また、シリアル演算器1
01gは、入力b2をシフトする3個のフリップフロッ
プからなるシフタ101g1、入力b0とシフタ101g
1の第1番目のフリップフロップの出力を加算して出力
する加算器101g2、入力b0とシフタ101g1の出
力を加算して出力する加算器101g3、シフタ101
g1の第1番目のフリップフロップの出力とシフタ10
1g1の出力を加算して出力する加算器101g4、入力
b3と加算器101g4の出力を加算して出力する加算器
101g5から構成されている。また、シリアル演算器
101hは、入力b0をシフトする3個のフリップフロ
ップからなるシフタ101e1、入力b0とシフタ101
h1の第1番目のフリップフロップの出力を加算して出
力する加算器101h2、入力b0とシフタ101h1の
出力を加算して出力する加算器101h3、シフタ10
1h1の第1番目のフリップフロップの出力とシフタ1
01h1の出力を加算して出力する加算器101h4、入
力b0と加算器101h4の出力を加算して出力する加算
器101h5から構成されている。
〜b3、出力をx0〜x3とすると、シリアル回路100
は、DCT演算式を展開して得られた各入力b0〜b3に
共通な係数を2のべきにある数値をかけた形で表現した
場合の該数値の部分を作成する前段のシリアル回路10
1と、このシリアル回路101により計算された係数出
力に対して出力方向(DCT演算式の横方向)に符号分
を含めた加減算を行なって出力x0〜x3として出力する
後段のシリアル回路102により構成されている。すな
わち、上記シリアル回路101は、入力b0について各
入力b0〜b3に共通な係数(本実施例では、17、8
5、48、72)を2のべきにある数値(本実施例で
は、2、42、6、18)をかけた形で表現した場合に
該数値の部分を作成するシリアル演算器101e、入力
b1について各入力b0〜b3に共通な係数を2のべきに
ある数値をかけた形で表現した場合に該数値の部分を作
成するシリアル演算器101f、入力b2について各入
力b0〜b3に共通な係数を2のべきにある数値をかけた
形で表現した場合に該数値の部分を作成するシリアル演
算器101g、入力b3について各入力b0〜b3に共通
な係数を2のべきにある数値をかけた形で表現した場合
に該数値の部分を作成するシリアル演算器101hから
構成されている。具体的には、シリアル演算器101e
は、入力b0をシフトする3個のフリップフロップから
なるシフタ101e1、入力b0とシフタ101e1の第
1番目のフリップフロップの出力を加算して出力する加
算器101e2、入力b0とシフタ101e1の出力を加
算して出力する加算器101e3、シフタ101e1の第
1番目のフリップフロップの出力とシフタ101e1の
出力を加算して出力する加算器101e4、入力b0と加
算器101e4の出力を加算して出力する加算器101
e5から構成されている。同様に、シリアル演算器10
1fは、入力b1をシフトする3個のフリップフロップ
からなるシフタ101f1、入力b0とシフタ101f1
の第1番目のフリップフロップの出力を加算して出力す
る加算器101f2、入力b0とシフタ101f1の出力
を加算して出力する加算器101f3、シフタ101f1
の第1番目のフリップフロップの出力とシフタ101f
1の出力を加算して出力する加算器101f4、入力b0
と加算器101f4の出力を加算して出力する加算器1
01f5から構成されている。また、シリアル演算器1
01gは、入力b2をシフトする3個のフリップフロッ
プからなるシフタ101g1、入力b0とシフタ101g
1の第1番目のフリップフロップの出力を加算して出力
する加算器101g2、入力b0とシフタ101g1の出
力を加算して出力する加算器101g3、シフタ101
g1の第1番目のフリップフロップの出力とシフタ10
1g1の出力を加算して出力する加算器101g4、入力
b3と加算器101g4の出力を加算して出力する加算器
101g5から構成されている。また、シリアル演算器
101hは、入力b0をシフトする3個のフリップフロ
ップからなるシフタ101e1、入力b0とシフタ101
h1の第1番目のフリップフロップの出力を加算して出
力する加算器101h2、入力b0とシフタ101h1の
出力を加算して出力する加算器101h3、シフタ10
1h1の第1番目のフリップフロップの出力とシフタ1
01h1の出力を加算して出力する加算器101h4、入
力b0と加算器101h4の出力を加算して出力する加算
器101h5から構成されている。
【0083】また、上記シリアル回路102は、シリア
ル演算器101e〜101hにより計算された係数出力
に対して出力方向に符号分を含めた加減算を順次行なっ
て出力x3〜x0として出力するシリアル演算器102e
〜102hにより構成されている。すなわち、上記シリ
アル演算器102eは、シリアル演算器101fの加算
器101f2の出力とシリアル演算器101eのシフタ
101e1の第1番目のフリップフロップの出力を加算
する加算器102e1、この加算器102e1の出力とシ
リアル演算器101gの加算器101g3の出力を加算
する加算器102e2、この加算器102e2の出力とシ
リアル演算器101hの加算器101h5の出力を加算
する加算器102e3、この加算器102e3の出力と入
力b3を加算する加算器102e4、この加算器102e
4の出力とシリアル演算器101eのシフタ101e1の
第1番目のフリップフロップの出力を加算して出力x3
として出力する加算器102e5から構成されている。
また、上記シリアル演算器102fは、シリアル演算器
101hの加算器101h2の出力からシリアル演算器
101fのシフタ101f1の第1番目のフリップフロ
ップの出力を減算する減算器102f1、この減算器1
02f1の出力とシリアル演算器101eの加算器10
1e3の出力を加算する加算器102f2、この加算器1
02f2の出力とシリアル演算器101gの加算器10
1g5の出力を加算する加算器102f3、この加算器1
02f3の出力と入力b2を加算する加算器102f4、
この加算器102f4の出力からシリアル演算器101
fのシフタ101f1の第1番目のフリップフロップの
出力を減算して出力x2として出力する減算器102f5
から構成されている。また、上記シリアル演算器102
gは、シリアル演算器101eの加算器101e2の出
力とシリアル演算器101gのシフタ101g1の第1
番目のフリップフロップの出力を加算する加算器102
g1、シリアル演算器101hの加算器101h3の出力
から加算器102g1の出力を減算する減算器102g
2、この減算器102g2の出力からシリアル演算器10
1fの加算器101f5の出力を減算する減算器102
g3、この減算器102g3の出力から入力b1を減算す
る減算器102g4、この減算器102g4の出力からシ
リアル演算器101gのシフタ101g1の第1番目の
フリップフロップの出力を減算して出力x1として出力
する減算器102g5から構成されている。また、上記
シリアル演算器102hは、シリアル演算器101hの
シフタ101h1の第1番目のフリップフロップの出力
からシリアル演算器101gの加算器101g2の出力
を減算する減算器102h1、この減算器102h1の出
力とシリアル演算器101fの加算器101f3の出力
を加算する加算器102h2、この加算器102h2の出
力からシリアル演算器101eの加算器101e5の出
力を減算する減算器102h3、この減算器102h3の
出力から入力b0を減算する減算器102h4、この減算
器102h4の出力とシリアル演算器101hのシフタ
101h1の第1番目のフリップフロップの出力を加算
して出力x0として出力する加算器102h5から構成さ
れている。
ル演算器101e〜101hにより計算された係数出力
に対して出力方向に符号分を含めた加減算を順次行なっ
て出力x3〜x0として出力するシリアル演算器102e
〜102hにより構成されている。すなわち、上記シリ
アル演算器102eは、シリアル演算器101fの加算
器101f2の出力とシリアル演算器101eのシフタ
101e1の第1番目のフリップフロップの出力を加算
する加算器102e1、この加算器102e1の出力とシ
リアル演算器101gの加算器101g3の出力を加算
する加算器102e2、この加算器102e2の出力とシ
リアル演算器101hの加算器101h5の出力を加算
する加算器102e3、この加算器102e3の出力と入
力b3を加算する加算器102e4、この加算器102e
4の出力とシリアル演算器101eのシフタ101e1の
第1番目のフリップフロップの出力を加算して出力x3
として出力する加算器102e5から構成されている。
また、上記シリアル演算器102fは、シリアル演算器
101hの加算器101h2の出力からシリアル演算器
101fのシフタ101f1の第1番目のフリップフロ
ップの出力を減算する減算器102f1、この減算器1
02f1の出力とシリアル演算器101eの加算器10
1e3の出力を加算する加算器102f2、この加算器1
02f2の出力とシリアル演算器101gの加算器10
1g5の出力を加算する加算器102f3、この加算器1
02f3の出力と入力b2を加算する加算器102f4、
この加算器102f4の出力からシリアル演算器101
fのシフタ101f1の第1番目のフリップフロップの
出力を減算して出力x2として出力する減算器102f5
から構成されている。また、上記シリアル演算器102
gは、シリアル演算器101eの加算器101e2の出
力とシリアル演算器101gのシフタ101g1の第1
番目のフリップフロップの出力を加算する加算器102
g1、シリアル演算器101hの加算器101h3の出力
から加算器102g1の出力を減算する減算器102g
2、この減算器102g2の出力からシリアル演算器10
1fの加算器101f5の出力を減算する減算器102
g3、この減算器102g3の出力から入力b1を減算す
る減算器102g4、この減算器102g4の出力からシ
リアル演算器101gのシフタ101g1の第1番目の
フリップフロップの出力を減算して出力x1として出力
する減算器102g5から構成されている。また、上記
シリアル演算器102hは、シリアル演算器101hの
シフタ101h1の第1番目のフリップフロップの出力
からシリアル演算器101gの加算器101g2の出力
を減算する減算器102h1、この減算器102h1の出
力とシリアル演算器101fの加算器101f3の出力
を加算する加算器102h2、この加算器102h2の出
力からシリアル演算器101eの加算器101e5の出
力を減算する減算器102h3、この減算器102h3の
出力から入力b0を減算する減算器102h4、この減算
器102h4の出力とシリアル演算器101hのシフタ
101h1の第1番目のフリップフロップの出力を加算
して出力x0として出力する加算器102h5から構成さ
れている。
【0084】次に、本実施例の動作を説明する。
【0085】本実施例の動作の説明にあたり、まず、デ
ータ圧縮伸張装置の全体動作を述べ、次いで前記基本原
理(I)に基づくデータ変換演算装置50における動作
及び前記基本原理(II)に基づくデータ変換演算装置9
0における動作を述べる。
ータ圧縮伸張装置の全体動作を述べ、次いで前記基本原
理(I)に基づくデータ変換演算装置50における動作
及び前記基本原理(II)に基づくデータ変換演算装置9
0における動作を述べる。
【0086】全体動作 図2において、データ記憶装置10に蓄えられているパ
ラレルデータはパラレル−シリアル変換装置11に入力
され、パラレル−シリアル変換装置11はデータ記憶装
置10から読み込んだパラレルデータをシリアルデータ
に変換してデータ変換演算装置50に出力する。データ
変換演算装置50はパラレル−シリアル変換装置11か
ら出力されたデータに対して一次元のDCT演算をシリ
アル演算の形で施す。この場合のシリアル演算は、デー
タ変換演算装置50においてDCT演算係数を簡単な整
数比に変えた形のシリアル回路により行なわれる。シリ
アルDCT演算されたデータはシリアル−パラレル変換
装置13に出力され、シリアル−パラレル変換装置13
はデータ変換演算装置50から出力されたシリアルデー
タをパラレルデータに変換してデータ記憶装置10に書
き込む。上述した処理を縦横(順不同)二次元に施す。
また、量子化装置51は、データ記憶装置10に蓄えら
れたデータ変換演算後のデータに対して、DCT演算係
数を簡単な整数比に変えることにより生じたゲインの変
化分を吸収するように構成された量子化テーブルの値で
逆数の乗算をすることによって量子化演算を行なう。す
なわち、DCT演算係数を簡単な整数比に変え、整数比
として表されたことによって生ずる各出力のゲインの変
化分は量子化装置51において吸収する。本実施例で
は、量子化テーブルを所定数倍(後述)することによっ
てゲインの変化分を量子化装置51において吸収するよ
うにしている。ところで、このような量子化テーブルを
用いた場合、一見すると従来のものと比べて量子化演算
のbit幅が、従来のものよりも多く必要であるかのよう
にも考えられるが、実際には、量子化演算には、逆数の
乗算であるため、係数(例えば、7)の逆数も、7×2
/COS(N/16)πの逆数も、ともに無限小数となるため、
丸め近似を必要とし、ほぼ同じ程度の誤差を含む。すな
わち、従来のCOS係数を2進歩の小数で表現した時点で
丸め誤差が乗ってしまうので、整数の比に置き変えても
誤差を押さえるためにbit幅を大きくする必要はない。
ラレルデータはパラレル−シリアル変換装置11に入力
され、パラレル−シリアル変換装置11はデータ記憶装
置10から読み込んだパラレルデータをシリアルデータ
に変換してデータ変換演算装置50に出力する。データ
変換演算装置50はパラレル−シリアル変換装置11か
ら出力されたデータに対して一次元のDCT演算をシリ
アル演算の形で施す。この場合のシリアル演算は、デー
タ変換演算装置50においてDCT演算係数を簡単な整
数比に変えた形のシリアル回路により行なわれる。シリ
アルDCT演算されたデータはシリアル−パラレル変換
装置13に出力され、シリアル−パラレル変換装置13
はデータ変換演算装置50から出力されたシリアルデー
タをパラレルデータに変換してデータ記憶装置10に書
き込む。上述した処理を縦横(順不同)二次元に施す。
また、量子化装置51は、データ記憶装置10に蓄えら
れたデータ変換演算後のデータに対して、DCT演算係
数を簡単な整数比に変えることにより生じたゲインの変
化分を吸収するように構成された量子化テーブルの値で
逆数の乗算をすることによって量子化演算を行なう。す
なわち、DCT演算係数を簡単な整数比に変え、整数比
として表されたことによって生ずる各出力のゲインの変
化分は量子化装置51において吸収する。本実施例で
は、量子化テーブルを所定数倍(後述)することによっ
てゲインの変化分を量子化装置51において吸収するよ
うにしている。ところで、このような量子化テーブルを
用いた場合、一見すると従来のものと比べて量子化演算
のbit幅が、従来のものよりも多く必要であるかのよう
にも考えられるが、実際には、量子化演算には、逆数の
乗算であるため、係数(例えば、7)の逆数も、7×2
/COS(N/16)πの逆数も、ともに無限小数となるため、
丸め近似を必要とし、ほぼ同じ程度の誤差を含む。すな
わち、従来のCOS係数を2進歩の小数で表現した時点で
丸め誤差が乗ってしまうので、整数の比に置き変えても
誤差を押さえるためにbit幅を大きくする必要はない。
【0087】上記データ変換演算装置50により実行さ
れるシリアルDCT演算を以下に説明するシリアル演算
によって行なう。
れるシリアルDCT演算を以下に説明するシリアル演算
によって行なう。
【0088】データ変換演算装置50における動作(図
4) データ変換演算装置50の基本的な動作は図22に示す
従来例と同様であるが、このデータ変換演算装置50に
おけるシリアル演算では後述するように一次元当りのゲ
インが65/64倍、二次元では4225/4096倍のゲインが変化
しているので、量子化時にその補正を行うように量子化
テーブルを4225/4096倍して、その値で除算(逆数の乗
算)することによって補正を行なう。
4) データ変換演算装置50の基本的な動作は図22に示す
従来例と同様であるが、このデータ変換演算装置50に
おけるシリアル演算では後述するように一次元当りのゲ
インが65/64倍、二次元では4225/4096倍のゲインが変化
しているので、量子化時にその補正を行うように量子化
テーブルを4225/4096倍して、その値で除算(逆数の乗
算)することによって補正を行なう。
【0089】以下、この演算について説明する。
【0090】ステージIの演算回路61の出力について
は、図18及び図22に示す従来例と同様であるので以
後、以下のように記する。
は、図18及び図22に示す従来例と同様であるので以
後、以下のように記する。
【0091】f0+f7=a0、f0-f7=b0、f1+f6=a
1、f1-f6=b1、f2+f5=a2、f2-f5=b2、f3+f4=
a3、f3-f4=b3 まず、図22に示す従来例においてF0〜F7がa0〜a3
およびb0〜b3によってどのように表わされていたかを
示す。
1、f1-f6=b1、f2+f5=a2、f2-f5=b2、f3+f4=
a3、f3-f4=b3 まず、図22に示す従来例においてF0〜F7がa0〜a3
およびb0〜b3によってどのように表わされていたかを
示す。
【0092】 F0=(724a0+724a1+724a2+724a3)×2048 F4=(724a0−724a1−724a2+724a3)×2048 F2=(473a0+192a1−192a2−473a3)×4096 F6=(192a0−473a1+473a2−192a3)×4096 F1=(295b0+16833b1+25883b2+15104b3)×16 F7=(−15104b0+25883b1−16833b2+2550b3) ×16 F3=(−18176b0−64255b1−12815b2+27264b3) ×16 F5=(27264b0+12815b1−64255b2+18176b3) ×16 この式を以下のように近似し簡略化する。
【0093】 F0=(92a0+92a1+92a2+92a3)×128 F4=(92a0−92a1−92a2+92a3)×128 F2=(60a0+25a1−25a2−60a3)×256 F6=(25a0−60a1+60a2−25a3)×256 F1=(17b0+48b1+72b2+85b3)×6×32 F7=(−85b0+72b1−48b2+17b3)×6×32 F3=(−48b0−85b1−17b2+72b3)×6×32 F5=(72b0+17b1−85b2+48b3)×6×32 ここで、各係数の比は従来のものと、ほぼ同等であるの
で各出力F0〜F7の比はほぼ同等と考えられるが、その
出力のゲインがどのように変化しているかについて考察
してみる。
で各出力F0〜F7の比はほぼ同等と考えられるが、その
出力のゲインがどのように変化しているかについて考察
してみる。
【0094】出力F0についてみると本来のDCTの計
算式では、出力F0は入力f0〜f7の和の2√2倍となっ
ているが、この比率では2のべきを除いて23倍となっ
ている。2のべき分は、取り込みのタイミングをずらす
ことによって無視できるので23に2√2を乗ずると約6
5となる。よってゲインは65/64倍となっていることが
わかる。
算式では、出力F0は入力f0〜f7の和の2√2倍となっ
ているが、この比率では2のべきを除いて23倍となっ
ている。2のべき分は、取り込みのタイミングをずらす
ことによって無視できるので23に2√2を乗ずると約6
5となる。よってゲインは65/64倍となっていることが
わかる。
【0095】このような演算式によりDCT変換を行な
うことにより、演算に必要な回路構成としてフリップフ
ロップ(FF)70個、1 Add unit 52個で済む。ま
た図5にあるようなタイミングによって一次元の処理を
行なうことができる。但し、図5はF0、F4についての
タイミングであり、他については最終出力については同
じであるが各ステージにおける出力に関しては異なる。
うことにより、演算に必要な回路構成としてフリップフ
ロップ(FF)70個、1 Add unit 52個で済む。ま
た図5にあるようなタイミングによって一次元の処理を
行なうことができる。但し、図5はF0、F4についての
タイミングであり、他については最終出力については同
じであるが各ステージにおける出力に関しては異なる。
【0096】実際には上記の演算式をさらに以下のよう
に変形して回路を構成する。
に変形して回路を構成する。
【0097】 F0=((a0+a3)×16+(a1+a2)×16)×2×8×46 F4=((a0+a3)×16−(a1+a2)×16)×2×8×46 F6=((a0−a3)×40−(a1−a2)×96)×2×8×10 F2=((a0−a3)×96+(a1−a2)×40)×2×8×10 F7=(((48×(b1+b2)+68×b3)×2)×2 −((48×(b2−b1)+68×b0)×2)×10)×12 F3=(((96×b3−68×(b1+b2))×2)×6 −((96×b0−68×(b2−b1))×2)×4)×12 F5=(((96×b0−68×(b2−b1))×2)×6 −((96×b3−68×(b1+b2))×2)×4)×12 F1=(((48×(b2−b1)+68×b0)×2)×2 −((48×(b1+b2)+68×b3)×2)×10)×12 以下、上記演算式に従って構成されたデータ変換演算装
置50の動作を説明する。
置50の動作を説明する。
【0098】まず、DCT演算処理の場合を述べると、
ここでは、ステージIの演算回路61において加算器8
1aに入力データf0とf7、加算器81bに入力データ
f1とf6、加算器81cに入力データf2とf5、加算器
81dに入力データf3とf4、減算器81eに入力デー
タf3とf4、減算器81fに入力データf2とf5、減算
器81gに入力データf1とf6、減算器81hに入力デ
ータf0とf7が入力される。これにより加算器81aは
入力データf0とf7の加算結果を出力し、加算器81b
は入力データf1とf6の加算結果を出力し、加算器81
cは入力データf2とf5の加算結果f2+f5を出力し、
加算器81dは入力データf3とf4の加算結果を出力す
るようになる。また、減算器81eは入力データf3と
f4の減算結果を出力し、減算器81fは入力データf2
とf5の減算結果を出力し、減算器81gは入力データ
f1とf6の減算結果を出力し、減算器81hは入力デー
タf0とf7の減算結果を出力するようになる。この場合
の入力データは、図4に示すように7bitと1bitのサイ
ンビットの8bitのデータからなっている。また、出力
データは、図5Iに示すように7+1bitと1bitのサイ
ンビットからなっている。
ここでは、ステージIの演算回路61において加算器8
1aに入力データf0とf7、加算器81bに入力データ
f1とf6、加算器81cに入力データf2とf5、加算器
81dに入力データf3とf4、減算器81eに入力デー
タf3とf4、減算器81fに入力データf2とf5、減算
器81gに入力データf1とf6、減算器81hに入力デ
ータf0とf7が入力される。これにより加算器81aは
入力データf0とf7の加算結果を出力し、加算器81b
は入力データf1とf6の加算結果を出力し、加算器81
cは入力データf2とf5の加算結果f2+f5を出力し、
加算器81dは入力データf3とf4の加算結果を出力す
るようになる。また、減算器81eは入力データf3と
f4の減算結果を出力し、減算器81fは入力データf2
とf5の減算結果を出力し、減算器81gは入力データ
f1とf6の減算結果を出力し、減算器81hは入力デー
タf0とf7の減算結果を出力するようになる。この場合
の入力データは、図4に示すように7bitと1bitのサイ
ンビットの8bitのデータからなっている。また、出力
データは、図5Iに示すように7+1bitと1bitのサイ
ンビットからなっている。
【0099】次いで、ステージIIの演算回路62に進
む。この演算回路62のシリアル演算器82a〜82h
には、ステージIの演算回路61で加算あるいは減算さ
れた加減算結果a0、b0、a1、b1、a2、b2、a3、
b3が入力データとして与えられる。上記演算器82a
では、係数を簡単な整数比に近似した場合のDCTシリ
アル演算式F0=((a0+a3)×16+(a1+a2)
×16)×2×8×46及び、F4=((a0+a3)×
16−(a1+a2)×16)×2×8×46に共通する
(a0+a3)×16の演算を実行する。この場合、演算
器82aには、加算器81aの出力(a0)と加算器8
1dの出力(a3)とが入力され、加算器82a1でこれ
ら入力を加算し、この加算結果がシフタ82a2に与え
られる。シフタ82a2からは、図5Iに示すように、
3個のフリップフロップの動作だけ遅延して出力され
る。また上記演算器82bでは、係数を簡単な整数比に
近似した場合のDCTシリアル演算式F0=((a0+a
3)×16+(a1+a2)×16)×2×8×46及
び、F4=((a0+a3)×16−(a1+a2)×1
6)×2×8×46に共通する(a1+a2)×16の演
算を実行する。この場合、演算器82bには、加算器8
1bの出力(a1)と加算器81cの出力(a2)とが入
力され、加算器82b1でこれら入力を加算し、この加
算結果がシフタ82b2に与えられる。シフタ82b2か
らは、図5Iに示すように、3個のフリップフロップの
動作だけ遅延して出力される。
む。この演算回路62のシリアル演算器82a〜82h
には、ステージIの演算回路61で加算あるいは減算さ
れた加減算結果a0、b0、a1、b1、a2、b2、a3、
b3が入力データとして与えられる。上記演算器82a
では、係数を簡単な整数比に近似した場合のDCTシリ
アル演算式F0=((a0+a3)×16+(a1+a2)
×16)×2×8×46及び、F4=((a0+a3)×
16−(a1+a2)×16)×2×8×46に共通する
(a0+a3)×16の演算を実行する。この場合、演算
器82aには、加算器81aの出力(a0)と加算器8
1dの出力(a3)とが入力され、加算器82a1でこれ
ら入力を加算し、この加算結果がシフタ82a2に与え
られる。シフタ82a2からは、図5Iに示すように、
3個のフリップフロップの動作だけ遅延して出力され
る。また上記演算器82bでは、係数を簡単な整数比に
近似した場合のDCTシリアル演算式F0=((a0+a
3)×16+(a1+a2)×16)×2×8×46及
び、F4=((a0+a3)×16−(a1+a2)×1
6)×2×8×46に共通する(a1+a2)×16の演
算を実行する。この場合、演算器82bには、加算器8
1bの出力(a1)と加算器81cの出力(a2)とが入
力され、加算器82b1でこれら入力を加算し、この加
算結果がシフタ82b2に与えられる。シフタ82b2か
らは、図5Iに示すように、3個のフリップフロップの
動作だけ遅延して出力される。
【0100】また上記演算器82cでは、係数を簡単な
整数比に近似した場合のDCTシリアル演算式F6=
((a0−a3)×40−(a1−a2)×96)×2×8
×10及び、F2=((a0−a3)×96+(a1−a
2)×40)×2×8×10の(a1−a2)×96と
(a1−a2)×40の演算を実行する。この場合、演算
器82cには、加算器81bの出力(a1)と加算器8
1cの出力(a2)とが入力され、減算器82c1で加算
器81bの出力から加算器81cの出力で減算すると
(a1−a2)が求められる。この減算器82c1の出力
をシフタ82c2に与え、このシフタ82c2の第1番目
のフリップフロップの出力とシフタ82c2の出力を加
算器82c3により加算し、またシフタ82c2の第2番
目のフリップフロップの出力と加算器82c3の出力を
82c4により加算することにより(a1−a2)×40
と(a1−a2)×96が求められることになる。この場
合、図5の入力に示す入力データに対して演算器82c
では、同図IIに示すタイミングで上述の演算結果を出力
データとして発生するようになる。また上記演算器82
dでは、係数を簡単な整数比に近似した場合のDCTシ
リアル演算式F6=((a0−a3)×40−(a1−a
2)×96)×2×8×10及び、F2=((a0−a3)
×96+(a1−a2)×40)×2×8×10の(a0
−a3)×40と(a0−a3)×96の演算を実行す
る。この場合、演算器82dには、加算器81aの出力
(a0)と加算器81dの出力(a3)とが入力され、減
算器82d1で加算器81aの出力を加算器81dの出
力で減算すると(a0−a3)が求められる。この減算器
82d1の出力をシフタ82d2に与え、このシフタ82
d2の第1番目のフリップフロップの出力とシフタ82
d2の出力を加算器82d3により加算し、またシフタ8
2d2の第2番目のフリップフロップの出力と加算器8
2d3の出力を82d4により加算することにより(a0
−a3)×40と(a0−a3)×96が求められること
になる。この場合、図5の入力に示す入力データに対し
て演算器82dでは、同図IIに示すタイミングで上述の
演算結果を出力データとして発生するようになる。
整数比に近似した場合のDCTシリアル演算式F6=
((a0−a3)×40−(a1−a2)×96)×2×8
×10及び、F2=((a0−a3)×96+(a1−a
2)×40)×2×8×10の(a1−a2)×96と
(a1−a2)×40の演算を実行する。この場合、演算
器82cには、加算器81bの出力(a1)と加算器8
1cの出力(a2)とが入力され、減算器82c1で加算
器81bの出力から加算器81cの出力で減算すると
(a1−a2)が求められる。この減算器82c1の出力
をシフタ82c2に与え、このシフタ82c2の第1番目
のフリップフロップの出力とシフタ82c2の出力を加
算器82c3により加算し、またシフタ82c2の第2番
目のフリップフロップの出力と加算器82c3の出力を
82c4により加算することにより(a1−a2)×40
と(a1−a2)×96が求められることになる。この場
合、図5の入力に示す入力データに対して演算器82c
では、同図IIに示すタイミングで上述の演算結果を出力
データとして発生するようになる。また上記演算器82
dでは、係数を簡単な整数比に近似した場合のDCTシ
リアル演算式F6=((a0−a3)×40−(a1−a
2)×96)×2×8×10及び、F2=((a0−a3)
×96+(a1−a2)×40)×2×8×10の(a0
−a3)×40と(a0−a3)×96の演算を実行す
る。この場合、演算器82dには、加算器81aの出力
(a0)と加算器81dの出力(a3)とが入力され、減
算器82d1で加算器81aの出力を加算器81dの出
力で減算すると(a0−a3)が求められる。この減算器
82d1の出力をシフタ82d2に与え、このシフタ82
d2の第1番目のフリップフロップの出力とシフタ82
d2の出力を加算器82d3により加算し、またシフタ8
2d2の第2番目のフリップフロップの出力と加算器8
2d3の出力を82d4により加算することにより(a0
−a3)×40と(a0−a3)×96が求められること
になる。この場合、図5の入力に示す入力データに対し
て演算器82dでは、同図IIに示すタイミングで上述の
演算結果を出力データとして発生するようになる。
【0101】一方、上記演算器82eでは、係数を簡単
な整数比に近似した場合のDCTシリアル演算式F7=
(((48×(b1+b2)+68×b3)×2)×2−
((48×(b2−b1)+68×b0)×2)×10)
×12とF1=(((48×(b2−b1)+68×b0)
×2)×2−((48×(b1+b2)+68×b3)×
2)×10)×12の68×b0の演算及び、F3=
(((96×b3−68×(b1+b2))×2)×6−
((96×b0−68×(b2−b1))×2)×4)×
12とF5=(((96×b0−68×(b2−b1))×
2)×6−((96×b3−68×(b1+b2))×
2)×4)×12の96×b0の演算を実行する。この
場合、演算器82eのシフタ82e1には、減算器81
eの出力(b0)が入力され、シフタ82e1の第3番目
のフリップフロップの出力が加算器82e2により加算
されるとともに、この加算結果がシフタ82e3により
1クロック遅延して出力され、また、シフタ82e1の
第1番目のフリップフロップの出力と第5番目のフリッ
プフロップの出力が加算器82e4により加算されて、
68×b0及び96×b0が求められることになる。この
場合、図5の入力に示す入力データに対して演算器82
eでは、同図IIに示すタイミングで上述の演算結果を出
力データとして発生するようになる。
な整数比に近似した場合のDCTシリアル演算式F7=
(((48×(b1+b2)+68×b3)×2)×2−
((48×(b2−b1)+68×b0)×2)×10)
×12とF1=(((48×(b2−b1)+68×b0)
×2)×2−((48×(b1+b2)+68×b3)×
2)×10)×12の68×b0の演算及び、F3=
(((96×b3−68×(b1+b2))×2)×6−
((96×b0−68×(b2−b1))×2)×4)×
12とF5=(((96×b0−68×(b2−b1))×
2)×6−((96×b3−68×(b1+b2))×
2)×4)×12の96×b0の演算を実行する。この
場合、演算器82eのシフタ82e1には、減算器81
eの出力(b0)が入力され、シフタ82e1の第3番目
のフリップフロップの出力が加算器82e2により加算
されるとともに、この加算結果がシフタ82e3により
1クロック遅延して出力され、また、シフタ82e1の
第1番目のフリップフロップの出力と第5番目のフリッ
プフロップの出力が加算器82e4により加算されて、
68×b0及び96×b0が求められることになる。この
場合、図5の入力に示す入力データに対して演算器82
eでは、同図IIに示すタイミングで上述の演算結果を出
力データとして発生するようになる。
【0102】また、上記演算器82fでは、係数を簡単
な整数比に近似した場合のDCTシリアル演算式F7=
(((48×(b1+b2)+68×b3)×2)×2−
((48×(b2−b1)+68×b0)×2)×10)
×12とF1=(((48×(b2−b1)+68×b0)
×2)×2−((48×(b1+b2)+68×b3)×
2)×10)×12の48×(b2−b1)の演算及び、
F3=(((96×b3−68×(b1+b2))×2)×
6−((96×b0−68×(b2−b1))×2)×
4)×12とF5=(((96×b0−68×(b2−b
1))×2)×6−((96×b3−68×(b1+b
2))×2)×4)×12の68×(b2−b1)の演算
を実行する。この場合、演算器82fには、減算器81
fの出力(b1)と減算器81gの出力(b2)が入力さ
れ、減算器82f1で加算器81gの出力を加算器81
fの出力で減算すると(b2−b1)が求められる。この
減算器82f1の出力をシフタ82f2に与え、このシフ
タ82f2の第2番目のフリップフロップの出力と第3
番目のフリップフロップの出力を加算器82f3により
加算し、またシフタ82f2の出力と減算器82f1の出
力を82f4により加算することにより(b2−b1)×
48と(b2−b1)×68が求められることになる。こ
の場合、図5の入力に示す入力データに対して演算器8
2fでは、同図IIに示すタイミングで上述の演算結果を
入力データとして発生するようになる。
な整数比に近似した場合のDCTシリアル演算式F7=
(((48×(b1+b2)+68×b3)×2)×2−
((48×(b2−b1)+68×b0)×2)×10)
×12とF1=(((48×(b2−b1)+68×b0)
×2)×2−((48×(b1+b2)+68×b3)×
2)×10)×12の48×(b2−b1)の演算及び、
F3=(((96×b3−68×(b1+b2))×2)×
6−((96×b0−68×(b2−b1))×2)×
4)×12とF5=(((96×b0−68×(b2−b
1))×2)×6−((96×b3−68×(b1+b
2))×2)×4)×12の68×(b2−b1)の演算
を実行する。この場合、演算器82fには、減算器81
fの出力(b1)と減算器81gの出力(b2)が入力さ
れ、減算器82f1で加算器81gの出力を加算器81
fの出力で減算すると(b2−b1)が求められる。この
減算器82f1の出力をシフタ82f2に与え、このシフ
タ82f2の第2番目のフリップフロップの出力と第3
番目のフリップフロップの出力を加算器82f3により
加算し、またシフタ82f2の出力と減算器82f1の出
力を82f4により加算することにより(b2−b1)×
48と(b2−b1)×68が求められることになる。こ
の場合、図5の入力に示す入力データに対して演算器8
2fでは、同図IIに示すタイミングで上述の演算結果を
入力データとして発生するようになる。
【0103】また、上記演算器82gでは、係数を簡単
な整数比に近似した場合のDCTシリアル演算式F7=
(((48×(b1+b2)+68×b3)×2)×2−
((48×(b2−b1)+68×b0)×2)×10)
×12とF1=(((48×(b2−b1)+68×b0)
×2)×2−((48×(b1+b2)+68×b3)×
2)×10)×12の48×(b1+b2)の演算及び、
F3=(((96×b3−68×(b1+b2))×2)×
6−((96×b0−68×(b2−b1))×2)×
4)×12とF5=(((96×b0−68×(b2−b
1))×2)×6−((96×b3−68×(b1+b
2))×2)×4)×12の68×(b1+b2)の演算
を実行する。この場合、演算器82gには、減算器81
fの出力(b1)と減算器81gの出力(b2)が入力さ
れ、加算器82g1で加算器81fの出力と加算器81
gの出力を加算すると(b1+b2)が求められる。この
加算器82g1の出力をシフタ82g2に与え、このシフ
タ82g2の第2番目のフリップフロップの出力と第3
番目のフリップフロップの出力を加算器82g3により
加算し、またシフタ82g2の出力と加算器82g1の出
力を82g4により加算することにより(b1+b2)×
48と(b1+b2)×68が求められることになる。こ
の場合、図5の入力に示す入力データに対して演算器8
2gでは、同図IIに示すタイミングで上述の演算結果を
入力データとして発生するようになる。
な整数比に近似した場合のDCTシリアル演算式F7=
(((48×(b1+b2)+68×b3)×2)×2−
((48×(b2−b1)+68×b0)×2)×10)
×12とF1=(((48×(b2−b1)+68×b0)
×2)×2−((48×(b1+b2)+68×b3)×
2)×10)×12の48×(b1+b2)の演算及び、
F3=(((96×b3−68×(b1+b2))×2)×
6−((96×b0−68×(b2−b1))×2)×
4)×12とF5=(((96×b0−68×(b2−b
1))×2)×6−((96×b3−68×(b1+b
2))×2)×4)×12の68×(b1+b2)の演算
を実行する。この場合、演算器82gには、減算器81
fの出力(b1)と減算器81gの出力(b2)が入力さ
れ、加算器82g1で加算器81fの出力と加算器81
gの出力を加算すると(b1+b2)が求められる。この
加算器82g1の出力をシフタ82g2に与え、このシフ
タ82g2の第2番目のフリップフロップの出力と第3
番目のフリップフロップの出力を加算器82g3により
加算し、またシフタ82g2の出力と加算器82g1の出
力を82g4により加算することにより(b1+b2)×
48と(b1+b2)×68が求められることになる。こ
の場合、図5の入力に示す入力データに対して演算器8
2gでは、同図IIに示すタイミングで上述の演算結果を
入力データとして発生するようになる。
【0104】また、上記演算器82hでは、係数を簡単
な整数比に近似した場合のDCTシリアル演算式F7=
(((48×(b1+b2)+68×b3)×2)×2−
((48×(b2−b1)+68×b0)×2)×10)
×12とF1=(((48×(b2−b1)+68×b0)
×2)×2−((48×(b1+b2)+68×b3)×
2)×10)×12の68×b3の演算及び、F3=
(((96×b3−68×(b1+b2))×2)×6−
((96×b0−68×(b2−b1))×2)×4)×
12とF5=(((96×b0−68×(b2−b1))×
2)×6−((96×b3−68×(b1+b2))×
2)×4)×12の96×b3の演算を実行する。この
場合、演算器82hのシフタ82h1には、減算器81
hの出力(b3)が入力され、シフタ82h1の第3番目
のフリップフロップの出力と第4番目のフリップフロッ
プの出力が加算器82h2により加算されるとともに、
この加算結果がシフタ82h3により1クロック遅延し
て出力され、また、シフタ82h1の第1番目のフリッ
プフロップの出力と第5番目のフリップフロップの出力
が加算器82h4により加算されて、68×b3及び96
×b3が求められることになる。この場合、図5の入力
に示す入力データに対して演算器82hでは、同図IIに
示すタイミングで上述の演算結果を入力データとして発
生するようになる。
な整数比に近似した場合のDCTシリアル演算式F7=
(((48×(b1+b2)+68×b3)×2)×2−
((48×(b2−b1)+68×b0)×2)×10)
×12とF1=(((48×(b2−b1)+68×b0)
×2)×2−((48×(b1+b2)+68×b3)×
2)×10)×12の68×b3の演算及び、F3=
(((96×b3−68×(b1+b2))×2)×6−
((96×b0−68×(b2−b1))×2)×4)×
12とF5=(((96×b0−68×(b2−b1))×
2)×6−((96×b3−68×(b1+b2))×
2)×4)×12の96×b3の演算を実行する。この
場合、演算器82hのシフタ82h1には、減算器81
hの出力(b3)が入力され、シフタ82h1の第3番目
のフリップフロップの出力と第4番目のフリップフロッ
プの出力が加算器82h2により加算されるとともに、
この加算結果がシフタ82h3により1クロック遅延し
て出力され、また、シフタ82h1の第1番目のフリッ
プフロップの出力と第5番目のフリップフロップの出力
が加算器82h4により加算されて、68×b3及び96
×b3が求められることになる。この場合、図5の入力
に示す入力データに対して演算器82hでは、同図IIに
示すタイミングで上述の演算結果を入力データとして発
生するようになる。
【0105】次いで、ステージIIIの演算回路63に進
む。この演算回路63では、ステージIIの演算回路62
の演算器82a、82bの出力が加算器83aおよび減
算器83bに与えられ、同様にして演算器82c、82
dの出力が減算器83c及び加算器83dに与えられ、
さらに演算器82e、82fの出力が加算器83e及び
減算器83fに、演算器82g、82hの出力が減算器
83及び加算器83hに与えられる。これにより、加算
器83aは、ステージIIの演算回路82の演算器82a
と演算器82bの出力を加算した結果((a0+a3)×
16+(a1+a2)×16)×2を出力し、減算器83
bはステージIIの演算回路62の演算器82aから演算
器82bの出力を減算した結果((a0+a3)×16−
(a1+a2)×16)×2を出力し、減算器83cはス
テージIIの演算回路62の演算器82cから演算器82
dの出力を減算した結果((a0−a3)×40−(a1
−a2)×96)×2を出力し、加算器83dは、ステ
ージIIの演算回路62の演算器82cと演算器82dの
出力を加算した結果((a0−a3)×96+(a1−a
2)×40)×2を出力するようになる。また、加算器
83eは、ステージIIの演算回路82の演算器82eと
演算器82fの出力を加算した結果(48×(b2−b
1)+68×b0)×2を出力し、減算器83fはステー
ジIIの演算回路62の演算器82eから演算器82fの
出力を減算した結果(96×b0−68×(b2−b
1))×2を出力し、減算器83gはステージIIの演算
回路62の演算器82gから演算器82hの出力を減算
した結果(96×b3−68×(b1+b2))×2を出
力し、加算器83hは、ステージIIの演算回路62の演
算器82gと演算器82hの出力を加算した結果(48
×(b1+b2)+68×b3)×2を出力するようにな
る。この場合、図5の入力データに対して各加算器83
a、83d、83e、83h及び減算器83b、83
c、83f、83gでは、同図IIIに示すタイミング
で、それぞれの演算結果を出力するようになる。
む。この演算回路63では、ステージIIの演算回路62
の演算器82a、82bの出力が加算器83aおよび減
算器83bに与えられ、同様にして演算器82c、82
dの出力が減算器83c及び加算器83dに与えられ、
さらに演算器82e、82fの出力が加算器83e及び
減算器83fに、演算器82g、82hの出力が減算器
83及び加算器83hに与えられる。これにより、加算
器83aは、ステージIIの演算回路82の演算器82a
と演算器82bの出力を加算した結果((a0+a3)×
16+(a1+a2)×16)×2を出力し、減算器83
bはステージIIの演算回路62の演算器82aから演算
器82bの出力を減算した結果((a0+a3)×16−
(a1+a2)×16)×2を出力し、減算器83cはス
テージIIの演算回路62の演算器82cから演算器82
dの出力を減算した結果((a0−a3)×40−(a1
−a2)×96)×2を出力し、加算器83dは、ステ
ージIIの演算回路62の演算器82cと演算器82dの
出力を加算した結果((a0−a3)×96+(a1−a
2)×40)×2を出力するようになる。また、加算器
83eは、ステージIIの演算回路82の演算器82eと
演算器82fの出力を加算した結果(48×(b2−b
1)+68×b0)×2を出力し、減算器83fはステー
ジIIの演算回路62の演算器82eから演算器82fの
出力を減算した結果(96×b0−68×(b2−b
1))×2を出力し、減算器83gはステージIIの演算
回路62の演算器82gから演算器82hの出力を減算
した結果(96×b3−68×(b1+b2))×2を出
力し、加算器83hは、ステージIIの演算回路62の演
算器82gと演算器82hの出力を加算した結果(48
×(b1+b2)+68×b3)×2を出力するようにな
る。この場合、図5の入力データに対して各加算器83
a、83d、83e、83h及び減算器83b、83
c、83f、83gでは、同図IIIに示すタイミング
で、それぞれの演算結果を出力するようになる。
【0106】次いで、ステージIVの演算回路64に進
む。この演算回路64では、ステージIIIの演算回路6
3の加算器83aの出力が演算器84aに与えられ、同
様にして減算器83bの出力が演算器84bに、減算器
83cの出力が演算器84cに、加算器83dの出力が
演算器84dに、加算器83eの出力が演算器84e
に、減算器83fの出力が演算器84fに、減算器83
gの出力が演算器84gに、加算器83hの出力が演算
器84hにそれぞれ与えられる。これにより、演算器8
4aは、ステージIIIの演算回路63の加算器83aの
出力((a0+a3)×16+(a1+a2)×16)×2
に対して×8×46の演算を実行し、その演算結果を出
力データF0として出力する。また、演算器84bは、
ステージIIIの演算回路63の減算器83bの出力
((a0+a3)×16−(a1+a2)×16)×2に対
して×8×46の演算を実行し、その演算結果を出力デ
ータF4として出力する。同様に、演算器84cは、ス
テージIIIの演算回路63の減算器83cの出力((a0
−a3)×40−(a1−a2)×96)×2に対して×
8×10の演算を実行し、その演算結果を出力データF
6として出力する。また、演算器84dは、ステージIII
の演算回路63の加算器83dの出力((a0−a3)×
96+(a1−a2)×40)×2に対して×8×10の
演算を実行し、その演算結果を出力データF2として出
力する。
む。この演算回路64では、ステージIIIの演算回路6
3の加算器83aの出力が演算器84aに与えられ、同
様にして減算器83bの出力が演算器84bに、減算器
83cの出力が演算器84cに、加算器83dの出力が
演算器84dに、加算器83eの出力が演算器84e
に、減算器83fの出力が演算器84fに、減算器83
gの出力が演算器84gに、加算器83hの出力が演算
器84hにそれぞれ与えられる。これにより、演算器8
4aは、ステージIIIの演算回路63の加算器83aの
出力((a0+a3)×16+(a1+a2)×16)×2
に対して×8×46の演算を実行し、その演算結果を出
力データF0として出力する。また、演算器84bは、
ステージIIIの演算回路63の減算器83bの出力
((a0+a3)×16−(a1+a2)×16)×2に対
して×8×46の演算を実行し、その演算結果を出力デ
ータF4として出力する。同様に、演算器84cは、ス
テージIIIの演算回路63の減算器83cの出力((a0
−a3)×40−(a1−a2)×96)×2に対して×
8×10の演算を実行し、その演算結果を出力データF
6として出力する。また、演算器84dは、ステージIII
の演算回路63の加算器83dの出力((a0−a3)×
96+(a1−a2)×40)×2に対して×8×10の
演算を実行し、その演算結果を出力データF2として出
力する。
【0107】また、odd側においては、演算器84e
のシフタ82e1には加算器83eの出力((48×
(b2−b1)+68×b0)×2)が入力され、このシ
フタ84e1の出力と加算器83eの出力を加算器84
e2で加算し、また、後述するシフタ84h1の第1番目
のフリップフロップの出力から、この加算器84e2の
出力を減算器84e3で減算する。減算器84e3の出力
はシフタ84e4に与えられ、このシフタ84e4の出力
から減算器84e3の出力を減算器84e5により減算
し、その演算結果を出力データF7として出力する。ま
た、演算器84fのシフタ82f1には減算器83fの
出力((96×b0−68×(b2−b1))×2)が入
力され、このシフタ84f1の第1番目のフリップフロ
ップの出力と減算器83fの出力を加算器84f2で加
算する。また、後述する加算器84g2の出力から、こ
のシフタ84f1の出力を、この減算器84f3で減算す
る。減算器84f3の出力はシフタ84f4に与えられ、
このシフタ84f4の出力から減算器84f3の出力を減
算器84f5により減算し、その演算結果を出力データ
F3として出力する。また、演算器84gのシフタ82
g1には減算器83gの出力((96×b3−68×(b
1+b2))×2)が入力され、このシフタ84g1の第
1番目のフリップフロップの出力と減算器83gの出力
を加算器84g2で加算する。また、加算器84f2の出
力と、このシフタ84g1の出力を、この加算器84g3
で加算する。加算器84g3の出力はシフタ84g4に与
えられ、このシフタ84g4の出力から加算器84g3の
出力を減算器84g5により減算し、その演算結果を出
力データF5として出力する。また、演算器84hのシ
フタ82h1には加算器83hの出力((48×(b1+
b2)+68×b3)×2)が入力され、このシフタ84
h1の出力と加算器83hの出力を加算器84h2で加算
し、また、シフタ84e1の第1番目のフリップフロッ
プの出力と、この加算器84h2の出力を加算器84h3
で減算する。加算器84h3の出力はシフタ84h4に与
えられ、このシフタ84h4の出力から加算器84h3の
出力を減算器84h5により減算し、その演算結果を出
力データF1として出力する。この場合、上記ステージI
Vの演算回路64の各演算器84a〜84hでは図5の
入力データに対してシリアル演算を実行し、同図IVに示
すタイミングで、その演算結果を出力データF0〜F7と
して発生するようになる。
のシフタ82e1には加算器83eの出力((48×
(b2−b1)+68×b0)×2)が入力され、このシ
フタ84e1の出力と加算器83eの出力を加算器84
e2で加算し、また、後述するシフタ84h1の第1番目
のフリップフロップの出力から、この加算器84e2の
出力を減算器84e3で減算する。減算器84e3の出力
はシフタ84e4に与えられ、このシフタ84e4の出力
から減算器84e3の出力を減算器84e5により減算
し、その演算結果を出力データF7として出力する。ま
た、演算器84fのシフタ82f1には減算器83fの
出力((96×b0−68×(b2−b1))×2)が入
力され、このシフタ84f1の第1番目のフリップフロ
ップの出力と減算器83fの出力を加算器84f2で加
算する。また、後述する加算器84g2の出力から、こ
のシフタ84f1の出力を、この減算器84f3で減算す
る。減算器84f3の出力はシフタ84f4に与えられ、
このシフタ84f4の出力から減算器84f3の出力を減
算器84f5により減算し、その演算結果を出力データ
F3として出力する。また、演算器84gのシフタ82
g1には減算器83gの出力((96×b3−68×(b
1+b2))×2)が入力され、このシフタ84g1の第
1番目のフリップフロップの出力と減算器83gの出力
を加算器84g2で加算する。また、加算器84f2の出
力と、このシフタ84g1の出力を、この加算器84g3
で加算する。加算器84g3の出力はシフタ84g4に与
えられ、このシフタ84g4の出力から加算器84g3の
出力を減算器84g5により減算し、その演算結果を出
力データF5として出力する。また、演算器84hのシ
フタ82h1には加算器83hの出力((48×(b1+
b2)+68×b3)×2)が入力され、このシフタ84
h1の出力と加算器83hの出力を加算器84h2で加算
し、また、シフタ84e1の第1番目のフリップフロッ
プの出力と、この加算器84h2の出力を加算器84h3
で減算する。加算器84h3の出力はシフタ84h4に与
えられ、このシフタ84h4の出力から加算器84h3の
出力を減算器84h5により減算し、その演算結果を出
力データF1として出力する。この場合、上記ステージI
Vの演算回路64の各演算器84a〜84hでは図5の
入力データに対してシリアル演算を実行し、同図IVに示
すタイミングで、その演算結果を出力データF0〜F7と
して発生するようになる。
【0108】以上の説明は、DCT演算処理の場合であ
るが、逆DCT演算処理の場合も上述したと同様であ
る。
るが、逆DCT演算処理の場合も上述したと同様であ
る。
【0109】この場合は入力データがステージIVの演算
回路64〜ステージIの演算回路61の順で与えられる
ようになる。
回路64〜ステージIの演算回路61の順で与えられる
ようになる。
【0110】図5は、データ変換演算装置50の入力か
ら出力までのタイミングチャートであり、ステージIの
演算回路61〜ステージIVの演算回路64の動作を総合
した場合のタイミングチャートを示している。本実施例
では、2のべきにとらわれずにDCTの演算係数を整数
値に置き換え、そのゲイン変化分を量子化装置51によ
って吸収するようにすることによって図4に示すように
回路規模を大幅に小さくすることができ、8bitのデー
タを入力した場合、1ライン当りの処理周期を21クロ
ックに減少させることができる。
ら出力までのタイミングチャートであり、ステージIの
演算回路61〜ステージIVの演算回路64の動作を総合
した場合のタイミングチャートを示している。本実施例
では、2のべきにとらわれずにDCTの演算係数を整数
値に置き換え、そのゲイン変化分を量子化装置51によ
って吸収するようにすることによって図4に示すように
回路規模を大幅に小さくすることができ、8bitのデー
タを入力した場合、1ライン当りの処理周期を21クロ
ックに減少させることができる。
【0111】なお、上述の例は一次元の場合であり、画
素等の二次元の場合には、この処理を縦、横2度行うこ
とによって実現するようにする。
素等の二次元の場合には、この処理を縦、横2度行うこ
とによって実現するようにする。
【0112】データ変換演算装置90における動作(図
7、図8) データ変換演算装置90の基本的な動作は図4に示した
データ変換演算装置50と同様であるが、ステージがI
〜IIIとなっており、かつステージIIのodd側がDC
T演算式をそのままハードウェア化したシリアル回路1
00により構成されているためこの部分の動作は異なっ
ている。まず、シリアル回路100の動作について説明
し、次いで、データ変換演算装置90の全体の動作を述
べる。
7、図8) データ変換演算装置90の基本的な動作は図4に示した
データ変換演算装置50と同様であるが、ステージがI
〜IIIとなっており、かつステージIIのodd側がDC
T演算式をそのままハードウェア化したシリアル回路1
00により構成されているためこの部分の動作は異なっ
ている。まず、シリアル回路100の動作について説明
し、次いで、データ変換演算装置90の全体の動作を述
べる。
【0113】前記図6のデータ変換演算装置50の破線
内の演算について、入力をb0〜b3、出力をx0〜x3と
して考えてみる。同図中破線内の演算は以下のような式
で表わすことができる。
内の演算について、入力をb0〜b3、出力をx0〜x3と
して考えてみる。同図中破線内の演算は以下のような式
で表わすことができる。
【0114】 x0=32×(−85b0+72b1−48b2+17b3) x1=32×(−48b0−85b1−17b2+72b3) x2=32×(72b0−17b1+85b2+48b3) x3=32×(17b0+48b1+72b2+85b3) 上記の式により、x0〜x3は各入力b0〜b3に対して、
17、48、72、85という一定の数値を乗じた値の
加減算によって得られることがわかる。この場合、上記
式に示すように、演算式のうち本来括弧内だけの比率で
求めればよいにもかかわらず従来のシリアル演算を行な
う場合には加減算及びバタフライ演算を用いていたため
×32が必要となり、結果的には32=25としてフリ
ップフロップ(FF)5段分の冗長性が存在していた。
17、48、72、85という一定の数値を乗じた値の
加減算によって得られることがわかる。この場合、上記
式に示すように、演算式のうち本来括弧内だけの比率で
求めればよいにもかかわらず従来のシリアル演算を行な
う場合には加減算及びバタフライ演算を用いていたため
×32が必要となり、結果的には32=25としてフリ
ップフロップ(FF)5段分の冗長性が存在していた。
【0115】上記式の係数17、48、72、85の比
率を同じままで高速化した回路が図8に示すシリアル回
路100である。
率を同じままで高速化した回路が図8に示すシリアル回
路100である。
【0116】図8のデータ変換演算装置90のシリアル
回路100について、入力をb0〜b3、出力をx0〜x3
として考えてみる。図8に示すような回路構成にする
と、各出力x0〜x3は以下のような式によって表わされ
る。
回路100について、入力をb0〜b3、出力をx0〜x3
として考えてみる。図8に示すような回路構成にする
と、各出力x0〜x3は以下のような式によって表わされ
る。
【0117】 x0=4×(−85b0+72b1−48b2+17b3) x1=4×(−48b0−85b1−17b2+72b3) x2=4×(72b0−17b1+85b2+48b3) x3=4×(17b0+48b1+72b2+85b3) 従来の式と比べてゲインは4/32=1/8=2-3倍異
なっている。つまり、2-3から3クロック従来のものよ
りも速く出力することがわかる。ここでは、破線内のみ
を高速化したため偶数成分F0、F2、F4、F6と出力タ
イミングおよびゲインが異なってしまうので、タイミン
グおよびゲインを揃えるために、偶数成分側から不必要
なシフトレジスタを取り去った構成図が図8である。ま
たその時のタイミングチャートが図10であり、入力か
ら出力まで23クロックによって行なう。
なっている。つまり、2-3から3クロック従来のものよ
りも速く出力することがわかる。ここでは、破線内のみ
を高速化したため偶数成分F0、F2、F4、F6と出力タ
イミングおよびゲインが異なってしまうので、タイミン
グおよびゲインを揃えるために、偶数成分側から不必要
なシフトレジスタを取り去った構成図が図8である。ま
たその時のタイミングチャートが図10であり、入力か
ら出力まで23クロックによって行なう。
【0118】以下、上記演算式をそのままハードウェア
化したシリアル回路100の動作を説明する。
化したシリアル回路100の動作を説明する。
【0119】図8において、シリアル回路100の前段
部分を構成するシリアル回路101のシリアル演算器1
01e〜101hには、図7のステージIの演算回路9
1で減算された減算結果b0、b1、b2、b3が入力デー
タとして与えられ、各入力b0〜b3に共通な係数を2の
べきにある数値をかけた形で表現した場合の該数値の部
分が演算される。すなわち、上記シリアル演算器101
eでは、入力b0が入力されると、この入力b0をシフト
あるいはシフト加算を行なうことによって各入力b0〜
b3に共通な係数17、85、48、72を2のべきに
ある数値(本実施例では、2、42、6、18)をかけ
た形で表現した場合の該数値の部分が作成される。この
場合、上記式に示すようにDCT演算式を展開して各入
力に共通な係数17、85、48、72が得られたとす
ると、図1の原理説明(II)で説明したように係数17
は16+1、係数85は42×21+1、係数48は6
×23、係数72は18×22と表現し、この数値2、4
2、6、18の部分(図1の破線内の数値参照)をシリ
アル演算器101eにより演算する。これにより、シリ
アル演算器101eのシフタ101e1の第1番目のフ
リップフロップから1個のフリップフロップの動作だけ
遅延して出力された「2」が、入力b0とシフタ101
e1の第1番目のフリップフロップの出力を加算するこ
とによって加算器101e5から「42」が、入力b0と
シフタ101e1の第1番目のフリップフロップの出力
を加算することによって加算器101e2から「6」
が、入力b0とシフタ101e1の出力を加算することに
よって加算器101e3から「18」がそれぞれ出力さ
れることになる。同様に、上記シリアル演算器101f
では、入力b1がシフトあるいはシフト加算されること
によって、シリアル演算器101fのシフタ101f1
の第1番目のフリップフロップから「2」が、入力b0
と加算器101e4の出力を加算して出力加算器101
f5から「42」が、加算器101f2から「6」が、加
算器101f3から「18」がそれぞれ出力されること
になる。また、上記シリアル演算器101gでは、入力
b2がシフトあるいはシフト加算されることによって、
シリアル演算器101gのシフタ101g1の第1番目
のフリップフロップから「2」が、加算器101g5か
ら「42」が、加算器101g2から「6」が、加算器
101g3から「18」がそれぞれ出力されることにな
り、上記シリアル演算器101hでは、入力b3がシフ
トあるいはシフト加算されることによって、シリアル演
算器101hのシフタ101h1の第1番目のフリップ
フロップから「2」が、加算器101h5から「42」
が、加算器101h2から「6」が、加算器101h3か
ら「18」がそれぞれ出力されることになる。
部分を構成するシリアル回路101のシリアル演算器1
01e〜101hには、図7のステージIの演算回路9
1で減算された減算結果b0、b1、b2、b3が入力デー
タとして与えられ、各入力b0〜b3に共通な係数を2の
べきにある数値をかけた形で表現した場合の該数値の部
分が演算される。すなわち、上記シリアル演算器101
eでは、入力b0が入力されると、この入力b0をシフト
あるいはシフト加算を行なうことによって各入力b0〜
b3に共通な係数17、85、48、72を2のべきに
ある数値(本実施例では、2、42、6、18)をかけ
た形で表現した場合の該数値の部分が作成される。この
場合、上記式に示すようにDCT演算式を展開して各入
力に共通な係数17、85、48、72が得られたとす
ると、図1の原理説明(II)で説明したように係数17
は16+1、係数85は42×21+1、係数48は6
×23、係数72は18×22と表現し、この数値2、4
2、6、18の部分(図1の破線内の数値参照)をシリ
アル演算器101eにより演算する。これにより、シリ
アル演算器101eのシフタ101e1の第1番目のフ
リップフロップから1個のフリップフロップの動作だけ
遅延して出力された「2」が、入力b0とシフタ101
e1の第1番目のフリップフロップの出力を加算するこ
とによって加算器101e5から「42」が、入力b0と
シフタ101e1の第1番目のフリップフロップの出力
を加算することによって加算器101e2から「6」
が、入力b0とシフタ101e1の出力を加算することに
よって加算器101e3から「18」がそれぞれ出力さ
れることになる。同様に、上記シリアル演算器101f
では、入力b1がシフトあるいはシフト加算されること
によって、シリアル演算器101fのシフタ101f1
の第1番目のフリップフロップから「2」が、入力b0
と加算器101e4の出力を加算して出力加算器101
f5から「42」が、加算器101f2から「6」が、加
算器101f3から「18」がそれぞれ出力されること
になる。また、上記シリアル演算器101gでは、入力
b2がシフトあるいはシフト加算されることによって、
シリアル演算器101gのシフタ101g1の第1番目
のフリップフロップから「2」が、加算器101g5か
ら「42」が、加算器101g2から「6」が、加算器
101g3から「18」がそれぞれ出力されることにな
り、上記シリアル演算器101hでは、入力b3がシフ
トあるいはシフト加算されることによって、シリアル演
算器101hのシフタ101h1の第1番目のフリップ
フロップから「2」が、加算器101h5から「42」
が、加算器101h2から「6」が、加算器101h3か
ら「18」がそれぞれ出力されることになる。
【0120】上記シリアル演算器101e〜101hで
演算されたDCT演算式の係数に相当する数値「2」、
「42」、「6」、「18」はシリアル回路100の後
段部分を構成するシリアル回路102のシリアル演算器
102e〜102hに入力され、各シリアル演算器10
2e〜102hは、シリアル演算器101e〜101h
により計算された係数出力に対してDCT演算式の横方
向に符号分を含めた加減算を順次行なって出力x3〜x0
として出力する。この場合、上記係数17、85、4
8、72を2のべきにある数値をかけた形で表現したと
きの2のべきの部分は各シリアル演算器102e〜10
2hの加減算器への入力位置により調整されるととも
に、原理説明(II)で説明した理由から係数17、8
5、48、72のうち、基本的に奇数のもの(係数1
7、85)についての加減算を先に行なうようにする。
演算されたDCT演算式の係数に相当する数値「2」、
「42」、「6」、「18」はシリアル回路100の後
段部分を構成するシリアル回路102のシリアル演算器
102e〜102hに入力され、各シリアル演算器10
2e〜102hは、シリアル演算器101e〜101h
により計算された係数出力に対してDCT演算式の横方
向に符号分を含めた加減算を順次行なって出力x3〜x0
として出力する。この場合、上記係数17、85、4
8、72を2のべきにある数値をかけた形で表現したと
きの2のべきの部分は各シリアル演算器102e〜10
2hの加減算器への入力位置により調整されるととも
に、原理説明(II)で説明した理由から係数17、8
5、48、72のうち、基本的に奇数のもの(係数1
7、85)についての加減算を先に行なうようにする。
【0121】上記シリアル演算器102eでは、DCT
演算式をそのままハードウェア化した場合のシリアル演
算式x3=4×(17b0+48b1+72b2+85b
3)を実行する。この場合、シリアル演算器102eの
加算器102e1には、シリアル演算器101fの加算
器101f2の出力とシリアル演算器101eのシフタ
101e1の第1番目のフリップフロップの出力とが入
力され、加算器102e1でこれら入力を加算し、この
加算器102e1の出力とシリアル演算器101gの加
算器101g3の出力を加算器102e2で加算し、この
加算器102e2の出力とシリアル演算器101hの加
算器101h5の出力を加算器102e3で加算し、この
加算器102e3の出力と入力b3を加算器102e4で
加算し、この加算器102e4の出力とシリアル演算器
101eのシフタ101e1の第1番目のフリップフロ
ップの出力を加算器102e5で加算すると出力x3が求
められる。
演算式をそのままハードウェア化した場合のシリアル演
算式x3=4×(17b0+48b1+72b2+85b
3)を実行する。この場合、シリアル演算器102eの
加算器102e1には、シリアル演算器101fの加算
器101f2の出力とシリアル演算器101eのシフタ
101e1の第1番目のフリップフロップの出力とが入
力され、加算器102e1でこれら入力を加算し、この
加算器102e1の出力とシリアル演算器101gの加
算器101g3の出力を加算器102e2で加算し、この
加算器102e2の出力とシリアル演算器101hの加
算器101h5の出力を加算器102e3で加算し、この
加算器102e3の出力と入力b3を加算器102e4で
加算し、この加算器102e4の出力とシリアル演算器
101eのシフタ101e1の第1番目のフリップフロ
ップの出力を加算器102e5で加算すると出力x3が求
められる。
【0122】また、上記シリアル演算器102fでは、
DCT演算式をそのままハードウェア化した場合のシリ
アル演算式x2=4×(72b0−17b1+85b2+4
8b3)を実行する。この場合、シリアル演算器102
fの減算器102f1には、シリアル演算器101hの
加算器101h2の出力とシリアル演算器101fのシ
フタ101f1の第1番目のフリップフロップの出力と
が入力され、減算器102f1で加算器101h2の出力
からシフタ101f1の第1番目のフリップフロップの
出力を減算し、この減算器102f1の出力とシリアル
演算器101eの加算器101e3の出力を加算器10
2f2で加算し、この加算器102f2の出力とシリアル
演算器101gの加算器101g5の出力を加算器10
2f3で加算し、この加算器102f3の出力と入力b2
を加算器102f4で加算し、この加算器102f4の出
力からシリアル演算器101fのシフタ101f1の第
1番目のフリップフロップの出力を減算器102f5で
減算すると出力x2が求められる。
DCT演算式をそのままハードウェア化した場合のシリ
アル演算式x2=4×(72b0−17b1+85b2+4
8b3)を実行する。この場合、シリアル演算器102
fの減算器102f1には、シリアル演算器101hの
加算器101h2の出力とシリアル演算器101fのシ
フタ101f1の第1番目のフリップフロップの出力と
が入力され、減算器102f1で加算器101h2の出力
からシフタ101f1の第1番目のフリップフロップの
出力を減算し、この減算器102f1の出力とシリアル
演算器101eの加算器101e3の出力を加算器10
2f2で加算し、この加算器102f2の出力とシリアル
演算器101gの加算器101g5の出力を加算器10
2f3で加算し、この加算器102f3の出力と入力b2
を加算器102f4で加算し、この加算器102f4の出
力からシリアル演算器101fのシフタ101f1の第
1番目のフリップフロップの出力を減算器102f5で
減算すると出力x2が求められる。
【0123】また、上記シリアル演算器102gでは、
DCT演算式をそのままハードウェア化した場合のシリ
アル演算式x1=4×(−48b0−85b1−17b2+
72b3)実行する。この場合、シリアル演算器102
gの加算器102g1には、シリアル演算器101eの
加算器101e2の出力とシリアル演算器101gのシ
フタ101g1の第1番目のフリップフロップの出力と
が入力され、加算器102g1でこれら入力を加算し、
次いで減算器102g2でシリアル演算器101hの加
算器101h3の出力から加算器102g1の出力を減算
し、この減算器102g2の出力からシリアル演算器1
01fの加算器101f5の出力を減算器102g3で減
算し、この減算器102g3の出力から入力b1を減算器
102g4で減算し、この減算器102g4の出力からシ
リアル演算器101gのシフタ101g1の第1番目の
フリップフロップの出力を減算器102g5で減算する
と出力x1が求められる。
DCT演算式をそのままハードウェア化した場合のシリ
アル演算式x1=4×(−48b0−85b1−17b2+
72b3)実行する。この場合、シリアル演算器102
gの加算器102g1には、シリアル演算器101eの
加算器101e2の出力とシリアル演算器101gのシ
フタ101g1の第1番目のフリップフロップの出力と
が入力され、加算器102g1でこれら入力を加算し、
次いで減算器102g2でシリアル演算器101hの加
算器101h3の出力から加算器102g1の出力を減算
し、この減算器102g2の出力からシリアル演算器1
01fの加算器101f5の出力を減算器102g3で減
算し、この減算器102g3の出力から入力b1を減算器
102g4で減算し、この減算器102g4の出力からシ
リアル演算器101gのシフタ101g1の第1番目の
フリップフロップの出力を減算器102g5で減算する
と出力x1が求められる。
【0124】また、上記シリアル演算器102hでは、
DCT演算式をそのままハードウェア化した場合のシリ
アル演算式x0=4×(−85b0+72b1−48b2+
17b3)実行する。この場合、シリアル演算器102
hの減算器102h1には、シリアル演算器101hの
シフタ101h1の第1番目のフリップフロップの出力
とシリアル演算器101gの加算器101g2の出力と
が入力され、減算器102h1でシフタ101h1の第1
番目のフリップフロップの出力から加算器101g2の
出力を減算し、この減算器102h1の出力とシリアル
演算器101fの加算器101f3の出力を加算器10
2h2で加算し、この加算器102h2の出力からシリア
ル演算器101eの加算器101e5の出力を減算器1
02h3で減算し、この減算器102h3の出力から入力
b0を減算器102h4で減算し、この減算器102h4
の出力とシリアル演算器101hのシフタ101h1の
第1番目のフリップフロップの出力を加算器102h5
で加算すると出力x0が求められる。
DCT演算式をそのままハードウェア化した場合のシリ
アル演算式x0=4×(−85b0+72b1−48b2+
17b3)実行する。この場合、シリアル演算器102
hの減算器102h1には、シリアル演算器101hの
シフタ101h1の第1番目のフリップフロップの出力
とシリアル演算器101gの加算器101g2の出力と
が入力され、減算器102h1でシフタ101h1の第1
番目のフリップフロップの出力から加算器101g2の
出力を減算し、この減算器102h1の出力とシリアル
演算器101fの加算器101f3の出力を加算器10
2h2で加算し、この加算器102h2の出力からシリア
ル演算器101eの加算器101e5の出力を減算器1
02h3で減算し、この減算器102h3の出力から入力
b0を減算器102h4で減算し、この減算器102h4
の出力とシリアル演算器101hのシフタ101h1の
第1番目のフリップフロップの出力を加算器102h5
で加算すると出力x0が求められる。
【0125】上記シリアル演算の場合、図10の入力デ
ータに対してシリアル演算器102e〜102hから
は、同図IIに示すタイミングで、それぞれの演算結果を
出力するようになる。
ータに対してシリアル演算器102e〜102hから
は、同図IIに示すタイミングで、それぞれの演算結果を
出力するようになる。
【0126】以下、上記シリアル回路100を含んで構
成されたデータ変換演算装置90の動作を説明する。
成されたデータ変換演算装置90の動作を説明する。
【0127】まず、DCT演算処理の場合を述べると、
ここでは、ステージIの演算回路91において加算器8
1aに入力データf0とf7、加算器81bに入力データ
f3とf4、加算器81cに入力データf1とf6、加算器
81dに入力データf2とf5、減算器81eに入力デー
タf0とf7、減算器81fに入力データf3とf4、減算
器81gに入力データf1とf6、減算器81hに入力デ
ータf2とf5が入力される。これにより加算器81aは
入力データf0とf7の加算結果を出力し、加算器81b
は入力データf3とf4の加算結果を出力し、加算器81
cは入力データf1とf6の加算結果f1+f6を出力し、
加算器81dは入力データf2とf5の加算結果を出力す
るようになる。また、減算器81eは入力データf0と
f7の減算結果を出力し、減算器81fは入力データf3
とf4の減算結果を出力し、減算器81gは入力データ
f1とf6の減算結果を出力し、減算器81hは入力デー
タf2とf5の減算結果を出力するようになる。この場合
の入力データは、図10に示すように7bitと1bitのサ
インビットの8bitのデータからなっている。また、出
力データは、図10Iに示すように7+1bitと1bitの
サインビットからなっている。
ここでは、ステージIの演算回路91において加算器8
1aに入力データf0とf7、加算器81bに入力データ
f3とf4、加算器81cに入力データf1とf6、加算器
81dに入力データf2とf5、減算器81eに入力デー
タf0とf7、減算器81fに入力データf3とf4、減算
器81gに入力データf1とf6、減算器81hに入力デ
ータf2とf5が入力される。これにより加算器81aは
入力データf0とf7の加算結果を出力し、加算器81b
は入力データf3とf4の加算結果を出力し、加算器81
cは入力データf1とf6の加算結果f1+f6を出力し、
加算器81dは入力データf2とf5の加算結果を出力す
るようになる。また、減算器81eは入力データf0と
f7の減算結果を出力し、減算器81fは入力データf3
とf4の減算結果を出力し、減算器81gは入力データ
f1とf6の減算結果を出力し、減算器81hは入力デー
タf2とf5の減算結果を出力するようになる。この場合
の入力データは、図10に示すように7bitと1bitのサ
インビットの8bitのデータからなっている。また、出
力データは、図10Iに示すように7+1bitと1bitの
サインビットからなっている。
【0128】次いで、ステージIIの演算回路92に進
む。この演算回路92のeven側のシリアル演算器9
2a〜92dには、ステージIの演算回路91で加算さ
れた加算結果a0、a1、a2、a3が入力データとして与
えられ、odd側のシリアル回路100には、ステージ
Iの演算回路91で減算された減算結果b0、b1、b
2、b3が入力データとして与えられる。上記演算器92
aでは、係数を簡単な整数比に近似した場合のDCTシ
リアル演算式F0=(92a0+92a1+92a2+92
a3)×128の括弧内の演算を実行する。この場合、
シリアル演算器92aの前段部を構成する加算器82a
1には、加算器81aの出力と加算器81dの出力とが
入力され、加算器82a1でこれら入力データを加算
し、この加算結果がシフタ82a2に与えられる。ま
た、上記シリアル演算器92bでは、係数を簡単な整数
比に近似した場合のDCTシリアル演算式F4=(92
a0−92a1−92a2+92a3)×128の括弧内の
演算を実行する。この場合、シリアル演算器92bの前
段部を構成する演算器92bには、加算器81bの出力
と加算器81cの出力とが入力され、加算器82b1で
これら入力データを加算し、この加算結果がシフタ82
b2に与えられる。これにより、シフタ82a2及びシフ
タ82b2からは3個のフリップフロップの動作だけ遅
延して出力されることになる。 また、上記シリアル演
算器92cでは、係数を簡単な整数比に近似した場合の
DCTシリアル演算式F6=(25a0+60a1−60
a2−25a3)×128の括弧内の演算を実行する。こ
の場合、シリアル演算器92cの前段部を構成する演算
器82cには、加算器81bの出力と加算器81cの出
力とが入力され、減算器82c1で加算器81bの出力
を加算器81cの出力で減算すると(a1−a2)が求め
られる。この減算器82c1の出力をシフタ82c2に与
え、このシフタ82c2の第1番目のフリップフロップ
の出力とシフタ82c2の出力を加算器82c3により加
算し、また、シフタ82c2の第2番目のフリップフロ
ップの出力と加算器82c3の出力を加算器82c4によ
り加算することにより「25」、「60」が求められる
ことになる。また、上記シリアル演算器92dでは、係
数を簡単な整数比に近似した場合のDCTシリアル演算
式F2=(60a0+25a1−25a2−60a3)×1
28の括弧内の演算を実行する。この場合、シリアル演
算器92dの前段部を構成する演算器82dには、加算
器81aの出力と加算器81dの出力とが入力され、減
算器82d1で加算器81aの出力を加算器81dの出
力で減算すると(a0−a3)が求められる。この減算器
82d1の出力をシフタ82d2に与え、このシフタ82
d2の第1番目のフリップフロップの出力とシフタ82
d2の出力を加算器82d3により加算し、また、シフタ
82d2の第2番目のフリップフロップの出力と加算器
82d3の出力を加算器82d4により加算することによ
り「60」、「25」が求められることになる。
む。この演算回路92のeven側のシリアル演算器9
2a〜92dには、ステージIの演算回路91で加算さ
れた加算結果a0、a1、a2、a3が入力データとして与
えられ、odd側のシリアル回路100には、ステージ
Iの演算回路91で減算された減算結果b0、b1、b
2、b3が入力データとして与えられる。上記演算器92
aでは、係数を簡単な整数比に近似した場合のDCTシ
リアル演算式F0=(92a0+92a1+92a2+92
a3)×128の括弧内の演算を実行する。この場合、
シリアル演算器92aの前段部を構成する加算器82a
1には、加算器81aの出力と加算器81dの出力とが
入力され、加算器82a1でこれら入力データを加算
し、この加算結果がシフタ82a2に与えられる。ま
た、上記シリアル演算器92bでは、係数を簡単な整数
比に近似した場合のDCTシリアル演算式F4=(92
a0−92a1−92a2+92a3)×128の括弧内の
演算を実行する。この場合、シリアル演算器92bの前
段部を構成する演算器92bには、加算器81bの出力
と加算器81cの出力とが入力され、加算器82b1で
これら入力データを加算し、この加算結果がシフタ82
b2に与えられる。これにより、シフタ82a2及びシフ
タ82b2からは3個のフリップフロップの動作だけ遅
延して出力されることになる。 また、上記シリアル演
算器92cでは、係数を簡単な整数比に近似した場合の
DCTシリアル演算式F6=(25a0+60a1−60
a2−25a3)×128の括弧内の演算を実行する。こ
の場合、シリアル演算器92cの前段部を構成する演算
器82cには、加算器81bの出力と加算器81cの出
力とが入力され、減算器82c1で加算器81bの出力
を加算器81cの出力で減算すると(a1−a2)が求め
られる。この減算器82c1の出力をシフタ82c2に与
え、このシフタ82c2の第1番目のフリップフロップ
の出力とシフタ82c2の出力を加算器82c3により加
算し、また、シフタ82c2の第2番目のフリップフロ
ップの出力と加算器82c3の出力を加算器82c4によ
り加算することにより「25」、「60」が求められる
ことになる。また、上記シリアル演算器92dでは、係
数を簡単な整数比に近似した場合のDCTシリアル演算
式F2=(60a0+25a1−25a2−60a3)×1
28の括弧内の演算を実行する。この場合、シリアル演
算器92dの前段部を構成する演算器82dには、加算
器81aの出力と加算器81dの出力とが入力され、減
算器82d1で加算器81aの出力を加算器81dの出
力で減算すると(a0−a3)が求められる。この減算器
82d1の出力をシフタ82d2に与え、このシフタ82
d2の第1番目のフリップフロップの出力とシフタ82
d2の出力を加算器82d3により加算し、また、シフタ
82d2の第2番目のフリップフロップの出力と加算器
82d3の出力を加算器82d4により加算することによ
り「60」、「25」が求められることになる。
【0129】次いで、上記演算器82a〜82dで求め
た演算結果は、シリアル演算器92a〜92dの後段部
を構成する加減算器に与えられる。具体的には、演算器
82a、82bの出力が加算器83aおよび減算器83
bに与えられ、演算器82c、82dの出力が減算器8
3c及び加算器83dに与えられ、さらに演算器82
e、82fの出力が加算器83e及び減算器83fに、
演算器82g、82hの出力が減算器83及び加算器8
3hに与えられる。これにより、加算器83aは、演算
器82aと演算器82bの出力を加算した結果(92a
0+92a1+92a2+92a3)を出力し、減算器83
bは、演算器82aから演算器82bの出力を減算した
結果(92a0−92a1−92a2+92a3)を出力
し、減算器83cは、演算器82cから演算器82dの
出力を減算した結果(25a0+60a1−60a2−2
5a3)を出力し、加算器83dは、演算器82cと演
算器82dの出力を加算した結果(60a0+25a1−
25a2−60a3)を出力するようになる。この場合、
図10の入力に示す入力データに対して演算器83a〜
83hでは、同図IIに示すタイミングで上述の演算結果
を出力データとして発生するようになる。
た演算結果は、シリアル演算器92a〜92dの後段部
を構成する加減算器に与えられる。具体的には、演算器
82a、82bの出力が加算器83aおよび減算器83
bに与えられ、演算器82c、82dの出力が減算器8
3c及び加算器83dに与えられ、さらに演算器82
e、82fの出力が加算器83e及び減算器83fに、
演算器82g、82hの出力が減算器83及び加算器8
3hに与えられる。これにより、加算器83aは、演算
器82aと演算器82bの出力を加算した結果(92a
0+92a1+92a2+92a3)を出力し、減算器83
bは、演算器82aから演算器82bの出力を減算した
結果(92a0−92a1−92a2+92a3)を出力
し、減算器83cは、演算器82cから演算器82dの
出力を減算した結果(25a0+60a1−60a2−2
5a3)を出力し、加算器83dは、演算器82cと演
算器82dの出力を加算した結果(60a0+25a1−
25a2−60a3)を出力するようになる。この場合、
図10の入力に示す入力データに対して演算器83a〜
83hでは、同図IIに示すタイミングで上述の演算結果
を出力データとして発生するようになる。
【0130】なお、ステージIIの演算回路92のodd
側を構成するシリアル回路100の動作は前述してい
る。
側を構成するシリアル回路100の動作は前述してい
る。
【0131】次いで、ステージIIIの演算回路93に進
む。この演算回路93では、ステージIIの演算回路92
の加算器83aの出力が演算器93aに与えられ、同様
にして減算器83bの出力が演算器93bに、減算器8
3cの出力が演算器93cに、加算器83dの出力が演
算器93dに、シリアル回路100の出力x0が演算器
93eに、シリアル回路100の出力x1が演算器93
fに、シリアル回路100の出力x2が演算器93g
に、シリアル回路100の出力x3が演算器93hにそ
れぞれ与えられる。これにより、演算器93aは、ステ
ージIIの演算回路92の加算器83aの出力(92a0
+92a1+92a2+92a3)に対して×128の演
算を実行し、出力F0のゲイン128を与え、その演算
結果を出力データF0として出力する。また、演算器9
3bは、ステージIIの演算回路92の減算器83bの出
力(92a0−92a1−92a2+92a3)に対して×
128の演算を実行し、出力F4のゲイン128を与
え、その演算結果を出力データF4として出力する。同
様に、演算器93cは、ステージIIの演算回路92の減
算器83cの出力(25a0+60a1−60a2−25
a3)に対して×128の演算を実行し、出力F6のゲイ
ン128を与え、その演算結果を出力データF6として
出力する。また、演算器93dは、ステージIIの演算回
路92の加算器83dの出力(60a0+25a1−25
a2−60a3)に対して×128の演算を実行し、出力
F2のゲイン128を与え、その演算結果を出力データ
F2として出力する。
む。この演算回路93では、ステージIIの演算回路92
の加算器83aの出力が演算器93aに与えられ、同様
にして減算器83bの出力が演算器93bに、減算器8
3cの出力が演算器93cに、加算器83dの出力が演
算器93dに、シリアル回路100の出力x0が演算器
93eに、シリアル回路100の出力x1が演算器93
fに、シリアル回路100の出力x2が演算器93g
に、シリアル回路100の出力x3が演算器93hにそ
れぞれ与えられる。これにより、演算器93aは、ステ
ージIIの演算回路92の加算器83aの出力(92a0
+92a1+92a2+92a3)に対して×128の演
算を実行し、出力F0のゲイン128を与え、その演算
結果を出力データF0として出力する。また、演算器9
3bは、ステージIIの演算回路92の減算器83bの出
力(92a0−92a1−92a2+92a3)に対して×
128の演算を実行し、出力F4のゲイン128を与
え、その演算結果を出力データF4として出力する。同
様に、演算器93cは、ステージIIの演算回路92の減
算器83cの出力(25a0+60a1−60a2−25
a3)に対して×128の演算を実行し、出力F6のゲイ
ン128を与え、その演算結果を出力データF6として
出力する。また、演算器93dは、ステージIIの演算回
路92の加算器83dの出力(60a0+25a1−25
a2−60a3)に対して×128の演算を実行し、出力
F2のゲイン128を与え、その演算結果を出力データ
F2として出力する。
【0132】また、odd側においては、演算器93e
のシフタ84e4及び減算器84e5は、ステージIIのシ
リアル回路100の出力x0に対して×32の演算を実
行して出力F7のゲイン32を与え、その演算結果を出
力データF7として出力する。また、演算器93fのシ
フタ84f4及び減算器84f5は、ステージIIのシリア
ル回路100の出力x1に対して×32の演算を実行し
て出力F3のゲイン32を与え、その演算結果を出力デ
ータF3として出力する。同様に、演算器93gのシフ
タ84g4及び減算器84g5は、ステージIIのシリアル
回路100の出力x2に対して×32の演算を実行して
出力F5のゲイン32を与え、その演算結果を出力デー
タF5として出力する。また、演算器93hのシフタ8
4h4及び減算器84h5は、ステージIIのシリアル回路
100の出力x3に対して×32の演算を実行して出力
F1のゲイン32を与え、その演算結果を出力データF1
として出力する。この場合、上記ステージIIIの演算回
路93の各演算器93a〜93hでは図10の入力デー
タに対してシリアル演算を実行し、同図IIIに示すタイ
ミングで、その演算結果を出力データF0〜F7として発
生するようになようになる。
のシフタ84e4及び減算器84e5は、ステージIIのシ
リアル回路100の出力x0に対して×32の演算を実
行して出力F7のゲイン32を与え、その演算結果を出
力データF7として出力する。また、演算器93fのシ
フタ84f4及び減算器84f5は、ステージIIのシリア
ル回路100の出力x1に対して×32の演算を実行し
て出力F3のゲイン32を与え、その演算結果を出力デ
ータF3として出力する。同様に、演算器93gのシフ
タ84g4及び減算器84g5は、ステージIIのシリアル
回路100の出力x2に対して×32の演算を実行して
出力F5のゲイン32を与え、その演算結果を出力デー
タF5として出力する。また、演算器93hのシフタ8
4h4及び減算器84h5は、ステージIIのシリアル回路
100の出力x3に対して×32の演算を実行して出力
F1のゲイン32を与え、その演算結果を出力データF1
として出力する。この場合、上記ステージIIIの演算回
路93の各演算器93a〜93hでは図10の入力デー
タに対してシリアル演算を実行し、同図IIIに示すタイ
ミングで、その演算結果を出力データF0〜F7として発
生するようになようになる。
【0133】以上の説明は、DCT演算処理の場合であ
るが、逆DCT演算処理の場合も上述したと同様であ
る。
るが、逆DCT演算処理の場合も上述したと同様であ
る。
【0134】この場合は入力データがステージIIIの演
算回路93〜ステージIの演算回路91の順で与えられ
るようになる。
算回路93〜ステージIの演算回路91の順で与えられ
るようになる。
【0135】図10は、データ変換演算装置90の入力
から出力までのタイミングチャートであり、ステージI
の演算回路91〜ステージIIIの演算回路93の動作を
総合した場合のタイミングチャートを示している。本実
施例では、DCT演算式を展開することによって各入力
に共通な係数が表れるように係数を分割し、このように
展開したDCT演算式をバタフライ演算にとらわれずに
そのままハードウェア化することによって偶数成分側か
らタイミングおよびゲインを揃えるために設けられたシ
フトレジスタを取り去ることができ、図9に示すデータ
変換演算装置50のタイミングチャートと比較して明ら
かなように7bitのデータを入力した場合、1ライン当
りの処理周期を26クロックから23クロックに減少さ
せることができる。
から出力までのタイミングチャートであり、ステージI
の演算回路91〜ステージIIIの演算回路93の動作を
総合した場合のタイミングチャートを示している。本実
施例では、DCT演算式を展開することによって各入力
に共通な係数が表れるように係数を分割し、このように
展開したDCT演算式をバタフライ演算にとらわれずに
そのままハードウェア化することによって偶数成分側か
らタイミングおよびゲインを揃えるために設けられたシ
フトレジスタを取り去ることができ、図9に示すデータ
変換演算装置50のタイミングチャートと比較して明ら
かなように7bitのデータを入力した場合、1ライン当
りの処理周期を26クロックから23クロックに減少さ
せることができる。
【0136】以上説明したように、本実施例のデータ圧
縮伸張装置は、画像データをパラレルデータの形で蓄え
るデータ記憶装置10と、データ記憶装置10から読み
込んだパラレルデータをシリアルデータに変換するパラ
レル−シリアル変換装装置11と、DCT演算係数を簡
単な整数比に変えた形のシリアル回路により構成される
とともに、odd側については演算式をそのままハード
ウェア化したシリアル回路100を含んで構成され、パ
ラレル−シリアル変換装装置11から出力されたデータ
に対して一次元のDCT演算をシリアル演算の形で施す
データ変換演算装置90と、シリアルDCT演算された
シリアルデータをパラレルデータに変換してデータ記憶
装置10に書き込むシリアル−パラレル変換装置13
と、データ記憶装置10に蓄えられたデータ変換演算後
のデータに対して、DCT演算係数を整数比に変えるこ
とにより生じたゲイン変化分を吸収させるように構成し
た量子化テーブルの値で除算することによって量子化演
算を行なう量子化装置51と、上記各部の動作をデータ
圧縮伸張装置の全体を制御する制御装置52とを有し、
シリアル回路100は、DCT演算式を展開して得られ
た各入力b0〜b3に共通な係数を2のべきにある数値を
かけた形で表現した場合の該数値の部分を作成するシリ
アル回路101と、このシリアル回路101により計算
された係数出力に対して式の横方向に符号分を含めた加
減算を行なって出力x0〜x3として出力するシリアル回
路102により構成されているので、演算式をそのまま
ハードウェア化することによってバタフライ演算部をな
くすとともにFF等の段数を減らすことができ、クロッ
ク数(時間)を短縮することができる。すなわち、図2
2に示す従来のデータ変換演算装置12の回路構成の場
合、8bitのデータを入力した場合図9に示すようにL
SB入力からMSB出力まで26クロックかかっていた
が、図7に示すデータ変換演算装置90ではステージII
のodd側にシリアル回路100を用いることにより偶
数成分側からタイミングおよびゲインを揃えるために設
けられたシフトレジスタを3段取り去ることができ、図
9に示すデータ変換演算装置50のタイミングチャート
と比較して明らかなように7bitのデータを入力した場
合、1ライン当りの処理周期を26クロックから23ク
ロックに減少させることができる。その結果、少ないク
ロック数によりデータ変換演算を実行できるという利点
があり、画像圧縮等のデータ圧縮に利用することができ
る。
縮伸張装置は、画像データをパラレルデータの形で蓄え
るデータ記憶装置10と、データ記憶装置10から読み
込んだパラレルデータをシリアルデータに変換するパラ
レル−シリアル変換装装置11と、DCT演算係数を簡
単な整数比に変えた形のシリアル回路により構成される
とともに、odd側については演算式をそのままハード
ウェア化したシリアル回路100を含んで構成され、パ
ラレル−シリアル変換装装置11から出力されたデータ
に対して一次元のDCT演算をシリアル演算の形で施す
データ変換演算装置90と、シリアルDCT演算された
シリアルデータをパラレルデータに変換してデータ記憶
装置10に書き込むシリアル−パラレル変換装置13
と、データ記憶装置10に蓄えられたデータ変換演算後
のデータに対して、DCT演算係数を整数比に変えるこ
とにより生じたゲイン変化分を吸収させるように構成し
た量子化テーブルの値で除算することによって量子化演
算を行なう量子化装置51と、上記各部の動作をデータ
圧縮伸張装置の全体を制御する制御装置52とを有し、
シリアル回路100は、DCT演算式を展開して得られ
た各入力b0〜b3に共通な係数を2のべきにある数値を
かけた形で表現した場合の該数値の部分を作成するシリ
アル回路101と、このシリアル回路101により計算
された係数出力に対して式の横方向に符号分を含めた加
減算を行なって出力x0〜x3として出力するシリアル回
路102により構成されているので、演算式をそのまま
ハードウェア化することによってバタフライ演算部をな
くすとともにFF等の段数を減らすことができ、クロッ
ク数(時間)を短縮することができる。すなわち、図2
2に示す従来のデータ変換演算装置12の回路構成の場
合、8bitのデータを入力した場合図9に示すようにL
SB入力からMSB出力まで26クロックかかっていた
が、図7に示すデータ変換演算装置90ではステージII
のodd側にシリアル回路100を用いることにより偶
数成分側からタイミングおよびゲインを揃えるために設
けられたシフトレジスタを3段取り去ることができ、図
9に示すデータ変換演算装置50のタイミングチャート
と比較して明らかなように7bitのデータを入力した場
合、1ライン当りの処理周期を26クロックから23ク
ロックに減少させることができる。その結果、少ないク
ロック数によりデータ変換演算を実行できるという利点
があり、画像圧縮等のデータ圧縮に利用することができ
る。
【0137】また、本実施例のデータ圧縮伸張装置は、
画像データをパラレルデータの形で蓄えるデータ記憶装
置10と、データ記憶装置10から読み込んだパラレル
データをシリアルデータに変換するパラレル−シリアル
変換装装置11と、DCT演算係数を簡単な整数比に変
えた形のシリアル回路により構成され、パラレル−シリ
アル変換装装置11から出力されたデータに対して一次
元のDCT演算をシリアル演算の形で施すデータ変換演
算装置50と、シリアルDCT演算されたシリアルデー
タをパラレルデータに変換してデータ記憶装置10に書
き込むシリアル−パラレル変換装置13と、データ記憶
装置10に蓄えられたデータ変換演算後のデータに対し
て、DCT演算係数を整数比に変えることにより生じた
ゲイン変化分を吸収させるように構成した量子化テーブ
ルの値で除算することによって量子化演算を行なう量子
化装置51と、上記各部の動作をデータ圧縮伸張装置の
全体を制御する制御装置52とを設け、2のべきで表現
できる部分はべきで表現してシリアル回路を構成する一
方で、べきで表現しようとすればビット数が大きくなっ
てしまう部分については敢えてべきにより表現しようと
しないで2のべきにとらわれずにDCT演算式の係数を
整数比に置き換え、そのゲイン変化分を量子化部によっ
て吸収するようにしているので、単にシリアル回路を実
現していた場合に比べ、データ変換演算装置50の回路
規模を大幅に小さくすることができるとともに、シリア
ルの段数を減少させて処理速度を向上させることがで
る。すなわち、図22に示す従来例では、フリップフロ
ップ(FF)が126個、1bitAdd(Sub)unitが 62個
必要となり未だ回路規模が大きかったが、本実施例で
は、演算に必要な回路構成としてフリップフロップ(F
F)70個、1 Add unit52個で済むことになり回路
規模を大幅に小さくすることができる。また、シリアル
回路を構成するフリップフロップ(FF)等の段数が削
減されるので、図5に示すように8bitのデータを入力
した場合、1ライン当りの処理周期を従来例の27クロ
ック(図26)から21クロックに減少させることがで
きる。 また、誤差を含んだ係数による演算は量子化装
置51において一度行われるのみであり演算の大部分が
誤差を含まない整数の比によって行なうことができ、量
子化の前までの演算におけるデータビット幅を従来のも
のより大幅に小さくすることができ、小さなバス幅で高
い演算精度を得ることができる。また、データ変換演算
装置50自体が、極めて小さなFF等の組合せからなる
シリアル回路によってDCT演算を行なうようにしてい
るので、回路規模を大幅に小さくすることができ、かつ
高速に処理を行なうことが可能になる。
画像データをパラレルデータの形で蓄えるデータ記憶装
置10と、データ記憶装置10から読み込んだパラレル
データをシリアルデータに変換するパラレル−シリアル
変換装装置11と、DCT演算係数を簡単な整数比に変
えた形のシリアル回路により構成され、パラレル−シリ
アル変換装装置11から出力されたデータに対して一次
元のDCT演算をシリアル演算の形で施すデータ変換演
算装置50と、シリアルDCT演算されたシリアルデー
タをパラレルデータに変換してデータ記憶装置10に書
き込むシリアル−パラレル変換装置13と、データ記憶
装置10に蓄えられたデータ変換演算後のデータに対し
て、DCT演算係数を整数比に変えることにより生じた
ゲイン変化分を吸収させるように構成した量子化テーブ
ルの値で除算することによって量子化演算を行なう量子
化装置51と、上記各部の動作をデータ圧縮伸張装置の
全体を制御する制御装置52とを設け、2のべきで表現
できる部分はべきで表現してシリアル回路を構成する一
方で、べきで表現しようとすればビット数が大きくなっ
てしまう部分については敢えてべきにより表現しようと
しないで2のべきにとらわれずにDCT演算式の係数を
整数比に置き換え、そのゲイン変化分を量子化部によっ
て吸収するようにしているので、単にシリアル回路を実
現していた場合に比べ、データ変換演算装置50の回路
規模を大幅に小さくすることができるとともに、シリア
ルの段数を減少させて処理速度を向上させることがで
る。すなわち、図22に示す従来例では、フリップフロ
ップ(FF)が126個、1bitAdd(Sub)unitが 62個
必要となり未だ回路規模が大きかったが、本実施例で
は、演算に必要な回路構成としてフリップフロップ(F
F)70個、1 Add unit52個で済むことになり回路
規模を大幅に小さくすることができる。また、シリアル
回路を構成するフリップフロップ(FF)等の段数が削
減されるので、図5に示すように8bitのデータを入力
した場合、1ライン当りの処理周期を従来例の27クロ
ック(図26)から21クロックに減少させることがで
きる。 また、誤差を含んだ係数による演算は量子化装
置51において一度行われるのみであり演算の大部分が
誤差を含まない整数の比によって行なうことができ、量
子化の前までの演算におけるデータビット幅を従来のも
のより大幅に小さくすることができ、小さなバス幅で高
い演算精度を得ることができる。また、データ変換演算
装置50自体が、極めて小さなFF等の組合せからなる
シリアル回路によってDCT演算を行なうようにしてい
るので、回路規模を大幅に小さくすることができ、かつ
高速に処理を行なうことが可能になる。
【0138】このように高い演算精度を持ちかつ回路規
模の小さなデータ圧縮伸張装置が実現できることからD
CTを用いた画像圧縮や音声圧縮を行うデータ圧縮伸張
装置に適用して好適である。
模の小さなデータ圧縮伸張装置が実現できることからD
CTを用いた画像圧縮や音声圧縮を行うデータ圧縮伸張
装置に適用して好適である。
【0139】なお、本実施例では、データ変換演算装置
90のステージIIのodd側にシリアル回路100を適
用した例を示したが、これには限定されず、データ変換
演算式を各項毎に展開し、展開した式に従ってシリアル
回路を構成するものであればどのような回路部分に適用
してもよいことは言うまでもない。
90のステージIIのodd側にシリアル回路100を適
用した例を示したが、これには限定されず、データ変換
演算式を各項毎に展開し、展開した式に従ってシリアル
回路を構成するものであればどのような回路部分に適用
してもよいことは言うまでもない。
【0140】また、本実施例では係数を例えば所定の整
数の比とする例を示したが、これには限定されず、整数
の比で表されるものであればどのような整数比でもよく
整数値であってもことは言うまでもない。
数の比とする例を示したが、これには限定されず、整数
の比で表されるものであればどのような整数比でもよく
整数値であってもことは言うまでもない。
【0141】また、演算係数を2のべき(2のn乗)の
和(差)で表現して図3に示すようなシリアルの回路に
より演算を行っているが、シリアルデータ処理が行われ
るものであればどのようなユニットの組合せでもよいこ
とは勿論である。
和(差)で表現して図3に示すようなシリアルの回路に
より演算を行っているが、シリアルデータ処理が行われ
るものであればどのようなユニットの組合せでもよいこ
とは勿論である。
【0142】また、上記画像圧縮装置等を構成する回路
や部材の数、種類などは前述した実施例に限られないこ
とは言うまでもなく、ソフトウェア(例えば、C言語)
により実現するようにしてもよい。
や部材の数、種類などは前述した実施例に限られないこ
とは言うまでもなく、ソフトウェア(例えば、C言語)
により実現するようにしてもよい。
【0143】また、本実施例では、データ変換演算装置
にDCTを適用しているが、これら符号化方式には限定
されず、符号化演算を行なうものであればどのような装
置や演算式にも適用できることは言うまでもない。例え
ば、ハール(Harr)変換、傾斜変換(スラント変換)、
対称性サイン変換などを用いたデータ圧縮伸張装置に適
用することができる。
にDCTを適用しているが、これら符号化方式には限定
されず、符号化演算を行なうものであればどのような装
置や演算式にも適用できることは言うまでもない。例え
ば、ハール(Harr)変換、傾斜変換(スラント変換)、
対称性サイン変換などを用いたデータ圧縮伸張装置に適
用することができる。
【0144】また、入力データに対してデータ変換を行
なうものであれば、データ変換の種類は何でもよく、D
CTによる周波数成分の変換のほか、例えばFFT,L
OT(Lapped Orthogonal Transform:重合直交変換)
等の直交データ変換に適用可能である。また、データ変
換演算部の係数を量子化部で吸収させるようにしている
が、係数を調整できるものであればどのような量子化部
で調整してもよいことは勿論である。
なうものであれば、データ変換の種類は何でもよく、D
CTによる周波数成分の変換のほか、例えばFFT,L
OT(Lapped Orthogonal Transform:重合直交変換)
等の直交データ変換に適用可能である。また、データ変
換演算部の係数を量子化部で吸収させるようにしている
が、係数を調整できるものであればどのような量子化部
で調整してもよいことは勿論である。
【0145】
【発明の効果】請求項1記載の発明によれば、所定のデ
ータを記憶するデータ記憶手段と、前記データ記憶手段
から出力されたデータに対して所定の係数に基づいてシ
リアル演算によりデータ変換演算を実行するデータ変換
演算手段と、前記データ変換演算手段によるデータ変換
後のデータに対して量子化演算を実行する量子化手段
と、前記データ記憶手段、前記データ変換演算手段及び
前記量子化手段を制御をする制御手段とを備えたデータ
圧縮伸張装置であって、前記データ変換演算手段のデー
タ変換演算式を展開し、展開した式に従って前記データ
変換演算手段を構成するようにしているので、シフトレ
ジスタ等のシリアル回路の段数を減少させてクロック数
を減らすことができ、処理速度を向上させることができ
る。
ータを記憶するデータ記憶手段と、前記データ記憶手段
から出力されたデータに対して所定の係数に基づいてシ
リアル演算によりデータ変換演算を実行するデータ変換
演算手段と、前記データ変換演算手段によるデータ変換
後のデータに対して量子化演算を実行する量子化手段
と、前記データ記憶手段、前記データ変換演算手段及び
前記量子化手段を制御をする制御手段とを備えたデータ
圧縮伸張装置であって、前記データ変換演算手段のデー
タ変換演算式を展開し、展開した式に従って前記データ
変換演算手段を構成するようにしているので、シフトレ
ジスタ等のシリアル回路の段数を減少させてクロック数
を減らすことができ、処理速度を向上させることができ
る。
【0146】また、請求項2、3、4、5、6、7、
8、9、10、11、12、13、14及び15記記載
の発明によれば、所定のデータを記憶するデータ記憶手
段と、前記データ記憶手段から出力されたデータに対し
て所定の係数に基づいてシリアル演算によりデータ変換
演算を実行するデータ変換演算手段と、前記データ変換
演算手段によるデータ変換後のデータに対して量子化演
算を実行する量子化手段と、前記データ記憶手段、前記
データ変換演算手段及び前記量子化手段を制御をする制
御手段とを備えたデータ圧縮伸張装置であって、前記デ
ータ変換演算手段の係数を整数の比に置き換え、該整数
の比に置き換えることにより生じたゲインの変化を、前
記量子化手段により調整するようにするとともに、デー
タ変換演算式を展開し、展開した式に従って前記データ
変換演算手段を構成するようにしているので、単にシリ
アル回路を実現していた場合に比べ、回路規模を大幅に
小さくすることができるとともに、シリアルの段数を減
少させて処理速度を向上させることができ、画像等のデ
ータ圧縮に利用することができる。
8、9、10、11、12、13、14及び15記記載
の発明によれば、所定のデータを記憶するデータ記憶手
段と、前記データ記憶手段から出力されたデータに対し
て所定の係数に基づいてシリアル演算によりデータ変換
演算を実行するデータ変換演算手段と、前記データ変換
演算手段によるデータ変換後のデータに対して量子化演
算を実行する量子化手段と、前記データ記憶手段、前記
データ変換演算手段及び前記量子化手段を制御をする制
御手段とを備えたデータ圧縮伸張装置であって、前記デ
ータ変換演算手段の係数を整数の比に置き換え、該整数
の比に置き換えることにより生じたゲインの変化を、前
記量子化手段により調整するようにするとともに、デー
タ変換演算式を展開し、展開した式に従って前記データ
変換演算手段を構成するようにしているので、単にシリ
アル回路を実現していた場合に比べ、回路規模を大幅に
小さくすることができるとともに、シリアルの段数を減
少させて処理速度を向上させることができ、画像等のデ
ータ圧縮に利用することができる。
【図1】データ圧縮伸張装置の原理説明図である。
【図2】データ圧縮伸張装置のブロック構成図である。
【図3】データ圧縮伸張装置のデータ変換演算装置のブ
ロック構成図である。
ロック構成図である。
【図4】データ圧縮伸張装置のデータ変換演算装置の回
路構成図である。
路構成図である。
【図5】データ圧縮伸張装置のデータ変換演算装置の動
作を説明するためのタイミングチャートである。
作を説明するためのタイミングチャートである。
【図6】データ圧縮伸張装置のデータ変換演算装置の回
路構成図である。
路構成図である。
【図7】データ圧縮伸張装置のデータ変換演算装置の回
路構成図である。
路構成図である。
【図8】データ圧縮伸張装置のデータ変換演算装置のシ
リアル回路の回路構成図である。
リアル回路の回路構成図である。
【図9】データ圧縮伸張装置のデータ変換演算装置の動
作を説明するためのタイミングチャートである。
作を説明するためのタイミングチャートである。
【図10】データ圧縮伸張装置のデータ変換演算装置の
動作を説明するためのタイミングチャートである。
動作を説明するためのタイミングチャートである。
【図11】従来のデータ圧縮伸張装置のブロック構成図
である。
である。
【図12】従来のデータ圧縮伸張装置の画像データの処
理を説明するための図である。
理を説明するための図である。
【図13】従来のデータ圧縮伸張装置の量子化テーブル
の例を示す図である。
の例を示す図である。
【図14】従来のデータ圧縮伸張装置のデータ変換演算
装置におけるシリアル演算を説明するための図である。
装置におけるシリアル演算を説明するための図である。
【図15】従来のデータ圧縮伸張装置のデータ変換演算
装置におけるシリアル演算を説明するための図である。
装置におけるシリアル演算を説明するための図である。
【図16】従来のデータ圧縮伸張装置のデータ変換演算
装置におけるシリアル演算を説明するための図である。
装置におけるシリアル演算を説明するための図である。
【図17】従来のデータ圧縮伸張装置のデータ変換演算
装置のブロック構成図である。
装置のブロック構成図である。
【図18】従来のデータ圧縮伸張装置のデータ変換演算
装置のIステージの回路構成図である。
装置のIステージの回路構成図である。
【図19】従来のデータ圧縮伸張装置のデータ変換演算
装置のIIステージの回路構成図である。
装置のIIステージの回路構成図である。
【図20】従来のデータ圧縮伸張装置のデータ変換演算
装置のIIIステージの回路構成図である。
装置のIIIステージの回路構成図である。
【図21】従来のデータ圧縮伸張装置のデータ変換演算
装置のIVステージの回路構成図である。
装置のIVステージの回路構成図である。
【図22】従来のデータ圧縮伸張装置のデータ変換演算
装置の回路構成図である。
装置の回路構成図である。
【図23】従来のデータ圧縮伸張装置のシリアル演算素
子を説明する図である。
子を説明する図である。
【図24】従来のデータ圧縮伸張装置のシリアル演算素
子を説明する図である。
子を説明する図である。
【図25】従来のデータ圧縮伸張装置のシリアル演算素
子を説明する図である。
子を説明する図である。
【図26】従来のデータ圧縮伸張装置のデータ変換演算
装置の動作を説明するためのタイミングチャートであ
る。
装置の動作を説明するためのタイミングチャートであ
る。
10 データ記憶装置 11 パラレル−シリアル変換装装置 13 シリアル−パラレル変換装置 51 量子化装置 50,90 データ変換演算装置 52 制御装置 91 ステージIの演算回路 92 ステージIIの演算回路 93 ステージIIIの演算回路 100 シリアル回路 101 シリアル回路(第1のシリアル演算部) 102 シリアル回路(第2のシリアル演算部)
【数3】
【数4】
Claims (15)
- 【請求項1】 所定のデータを記憶するデータ記憶手段
と、 前記データ記憶手段から出力されたデータに対して所定
の係数に基づいてシリアル演算によりデータ変換演算を
実行するデータ変換演算手段と、 前記データ変換演算手段によるデータ変換後のデータに
対して量子化演算を実行する量子化手段と、 前記データ記憶手段、前記データ変換演算手段及び前記
量子化手段を制御をする制御手段とを備えたデータ圧縮
伸張装置であって、 前記データ変換演算手段のデータ変換演算式を展開し、
展開した式に従って前記データ変換演算手段を構成する
ようにしたことを特徴とするデータ圧縮伸張装置。 - 【請求項2】 所定のデータを記憶するデータ記憶手段
と、 前記データ記憶手段から出力されたデータに対して所定
の係数に基づいてシリアル演算によりデータ変換演算を
実行するデータ変換演算手段と、 前記データ変換演算手段によるデータ変換後のデータに
対して量子化演算を実行する量子化手段と、 前記データ記憶手段、前記データ変換演算手段及び前記
量子化手段を制御をする制御手段とを備えたデータ圧縮
伸張装置であって、 前記データ変換演算手段の係数を整数の比に置き換え、
該整数の比に置き換えることにより生じたゲインの変化
を、前記量子化手段により調整するようにするととも
に、データ変換演算式を展開し、展開した式に従って前
記データ変換演算手段を構成するようにしたことを特徴
とするデータ圧縮伸張装置。前記データ変換演算手段の
データ変換演算式を展開し、展開した式に従って前記デ
ータ変換演算手段を構成するようにしたことを特徴とす
るデータ圧縮伸張装置。 - 【請求項3】 所定のデータを記憶するデータ記憶手段
と、 前記データ記憶手段のデータをパラレルデータからシリ
アルデータに変換するパラレル−シリアル変換手段と、 前記パラレル−シリアル変換手段から出力されたデータ
に対して所定の係数に基づいてシリアル演算によりデー
タ変換演算を実行するデータ変換演算手段と、 前記データ変換手段から出力されるシリアルデータをパ
ラレルデータに変換し、前記データ記憶手段に書き込む
シリアル−パラレル変換手段と、 前記データ変換演算手段によるデータ変換後のデータに
対して量子化演算を実行する量子化手段と、 前記データ記憶手段、前記パラレル−シリアル変換手
段、前記データ変換演算手段、前記シリアル−パラレル
変換手段及び前記量子化手段を制御をする制御手段とを
備えたデータ圧縮伸張装置であって、 前記データ変換演算手段の係数を整数の比に置き換え、
該整数の比に置き換えることにより生じたゲインの変化
を、前記量子化手段により調整するようにするととも
に、データ変換演算式を展開し、展開した式に従って前
記データ変換演算手段を構成するようにしたことを特徴
とするデータ圧縮伸張装置。 - 【請求項4】 所定のデータを記憶するデータ記憶手段
と、 前記データ記憶手段から出力されたデータに対して所定
の係数に基づいてシリアル演算によりデータ変換演算を
実行するデータ変換演算手段と、 前記データ変換演算手段によるデータ変換後のデータに
対して量子化演算を実行する量子化手段と、 前記データ記憶手段、前記データ変換演算手段及び前記
量子化手段を制御をする制御手段とを備えたデータ圧縮
伸張装置であって、 前記データ変換演算手段のデータ変換演算式の係数の値
を2のべきで表現するとともに、該係数の値を2のべき
で表現するとき所定以上ビット数が大きくなる部分につ
いては該係数を整数の比に置き換え、該整数の比に置き
換えることにより生じたゲインの変化を、前記量子化手
段により調整するようにするとともに、データ変換演算
式を展開し、展開した式に従って前記データ変換演算手
段を構成するようにしたことを特徴とするデータ圧縮伸
張装置。 - 【請求項5】 前記データ変換演算手段は、各入力に所
定の係数が表れるようにデータ変換演算式を展開し、該
展開したデータ変換演算式の係数部分をシリアル演算す
る第1のシリアル演算部と、該第1のシリアル演算部の
出力を加減算して該展開したデータ変換演算式の演算を
実行する第2のシリアル演算部とにより構成するように
したことを請求項1、請求項2、請求項3又は請求項4
の何れかに記載のデータ圧縮伸張装置。 - 【請求項6】 前記第1のシリアル演算部は、前記展開
したデータ変換演算式の係数を2のべきに数値をかけた
形で表現するとともに、該係数を2のべきに数値をかけ
た形で表現した場合の数値部分をシリアル演算するシリ
アル回路により構成するようにしたことを特徴とする請
求項5に記載のデータ圧縮伸張装置。 - 【請求項7】 前記第2のシリアル演算部は、前記第1
のシリアル演算部から出力された数値を加減算して出力
する複数の加減算器により構成され、前記展開したデー
タ変換演算式の係数を2のべきに数値をかけた形で表現
した場合の2のべき部分を各加減算器への入力位置によ
り調整するようにしたことを特徴とする請求項5に記載
のデータ圧縮伸張装置。 - 【請求項8】 前記データ変換演算手段は、データに対
してシリアル演算により直交変換を実行する直交変換手
段であることを特徴とする請求項1、請求項2、請求項
3又は請求項4の何れかに記載のデータ圧縮伸張装置。 - 【請求項9】 前記データ変換演算手段は、データに対
してシリアル演算により離散コサイン変換(DCT)を
実行する離散コサイン変換手段であることを特徴とする
請求項1、請求項2、請求項3又は請求項4の何れかに
記載のデータ圧縮伸張装置。 - 【請求項10】 前記データ変換演算手段は、入力され
たデータを所定のクロックに応答して順次移動させるシ
リアル演算器を含んで構成されることを特徴とする請求
項1、請求項2、請求項3又は請求項4の何れかに記載
のデータ圧縮伸張装置。 - 【請求項11】 前記データ変換演算手段は、データ変
換演算式の係数の値を2のべきで表現したシリアル回路
により構成し、該シリアル回路によるシリアル演算によ
りデータ変換演算を実行するようにしたことを特徴とす
る請求項1、請求項2、請求項3又は請求項4の何れか
に記載のデータ圧縮伸張装置。 - 【請求項12】 前記データ変換演算手段は、データ変
換演算式の係数の値を2のべきで表現するとともに、該
係数の値を2のべきで表現するとき所定以上ビット数が
大きくなる部分については該係数を整数の比に置き換え
たシリアル回路により構成し、該シリアル回路によるシ
リアル演算によりデータ変換演算を実行するようにした
ことを特徴とする請求項2、請求項3又は請求項4の何
れかに記載のデータ圧縮伸張装置。 - 【請求項13】 前記データ変換演算手段で用いられる
データ変換演算式は、該データ変換演算式の係数を、前
記量子化手段の量子化演算に用いる量子化係数に含ませ
るように作成したことを特徴とする請求項2、請求項3
又は請求項4の何れかに記載のデータ圧縮伸張装置。 - 【請求項14】 前記量子化手段によるゲインの調整
は、前記データ変換演算手段の係数を整数の比に変える
ことにより生じたゲイン変化分を吸収させるように構成
された量子化テーブルにより行なわれることを特徴とす
る請求項2、請求項3又は請求項4の何れかに記載のデ
ータ圧縮伸張装置。 - 【請求項15】 前記データ変換演算手段の係数の整数
の比への置き換えは、該係数を整数値に置き換えること
により行なうようにしたことを特徴とする請求項2、請
求項3、請求項4、請求項12又は請求項14の何れか
に記載のデータ圧縮伸張装置。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP36089092A JP3099564B2 (ja) | 1992-12-30 | 1992-12-30 | データ圧縮伸張装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP36089092A JP3099564B2 (ja) | 1992-12-30 | 1992-12-30 | データ圧縮伸張装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH06204888A true JPH06204888A (ja) | 1994-07-22 |
JP3099564B2 JP3099564B2 (ja) | 2000-10-16 |
Family
ID=18471347
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP36089092A Expired - Fee Related JP3099564B2 (ja) | 1992-12-30 | 1992-12-30 | データ圧縮伸張装置 |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP3099564B2 (ja) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4806464B2 (ja) * | 2007-03-29 | 2011-11-02 | 富士通株式会社 | 画像圧縮装置、画像圧縮方法、画像復元装置、及びプログラム |
-
1992
- 1992-12-30 JP JP36089092A patent/JP3099564B2/ja not_active Expired - Fee Related
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4806464B2 (ja) * | 2007-03-29 | 2011-11-02 | 富士通株式会社 | 画像圧縮装置、画像圧縮方法、画像復元装置、及びプログラム |
US8467619B2 (en) | 2007-03-29 | 2013-06-18 | Fujitsu Limited | Image compressing apparatus, image compressing method, image decompressing apparatus, and storage medium |
Also Published As
Publication number | Publication date |
---|---|
JP3099564B2 (ja) | 2000-10-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JPH07146853A (ja) | 逆離散余弦変換プロセッサ | |
JPH08235159A (ja) | 逆コサイン変換装置 | |
JPH06181438A (ja) | デジタル・デルタ−シグマ変調器 | |
US7236997B2 (en) | Filter processing apparatus and method | |
JP3099564B2 (ja) | データ圧縮伸張装置 | |
US5555321A (en) | Image data binary coding method and apparatus | |
US6493391B1 (en) | Picture decoding method and apparatus | |
JPH06204885A (ja) | データ圧縮伸張装置 | |
JP4738408B2 (ja) | 行列演算装置 | |
JPH0654307A (ja) | データ圧縮装置 | |
JPH1155076A (ja) | サンプリング周波数変換装置 | |
JPH06204887A (ja) | データ圧縮伸張装置 | |
JP2001086366A (ja) | デジタルフィルタ及びその処理方法 | |
JP3225614B2 (ja) | データ圧縮装置 | |
JPH06205391A (ja) | データ圧縮伸張装置 | |
JPH06204886A (ja) | データ圧縮伸張装置 | |
JPH06205392A (ja) | データ圧縮伸張装置 | |
JP3046115B2 (ja) | 離散コサイン変換器 | |
JPH0583141A (ja) | 符号化データ処理装置 | |
JPH04222121A (ja) | データ圧縮装置 | |
JP3046116B2 (ja) | 離散コサイン変換器 | |
WO2000035202A1 (en) | Filter arithmetic device | |
JP3681940B2 (ja) | 画像縮小装置 | |
JP2734131B2 (ja) | ディスクリートコサイン変換装置 | |
JPH08305684A (ja) | バタフライ演算装置及び逆離散余弦変換装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20080818 Year of fee payment: 8 |
|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20090818 Year of fee payment: 9 |
|
FPAY | Renewal fee payment (prs date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100818 Year of fee payment: 10 |
|
LAPS | Cancellation because of no payment of annual fees |