JP3334910B2 - 画像データ圧縮装置及び方法 - Google Patents
画像データ圧縮装置及び方法Info
- Publication number
- JP3334910B2 JP3334910B2 JP20252592A JP20252592A JP3334910B2 JP 3334910 B2 JP3334910 B2 JP 3334910B2 JP 20252592 A JP20252592 A JP 20252592A JP 20252592 A JP20252592 A JP 20252592A JP 3334910 B2 JP3334910 B2 JP 3334910B2
- Authority
- JP
- Japan
- Prior art keywords
- data
- pixel data
- pixel
- output
- unit
- 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.)
- Expired - Fee Related
Links
Landscapes
- Compression Or Coding Systems Of Tv Signals (AREA)
- Compression Of Band Width Or Redundancy In Fax (AREA)
- Image Processing (AREA)
Description
【0001】
【産業上の利用分野】本発明は画像データ圧縮伸長方法
及び装置に関する。
及び装置に関する。
【0002】
【従来の技術】近年DTPなどによりコンピュータ上で
作成される画像は、より高画質な画像が要求されてお
り、カラー化、多階調化が進んでいる。この種の画像に
おける情報量は、例えば、A4サイズ,400dpi,
256階調、3色カラーの場合で約46Mbyteにも
なる。画像データをページ記述言語(Page Dis
cription Language)などのコード情
報として扱えば情報量は少なくなる。しかしながら、コ
ード情報から画像データへの展開に時間がかかるうえ
に、コード情報を展開しても元の画像データを再現でき
ないという問題点がある。
作成される画像は、より高画質な画像が要求されてお
り、カラー化、多階調化が進んでいる。この種の画像に
おける情報量は、例えば、A4サイズ,400dpi,
256階調、3色カラーの場合で約46Mbyteにも
なる。画像データをページ記述言語(Page Dis
cription Language)などのコード情
報として扱えば情報量は少なくなる。しかしながら、コ
ード情報から画像データへの展開に時間がかかるうえ
に、コード情報を展開しても元の画像データを再現でき
ないという問題点がある。
【0003】カラー多値画像の一般的な圧縮方法として
は、JPEG(Joint Photographic
Expent Group)が推奨するADCT(A
daptive Discrete Cosine T
ransform)方式による圧縮法がある。ADCT
圧縮法について以下に説明する。
は、JPEG(Joint Photographic
Expent Group)が推奨するADCT(A
daptive Discrete Cosine T
ransform)方式による圧縮法がある。ADCT
圧縮法について以下に説明する。
【0004】図12はADCT圧縮装置の機能構成を表
すブロック図である。3101は色空間変換部であり、
NTSC方式の各色毎の信号(赤(R)、緑(G)、青
(B))による色空間(NTSC−RGB)を、輝度信
号Yと2つの色差信号Cr,Cbとで表される色空間
(YCrCb)に変換する。3102は、サブサンプリ
ング部であり、人間の眼が輝度に敏感で色差に鈍感であ
るという特性を利用して、色差データの減少を行う。具
体的には、サブサンプリング部3102はとなりあう2
つの色差データの平均値をとり、色差データの量を1/
2に減少させている。3103はDCT変換部であり、
サブサンプリング部3102を経て入力された画像デー
タを水平及び垂直方向にとなり合う8×8のブロクに分
割し、DCT変換をかけ、周波数空間に変換する。31
04は量子化部であり、64個の各DCT係数をステッ
プ幅の異なった量子化値で割る。3105はハフマン符
号化部であり、量子化された64個のDCT係数を1つ
のDC係数と63個のAC係数に分け、それぞれの係数
をJPEGが推奨しているハフマンテーブルに従って符
号化する。符号化されたデータは量子化テーブルデー
タ、ハフンマンテーブルデータなどのヘッダを添付して
メモリに蓄積されるかまたは他の装置等へ送信される。
すブロック図である。3101は色空間変換部であり、
NTSC方式の各色毎の信号(赤(R)、緑(G)、青
(B))による色空間(NTSC−RGB)を、輝度信
号Yと2つの色差信号Cr,Cbとで表される色空間
(YCrCb)に変換する。3102は、サブサンプリ
ング部であり、人間の眼が輝度に敏感で色差に鈍感であ
るという特性を利用して、色差データの減少を行う。具
体的には、サブサンプリング部3102はとなりあう2
つの色差データの平均値をとり、色差データの量を1/
2に減少させている。3103はDCT変換部であり、
サブサンプリング部3102を経て入力された画像デー
タを水平及び垂直方向にとなり合う8×8のブロクに分
割し、DCT変換をかけ、周波数空間に変換する。31
04は量子化部であり、64個の各DCT係数をステッ
プ幅の異なった量子化値で割る。3105はハフマン符
号化部であり、量子化された64個のDCT係数を1つ
のDC係数と63個のAC係数に分け、それぞれの係数
をJPEGが推奨しているハフマンテーブルに従って符
号化する。符号化されたデータは量子化テーブルデー
タ、ハフンマンテーブルデータなどのヘッダを添付して
メモリに蓄積されるかまたは他の装置等へ送信される。
【0005】図13はADCT伸長装置の機能構成を表
すブロック図である。3205はハフマン複合化部であ
り、入力された符号化データを複号化し、量子化データ
を生成する。3204は逆量子化部であり、ハフマン複
合化部3205にて生成された量子化データをDCT係
数データに変換する。これは、量子化部3104で量子
化する際に使用した量子化テーブルデータを用いて、6
4個の係数に量子化値を乗ずることにより得られる。3
203は逆DCT変換部であり、逆量子化3204にて
得られたDCT係数データを実画像データに逆DCT変
換する。3202は補間部であり、データ圧縮時におけ
るサブサンプリング部3102により欠落したCrおよ
びCbのデータを単純に繰り返し法により補間する。3
201は色空間編間部であり、YCrCbのデータをN
TSC−RGBのデータまたはそのデバイスの色空間デ
ータに変換する。
すブロック図である。3205はハフマン複合化部であ
り、入力された符号化データを複号化し、量子化データ
を生成する。3204は逆量子化部であり、ハフマン複
合化部3205にて生成された量子化データをDCT係
数データに変換する。これは、量子化部3104で量子
化する際に使用した量子化テーブルデータを用いて、6
4個の係数に量子化値を乗ずることにより得られる。3
203は逆DCT変換部であり、逆量子化3204にて
得られたDCT係数データを実画像データに逆DCT変
換する。3202は補間部であり、データ圧縮時におけ
るサブサンプリング部3102により欠落したCrおよ
びCbのデータを単純に繰り返し法により補間する。3
201は色空間編間部であり、YCrCbのデータをN
TSC−RGBのデータまたはそのデバイスの色空間デ
ータに変換する。
【0006】
【発明が解決しようとする課題】しかしながら、上記A
DCT圧縮法は、サブサンプリング部及び量子化部にお
いて、量子化時にデータの損失を伴う不可逆圧縮法であ
る。従って、伸長されたデータは圧縮前のデータとは異
なるものとなる。
DCT圧縮法は、サブサンプリング部及び量子化部にお
いて、量子化時にデータの損失を伴う不可逆圧縮法であ
る。従って、伸長されたデータは圧縮前のデータとは異
なるものとなる。
【0007】DTPデータ等のコンピュータ上で作成し
た画像(コンピュータ作成画像)は、アウトラインのき
れいさ、1図形(または1文字)単一色によるノイズの
ない色塗りがその長所である。ところが、ADCT圧縮
法により画像データを処理すると、図形のアウトライン
のみだれ、疑似エッジ(モスキートノイズと呼ばれる)
の発生、量子化による色の変化等が発生し、コンピュー
タ作成画像の長所が発揮されない。特に上述の圧縮法は
8×8ブロック処理であるため、境界域では大幅に色が
変化してしまう。圧縮率を上げると最終的に交流成分は
失われてブロック歪が発生し、解像度が1/8になった
ような画像となる。
た画像(コンピュータ作成画像)は、アウトラインのき
れいさ、1図形(または1文字)単一色によるノイズの
ない色塗りがその長所である。ところが、ADCT圧縮
法により画像データを処理すると、図形のアウトライン
のみだれ、疑似エッジ(モスキートノイズと呼ばれる)
の発生、量子化による色の変化等が発生し、コンピュー
タ作成画像の長所が発揮されない。特に上述の圧縮法は
8×8ブロック処理であるため、境界域では大幅に色が
変化してしまう。圧縮率を上げると最終的に交流成分は
失われてブロック歪が発生し、解像度が1/8になった
ような画像となる。
【0008】このため、画質の劣化が目に見えない程度
の量子化におさえて圧縮することも考えられるが、もと
もと高周波数データが多いことを特徴とするコンピュー
タ作成画像であるため、圧縮率において実用的でない。
従って、DTPで作成した画像のようなコンピュータ作
成画像は可逆で高圧縮率の得られる圧縮法で圧縮するこ
とが必要である。
の量子化におさえて圧縮することも考えられるが、もと
もと高周波数データが多いことを特徴とするコンピュー
タ作成画像であるため、圧縮率において実用的でない。
従って、DTPで作成した画像のようなコンピュータ作
成画像は可逆で高圧縮率の得られる圧縮法で圧縮するこ
とが必要である。
【0009】本発明は上記の問題点に鑑みてなされたも
のであり、コンピュータなどにより作成された多値画像
を劣化なく高い圧縮率で圧縮する画像データ圧縮伸長方
法及び装置を提供することを目的とする。
のであり、コンピュータなどにより作成された多値画像
を劣化なく高い圧縮率で圧縮する画像データ圧縮伸長方
法及び装置を提供することを目的とする。
【0010】
【課題を解決するための手段】上記課題を解決するため
に、本発明の画像データ処理装置によれば、過去に出現
した画素データをパレット番号付けして記憶するパレッ
ト記憶手段(例えば実施例におけるパレットメモリ7に
相当)と、原画像からの入力画素データと、前記入力画
素データの1つ前の画素データとを比較する第1の比較
手段(同じく第1比較器4に相当)と、前記第1の比較
手段にて比較された両データが不一致であるときの画素
データを少なくとも1つ以上保持する保持手段(同じく
第2ラッチ部3に相当)と、前記入力画素データと前記
保持手段に保持されている画素データとを比較する第2
の比較手段(同じく第2比較器5に相当)と、前記第2
の比較手段による比較において、前記入力画素データと
前記保持手段に保持されたどの画素データとも一致しな
いとき、前記入力画素データを前記パレット記憶手段に
記憶されている画素データのどれかと一致するか検索
し、前記入力画素データのパレット番号を出力する出力
手段(同じくパレットコントローラ6に相当)とを備え
ることを特徴とする。
に、本発明の画像データ処理装置によれば、過去に出現
した画素データをパレット番号付けして記憶するパレッ
ト記憶手段(例えば実施例におけるパレットメモリ7に
相当)と、原画像からの入力画素データと、前記入力画
素データの1つ前の画素データとを比較する第1の比較
手段(同じく第1比較器4に相当)と、前記第1の比較
手段にて比較された両データが不一致であるときの画素
データを少なくとも1つ以上保持する保持手段(同じく
第2ラッチ部3に相当)と、前記入力画素データと前記
保持手段に保持されている画素データとを比較する第2
の比較手段(同じく第2比較器5に相当)と、前記第2
の比較手段による比較において、前記入力画素データと
前記保持手段に保持されたどの画素データとも一致しな
いとき、前記入力画素データを前記パレット記憶手段に
記憶されている画素データのどれかと一致するか検索
し、前記入力画素データのパレット番号を出力する出力
手段(同じくパレットコントローラ6に相当)とを備え
ることを特徴とする。
【0011】
【0012】
【0013】
【0014】
【0015】
【実施例】以下に本発明による好適な実施例について添
付の図面を参照して説明する。
付の図面を参照して説明する。
【0016】(実施例1) <データ圧縮装置>実施例1によるデータ圧縮装置につ
いて以下に説明する。
いて以下に説明する。
【0017】図1は実施例1によるデータ圧縮装置の機
能構成を表すブロック図である。1は画素データ並び変
え部であり、NTSC−RGB形式の、1画素あたり2
4bitの画素データを発生する。2は第1ラッチ部で
あり、画素データ並び変え部1からの画素データ(24
bit)を保持する。3は第2ラッチ部であり、第1ラ
ッチ部2より出力される画素データ(24bit)を保
持する。4は第1比較部であり、画素データ並び変え部
1からの画素データと第1ラッチ部2に保持されている
画素データとを比較し、両者が等しいとき「0」を、異
なるとき「1」という信号1aを出力する。5は第2比
較部であり、画素データ並び変え部1からの画素データ
と、第2ラッチ部3に保持された画素データとを比較
し、両者が等しいとき「0」を、異なるとき「1」とい
う信号1bを出力する。
能構成を表すブロック図である。1は画素データ並び変
え部であり、NTSC−RGB形式の、1画素あたり2
4bitの画素データを発生する。2は第1ラッチ部で
あり、画素データ並び変え部1からの画素データ(24
bit)を保持する。3は第2ラッチ部であり、第1ラ
ッチ部2より出力される画素データ(24bit)を保
持する。4は第1比較部であり、画素データ並び変え部
1からの画素データと第1ラッチ部2に保持されている
画素データとを比較し、両者が等しいとき「0」を、異
なるとき「1」という信号1aを出力する。5は第2比
較部であり、画素データ並び変え部1からの画素データ
と、第2ラッチ部3に保持された画素データとを比較
し、両者が等しいとき「0」を、異なるとき「1」とい
う信号1bを出力する。
【0018】6はパレットコントロール部であり、信号
1aと1bのAND信号により作動し、画素データ並び
変え部1からの画素データがパレットメモリに存在する
かどうか検索し、存在しなかったらカウンタをインクリ
メントし新たにその画素データを登録し、その画素デー
タのパレット番号を出力する。
1aと1bのAND信号により作動し、画素データ並び
変え部1からの画素データがパレットメモリに存在する
かどうか検索し、存在しなかったらカウンタをインクリ
メントし新たにその画素データを登録し、その画素デー
タのパレット番号を出力する。
【0019】7はパレットメモリで24bit画素デー
タを2m 個記憶できる。
タを2m 個記憶できる。
【0020】8はセレクタ部で信号1a,1b,1c,
1dのどれかを選択しメモリ10の深さ分データがたま
ったら出力する。
1dのどれかを選択しメモリ10の深さ分データがたま
ったら出力する。
【0021】9は制御部で、信号1a,1bの状態から
上述の各構成の動作タイミングの制御、特にセレクタ部
の制御(各信号の選択及び信号1d選択時の有効ビット
数制御)を行う。
上述の各構成の動作タイミングの制御、特にセレクタ部
の制御(各信号の選択及び信号1d選択時の有効ビット
数制御)を行う。
【0022】10はメモリであり、セレクタ部からの出
力を順次記憶していく。
力を順次記憶していく。
【0023】上記の構成におけるデータ圧縮装置の動作
について、図2〜図4のフローチャートを参照しながら
以下に説明する。
について、図2〜図4のフローチャートを参照しながら
以下に説明する。
【0024】図2〜図4は実施例1のデータ圧縮装置に
よる処理手順を表すフローチャートである。尚、以下の
説明においては、第1ラッチ部2に保持される最新の更
新後の色データをnext[3]とし、第2ラッチ部3
に保持される最新の更新前の色データをformer
[3]とする。また、画素データ並び変え部1より出力
される画素データをpresent[3]とする。ne
xt[3],fomer[3],present[3]
はNTSC−RGB形式のデータであり、R,G,Bそ
れぞれのデータを有する1×3の配列構造データであ
る。
よる処理手順を表すフローチャートである。尚、以下の
説明においては、第1ラッチ部2に保持される最新の更
新後の色データをnext[3]とし、第2ラッチ部3
に保持される最新の更新前の色データをformer
[3]とする。また、画素データ並び変え部1より出力
される画素データをpresent[3]とする。ne
xt[3],fomer[3],present[3]
はNTSC−RGB形式のデータであり、R,G,Bそ
れぞれのデータを有する1×3の配列構造データであ
る。
【0025】まず、ステップS11で、第1ラッチ部2
と第2ラッチ部3の初期設定を行う。即ち、next
[3]と、former[3]に初期値をセットする。
本データ圧縮装置においては、通常の画像は白地に黒が
多いと仮定し、初期値をnext[3]={255,2
55,255}(白)、former[3]={0,
0,0}(黒)とする。次にステップS12において処
理済の画素数をカウントするカウンタcountをゼロ
にリセットし、それまでの出現画素データの数をカウン
トするカウンタcolornumをゼロにリセットす
る。又、colornumがパレットメモリ許容数2m
を越えたら1になるフラグflagを0に、出力ビッ
ト長を表すoutbitを1に、outbitをインク
リメントするタイミングをとるcbeckを2にリセッ
トする。
と第2ラッチ部3の初期設定を行う。即ち、next
[3]と、former[3]に初期値をセットする。
本データ圧縮装置においては、通常の画像は白地に黒が
多いと仮定し、初期値をnext[3]={255,2
55,255}(白)、former[3]={0,
0,0}(黒)とする。次にステップS12において処
理済の画素数をカウントするカウンタcountをゼロ
にリセットし、それまでの出現画素データの数をカウン
トするカウンタcolornumをゼロにリセットす
る。又、colornumがパレットメモリ許容数2m
を越えたら1になるフラグflagを0に、出力ビッ
ト長を表すoutbitを1に、outbitをインク
リメントするタイミングをとるcbeckを2にリセッ
トする。
【0026】ステップS13において、画素データ並び
変え部1より画素データpresent[3]を入力す
る。そして、ステップS14では、第1比較部4により
present[3]とnext[3]を比較する。こ
の比較の結果、present[3]とnext[3]
とが等しければステップS15へ進み、等しくない場合
は図3のステップS21へ進む。
変え部1より画素データpresent[3]を入力す
る。そして、ステップS14では、第1比較部4により
present[3]とnext[3]を比較する。こ
の比較の結果、present[3]とnext[3]
とが等しければステップS15へ進み、等しくない場合
は図3のステップS21へ進む。
【0027】ステップS15では、第1比較部4の比較
結果である「0」を出力し、ステップS16へ進む。
結果である「0」を出力し、ステップS16へ進む。
【0028】ステップS16においてcountをイン
クリメントし、ステップS17において、すべての画素
の処理が終了したかどうかをチエックする。即ち、co
unt≧全画素数であれば全ての画素の処理が終了した
と判断し、本データ圧縮処理を終了する。また、cou
nt<全画素数のときは、未処理の画素データが残って
いるのでステップS13に戻り上述の処理を繰り返す。
クリメントし、ステップS17において、すべての画素
の処理が終了したかどうかをチエックする。即ち、co
unt≧全画素数であれば全ての画素の処理が終了した
と判断し、本データ圧縮処理を終了する。また、cou
nt<全画素数のときは、未処理の画素データが残って
いるのでステップS13に戻り上述の処理を繰り返す。
【0029】次に図3のフローチャートを参照して、p
resent[3]≠next[3]の場合の処理にち
て説明する。
resent[3]≠next[3]の場合の処理にち
て説明する。
【0030】ステップS21では第1比較部4の比較結
果である「1」を出力する。ステップS22では、pr
esent[3]とformer[3]とを第2比較部
5により比較する。この比較の結果、present
[3]=former[3]であればステップS23へ
進み、またpresent[3]≠former[3]
であれば図4のステップS28へ進む。
果である「1」を出力する。ステップS22では、pr
esent[3]とformer[3]とを第2比較部
5により比較する。この比較の結果、present
[3]=former[3]であればステップS23へ
進み、またpresent[3]≠former[3]
であれば図4のステップS28へ進む。
【0031】ステップS23では、第2比較部5の比較
結果である「0」を出力しステップS26へ進む。
結果である「0」を出力しステップS26へ進む。
【0032】ステップS26では、最新の更新前のデー
タformer[3]に最新の更新後のデータnext
[3]を代入する。そして、ステップS27において、
最新の更新後のデータとして画像発生部1より現在出力
されているデータpresent[3]を代入する。そ
して、図2のフローチャートにおけるステップS17へ
進み、前述の処理を実行する。
タformer[3]に最新の更新後のデータnext
[3]を代入する。そして、ステップS27において、
最新の更新後のデータとして画像発生部1より現在出力
されているデータpresent[3]を代入する。そ
して、図2のフローチャートにおけるステップS17へ
進み、前述の処理を実行する。
【0033】次に図4のフローチャートを参照してpr
esent[3]≠fomer[3]の場合の処理につ
いて説明する。
esent[3]≠fomer[3]の場合の処理につ
いて説明する。
【0034】ステップS28では第2比較部5の比較結
果である「1」を出力する。ステップS29ではフラグ
flagはゼロであるかチエックする。即ち、colo
rnumがパレットメモリの許容数2m に達していな
いか判断し、達していなければステップS30に進み達
していたらステップS40に進む。
果である「1」を出力する。ステップS29ではフラグ
flagはゼロであるかチエックする。即ち、colo
rnumがパレットメモリの許容数2m に達していな
いか判断し、達していなければステップS30に進み達
していたらステップS40に進む。
【0035】ステップS30ではパレットメモリの中に
画素データpresent[3]がすでに登録されてい
るか検索している。即ち、カウンタiをそれまでの出現
画素データcolornumの数だけ回して、パレット
メモリのアドレスiがpresent[3]と一致する
かどうか判断し(S303)、一致していたらパレット
番号Pにアドレスiを代入する(S305)。colo
rnumの数だけ上述の処理を行い、一致する画素デー
タを記憶するアドレスがない時はpresent[3]
を新規のデータとして処理するためステップS35に進
む。ステップS35ではパレットメモリのアドレスco
lornumにpresent[3]を登録し、パレッ
ト番号Pにアドレスcolornumを代入する。
画素データpresent[3]がすでに登録されてい
るか検索している。即ち、カウンタiをそれまでの出現
画素データcolornumの数だけ回して、パレット
メモリのアドレスiがpresent[3]と一致する
かどうか判断し(S303)、一致していたらパレット
番号Pにアドレスiを代入する(S305)。colo
rnumの数だけ上述の処理を行い、一致する画素デー
タを記憶するアドレスがない時はpresent[3]
を新規のデータとして処理するためステップS35に進
む。ステップS35ではパレットメモリのアドレスco
lornumにpresent[3]を登録し、パレッ
ト番号Pにアドレスcolornumを代入する。
【0036】ステップS36ではcolornumをイ
ンクリメントする。
ンクリメントする。
【0037】ステップS37でcolornumがパレ
ットメモリの許容数2m に達しているかどうかチェッ
クする。達していたらステップS38に進みフラグfr
agに1を代入する。
ットメモリの許容数2m に達しているかどうかチェッ
クする。達していたらステップS38に進みフラグfr
agに1を代入する。
【0038】ステップS39でパレット番号Pを下位o
utbit分だけ出力する。ステップS41でChec
kとcolornumが等しいかどうか調べ等しかった
らステップS42に進みoutbitをインクリメント
し(ステップS42)checkをcheckの2乗で
更新する(ステップS43)。すなわち、パレットメモ
リアドレス1の画素が出現するとcolornum=2
となり、outbitがインクリメントされ次の画素の
処理からはパレットメモリアドレスを表す信号は2ビッ
トとなる。同時に次にoutbitをインクリメントす
るための信号checkは4となる。
utbit分だけ出力する。ステップS41でChec
kとcolornumが等しいかどうか調べ等しかった
らステップS42に進みoutbitをインクリメント
し(ステップS42)checkをcheckの2乗で
更新する(ステップS43)。すなわち、パレットメモ
リアドレス1の画素が出現するとcolornum=2
となり、outbitがインクリメントされ次の画素の
処理からはパレットメモリアドレスを表す信号は2ビッ
トとなる。同時に次にoutbitをインクリメントす
るための信号checkは4となる。
【0039】次は、パレットメモリアドレス0×11の
画素が出現するとcolornum=4となりoutb
it=3となりcheckは8となる。パレットメモリ
アドレスを表す信号の最初の1ビットが1の時に以上の
処理は行われる。
画素が出現するとcolornum=4となりoutb
it=3となりcheckは8となる。パレットメモリ
アドレスを表す信号の最初の1ビットが1の時に以上の
処理は行われる。
【0040】一方、S40では(ステップS29ではフ
ラグが0でない時(即ち、画素データ数がパレットメモ
リの許容数を越えてしまった時))パレットメモリ表現
をあきらめて画素データ24bitをそのまま出力す
る。
ラグが0でない時(即ち、画素データ数がパレットメモ
リの許容数を越えてしまった時))パレットメモリ表現
をあきらめて画素データ24bitをそのまま出力す
る。
【0041】上述のデータ圧縮装置による動作をさらに
具体的な例を挙げて説明する。
具体的な例を挙げて説明する。
【0042】図5はデータ圧縮処理されるNTSC−R
GBデータの例である。
GBデータの例である。
【0043】図6は本データ圧縮装置による画素の処理
順序を現す例である。同図に示されるごとく2次元のデ
ータはジグザグに並び変えられ処理される。このように
深さ8画素でジグザグに処理することにより、ラスター
方式に比べて通常の画像では画素データの反転が多くな
り圧縮効率がよいし、スキャナで読んだようなイメージ
画が混在したときのADCT処理との併合が簡単にな
る。
順序を現す例である。同図に示されるごとく2次元のデ
ータはジグザグに並び変えられ処理される。このように
深さ8画素でジグザグに処理することにより、ラスター
方式に比べて通常の画像では画素データの反転が多くな
り圧縮効率がよいし、スキャナで読んだようなイメージ
画が混在したときのADCT処理との併合が簡単にな
る。
【0044】以上の並び変え処理は図1の画素データ並
び変え部1で実行される。
び変え部1で実行される。
【0045】まず、next[3],former
[3],count,flag,colornumのそ
れぞれに初期値をセットする(ステップS11,1
2)。次に現在の値を示すpresent[3]を画素
データ並び変え部1より入力する(ステップS13)。
まず画素1のデータが入力されるのでpresent
[3]={255,255,255}となる。次に第1
比較部4はこのpresent[3]とnext[3]
を比較する(ステップS14)。ここでpresent
[3]とnext[3]はともに{255,255,2
55}のデータを有しており、present[3]と
next[3]は等しいのでステップS15に進む。こ
のとき本実施例では第1比較部より「0」が出力される
(ステップS15)。1画素の処理が終了したのでカウ
ンタをインクリメントする(ステップS16)。このと
きcount=1であり、まだすべての画素の処理は終
了していないのでステップS13に戻る(ステップS1
7)。
[3],count,flag,colornumのそ
れぞれに初期値をセットする(ステップS11,1
2)。次に現在の値を示すpresent[3]を画素
データ並び変え部1より入力する(ステップS13)。
まず画素1のデータが入力されるのでpresent
[3]={255,255,255}となる。次に第1
比較部4はこのpresent[3]とnext[3]
を比較する(ステップS14)。ここでpresent
[3]とnext[3]はともに{255,255,2
55}のデータを有しており、present[3]と
next[3]は等しいのでステップS15に進む。こ
のとき本実施例では第1比較部より「0」が出力される
(ステップS15)。1画素の処理が終了したのでカウ
ンタをインクリメントする(ステップS16)。このと
きcount=1であり、まだすべての画素の処理は終
了していないのでステップS13に戻る(ステップS1
7)。
【0046】次の画素2は画素1と同じ値を有している
ので同様の処理が行われる。
ので同様の処理が行われる。
【0047】次の画素3は異なるデータを有しているの
で処理手順が異なる。
で処理手順が異なる。
【0048】画素データ並び変え部1より出力されるデ
ータは{160,0,240}の値を有し、従って、p
resent[3]={160,0,240}となる
(ステップS13)。次にpresent[3]とne
xt[3]={255,255,255}と比較する
(ステップS14)。今回は両者は異なる値を有してい
るのでステップS21に進み、第1比較部からは「1」
が出力される(ステップS21)。
ータは{160,0,240}の値を有し、従って、p
resent[3]={160,0,240}となる
(ステップS13)。次にpresent[3]とne
xt[3]={255,255,255}と比較する
(ステップS14)。今回は両者は異なる値を有してい
るのでステップS21に進み、第1比較部からは「1」
が出力される(ステップS21)。
【0049】さらに、present「3」とform
er[3]={0,0,0}とを比較する(ステップS
22)。両者は異なる値を有しているのでステップS2
8に進み、第2比較部から「1」が出力される(ステッ
プS28)。
er[3]={0,0,0}とを比較する(ステップS
22)。両者は異なる値を有しているのでステップS2
8に進み、第2比較部から「1」が出力される(ステッ
プS28)。
【0050】ステップS29で、colornumがパ
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べるのだが、現時点でcolornum=0であ
り、登録されていないのでステップS35に進む。
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べるのだが、現時点でcolornum=0であ
り、登録されていないのでステップS35に進む。
【0051】S35ではパレットメモリのアドレス0
(=colornum)にpresentのデータ{1
60,0,240}を登録する。そしてパレット番号P
に0を代入する(ステップS35)。そしてcolor
numをインクリメントする(ステップS36)。次に
colornumがパレットメモリの限界値2のm乗に
達したかどうかチェックする(ステップS37)。この
実施例ではm=8とし、2のm乗は256なので、co
lornum=1であるから達していない。従って何の
処理も行われずステップS39に進む。ステップS39
ではパレット番号P=0を1ビット分出力する(=ou
tbit)。
(=colornum)にpresentのデータ{1
60,0,240}を登録する。そしてパレット番号P
に0を代入する(ステップS35)。そしてcolor
numをインクリメントする(ステップS36)。次に
colornumがパレットメモリの限界値2のm乗に
達したかどうかチェックする(ステップS37)。この
実施例ではm=8とし、2のm乗は256なので、co
lornum=1であるから達していない。従って何の
処理も行われずステップS39に進む。ステップS39
ではパレット番号P=0を1ビット分出力する(=ou
tbit)。
【0052】ステップS41では、colornum=
1がcheck=2と等しいかどうか調べている。ここ
で、等しくないので何の処理も行わずステップS27に
進む。
1がcheck=2と等しいかどうか調べている。ここ
で、等しくないので何の処理も行わずステップS27に
進む。
【0053】ここで、next[3]とformer
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={160,0,240}、f
ormer[3]={255,255,255}とな
る。
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={160,0,240}、f
ormer[3]={255,255,255}とな
る。
【0054】この時点での出力状態は以下のようにな
る。
る。
【0055】(0)(0)(1/1/0) (見やすくするために1つの画素に対する出力はカッコ
でくくり1つの画素内の出力はスラッシュで区分した)
また、パレットメモリの中は以下のようになる。
でくくり1つの画素内の出力はスラッシュで区分した)
また、パレットメモリの中は以下のようになる。
【0056】アドレス<00000000>の中身=1
0100000/00000000/11110000
0100000/00000000/11110000
【0057】次の画素4はnext[3]と同じデータ
を有しているので第1比較部4から「0」が出力され
る。
を有しているので第1比較部4から「0」が出力され
る。
【0058】次の画素5={255,255,255}
はnext[3]と異なるデータを有しているがfor
mer[3]と同じ値であるので第1比較部4から
「1」が出力され第2比較部5から「0」が出力され
る。ここで、next[3]とfoemer[3]のデ
ータを更新する。こうしてnext[3]={255,
255,255}、former[3]={160,
0,240}となる。
はnext[3]と異なるデータを有しているがfor
mer[3]と同じ値であるので第1比較部4から
「1」が出力され第2比較部5から「0」が出力され
る。ここで、next[3]とfoemer[3]のデ
ータを更新する。こうしてnext[3]={255,
255,255}、former[3]={160,
0,240}となる。
【0059】次の画素6はnext[3]と同じデータ
を有しているので第1比較部4から「0」が出力され
る。
を有しているので第1比較部4から「0」が出力され
る。
【0060】次の画素7は異なるデータを有しているの
で処理手順が異なる。
で処理手順が異なる。
【0061】画素データ並び変え部1より出力されるデ
ータは{0,0,0}の値を有し、従って、prese
nt[3]={0,0,0}となる(ステップS1
3)。次にpresent[3]とnext[3]=
{255,255,255}と比較する(ステップS1
4)。今回は両者は異なる値を有しているのでステップ
S21に進み、第1比較部からは「1」が出力される
(ステップS21)。
ータは{0,0,0}の値を有し、従って、prese
nt[3]={0,0,0}となる(ステップS1
3)。次にpresent[3]とnext[3]=
{255,255,255}と比較する(ステップS1
4)。今回は両者は異なる値を有しているのでステップ
S21に進み、第1比較部からは「1」が出力される
(ステップS21)。
【0062】さらに、present「3」とform
er[3]={160,0,240}とを比較する(ス
テップS22)。両者は異なる値を有しているのでステ
ップS28に進み、第2比較部から「1」が出力される
(ステップS28)。
er[3]={160,0,240}とを比較する(ス
テップS22)。両者は異なる値を有しているのでステ
ップS28に進み、第2比較部から「1」が出力される
(ステップS28)。
【0063】ステップS29で、colornumがパ
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べるのだが、現時点でcolornum=1であ
り、アドレス0の画素データを調べると{160,0,
240}であり、画素データ{0,0,0}は登録され
ていないのでステップS35に進む。
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べるのだが、現時点でcolornum=1であ
り、アドレス0の画素データを調べると{160,0,
240}であり、画素データ{0,0,0}は登録され
ていないのでステップS35に進む。
【0064】S35ではパレットメモリのアドレス0
(=colornum)にpresentのデータ
{0,0,0}を登録する。そしてパレット番号Pに1
を代入する(ステップS35)。そしてcolornu
mをインクリメントする(ステップS36)。次にco
lornumがパレットメモリの限界値2のm乗に達し
たかどうかチェックする(ステップS37)。ここで、
colornum=2であるから達していない。従って
何の処理も行われずステップS39に進む。ステップS
39ではパレット番号P=1を1ビット分出力する(=
outbit)。
(=colornum)にpresentのデータ
{0,0,0}を登録する。そしてパレット番号Pに1
を代入する(ステップS35)。そしてcolornu
mをインクリメントする(ステップS36)。次にco
lornumがパレットメモリの限界値2のm乗に達し
たかどうかチェックする(ステップS37)。ここで、
colornum=2であるから達していない。従って
何の処理も行われずステップS39に進む。ステップS
39ではパレット番号P=1を1ビット分出力する(=
outbit)。
【0065】次にステップS41で、colornum
とcheckを比較している。両者は共に2であり等し
い。ステップS42に進み、outbitをインクリメ
ントする。そして、checkにcheck2 =4を代
入する(ステップS43)。
とcheckを比較している。両者は共に2であり等し
い。ステップS42に進み、outbitをインクリメ
ントする。そして、checkにcheck2 =4を代
入する(ステップS43)。
【0066】ここで、next[3]とformer
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={0,0,0}、forme
r[3]={255,255,255}となる。
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={0,0,0}、forme
r[3]={255,255,255}となる。
【0067】この時点での出力状態は以下のようにな
る。
る。
【0068】(0)(0)(1/1/0)(0)(1/
0)(0)(1/1/1)
0)(0)(1/1/1)
【0069】また、パレットメモリの中は以下のように
なる。
なる。
【0070】アドレス<00000000>の中身=1
01000000000000011110000 アドレス<00000001>の中身=0000000
00000000000000000
01000000000000011110000 アドレス<00000001>の中身=0000000
00000000000000000
【0071】次の画素8はnext[3]と同じデータ
を有しているので第1比較部4から「0」が出力され
る。
を有しているので第1比較部4から「0」が出力され
る。
【0072】次の画素9は{200,10,0}の値を
有し、従ってpresent[3]={200,10,
0}となる(ステップS13)。present[3]
はnext[3]={0,0,0}ともformer
[3]={255,255,255}とも異なる値を有
しているので第1比較部からは「1」が出力され(ステ
ップS21)、第2比較部からも「1」が出力される
(ステップS28)。
有し、従ってpresent[3]={200,10,
0}となる(ステップS13)。present[3]
はnext[3]={0,0,0}ともformer
[3]={255,255,255}とも異なる値を有
しているので第1比較部からは「1」が出力され(ステ
ップS21)、第2比較部からも「1」が出力される
(ステップS28)。
【0073】ステップS29で、colornumがパ
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べるのだが、現時点でcolornum=2であ
り、アドレス0及び1の画素データを調べると{16
0,0,240}{0,0,0}であり、画素データ
{200,10,0}は登録されていないのでステップ
S35に進む。
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べるのだが、現時点でcolornum=2であ
り、アドレス0及び1の画素データを調べると{16
0,0,240}{0,0,0}であり、画素データ
{200,10,0}は登録されていないのでステップ
S35に進む。
【0074】S35ではパレットメモリのアドレス2
(=colornum)にpresentのデータ{2
00,10,0}を登録する。そしてパレット番号Pに
2を代入する(ステップS35)。そしてcolorn
umをインクリメントする(ステップS36)。次にc
olornumがパレットメモリの限界値2のm乗に達
したかどうかチェックする(ステップS37)。ここ
で、colornum=3であるから達していない。従
って何の処理も行われずステップS39に進む。ステッ
プS39ではパレット番号P=2を2ビット分(10)
出力する(=outbit)。
(=colornum)にpresentのデータ{2
00,10,0}を登録する。そしてパレット番号Pに
2を代入する(ステップS35)。そしてcolorn
umをインクリメントする(ステップS36)。次にc
olornumがパレットメモリの限界値2のm乗に達
したかどうかチェックする(ステップS37)。ここ
で、colornum=3であるから達していない。従
って何の処理も行われずステップS39に進む。ステッ
プS39ではパレット番号P=2を2ビット分(10)
出力する(=outbit)。
【0075】次にステップS41で、colornum
=3とcheck=4を比較している。両者は異なるの
で何も処理は行われずステップS26に進む。
=3とcheck=4を比較している。両者は異なるの
で何も処理は行われずステップS26に進む。
【0076】ここで、next[3]とformer
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={210,10,0}、fo
rmer[3]={0,0,0}となる。
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={210,10,0}、fo
rmer[3]={0,0,0}となる。
【0077】この時点での出力状態は以下のようにな
る。
る。
【0078】(0)(0)(1/1/0)(0)(1/
0)(0)(1/1/1)(0)(1/1/10) また、パレットメモリの中は以下のようになる。
0)(0)(1/1/1)(0)(1/1/10) また、パレットメモリの中は以下のようになる。
【0079】アドレス<00000000>の中身=1
01000000000000011110000 アドレス<00000001>の中身=0000000
00000000000000000 アドレス<00000010>の中身=1100100
00000101000000000
01000000000000011110000 アドレス<00000001>の中身=0000000
00000000000000000 アドレス<00000010>の中身=1100100
00000101000000000
【0080】次の画素10はnext[3]と異なるデ
ータを有しているがformer[3]と同じ値である
ので第1比較部4から「1」が出力され第2比較部5か
ら「0」が出力される。ここで、next[3]とfo
emer[3]のデータを更新する。こうしてnext
[3]={0,0,0}、former[3]={21
0,10,0}となる。
ータを有しているがformer[3]と同じ値である
ので第1比較部4から「1」が出力され第2比較部5か
ら「0」が出力される。ここで、next[3]とfo
emer[3]のデータを更新する。こうしてnext
[3]={0,0,0}、former[3]={21
0,10,0}となる。
【0081】次の画素11は{255,255,25
5}の値を有し、従って、present[3]={2
55,255,255}となる(ステップS13)。p
resent[3]はnext[3]={0,0,0}
ともformer[3]={210,10,0}とも異
なる値を有しているので第1比較部からは「1」が出力
され(ステップS21)、第2比較部からも「1」が出
力される(ステップS28)。
5}の値を有し、従って、present[3]={2
55,255,255}となる(ステップS13)。p
resent[3]はnext[3]={0,0,0}
ともformer[3]={210,10,0}とも異
なる値を有しているので第1比較部からは「1」が出力
され(ステップS21)、第2比較部からも「1」が出
力される(ステップS28)。
【0082】ステップS29で、colornumがパ
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べるのだが、現時点でcolornum=3であ
り、アドレス0、1及び2の画素データを調べると{1
60,0,240}{0,0,0}{200,10,
0}であり、画素データ{255,255,255}は
登録されていないのでステップS35に進む。
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べるのだが、現時点でcolornum=3であ
り、アドレス0、1及び2の画素データを調べると{1
60,0,240}{0,0,0}{200,10,
0}であり、画素データ{255,255,255}は
登録されていないのでステップS35に進む。
【0083】S35ではパレットメモリのアドレス3
(=colornum)にpresentのデータ{2
55,255,255}を登録する。そしてパレット番
号Pに3を代入する(ステップS35)。そしてcol
ornumをインクリメントする(ステップS36)。
次にcolornumがパレットメモリの限界値2のm
乗に達したかどうかチェックする(ステップS37)。
ここで、colornum=4であるから達していな
い。従って何の処理も行われずステップS39に進む。
ステップS39ではパレット番号P=2を2ビット分
(11)出力する(=outbit)。
(=colornum)にpresentのデータ{2
55,255,255}を登録する。そしてパレット番
号Pに3を代入する(ステップS35)。そしてcol
ornumをインクリメントする(ステップS36)。
次にcolornumがパレットメモリの限界値2のm
乗に達したかどうかチェックする(ステップS37)。
ここで、colornum=4であるから達していな
い。従って何の処理も行われずステップS39に進む。
ステップS39ではパレット番号P=2を2ビット分
(11)出力する(=outbit)。
【0084】次にステップS41では、colornu
mとcheckを比較している。両者は共に4であり等
しいのでステップS42に進み、outbitをインク
リメントする。そして、checkにcheck2 =
8を代入する(ステップS43)。
mとcheckを比較している。両者は共に4であり等
しいのでステップS42に進み、outbitをインク
リメントする。そして、checkにcheck2 =
8を代入する(ステップS43)。
【0085】ここで、next[3]とformer
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={255,255,25
5}、former[3]={0,0,0}となる。
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={255,255,25
5}、former[3]={0,0,0}となる。
【0086】この時点での出力状態は以下のようにな
る。
る。
【0087】(0)(0)(1/1/0)(0)(1/
0)(0)(1/1/1)(0)(1/1/10)(1
/0)(1/1/11)
0)(0)(1/1/1)(0)(1/1/10)(1
/0)(1/1/11)
【0088】また、パレットメモリの中は以下のように
なる。
なる。
【0089】アドレス<00000000>の中身=1
01000000000000011110000 アドレス<00000001>の中身=0000000
00000000000000000 アドレス<00000010>の中身=1100100
00000101000000000 アドレス<00000011>の中身=1111111
11111111111111111
01000000000000011110000 アドレス<00000001>の中身=0000000
00000000000000000 アドレス<00000010>の中身=1100100
00000101000000000 アドレス<00000011>の中身=1111111
11111111111111111
【0090】次の画素12はnext[3]と同じデー
タを有しているので第1比較部4から「0」が出力され
る。
タを有しているので第1比較部4から「0」が出力され
る。
【0091】次の画素13は{160,0,240}の
値を有し、従ってpresent[3]={160,
0,240}となる(ステップS13)。presen
t[3]はnext[3]={255,255,25
5}ともformer[3]={0,0,0}異なる値
を有しているので第1比較部からは「1」が出力され
(ステップS21)、第2比較部からも「1」が出力さ
れる(ステップS28)。
値を有し、従ってpresent[3]={160,
0,240}となる(ステップS13)。presen
t[3]はnext[3]={255,255,25
5}ともformer[3]={0,0,0}異なる値
を有しているので第1比較部からは「1」が出力され
(ステップS21)、第2比較部からも「1」が出力さ
れる(ステップS28)。
【0092】ステップS29で、colornumがパ
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べる。現時点でcolornum=4であり、アド
レス0、1、2及び3の画素データを調べるとアドレス
0に{160,0,240}が登録されているのでパレ
ット番号Pに0を代入してステップS39に進む。
レットメモリの限界値2のm乗に達しているかどうかを
示すフラグflagをチェックしている。flag=0
なので達していないということでステップS30に進
む。ステップS30ではパレットメモリ内にprese
nt[3]のデータがすでにもう登録されているかどう
か調べる。現時点でcolornum=4であり、アド
レス0、1、2及び3の画素データを調べるとアドレス
0に{160,0,240}が登録されているのでパレ
ット番号Pに0を代入してステップS39に進む。
【0093】次にステップS41でcolornum=
4;check=8を比較している。両者異なるので何
の処理も行わずステップS26に進む。
4;check=8を比較している。両者異なるので何
の処理も行わずステップS26に進む。
【0094】ステップS39ではパレット番号P=0を
3ビット分(000)出力する(=outbit)。
3ビット分(000)出力する(=outbit)。
【0095】ここで、next[3]とformer
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={160,0,240}、f
ormer[3]={255,255,255}とな
る。
[3]のデータを更新する。即ち、former[3]
にnext[3]が代入されnext[3]にpres
ent[3]が代入される(ステップS26,27)。
こうしてnext[3]={160,0,240}、f
ormer[3]={255,255,255}とな
る。
【0096】この時点での出力状態は以下のようにな
る。
る。
【0097】(0)(0)(1/1/0)(0)(1/
0)(0)(1/1/1)(0)(1/1/10)(1
/0)(1/1/11)(0)(1/1/000)
0)(0)(1/1/1)(0)(1/1/10)(1
/0)(1/1/11)(0)(1/1/000)
【0098】パレットメモリの中は変化がない。
【0099】以上の処理を図5の画像に繰り返すことに
よって以下の符号データが完成する。
よって以下の符号データが完成する。
【0100】(0)(0)(1/1/0)(0)(1/
0)(0)(1/1/1)(0) (1/1/10)(1/0)(1/1/11)(0)
(1/1/000)(0)(1/0)(0) (0)(0)(1/0)(0)(0)(1/1/01
0)(0)(0) (1/1/001)(1/0)(0)(0)(0)(1
/1/011)(0)(0) (0)(0)(0)(1/0)(0)(1/1/00
0)(1/1/001)(0) (0)(1/1/010)(0)(0)(0)(1/1
/011)(0)(0) (0)(0)(0)(0)(1/1/000)(1/1
/010)(0)(0) (0)(1/1/001)(1/1/000)(1/1
/011)(0)(0)(0)(0) (0)(0)(0)(1/1/100)(0)(0)
(1/1/001)(0) (0)(0)(1/0)(0)(0)(0)(1/1/
011)(0) (0)(1/0)(0)(1/1/101)(0)
(0)(0)(0) (0)(1/1/001)(1/1/100)(0)
(1/1/101)(1/0)(0)(0) …
0)(0)(1/1/1)(0) (1/1/10)(1/0)(1/1/11)(0)
(1/1/000)(0)(1/0)(0) (0)(0)(1/0)(0)(0)(1/1/01
0)(0)(0) (1/1/001)(1/0)(0)(0)(0)(1
/1/011)(0)(0) (0)(0)(0)(1/0)(0)(1/1/00
0)(1/1/001)(0) (0)(1/1/010)(0)(0)(0)(1/1
/011)(0)(0) (0)(0)(0)(0)(1/1/000)(1/1
/010)(0)(0) (0)(1/1/001)(1/1/000)(1/1
/011)(0)(0)(0)(0) (0)(0)(0)(1/1/100)(0)(0)
(1/1/001)(0) (0)(0)(1/0)(0)(0)(0)(1/1/
011)(0) (0)(1/0)(0)(1/1/101)(0)
(0)(0)(0) (0)(1/1/001)(1/1/100)(0)
(1/1/101)(1/0)(0)(0) …
【0101】また、パレットメモリの中は以下のように
なる。
なる。
【0102】アドレス<00000000>の中身=1
01000000000000011110000 アドレス<00000001>の中身=0000000
00000000000000000 アドレス<00000010>の中身=1100100
00000101000000000 アドレス<00000011>の中身=1111111
11111111111111111 アドレス<00000100>の中身=0000000
00000000011111111 アドレス<00000101>の中身=0000101
01000111001111000
01000000000000011110000 アドレス<00000001>の中身=0000000
00000000000000000 アドレス<00000010>の中身=1100100
00000101000000000 アドレス<00000011>の中身=1111111
11111111111111111 アドレス<00000100>の中身=0000000
00000000011111111 アドレス<00000101>の中身=0000101
01000111001111000
【0103】もし、出現画素データが256色に達する
と、パレットメモリでは許容できなくなるため、ステッ
プS38でフラグが立ち、以後の処理ではパレットメモ
リのアドレス信号(1〜8ビット)を出力するのでなく
present[3]の画素データ24ビットが出力さ
れる(ステップS40)。
と、パレットメモリでは許容できなくなるため、ステッ
プS38でフラグが立ち、以後の処理ではパレットメモ
リのアドレス信号(1〜8ビット)を出力するのでなく
present[3]の画素データ24ビットが出力さ
れる(ステップS40)。
【0104】<データ伸長処理>次に、上述のデータ圧
縮装置により圧縮されたでデータを、元の画像データに
復元するデータ伸長装置について説明する。
縮装置により圧縮されたでデータを、元の画像データに
復元するデータ伸長装置について説明する。
【0105】図7は実施例1によるデータ伸長装置の機
能構成を現すブロック図である。同図において701は
分配部であり、メモリ10から読み出したデータをビッ
ト単位に分割し、さらに制御部710の制御により第3
比較部702、第4比較部703、パレットメモリ部7
04、スイッチ705のどれかに読み出したデータを分
配する。特にパレットメモリ部に分配するときはデータ
の補間も行う。702は第3比較部で、分配部701か
ら分配された1ビットデータをOFF信号である0を比
較して等しかったら「0」、異なれば「1」という信号
7aを出力する。703は第4比較部で、分配部701
から分配された1ビットデータをOFF信号である0と
比較して等しかったら「0」、異なれば「1」という信
号7bを出力する。704はパレットメモリ部で、分配
部701から分配された8ビットデータが指し示すアド
レスに格納されている画素データ24ビットを出力す
る。705はスイッチで、制御部710の制御により、
分配部からの24ビット画素データとパレットメモリか
らの24ビット画素データのスイッチングをする。70
6はセレクタで、スイッチ705からの画素データと第
4ラッチ部708からの画素データを入力し、第4比較
部703の出力信号7bの制御によりどちらかを選択す
る。707は第3ラッチ部であり、セレクタからの出力
である画素データを信号7aを書き込み信号として保持
する。708は第4ラッチ部であり、第3ラッチ部から
の出力画素データを信号7aを書き込み信号として保持
する。709は画素データ格納部であり、第3ラッチ部
からの出力をその画素位置に対応する場所に保持する。
710は制御部であり、信号7a及び7bの状態から各
部の動作タイミングの制御、特に分配部の制御(各信号
のビット数制御及びパレットメモリに分配するデータの
補間)を行う。
能構成を現すブロック図である。同図において701は
分配部であり、メモリ10から読み出したデータをビッ
ト単位に分割し、さらに制御部710の制御により第3
比較部702、第4比較部703、パレットメモリ部7
04、スイッチ705のどれかに読み出したデータを分
配する。特にパレットメモリ部に分配するときはデータ
の補間も行う。702は第3比較部で、分配部701か
ら分配された1ビットデータをOFF信号である0を比
較して等しかったら「0」、異なれば「1」という信号
7aを出力する。703は第4比較部で、分配部701
から分配された1ビットデータをOFF信号である0と
比較して等しかったら「0」、異なれば「1」という信
号7bを出力する。704はパレットメモリ部で、分配
部701から分配された8ビットデータが指し示すアド
レスに格納されている画素データ24ビットを出力す
る。705はスイッチで、制御部710の制御により、
分配部からの24ビット画素データとパレットメモリか
らの24ビット画素データのスイッチングをする。70
6はセレクタで、スイッチ705からの画素データと第
4ラッチ部708からの画素データを入力し、第4比較
部703の出力信号7bの制御によりどちらかを選択す
る。707は第3ラッチ部であり、セレクタからの出力
である画素データを信号7aを書き込み信号として保持
する。708は第4ラッチ部であり、第3ラッチ部から
の出力画素データを信号7aを書き込み信号として保持
する。709は画素データ格納部であり、第3ラッチ部
からの出力をその画素位置に対応する場所に保持する。
710は制御部であり、信号7a及び7bの状態から各
部の動作タイミングの制御、特に分配部の制御(各信号
のビット数制御及びパレットメモリに分配するデータの
補間)を行う。
【0106】上記の構成におけるデータ伸長装置の動作
について、図8〜図10のフローチャートを参照しなが
ら以下に説明する。
について、図8〜図10のフローチャートを参照しなが
ら以下に説明する。
【0107】図8〜図10は実施例1のデータ伸長装置
による処理手順を表わすフローチャートである。尚、以
下の説明においては、第3ラッチ部707に保持される
データをnext[3]とし、第4ラッチ部708に保
持されるデータをformer[3]とする。
による処理手順を表わすフローチャートである。尚、以
下の説明においては、第3ラッチ部707に保持される
データをnext[3]とし、第4ラッチ部708に保
持されるデータをformer[3]とする。
【0108】ステップS81で第3ラッチ部707及び
第4ラッチ部708を初期化し、next[3]とfo
rmer[3]に初期値をセットする。この初期値は、
圧縮時と同じ値にする必要があり、ここでは、next
[3]={255,255,255}、former
[3]={0,0,0}となる。ステップS82で出現
画素データを計数するcolornumとcolorn
umがパレットメモリの許容数を越えたことを示し、f
lagをリセットすると同時に出力ビット長さを表すo
utbitを1にし、outbitをインクリメントす
るタイミングをとるcheckを2にリセットする。次
にステップS83で分配部701から1ビットデータを
読み出し、これをdata1とする。次にステップS8
4において、第3比較部702によりdata1が
「0」であるかどうか判断する。この結果、data1
=0であればステップS85へ進む。また、data1
≠0の時は図8のステップS91へ処理を進める。
第4ラッチ部708を初期化し、next[3]とfo
rmer[3]に初期値をセットする。この初期値は、
圧縮時と同じ値にする必要があり、ここでは、next
[3]={255,255,255}、former
[3]={0,0,0}となる。ステップS82で出現
画素データを計数するcolornumとcolorn
umがパレットメモリの許容数を越えたことを示し、f
lagをリセットすると同時に出力ビット長さを表すo
utbitを1にし、outbitをインクリメントす
るタイミングをとるcheckを2にリセットする。次
にステップS83で分配部701から1ビットデータを
読み出し、これをdata1とする。次にステップS8
4において、第3比較部702によりdata1が
「0」であるかどうか判断する。この結果、data1
=0であればステップS85へ進む。また、data1
≠0の時は図8のステップS91へ処理を進める。
【0109】ステップS85ではnext[3]をその
位置の画素とし出力する。そしてステップS86へ進
み、まだ圧縮データが残っていればステップS83へ戻
り上述の処理を繰り返す。また、圧縮データが残ってい
なければ、本データ伸長処理を終了する。
位置の画素とし出力する。そしてステップS86へ進
み、まだ圧縮データが残っていればステップS83へ戻
り上述の処理を繰り返す。また、圧縮データが残ってい
なければ、本データ伸長処理を終了する。
【0110】次にdata1=1の場合の処理を図9の
フローチャートにより説明する。data1の値が1で
あるということは、その位置の画素の色データは1画素
前の色データと異なる値をもっているということであ
る。ステップS91にて第3比較部702からの結果出
力が「1」となるので、分配部から1ビットデータを読
み出し、これをdata2とする。ステップS92で、
第4比較部704によりdata2=0であるかどうか
を比較し、data2=0の時ステップS93へ進み、
data2≠0の時はステップS101へ進む(図1
0)。
フローチャートにより説明する。data1の値が1で
あるということは、その位置の画素の色データは1画素
前の色データと異なる値をもっているということであ
る。ステップS91にて第3比較部702からの結果出
力が「1」となるので、分配部から1ビットデータを読
み出し、これをdata2とする。ステップS92で、
第4比較部704によりdata2=0であるかどうか
を比較し、data2=0の時ステップS93へ進み、
data2≠0の時はステップS101へ進む(図1
0)。
【0111】ステップS93では、data2=0なの
で、その位置の画素はformer[3]の色データと
同じであるということで、続くステップS93にてne
xt[3]とformer[3]とのデータの入れ替え
を実行した後、前述のステップS85へ進む。ステップ
S85ではnext[3]のデータ(入れ替え前はfo
rmer[3]の色データであった)を出力する。
で、その位置の画素はformer[3]の色データと
同じであるということで、続くステップS93にてne
xt[3]とformer[3]とのデータの入れ替え
を実行した後、前述のステップS85へ進む。ステップ
S85ではnext[3]のデータ(入れ替え前はfo
rmer[3]の色データであった)を出力する。
【0112】以上のステップS93の処理を実行する動
作を図7のブロック図により説明する。第4比較部70
3からの結果出力が「0」となるので、セレクタ部70
6は第4ラッチ部708からの出力(former
[3])を保持する。次に、後のデータ入れ替えのため
に、第4ラッチ部708に、第3ラッチ部707の出力
データを保持する。そして、セレクタ部706に保持さ
れているデータを第3ラッチ部707に保持する。そし
て、この第3ラッチ部707に保持されたデータを画素
データ格納部709へ格納する。このようにして、fo
rmer[3]データが画素データとして出力され、更
に、next[3]とformer[3]とのデータの
交換とが実行される。
作を図7のブロック図により説明する。第4比較部70
3からの結果出力が「0」となるので、セレクタ部70
6は第4ラッチ部708からの出力(former
[3])を保持する。次に、後のデータ入れ替えのため
に、第4ラッチ部708に、第3ラッチ部707の出力
データを保持する。そして、セレクタ部706に保持さ
れているデータを第3ラッチ部707に保持する。そし
て、この第3ラッチ部707に保持されたデータを画素
データ格納部709へ格納する。このようにして、fo
rmer[3]データが画素データとして出力され、更
に、next[3]とformer[3]とのデータの
交換とが実行される。
【0113】一方、data2=1の場合は、その位置
の画素はnext[3]でもformer[3]でもな
い新たな色データを持っている。従って、新たな色デー
タ又は色データのパレットメモリのアドレスを分配部よ
り読み出して画素データ格納部709へ出力するととも
に、next[3]及びformer[3]のデータの
更新を実行する。まずステップS101において、fo
rmer[3]にnext[3]の値を代入する。
の画素はnext[3]でもformer[3]でもな
い新たな色データを持っている。従って、新たな色デー
タ又は色データのパレットメモリのアドレスを分配部よ
り読み出して画素データ格納部709へ出力するととも
に、next[3]及びformer[3]のデータの
更新を実行する。まずステップS101において、fo
rmer[3]にnext[3]の値を代入する。
【0114】次にステップS102において、フラグf
lagが0であるか、即ちcolorunmがパレット
メモリの限度量256に達していないかチェックする。
lagが0であるか、即ちcolorunmがパレット
メモリの限度量256に達していないかチェックする。
【0115】達していない場合、ステップS103に進
み達していた場合はステップS109に進む。
み達していた場合はステップS109に進む。
【0116】ステップS103では分配部から8−ou
tbit分上位ビットに0を補完された8ビットデータ
を得、data3に入力する。
tbit分上位ビットに0を補完された8ビットデータ
を得、data3に入力する。
【0117】ステップS104ではパレットメモリアド
レスdata3に格納されている画素データをnext
[3]に入力する。
レスdata3に格納されている画素データをnext
[3]に入力する。
【0118】ステップS105ではdata3がcol
ornumと等しいかどうかチェックし、等しい時、そ
れは新しい画素データとなるのでステップS106に進
む。異なる時は何もせずにステップS85に飛ぶ。ステ
ップS106ではcolornumをステップS107
ではcolornumがパレットメモリの限度量に達し
ていないかチェックし、達していたらステップS108
でフラグを立て、達していなかったら何もせずにステッ
プS85に進みnext[3]を出力する。
ornumと等しいかどうかチェックし、等しい時、そ
れは新しい画素データとなるのでステップS106に進
む。異なる時は何もせずにステップS85に飛ぶ。ステ
ップS106ではcolornumをステップS107
ではcolornumがパレットメモリの限度量に達し
ていないかチェックし、達していたらステップS108
でフラグを立て、達していなかったら何もせずにステッ
プS85に進みnext[3]を出力する。
【0119】ステップS110ではcolornumと
checkが等しいかどうか調べ、等しかったらステッ
プS111に進み、outbitをインクリメントし、
checkをcheckの2乗で更新する(ステップS
112)。
checkが等しいかどうか調べ、等しかったらステッ
プS111に進み、outbitをインクリメントし、
checkをcheckの2乗で更新する(ステップS
112)。
【0120】一方、ステップS102で、フラグが立っ
ていた時、ステップS109に進み、分配部から画素デ
ータを示す24ビットデータを取り出し、next
[3]に格納し、ステップS85に進みnext[3]
を出力する。
ていた時、ステップS109に進み、分配部から画素デ
ータを示す24ビットデータを取り出し、next
[3]に格納し、ステップS85に進みnext[3]
を出力する。
【0121】以上のフローチャートに従い、実際の圧縮
データを伸長してみる。上述のデータ圧縮装置により図
5に示される画像データを圧縮処理したデータを伸長処
理する。
データを伸長してみる。上述のデータ圧縮装置により図
5に示される画像データを圧縮処理したデータを伸長処
理する。
【0122】最初にnext[3]とformer
[3]に初期値をセットする(ステップS81)。
[3]に初期値をセットする(ステップS81)。
【0123】また、出現画素データを計数するカウンタ
colornumとcolornumがパレットメモリ
の限度値256に達していないかどうかを示すflag
をリセットする(ステップS82)。
colornumとcolornumがパレットメモリ
の限度値256に達していないかどうかを示すflag
をリセットする(ステップS82)。
【0124】分配部701はメモリ10からメモリ10
の深さビット分のデータを取り出し記憶しておいて制御
部710の制御により各部に必要ビット数だけ分配し、
以上の処理をメモリ10内のデータがなくなるまでくり
返す。まず、分配部から1ビットデータがdatalに
代入される(ステップS83)。datal=0である
のでこの画素はnext[3]と等しいことがわかり、
{255,255,255}が出力される(ステップS
85)。次に分配部から分配されるデータも0であるの
で同様に{255,255,255}が出力される。こ
うして図5の画素1、画素2に対応するデータが画素デ
ータ格納部709に格納される。
の深さビット分のデータを取り出し記憶しておいて制御
部710の制御により各部に必要ビット数だけ分配し、
以上の処理をメモリ10内のデータがなくなるまでくり
返す。まず、分配部から1ビットデータがdatalに
代入される(ステップS83)。datal=0である
のでこの画素はnext[3]と等しいことがわかり、
{255,255,255}が出力される(ステップS
85)。次に分配部から分配されるデータも0であるの
で同様に{255,255,255}が出力される。こ
うして図5の画素1、画素2に対応するデータが画素デ
ータ格納部709に格納される。
【0125】次に分配部から分配されるデータは1であ
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しformer[3]=
{255,255,255}となる(ステップS10
1)。ここで、フラグflagをチェックすると0であ
るのでステップS103に進む(ステップS102)。
ステップS103では分配部から7ビット(8−out
bit)上位に0を代入された8ビットデータ、即ち0
という1ビットデータに0を7個上位に補間されたデー
タ00000000がdata3に代入される。
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しformer[3]=
{255,255,255}となる(ステップS10
1)。ここで、フラグflagをチェックすると0であ
るのでステップS103に進む(ステップS102)。
ステップS103では分配部から7ビット(8−out
bit)上位に0を代入された8ビットデータ、即ち0
という1ビットデータに0を7個上位に補間されたデー
タ00000000がdata3に代入される。
【0126】ステップS104ではパレットメモリのア
ドレスdata3=00000000の位置の画素デー
タ{160,0,240}をnext[3]に代入す
る。ここでdata3=colornumであるのでス
テップS106に進む(ステップS105)。そしてc
olornumをインクリメントする(ステップS10
6)。ここで、colornum=1がパレットメモリ
の限度値256に達していないかどうかチェックし、達
していないので何の処理も行わずステップS110に進
む(ステップS107)。ステップS110では、co
lornum=1とcheck=2を比較している。こ
こで両者は異なるので、何の処理も行わずステップS8
5に進む。ステップS85ではその位置の画素としてn
ext[3]を画素データ格納部709に出力する。
ドレスdata3=00000000の位置の画素デー
タ{160,0,240}をnext[3]に代入す
る。ここでdata3=colornumであるのでス
テップS106に進む(ステップS105)。そしてc
olornumをインクリメントする(ステップS10
6)。ここで、colornum=1がパレットメモリ
の限度値256に達していないかどうかチェックし、達
していないので何の処理も行わずステップS110に進
む(ステップS107)。ステップS110では、co
lornum=1とcheck=2を比較している。こ
こで両者は異なるので、何の処理も行わずステップS8
5に進む。ステップS85ではその位置の画素としてn
ext[3]を画素データ格納部709に出力する。
【0127】こうして図5の画素「3」に対応するデー
タが画素データ格納部709に格納される。
タが画素データ格納部709に格納される。
【0128】尚図5中の画素を特定する番号には丸を付
して示している。
して示している。
【0129】次に分配部から分配されるデータは0であ
るのでnext[3]={160,0,240}がその
位置の画素として画素データ格納部709に出力され
る。
るのでnext[3]={160,0,240}がその
位置の画素として画素データ格納部709に出力され
る。
【0130】こうして図5の画素「4」に対応するデー
タが画素データ格納部709に格納される。
タが画素データ格納部709に格納される。
【0131】次に分配部から分配されるデータは1であ
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。data2は0であ
るのでステップS93に進み、former[3]とn
ext[3]を交換しfurmer[3]={160,
0,240},next[3]={255,255,2
55}となる。そしてステップS85でnext[3]
がその位置の画素として画素データ格納部709に出力
される。
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。data2は0であ
るのでステップS93に進み、former[3]とn
ext[3]を交換しfurmer[3]={160,
0,240},next[3]={255,255,2
55}となる。そしてステップS85でnext[3]
がその位置の画素として画素データ格納部709に出力
される。
【0132】こうして図5の画素「5」に対応するデー
タが画素データ格納部709に格納される。
タが画素データ格納部709に格納される。
【0133】次に分配部から分配されるデータは0であ
るのでnext[3]={255,255,255}が
その位置の画素として画素データ格納部709に出力さ
れる。
るのでnext[3]={255,255,255}が
その位置の画素として画素データ格納部709に出力さ
れる。
【0134】こうして図5の画素「6」に対応するデー
タが画素データ格納部709に格納される。
タが画素データ格納部709に格納される。
【0135】次に分配部から分配されるデータは1であ
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しformer[3]=
{255,255,255}となる(ステップS10
1)。ここで、フラグflagをチェックすると0であ
るのでステップS103に進む(ステップS102)。
ステップS103では分配部から7ビット(8−out
bit)上位に0を代入された8ビットデータ、即ち1
という1ビットデータに0を7個上位に補間されたデー
タ00000001がdata3に代入される。
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しformer[3]=
{255,255,255}となる(ステップS10
1)。ここで、フラグflagをチェックすると0であ
るのでステップS103に進む(ステップS102)。
ステップS103では分配部から7ビット(8−out
bit)上位に0を代入された8ビットデータ、即ち1
という1ビットデータに0を7個上位に補間されたデー
タ00000001がdata3に代入される。
【0136】ステップS104ではパレットメモリのア
ドレスdata3=00000001の位置の画素デー
タ{0,0,0}をnext[3]に代入する。ここで
data3=colornumであるのでステップS1
06に進む(ステップS105)。そしてcolorn
umをインクリメントする(ステップS106)。ここ
で、colornum=2がパレットメモリの限度値2
56に達していないかどうかチェックし、達していない
ので何の処理も行わずステップS110に進む(ステッ
プS107)。ステップS110では、colornu
mとcheckを比較する。両者は共に2であるのでス
テップS111に進み、outbitをインクリメント
する。ステップS112ではcheckにcheck2
を代入している。ステップS85ではその位置の画素と
してnext[3]を画素データ格納部709に出力す
る。
ドレスdata3=00000001の位置の画素デー
タ{0,0,0}をnext[3]に代入する。ここで
data3=colornumであるのでステップS1
06に進む(ステップS105)。そしてcolorn
umをインクリメントする(ステップS106)。ここ
で、colornum=2がパレットメモリの限度値2
56に達していないかどうかチェックし、達していない
ので何の処理も行わずステップS110に進む(ステッ
プS107)。ステップS110では、colornu
mとcheckを比較する。両者は共に2であるのでス
テップS111に進み、outbitをインクリメント
する。ステップS112ではcheckにcheck2
を代入している。ステップS85ではその位置の画素と
してnext[3]を画素データ格納部709に出力す
る。
【0137】こうして図5の画素「7」に対応するデー
タが画素データ格納部709に格納される。
タが画素データ格納部709に格納される。
【0138】次に分配部から分配されるデータは0であ
るのでnext[3]={0,0,0}がその位置の画
素として画素データ格納部709に出力される。
るのでnext[3]={0,0,0}がその位置の画
素として画素データ格納部709に出力される。
【0139】こうして図5の画素「8」に対応するデー
タが画素データ格納部709に格納される。
タが画素データ格納部709に格納される。
【0140】次に分配部から分配されるデータは1であ
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しfurmer[3]=
{0,0,0}となる(ステップS101)。ここで、
フラグflagをチェックすると0であるのでステップ
S103に進む(ステップS102)。ステップS10
3では分配部から6ビット(8−outbit)上位に
0を代入された8ビットデータ、即ち10という2ビッ
トデータに0を6個上位に補間されたデータ00000
010がdata3に代入される。
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しfurmer[3]=
{0,0,0}となる(ステップS101)。ここで、
フラグflagをチェックすると0であるのでステップ
S103に進む(ステップS102)。ステップS10
3では分配部から6ビット(8−outbit)上位に
0を代入された8ビットデータ、即ち10という2ビッ
トデータに0を6個上位に補間されたデータ00000
010がdata3に代入される。
【0141】ステップS104ではパレットメモリのア
ドレスdata3=00000010の位置の画素デー
タ{200,10,0}をnext[3]に代入する。
ここでdata3=colornumであるのでステッ
プS106に進む(ステップS105)。そしてcol
ornumをインクリメントする(ステップS10
6)。ここで、colornum=3がパレットメモリ
の限度値256に達していないかどうかチェックし、達
していないので何の処理も行わずステップS110に進
む(ステップS107)。ステップS110ではcol
ornum=3とcheck=4を比較する。両者は異
なるので何の処理も行わず、ステップS85に進む。ス
テップS85ではその位置の画素としてnext[3]
を画素データ格納部709に出力する。
ドレスdata3=00000010の位置の画素デー
タ{200,10,0}をnext[3]に代入する。
ここでdata3=colornumであるのでステッ
プS106に進む(ステップS105)。そしてcol
ornumをインクリメントする(ステップS10
6)。ここで、colornum=3がパレットメモリ
の限度値256に達していないかどうかチェックし、達
していないので何の処理も行わずステップS110に進
む(ステップS107)。ステップS110ではcol
ornum=3とcheck=4を比較する。両者は異
なるので何の処理も行わず、ステップS85に進む。ス
テップS85ではその位置の画素としてnext[3]
を画素データ格納部709に出力する。
【0142】こうして図5の画素「9」に対応するデー
タが画素データ格納部709に格納される。
タが画素データ格納部709に格納される。
【0143】次に分配部から分配されるデータは1であ
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。data2は0であ
るのでステップS93に進み、former[3]とn
ext[3]を交換しformer[3]={200,
10,0},next[3]={0,0,0}となる。
そしてステップS85でnext[3]がその位置の画
素として画素データ格納部709に出力される。
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。data2は0であ
るのでステップS93に進み、former[3]とn
ext[3]を交換しformer[3]={200,
10,0},next[3]={0,0,0}となる。
そしてステップS85でnext[3]がその位置の画
素として画素データ格納部709に出力される。
【0144】こうして図5の画素「10」に対応するデ
ータが画素データ格納部709に格納される。
ータが画素データ格納部709に格納される。
【0145】次に分配部から分配されるデータは1であ
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しfurmer[3]=
{0,0,0}となる(ステップS101)。ここで、
フラグflagをチェックすると0であるのでステップ
S103に進む(ステップS102)。ステップS10
3では分配部から6ビット(8−outbit)上位に
0を代入された8ビットデータ、即ち11という2ビッ
トデータに0を6個上位に補間されたデータ00000
011がdata3に代入される。
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しfurmer[3]=
{0,0,0}となる(ステップS101)。ここで、
フラグflagをチェックすると0であるのでステップ
S103に進む(ステップS102)。ステップS10
3では分配部から6ビット(8−outbit)上位に
0を代入された8ビットデータ、即ち11という2ビッ
トデータに0を6個上位に補間されたデータ00000
011がdata3に代入される。
【0146】ステップS104ではパレットメモリのア
ドレスdata3=00000011の位置の画素デー
タ{255,255,255}をnext[3]に代入
する。ここでdata3=colornumであるので
ステップS106に進む(ステップS105)。そして
colornumをインクリメントする(ステップS1
06)。ここで、colornum=4がパレットメモ
リの限度値256に達していないかどうかチェックし、
達していないので何の処理も行わずステップS110に
進む(ステップS107)。ステップS110ではco
lornum=4とcheck=4を比較する。両者は
等しいのでステップS111に進み、outbitをイ
ンクリメントする。ステップS112ではcheckに
check2を代入する。ステップS85ではその位置
の画素としてnext[3]を画素データ格納部709
に出力する。
ドレスdata3=00000011の位置の画素デー
タ{255,255,255}をnext[3]に代入
する。ここでdata3=colornumであるので
ステップS106に進む(ステップS105)。そして
colornumをインクリメントする(ステップS1
06)。ここで、colornum=4がパレットメモ
リの限度値256に達していないかどうかチェックし、
達していないので何の処理も行わずステップS110に
進む(ステップS107)。ステップS110ではco
lornum=4とcheck=4を比較する。両者は
等しいのでステップS111に進み、outbitをイ
ンクリメントする。ステップS112ではcheckに
check2を代入する。ステップS85ではその位置
の画素としてnext[3]を画素データ格納部709
に出力する。
【0147】こうして図5の画素「11」に対応するデ
ータが画素データ格納部709に格納される。
ータが画素データ格納部709に格納される。
【0148】次に分配部から分配されるデータは0であ
るのでnext[3]={255,255,255}が
その位置の画素として画素データ格納部709に出力さ
れる。
るのでnext[3]={255,255,255}が
その位置の画素として画素データ格納部709に出力さ
れる。
【0149】こうして図5の画素「12」に対応するデ
ータが画素データ格納部709に格納される。
ータが画素データ格納部709に格納される。
【0150】次に分配部から分配されるデータは1であ
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しfurmer[3]=
{255,255,255}となる(ステップS10
1)。ここで、フラグflagをチェックすると0であ
るのでステップS103に進む(ステップS102)。
ステップS103では分配部から5ビット(8−out
bit)上位に0を代入された8ビットデータ、即ち0
00という3ビットデータに0を5個上位に補間された
データ00000000がdata3に代入される。
るのでステップS91に進み、さらに分配部から1ビッ
トデータをdata2に代入する。さらに、data2
も1であるのでステップS101に進み、former
[3]にnext[3]を代入しfurmer[3]=
{255,255,255}となる(ステップS10
1)。ここで、フラグflagをチェックすると0であ
るのでステップS103に進む(ステップS102)。
ステップS103では分配部から5ビット(8−out
bit)上位に0を代入された8ビットデータ、即ち0
00という3ビットデータに0を5個上位に補間された
データ00000000がdata3に代入される。
【0151】ステップS104ではパレットメモリのア
ドレスdata3=00000000の位置の画素デー
タ{160,0,240}をnext[3]に代入す
る。ここでdata3とcolornumは異なるので
何の処理も行わずステップS110に進む(ステップS
105)。ステップS110ではcolornum=5
とcheck=8を比較する。両者は異なるので何の処
理も行わずステップS85に進む。ステップS85では
その位置の画素としてnext[3]を画素データ格納
部709に出力する。
ドレスdata3=00000000の位置の画素デー
タ{160,0,240}をnext[3]に代入す
る。ここでdata3とcolornumは異なるので
何の処理も行わずステップS110に進む(ステップS
105)。ステップS110ではcolornum=5
とcheck=8を比較する。両者は異なるので何の処
理も行わずステップS85に進む。ステップS85では
その位置の画素としてnext[3]を画素データ格納
部709に出力する。
【0152】こうして図5の画素「13」に対応するデ
ータが画素データ格納部709に格納される。
ータが画素データ格納部709に格納される。
【0153】すべての圧縮データに対して上述の伸長処
理を実行すると、図5のRGBデータをまったく変化す
ることなく復元することができる。
理を実行すると、図5のRGBデータをまったく変化す
ることなく復元することができる。
【0154】以上説明してきたように、実施例1による
画像データ圧縮伸長装置は可逆圧縮法であり、圧縮率も
高いという特徴を有している。特に、コンピュータ上で
作成した画像等のように、1領域中を同一のデータを持
つ画素が連続しているような画像に対して優れた効果を
発揮する。
画像データ圧縮伸長装置は可逆圧縮法であり、圧縮率も
高いという特徴を有している。特に、コンピュータ上で
作成した画像等のように、1領域中を同一のデータを持
つ画素が連続しているような画像に対して優れた効果を
発揮する。
【0155】尚、上述の第1ラッチ部2の動作は、上述
のフローチャートに示されるように、第1比較部4の比
較結果に基づいて保持データを更新してもよいし、画素
データ発生部1から画素データが入力される毎に保持デ
ータを更新するようにしてもよい。
のフローチャートに示されるように、第1比較部4の比
較結果に基づいて保持データを更新してもよいし、画素
データ発生部1から画素データが入力される毎に保持デ
ータを更新するようにしてもよい。
【0156】(実施例2)上述の実施例1においてメモ
リ部は1つであるがこれを第1比較部4からの出力を記
憶するメモリ、第2比較部5からの出力を記憶するメモ
リ、画素データを記憶するメモリの3つに分けても良
い。その場合、ハード構成が簡単になるメリットがあ
る。
リ部は1つであるがこれを第1比較部4からの出力を記
憶するメモリ、第2比較部5からの出力を記憶するメモ
リ、画素データを記憶するメモリの3つに分けても良
い。その場合、ハード構成が簡単になるメリットがあ
る。
【0157】(実施例3)以上説明した実施例2におい
て、第1比較部4、及び第2比較部5から出力されるデ
ータは、ON/OFF(1/0)を示すフラグ制により
構成されている。本実施例2においては、第1比較部4
及び第2比較部5から出力されるデータをフラグ制では
なく、トリガー制により構成する。フラグ制とトリガー
制の違いを図11に表す。1101がフラグ制を表し、
1102がトリガー制を表す。同図から明らかなよう
に、トリガー制1102の方が同じデータが長く続く傾
向がある。この性質を利用して、第1比較部4及び第2
比較部5から出力されるデータに関しては、さらにMH
などのランレングス圧縮をかけ、データ量の削減を達成
することができる。また、MHに限らず、出来上がった
圧縮データにさらにハフマン符号またはLempel−
Ziv符号化などをかけ、さらなるデータ圧縮を実施す
ることが出来る。
て、第1比較部4、及び第2比較部5から出力されるデ
ータは、ON/OFF(1/0)を示すフラグ制により
構成されている。本実施例2においては、第1比較部4
及び第2比較部5から出力されるデータをフラグ制では
なく、トリガー制により構成する。フラグ制とトリガー
制の違いを図11に表す。1101がフラグ制を表し、
1102がトリガー制を表す。同図から明らかなよう
に、トリガー制1102の方が同じデータが長く続く傾
向がある。この性質を利用して、第1比較部4及び第2
比較部5から出力されるデータに関しては、さらにMH
などのランレングス圧縮をかけ、データ量の削減を達成
することができる。また、MHに限らず、出来上がった
圧縮データにさらにハフマン符号またはLempel−
Ziv符号化などをかけ、さらなるデータ圧縮を実施す
ることが出来る。
【0158】(実施例4)以上説明した実施例におい
て、以前の画素データを記憶するラッチ(第2ラッチ
部)は1つであるが、複数もっても良い。
て、以前の画素データを記憶するラッチ(第2ラッチ
部)は1つであるが、複数もっても良い。
【0159】例えば3つとすると、以前の色データ(第
21ラッチ部、第22ラッチ部、第23ラッチ部)が3
つまで記憶でき、パレットメモリアドレスや画素データ
24bitを出力する回数が減り、圧縮率が向上する。
その場合、第2比較部(第21比較部、第22比較部、
第23比較部)も3つとなり、それぞれの比較結果によ
り、信号1bにあたいする信号は2bitの値を有し、
例えば、 00:present[3]が第21ラッチ部と一致 01:present[3]が第22ラッチ部と一致 10:present[3]が第23ラッチ部と一致 11:どれとも一致しないのでパレットアドレス又は画
素データ出力という信号になる。
21ラッチ部、第22ラッチ部、第23ラッチ部)が3
つまで記憶でき、パレットメモリアドレスや画素データ
24bitを出力する回数が減り、圧縮率が向上する。
その場合、第2比較部(第21比較部、第22比較部、
第23比較部)も3つとなり、それぞれの比較結果によ
り、信号1bにあたいする信号は2bitの値を有し、
例えば、 00:present[3]が第21ラッチ部と一致 01:present[3]が第22ラッチ部と一致 10:present[3]が第23ラッチ部と一致 11:どれとも一致しないのでパレットアドレス又は画
素データ出力という信号になる。
【0160】この時、第1比較部が不一致だった時に更
新される第2ラッチ部のデータは、 1b=00:第21ラッチ部のデータを第1ラッチ部の
データで更新する。
新される第2ラッチ部のデータは、 1b=00:第21ラッチ部のデータを第1ラッチ部の
データで更新する。
【0161】=01:第22ラッチ部のデータを第1ラ
ッチ部のデータで更新する。
ッチ部のデータで更新する。
【0162】=10:第23ラッチ部のデータを第1ラ
ッチ部のデータで更新する。
ッチ部のデータで更新する。
【0163】=11:一番古く更新されたラッチ部を第
1ラッチ部のデータで更新する。
1ラッチ部のデータで更新する。
【0164】又は1b=11の時は必ず第23ラッチ部
を更新することにしても良い。
を更新することにしても良い。
【0165】(実施例5)以上説明した実施例1ではパ
レットメモリアドレスを示すデータをアドレスビット数
がmの時、colornumの値に従って(1〜m)ビ
ットまで可変としたが、mビット固定としても良い。
レットメモリアドレスを示すデータをアドレスビット数
がmの時、colornumの値に従って(1〜m)ビ
ットまで可変としたが、mビット固定としても良い。
【0166】その場合図1セレクタ部8の制御及び図7
分配部701の制御はもっと簡単になる。
分配部701の制御はもっと簡単になる。
【0167】尚、上述の各実施例においてはハードウエ
アによりその圧縮伸長方法を実現しているが、ソフトウ
エアによりこれを実現してもよい。
アによりその圧縮伸長方法を実現しているが、ソフトウ
エアによりこれを実現してもよい。
【0168】尚、上述の各実施例における画素データ圧
縮装置では、第2ラッチ部(3)に保持される画素デー
タは1つだけであるがこれに限られるものではない。前
回の更新後の画素データ、前々回の更新後の画素データ
というように保持する画素データの数は複数であっても
よい。
縮装置では、第2ラッチ部(3)に保持される画素デー
タは1つだけであるがこれに限られるものではない。前
回の更新後の画素データ、前々回の更新後の画素データ
というように保持する画素データの数は複数であっても
よい。
【0169】尚、本発明は、複数の機器から構成される
システムに適用しても1つの機器から成る装置に適用し
ても良い。また、本発明は、システム或は装置にプログ
ラムを供給することによって達成される場合にも適用で
きることはいうまでもない。
システムに適用しても1つの機器から成る装置に適用し
ても良い。また、本発明は、システム或は装置にプログ
ラムを供給することによって達成される場合にも適用で
きることはいうまでもない。
【0170】
【発明の効果】以上説明したように、本発明によるデー
タ圧縮装置及び方法によれば、コンピュータなどにより
作成された多値画像を劣化なく高い圧縮率で圧縮するこ
とが可能となる。
タ圧縮装置及び方法によれば、コンピュータなどにより
作成された多値画像を劣化なく高い圧縮率で圧縮するこ
とが可能となる。
【図1】実施例1のデータ圧縮装置の概略構成を表すブ
ロック図である。
ロック図である。
【図2】実施例1のデータ圧縮装置の処理手順を表すフ
ローチャートである。
ローチャートである。
【図3】実施例1のデータ圧縮装置の処理手順を表すフ
ローチャートである。
ローチャートである。
【図4】実施例1のデータ圧縮装置の処理手順を表すフ
ローチャートである。
ローチャートである。
【図5】画像データの1例を表す図である。
【図6】データ圧縮処理する画素の順番を表す図であ
る。
る。
【図7】実施例1のデータ伸長装置の概略構成を表すブ
ロック図である。
ロック図である。
【図8】実施例1のデータ伸長装置の処理手順を表すフ
ローチャートである。
ローチャートである。
【図9】実施例1のデータ伸長装置の処理手順を表すフ
ローチャートである。
ローチャートである。
【図10】実施例1のデータ伸長装置の処理手順を表す
フローチャートである。
フローチャートである。
【図11】フラグ制とトリガ制によるON/OFFの表
現の違いを表す図である。
現の違いを表す図である。
【図12】ADCT圧縮装置の機能構成を表すブロック
図である。
図である。
【図13】ADCT伸長装置の機能構成を表すブロック
図である。
図である。
1 画素データ発生部 2 第1ラッチ部 3 第2ラッチ部 4 第1比較部 5 第2比較部 6 第1メモリ部 7 第2メモリ部
フロントページの続き (58)調査した分野(Int.Cl.7,DB名) G06T 9/00 H04N 1/41 JICSTファイル(JOIS)
Claims (6)
- 【請求項1】 過去に出現した画素データをパレット番
号付けして記憶するパレット記憶手段と、 原画像からの入力画素データと、前記入力画素データの
1つ前の画素データとを比較する第1の比較手段と、 前記第1の比較手段にて比較された両データが不一致で
あるときの画素データを少なくとも1つ以上保持する保
持手段と、 前記入力画素データと前記保持手段に保持されている画
素データとを比較する第2の比較手段と、 前記第2の比較手段による比較において、前記入力画素
データと前記保持手段に保持されたどの画素データとも
一致しないとき、前記入力画素データを前記パレット記
憶手段に記憶されている画素データのどれかと一致する
か検索し、前記入力画素データのパレット番号を出力す
る出力手段とを備えることを特徴とする画像データ圧縮
装置。 - 【請求項2】 前記第1の比較手段における一致/不一
致を示す比較結果と、前記第2の比較手段における一致
/不一致を示す比較結果と、前記出力手段により出力さ
れるパレット番号を記憶する記憶手段を更に備えること
を特徴とする請求項1に記載の画像データ圧縮装置。 - 【請求項3】 前記第1の比較手段にて比較された両デ
ータが不一致であるとき、前記出力手段は、前記保持手
段に保持された画素データの何れかを前記入力画素デー
タの1つ前の画素データにて更新することを特徴とする
請求項1に記載の画像データ圧縮装置。 - 【請求項4】 過去に出現した画素データをパレット番
号付けして記憶するパレット記憶行程と、 原画像からの入力画素データと、前記入力画素データの
1つ前の画素データとを比較する第1の比較行程と、 前記第1の比較行程にて比較された両データが不一致で
あるときの画素データを少なくとも1つ以上保持する保
持行程と、 前記入力画素データと前記保持行程に保持されている画
素データとを比較する第2の比較行程と、 前記第2の比較行程による比較において、前記入力画素
データと前記保持行程に保持されたどの画素データとも
一致しないとき、前記入力画素データを前記パレット記
憶行程にて記憶されている画素データのどれかと一致す
るか検索し、前記入力画素データのパレット番号を出力
する出力行程とを備えることを特徴とする画像データ圧
縮方法。 - 【請求項5】 前記第1の比較行程における一致/不一
致を示す比較結果と、前記第2の比較行程における一致
/不一致を示す比較結果と、前記出力行程にて出力され
るパレット番号を記憶する記憶行程を更に備えることを
特徴とする請求項4に記載の画像データ圧縮方法。 - 【請求項6】 前記第1の比較行程にて比較された両デ
ータが不一致であるとき、前記保持行程にて保持された
画素データの何れかを前記入力画素データの1つ前の画
素データにて更新する更新行程とを備えることを特徴と
する請求項4に記載の画像データ圧縮方法。
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP20252592A JP3334910B2 (ja) | 1992-07-29 | 1992-07-29 | 画像データ圧縮装置及び方法 |
US08/036,559 US5796872A (en) | 1992-03-25 | 1993-03-23 | Method and apparatus for compressing and decompressing image data |
DE69329510T DE69329510D1 (de) | 1992-03-25 | 1993-03-24 | Verfahren und Gerät zur Bilddatenkompression und -dekompression |
EP93302227A EP0562834B1 (en) | 1992-03-25 | 1993-03-24 | Method and apparatus for compressing and decompressing image data |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP20252592A JP3334910B2 (ja) | 1992-07-29 | 1992-07-29 | 画像データ圧縮装置及び方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH0652298A JPH0652298A (ja) | 1994-02-25 |
JP3334910B2 true JP3334910B2 (ja) | 2002-10-15 |
Family
ID=16458940
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP20252592A Expired - Fee Related JP3334910B2 (ja) | 1992-03-25 | 1992-07-29 | 画像データ圧縮装置及び方法 |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP3334910B2 (ja) |
-
1992
- 1992-07-29 JP JP20252592A patent/JP3334910B2/ja not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
JPH0652298A (ja) | 1994-02-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4367880B2 (ja) | 画像処理装置及びその方法並びに記憶媒体 | |
DE69631999T2 (de) | Bildverarbeitungsgerät und Verfahren | |
US6427025B1 (en) | Image processing with selection between reversible and irreversible compression | |
JPH04328960A (ja) | 画像データ伝送装置および画像データ伝送方法 | |
JP2000114980A (ja) | 量子化方法,および量子化プログラムを記録した記録媒体 | |
JP3462867B2 (ja) | 画像圧縮方法および装置、画像圧縮プログラムならびに画像処理装置 | |
JP3334910B2 (ja) | 画像データ圧縮装置及び方法 | |
JP2000125111A (ja) | 画像圧縮方法、画像復元方法、画像圧縮装置、画像読取装置、画像圧縮プログラム記憶媒体、および画像復元プログラム記憶媒体 | |
JP3108133B2 (ja) | カラー文書画像の適応符号化方式 | |
JPH0654208A (ja) | 画像処理方法および画像処理装置 | |
JPH07240845A (ja) | 画像のデータ圧縮および伸張 | |
US5796872A (en) | Method and apparatus for compressing and decompressing image data | |
US5903671A (en) | Data compression method and apparatus therefor | |
JP3260284B2 (ja) | 画像圧縮装置および画像伸張装置 | |
JP3256298B2 (ja) | 画像データ符号化方法及び装置 | |
JP3822512B2 (ja) | 画像データ圧縮装置、画像データ圧縮方法、記録媒体およびプログラム | |
JP3590648B2 (ja) | 原画像データの圧縮処理の方法及び原画像データの伸張処理の方法 | |
JP2809552B2 (ja) | 画像符号化処理方法および画像復号化処理方法 | |
JP2791410B2 (ja) | 圧縮画像データ抽出装置 | |
JP2810585B2 (ja) | 画像符号化処理方法および画像復号化処理方法 | |
JPH03266564A (ja) | 画像符号化方式及びその装置 | |
JP3236079B2 (ja) | 画像データ圧縮方法 | |
JP3087790B2 (ja) | 画像データ圧縮伸長方法及び装置 | |
JP2830388B2 (ja) | 画像符号化装置 | |
JP3264519B2 (ja) | 画像データ圧縮装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20020716 |
|
LAPS | Cancellation because of no payment of annual fees |