JP4377351B2 - データ圧縮装置およびデータ圧縮プログラム - Google Patents

データ圧縮装置およびデータ圧縮プログラム Download PDF

Info

Publication number
JP4377351B2
JP4377351B2 JP2005091483A JP2005091483A JP4377351B2 JP 4377351 B2 JP4377351 B2 JP 4377351B2 JP 2005091483 A JP2005091483 A JP 2005091483A JP 2005091483 A JP2005091483 A JP 2005091483A JP 4377351 B2 JP4377351 B2 JP 4377351B2
Authority
JP
Japan
Prior art keywords
data
unit
compression
numerical value
data compression
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.)
Active
Application number
JP2005091483A
Other languages
English (en)
Other versions
JP2006279208A (ja
Inventor
由紀夫 杉田
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Fujifilm Corp
Original Assignee
Fujifilm Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Fujifilm Corp filed Critical Fujifilm Corp
Priority to JP2005091483A priority Critical patent/JP4377351B2/ja
Priority to US11/345,546 priority patent/US7183950B2/en
Publication of JP2006279208A publication Critical patent/JP2006279208A/ja
Application granted granted Critical
Publication of JP4377351B2 publication Critical patent/JP4377351B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Compression Of Band Width Or Redundancy In Fax (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)

Description

本発明は、画像データ等のデータを圧縮するデータ圧縮装置、およびコンピュータ等の情報処理装置をデータ圧縮装置として動作させるデータ圧縮プログラムに関する。
従来より、記憶容量の低減化や通信量の低減化等のために、画像データ等のデータを圧縮する技術が広く採用されている。
例えば、特許文献1には、原画像から代表色を選定しCLUT(カラールックアップテーブル)を構成する際に、連続する色番号が近い値の色データを持つように色番号を割り当て、次にCLUTに対応したビットマップを作成して隣接画素間の色番号の差分を求め、差分が大きな値を取る場合、画質劣化を起こさない範囲でビットマップの色番号を変更し、差分を小さな値に偏らせ、差分データに対してランレングス符号化を施すという技術が開示されている。
また、特許文献2には、各色に対応してそれぞれ割り当てられたデータが複数集まって構成される画像用データを非可逆圧縮して符号化し、そして、データの1つを透明色に割り当てると共に、その透明色を可逆とし、画像用データを即値(差分符号化の際の最初の値)とその即値に続く複数の差分値(差分符号化の際の前の値)とで構成し、それらの値を非可逆圧縮して符号化等する際、透明色を表す即値と差分値とを可逆とし、さらに、透明色を表す即値を、各一色のデータ値の中間の値としたり、透明色を表す差分値を「0」としたりするという技術が提案されている。
また、特許文献3には、数を予測された数(s'(j))と実際の数(s(j))との差分によって符号化することが提案されている。
さらに、特許文献4には、n列目の画素データ列に対して、副走査方向の同一画素データの分布状況を認識するとともに、主走査方向の同ー画素データの分布状況を認識し、これらの認識結果を基に、副走査方向に連続する同ー画素データを圧縮処理するか、あるいは主走査方向に連続する同一画素データを圧縮処理するかを決定する画像圧縮装置が提案されている。
ここで、データ圧縮技術を適用した1つのシステムを紹介する。
図1は、データ圧縮技術が適用されたプリントシステムの一例を示す図、図2は、プリントシステムにおけるデータ処理の流れを示す図である。
このプリントシステムは、図1に示すように、ホストコントローラ100と、インターフェース機器200と、プリンタ300とで構成されており、ホストコントローラ100とインターフェース機器200との間はSCSI等の汎用インターフェースケーブル150で接続され、さらにインターフェース機器200とプリンタ300との間は専用インターフェースケーブル250で接続されている。
ホストコントローラ100の内部では、図2に示すように、PDF,PS,TIFF等、様々な言語やフォーマットで記述された文字や画像のデータ11が、画像(CT;Continuous Tone)データと文字やライン等(LW;Line Work)のデータとに分けられて、それぞれについてRIP(Raster Image Processing)を行なうことによりビットマップデータ12A,13Aが生成され、さらにそれぞれについてデータ圧縮処理が行なわれて、CTについては非可逆の圧縮データ14、LWについては可逆の圧縮データ15が生成される。これらの圧縮データ14,15は、図1に示す汎用インターフェースケーブル150を経由して、ホストコントローラ100からインターフェース機器200に転送される。インターフェース機器200では、転送されてきた圧縮データ14,15にデータ伸長処理を施して、ホストコントローラ100でデータ圧縮処理を行なう前の状態のビットマップデータ12A,13Aに対応するビットマップデータ12B,13Bを生成する。ここで、CTデータについてはホストコントローラ100でのデータ圧縮の際非可逆圧縮処理が行なわれているため、データ伸長後のCTデータ(ビットマップデータ12B)は完全にはデータ圧縮前のCTデータ(ビットマップデータ12A)には戻らないが、ほぼ同一のビットマップデータが復元される。LWデータについては、ホストコントローラ100でのデータ圧縮の際可逆圧縮処理が行なわれているため、データ伸長後のLWデータ(ビットマップデータ13B)は、データ圧縮前のLWデータ(ビットマップデータ13A)と同一のデータに復元される。
インターフェース機器200では、データ伸長後のCTデータ(ビットマップデータ12B)とLWデータ(ビットマップデータ13B)とが合成され、さらに網点情報等がタグとして付加されてプリンタ300に送られる。プリンタ300では、インターフェース機器200から受け取ったビットマップデータとそれに付加されたタグ情報とに従って画像がプリント出力される。
ホストコントローラ100とインターフェース機器200とが例えば相互に離れている場合、あるいは、インターフェース機器200が複数台のホストコントローラから画像データを受信するシステムの場合など、ホストコントローラ100とインターフェース機器200を別々の装置として構成する必要がある場合には、図2に示すような、ホストコントローラ100でデータ圧縮を行なってインターフェース機器200にデータ転送しインターフェース機器でデータ伸長するように構成することにより、ホストコントローラ100からインターフェース機器200へのデータ転送時間を短縮することができ、プリントの生産性が向上する。
ここで、一般的には、CTデータについては、非可逆ではあるが圧縮率の高いJPEG等の圧縮方式が採用され、LWデータについてはPackBits等の可逆圧縮方式が採用される。
特開平5−328142号公報 特開平10−164620号公報 特表2001−5−20822号公報 特開平9−200540号公報
しかし、JPEG等の圧縮方式では、ソフトウェアでの圧縮処理に時間を要し、圧縮処理のシステム全体としての処理能力を劣化させる要因となっていた。
また、JPEG等は非可逆な圧縮処理であるため画質の劣化を必然的に伴うが、近年、高画質化への要求がますます高まってきており、CTデータについても画質の劣化を招かないよう可逆圧縮を行うことが検討されてきている。
本発明は上記事情に鑑み、CTデータの圧縮に適用可能な新たな好ましい可逆圧縮処理を行うことができるデータ圧縮装置およびデータ圧縮プログラムを提供することを目的とする。
上記目的を達成する本発明のデータ圧縮装置は、
所定の単位ビット数で表わされる数値の連続からなる被圧縮データにデータ圧縮処理を施すデータ圧縮装置において、
被圧縮データを構成する数値の連続について隣接する数値どうしの差分を求めることによりその差分を表わす数値の連続からなる新たな被圧縮データを生成する差分生成部と、
上記差分生成部によって生成された新たな被圧縮データを構成する各数値を所定値だけオフセットさせるオフセット部と、
上記オフセット部によって数値がオフセットされた被圧縮データの各数値を、上記単位ビット数よりも小さい所定の分割ビット数のところで上位ビット部分と下位ビット部分とに分けることによって、その被圧縮データを、各数値における上位ビット部分の連続からなる上位データと各数値の下位ビット部分の連続からなる下位データとに分割する分割部と、
上記分割部によって分割された上位データに対して可逆圧縮処理を施す上位データ圧縮部と、
上記分割部によって分割された下位データに対して、符号と数値を対応づけるテーブルを用いてエントロピー符号化を施す符号化処理を含む可逆圧縮処理を施す下位データ圧縮部と、
上記下位データ圧縮部における可逆圧縮処理に先だって、上記テーブルに、上記エントロピー符号化が施される被圧縮データ中で出現頻度の高い数値ほど符号長の短かい符号を割り当てる割当部とを備えたことを特徴とする。
ここで、上記の『被圧縮データを構成する数値の連続について隣接する数値どうしの差分を求めることにより』における『隣接する』とは、データストリーム上で隣接してもよいが、必ずしもそれに限定されるものではない。例えば、2次元画像データが1次元ストリーム状のデータとして扱われている場合であれば、2次元的な画像上で見て隣接してもよい。以下においても同様である。
この本発明のデータ圧縮装置は、
上記下位データ圧縮部が、上記符号化処理として、ハフマンテーブルを用いてハフマン符号化を施す符号化処理を行うものであってもよい。
また、本発明のデータ圧縮装置は、
上記割当部が、画像を表す被圧縮データ中の、その画像の一部分に相当する数値を分析することによって前記出現頻度を求めるものであることが好ましい。
さらに、本発明のデータ圧縮装置は、
上記割当部が、画像を表す被圧縮データ中の、その画像の一部分に相当する数値に対し、上記差分生成部、上記オフセット部、および上記分割部のそれぞれにおける処理と同等の処理を施して分析用データを作成し、その分析用データを分析することによって前記出現頻度を求めるものであることが、より好ましい。
また、本発明のデータ圧縮装置は、
上記上位データ圧縮部が、上記上位データに対して、符号と数値を対応づけるテーブルを用いてエントロピー符号化を施す符号化処理を含む可逆圧縮処理を施すものであり、
上記割当部が、画像を表す被圧縮データ中の、その画像の一部分に相当する数値を分析することによって、上記上位データ圧縮部および上記下位データ圧縮部の各被圧縮データにおける数値の出現頻度を求め、それらの出現頻度に基づいて、上記上位データ圧縮部と上記下位データ圧縮部とのそれぞれにおける上記テーブルに、出現頻度の高い数値ほど符号長の短かい符号を割り当てるものであることが好ましい。
また、本発明のデータ圧縮装置は、
上記上位データ圧縮部が、上記上位データに対して、符号と数値を対応づけるテーブルを用いてエントロピー符号化を施す符号化処理を含む可逆圧縮処理を施すものであり、
上記割当部が、画像を表す被圧縮データ中の、その画像の一部分に相当する数値に対し、上記差分生成部、上記オフセット部、および上記分割部のそれぞれにおける処理と同等の処理を施して分析用データを作成し、その分析用データを分析することによって、上記上位データ圧縮部および上記下位データ圧縮部の各被圧縮データにおける数値の出現頻度を求め、それらの出現頻度に基づいて、上記上位データ圧縮部と上記下位データ圧縮部とのそれぞれにおける上記テーブルに、出現頻度の高い数値ほど符号長の短かい符号を割り当てるものであることが、より好ましい。
ここで、これらの本発明のデータ圧縮装置において、上記上位データ圧縮部が、上記符号化処理として、ハフマンテーブルを用いてハフマン符号化を施す符号化処理を行うものであり、
上記割当部が、上記上位データ圧縮部のハフマンテーブルに符号を割り当てるものであってもよい。
また、本発明のデータ圧縮装置は、
上記上位データ圧縮部が、上位データ中、1つもしくは複数の所定の圧縮対象数値を除く数値についてはそのまま出力するとともに、圧縮対象数値については、その圧縮対象数値と、圧縮対象数値と同一の圧縮対象数値の連続数を表わす数値とに符号化して出力する第1の符号化部を備えたものであることが好ましい。
また、本発明のデータ圧縮装置は、
上記下位データ圧縮部が、圧縮省略の指示を受けて下位データを無圧縮で出力するものであることも好適である。
上記目的を達成する本発明のデータ圧縮プログラムは、
プログラムを実行する情報処理装置内に組み込まれて該情報処理装置に、所定の単位ビット数で表わされる数値の連続からなる被圧縮データに対するデータ圧縮処理を実行させるデータ圧縮プログラムにおいて、
上記情報処理装置上に、
被圧縮データを構成する数値の連続について隣接する数値どうしの差分を求めることによりその差分を表わす数値の連続からなる新たな被圧縮データを生成する差分生成部と、
差分生成部によって生成された新たな被圧縮データを構成する各数値を所定値だけオフセットさせるオフセット部と、
オフセット部によって数値がオフセットされた被圧縮データの各数値を、上記単位ビット数よりも小さい所定の分割ビット数のところで上位ビット部分と下位ビット部分とに分けることによって、その被圧縮データを、各数値における上位ビット部分の連続からなる上位データと各数値の下位ビット部分の連続からなる下位データとに分割する分割部と、
分割部によって分割された上位データに対して可逆圧縮処理を施す上位データ圧縮部と、
分割部によって分割された下位データに対して可逆圧縮処理を施す下位データ圧縮部とを構築することを特徴とする。
なお、本発明にいうデータ圧縮プログラムについては、ここではその基本形態のみを示すのにとどめるが、これは単に重複を避けるためであり、本発明にいうデータ圧縮プログラムには、上記の基本形態のみではなく、前述したデータ圧縮装置の各形態に対応する各種の形態が含まれる。
また、本発明のデータ圧縮プログラムがコンピュータ上に構成する差分生成部などといった要素は、1つの要素が1つのプログラム部品によって構築されるものであってもよく、1つの要素が複数のプログラム部品によって構築されるものであってもよく、複数の要素が1つのプログラム部品によって構築されるものであってもよい。また、これらの要素は、そのような作用を自分自身で実行するものとして構築されてもよく、あるいは、コンピュータに組み込まれている他のプログラムやプログラム部品に指示を与えて実行するものとして構築されても良い。
上記本発明のデータ圧縮装置ないしデータ圧縮プログラムによれば、元の被圧縮データから差分生成部によって生成されてオフセット部によって数値がオフセットされた新たな被圧縮データが上位データと下位データとに分割され、それぞれ上位データ圧縮部と下位データ圧縮部とで可逆圧縮処理が施される。一般に、CTデータから得られる新たな被圧縮データの場合には、後で詳述するように、上位データと下位データとではデータ中の数値の分布傾向が顕著に異なっているので、各データに適した可逆圧縮処理が存在し、本発明による圧縮処理によって全体として大きな圧縮率が達成される。また、下位データには、データ毎に最適化されたテーブルが用いられてエントロピー符号化(典型的にはハフマン符号化)が施されるので大きな圧縮率が安定的に得られる。更に、各データに施される可逆圧縮処理としては、アルゴリズムが単純な処理が適用可能であるため、圧本発明による圧縮処理は処理時間が短い。このように、本発明のデータ圧縮装置ないしデータ圧縮プログラムによれば、CTデータの圧縮に適用すると特に好ましい新たな可逆圧縮処理が実現される。
また、上記割当部が、画像の一部分に相当する数値の分析によって出現頻度を求めるものであると、出現頻度の精度を維持しつつ演算の負担を軽減することができる。
また、上記割当部が、上記の分析用データを分析することによって出現頻度を求めるものであると、画像を一部分ずつ処理していく場合であっても、画像全体の傾向に最適化されたテーブルで適切に処理することができる。
また、上記の上位データ圧縮部もエントロピー符号化(典型的にはハフマン符号化)をデータに施すものである場合には、上記割当部が上位データ圧縮部用のテーブルについても最適なテーブルを作成するものであると、圧縮率の一層の向上が見込まれる。
また、上記の上位データ圧縮部が第1の符号化部を備えると、圧縮対象数値のみが、その圧縮対象数値と連続数とを表わす数値とに符号化されるため、原データよりも冗長度が増すという事態が回避され、圧縮率が向上する。
さらに、上記の下位データ圧縮部が、圧縮省略の指示を受けて下位データを無圧縮で出力するものであると、そのような指示によってより高速な圧縮処理を選択することができる。
以下において説明する実施形態は、図1に示す全体システムの中のホストコントローラに組み込まれる画像圧縮装置であり、さらに具体的には、図2に示すホストコントローラ内のCTのビットマップデータ12Aについてデータ圧縮を行なう処理に関するものである。したがって、ここでは、図1,図2を参照して説明したCTデータについてのデータ圧縮処理が以下に説明する本発明の実施形態としてのデータ圧縮処理に置き換わり、インターフェース機器内でのデータ伸長(解凍)処理もその本発明の実施形態としてのデータ圧縮処理に対応したデータ伸長(解凍)処理に置き換わるものと理解し、図1に示す全体システムおよび図2に示す処理の流れについて重複した図示および重複説明は省略する。
図3は、本発明のデータ圧縮装置の一実施形態に相当する画像圧縮装置を示すブロック構成図である。
この図3に示す画像圧縮装置500は、差分符号化部510、オフセット部520、プレーン分割部530、Lプレーン圧縮部540、Hプレーン圧縮部550、および最適ハフマンテーブル生成部560を備えている。各部510〜560の詳細は後述するが、この画像圧縮装置500内での画像データの流れは以下のとおりである。
入力画像ファイルD0(本実施形態では、図2に示すように、ビットマップに展開されたCTデータ12Aが格納されたファイル)は、図4に示すデータ圧縮装置500の、差分符号化部510と最適ハフマンテーブル生成部560との双方に入力され、差分符号化部510に入力されたデータには圧縮処理が施されて圧縮データが作成され、最適ハフマンテーブル生成部560に入力されたデータは、ハフマンテーブルの最適化に用いられる。
差分符号化部510では、2次元差分符号化処理、すなわち、入力されてきたデータを構成する数値の連続について、画像上で見てその数値に複数方向それぞれに隣接する複数の数値に基づいた2次元的な差分を求めることによりその差分を表わす8ビットの数値の連続からなる画像データを生成する処理が行なわれる。この差分符号化部510は、本発明にいう差分生成部の一例に相当する。
差分符号化部510で生成された、差分を表わす数値の連続からなる画像データは、オフセット部520に入力されて所定値だけオフセットされる。その後、プレーン分割部530で、画像データ中の8ビットの各数値が下位4ビットと上位4ビットとに分けられることにより、画像データは、下位4ビットの数値の連続からなる下位サブプレーンD1Lと上位4ビットの数値の連続からなる上位サブプレーンD1Hに分割される。このオフセット部520は、本発明にいうオフセット部の一例に相当し、プレーン分割部530は、本発明にいう分割部の一例に相当する。また、下位サブプレーンD1Lおよび上位サブプレーンD1Hは、それぞれ、本発明にいう下位データおよび上位データの各一例に相当する。
プレーン分割部530で分割された下位サブプレーンD1Lおよび上位サブプレーンD1Hは、それぞれ、Lプレーン圧縮部540およびHプレーン圧縮部550に入力されて可逆圧縮が施される。これらLプレーン圧縮部540およびHプレーン圧縮部550は、それぞれ、本発明にいう下位データ圧縮部および上位データ圧縮部の各一例に相当する。
Lプレーン圧縮部540のハフマン符号化部541では、数値と符号とを対応づけるハフマンテーブルに従って、そのハフマン符号化部541に入力されてきた下位サブプレーンD1Lを構成する数値をそのハフマンテーブルに従う符号に置き換える符号化処理が行なわれる。このハフマン符号化は、エントロピー符号化の一種である。なお、Lプレーン圧縮部540にはモード切換部542が組み込まれており、このモード切換部542は、ユーザから、高速モードと通常モードとの切り換えを指示されて、上記のハフマン符号化部541によるハフマン符号化を経る通常モードと、ハフマン符号化を省略して下位サブプレーンD1Lをそのまま出力する高速モードとを切り換える。このようなLプレーン圧縮部540からは、下位サブプレーンD1Lが圧縮された下位圧縮データD2Lが出力されるが、高速モードの場合には下位圧縮データD2Lは下位サブプレーンD1Lそのものである。
一方、Hプレーン圧縮部550には、ランレングス符号化部551とハフマン符号化部553が備えられており、上位サブプレーンD1Hはランレングス符号化部551に入力される。
ランレングス符号化部551では、先ず、入力されてきた上位サブプレーンD1Hのデータの中から1つもしくは複数の圧縮対象数値の存在及び同一の圧縮対象数値の連続数が検出される。次いで、ランレングス符号化部551では、その検出結果を受けて、上位サブプレーンD1Hのデータ中、圧縮対象数値を除く数値についてはそのまま出力すると共に、圧縮対象数値については、その圧縮対象数値と、その圧縮対象数値と同一の圧縮対象数値の連続数を表わす数値とに符号化して出力するという符号化処理が行なわれる。このランレングス符号化部551では、その符号化処理にあたっては、同一の圧縮対象数値の連続数に応じ、その連続数を異なるビット数で表現する符号化が行なわれる。ここでは、具体的には、同一の圧縮対象数値の連続数が所定数以下のときはその連続数を1単位ビット数で表現し、その連続数が所定数を越えるときは2単位ビット数で表現する符号化が行なわれる。本実施形態では、このランレングス符号化部551が、本発明にいう第1の符号化部の一例に相当する。
また、ランレングス符号化部551での符号化後のデータは、次に、ハフマン符号化部553に入力される。ハフマン符号化部553では、そのハフマン符号化部553に入力されてきたデータを構成する数値を、ハフマンテーブルに従う符号、すなわち、出現頻度の高い数値ほど短かいビット長で表わされる符号に置き換える符号化処理が行なわれる。
ハフマン符号化部553でハフマン符号化された後のデータは、データスキャニング部552で割り当てられた数値と符号との割当テーブルを含む圧縮情報が添付され、上位サブプレーンD1Hが圧縮された上位圧縮データD2HとしてHプレーン圧縮部550から出力される。
上述したLプレーン圧縮部540およびHプレーン圧縮部550のそれぞれで行われるハフマン符号化には、圧縮対象の画像に対して最適化されたハフマンテーブルが用いられる。このようなハフマンテーブルは、最適ハフマンテーブル生成部560で作成され、この最適ハフマンテーブル生成部560は、本発明にいう割当部の一例に相当する。
最適ハフマンテーブル生成部560に渡された画像データは、先ず、プレスキャン部561に入力され、そのプレスキャン部561では、その画像データから、画像の一部に相当する部分データを抽出し、その部分データに対して、上述した差分符号化部510、オフセット部520、プレーン分割部530、およびランレングス符号化部551の処理と同じ処理を施す。
プレスキャン部561の処理を経たデータはヒストグラム解析部562に入力され、ヒストグラム解析部562では、そのデータ中に出現する全ての数値の出現頻度(ヒストグラム)が求められる。
ヒストグラム解析部562によって求められたデータヒストグラム(数値の出現頻度)はテーブル作成部563に渡され、テーブル作成部563では、そのデータヒストグラムに基づき、被圧縮データの圧縮に最適なハフマンテーブルを、Lプレーン圧縮部540およびHプレーン圧縮部550それぞれ用に作成される。
このように作成された作成されたハフマンテーブルは、Lプレーン圧縮部540およびHプレーン圧縮部550それぞれのハフマン符号化部541,553に渡され、それらのハフマン符号化部541,553では、その渡されたハフマンテーブルに従ってハフマン符号化が行われ、下位圧縮データD2Lおよび上位圧縮データD2Hが出力される。
このようにLプレーン圧縮部540およびHプレーン圧縮部550のそれぞれから出力される下位圧縮データD2Lと上位圧縮データD2Hとの組は、元々の画像データが可逆圧縮された可逆圧縮データを構成し、この可逆圧縮データは、図1に示すSCSI等の汎用インターフェース150を経由してインターフェース機器200に転送される。インターフェース機器200では、その受け取った可逆圧縮データにデータ伸長処理が施されるが、このデータ伸長処理にあたっては、図3で説明した各種の符号化処理に対応する復号化処理が施されて元の入力画像ファイル中の画像データと同一の画像データが復元される。
図4は、図1に示すホストコントローラのハードウェア構成図である。
図1に示すホストコントローラ100は、図4に示す構成のコンピュータシステムで構成されている。
この図4に示す、コンピュータシステムで構成されたホストコントローラ100には、CPU111、RAM112、通信インターフェース113、ハードディスクコントローラ114、FDドライブ115、CDROMドライブ116、マウスコントローラ117、キーボードコントローラ118、ディスプレイコントローラ119、および通信用ボード120が備えられており、これらはバス110で相互に接続されている。
ハードディスクコントローラ114は、このホストコントローラ100に内蔵されているハードディスク104のアクセスを制御するものであり、FDドライブ115、CDROMドライブ116は、このホストコントローラ100に取出し自在に装填されるフレキシブルディスク(FD)130、CDROM140のアクセスを制御するものである。また、マウスコントローラ117、キーボードコントローラ118は、このホストコントローラ100に備えられたマウス107、キーボード108の操作を検出してCPU111に伝達する役割を担っている。さらに、ディスプレイコントローラ119は、このCPU111の指示に基づいて、ホストコントローラ100に備えられた画像ディスプレイ109の表示画面上に画像を表示する役割を担っている。
通信用ボード120は、SCSI等の汎用インターフェースプロトコルに準拠した通信を担っており、圧縮後の画像データをインターフェースケーブル150を介してインターフェース機器200(図1参照)に転送する役割を担っている。
さらに、通信用インターフェース113は、インターネット等の汎用の通信を担っており、このホストコントローラ100は、この通信用インターフェース113を経由して画像データを取り込むこともできる。
RAM112には、ハードディスク104に格納されているプログラムが読み出されてCPU111での実行のために展開され、CPU111では、そのRAM112に展開されたプログラムが読み出されて実行される。
図5は、本発明のデータ圧縮プログラムの一実施形態に相当する画像圧縮処理プログラムの模式構成図である。
ここでは、この画像圧縮プログラム600は、CDROM140に記憶されている。
この画像圧縮プログラム600は、差分符号化部610、オフセット部620、プレーン分割部630、Lプレーン圧縮部640、Hプレーン圧縮部650、および最適ハフマンテーブル生成部660から構成されている。このCDROM140には、ここに示す画像圧縮プログラム600のほか、図1に示すホストコントローラ100における一連の処理を実行するための各種プログラムが記憶されているが、それらについては従来と同様であるため図示および説明は省略する。
この図5に示すCDROM140が、図4に示すホストコントローラ100に装填されCDROMドライブ116でアクセスされてそのCDROM140に記憶されているプログラムがこのホストコントローラ100にアップロードされ、ハードディスク104に記憶される。このハードディスク104に記憶されたプログラムがそのハードディスク104から読み出されてRAM112に展開されCPU111で実行されると、このホストコントローラ100は、図3に示す画像圧縮装置500としての処理を含む、ホストコントローラとしての各種処理を実行する装置として動作する。
ここで、図5に示す画像圧縮プログラム600は、ホストコントローラ100にインストールされてCPU111で実行されることにより、そのホストコントローラ100内に図3に示す画像圧縮装置500を実現するものであり、差分符号化部610、オフセット部620、プレーン分割部630、Lプレーン圧縮部640、Hプレーン圧縮部650、および最適ハフマンテーブル生成部660は、CPU111で実行されることにより、そのホストコントローラ100を、図3に示す画像圧縮装置500を構成する、それぞれ、差分符号化部510、オフセット部520、プレーン分割部530、Lプレーン圧縮部540、Hプレーン圧縮部550、および最適ハフマンテーブル生成部560として動作させるプログラム部品である。つまり、これらのプログラム部品により、画像圧縮装置500の構成要素がホストコントローラ100上に実質的に構築されることとなる。
図5の画像圧縮プログラム600を構成する各部610〜660の、CPU111で実行されたときの作用は、それぞれ、図3の画像圧縮装置500を構成する各部510〜560の作用そのものである。したがって、図3の画像圧縮装置500の各部510〜560に関する、これまでの説明、および、以下に説明する詳細説明をもって、図5の画像圧縮プログラム600を構成する各部610〜660の説明を兼ねるものとする。
図6は、図3のデータ圧縮装置500に入力される入力画像ファイル中の画像データのデータ構造を示す図である。
図6に示すように、図3に示すデータ圧縮装置500に入力される画像データは、所定の主走査方向に画素がM個並んでいる。その主走査方向とは直角な副走査方向に教えていったときのN番目のラインについて、主走査方向に並ぶ各画素の画素値は、その並び順に、
n,1,Dn,2,…,Dn,m-2,Dn,m-1,Dn,m
と表現される。
これと同様に、副走査方向の(N+1)番目のラインについて、主走査方向に並ぶ各画素の画素値は、その並びの順に、
n+1,1,Dn+1,2,…,Dn+1,m-2,Dn+1,m-1,Dn+1,m
と表現される。
ここで、図3に示すデータ圧縮装置500を構成する差分符号化部510には、上記のような画像データが入力されて2次元差分符号化処理が施され、主走査方向に隣接する画素どうしの差分における副走査方向での更なる差分が求められる。
この2次元差分符号化処理を具体的に説明する。
図7は、図3のデータ圧縮装置500を構成する差分符号化部510における2次元差分符号化処理を例示して示す図である。
この図の左側(パート(A))に示す各数値のうち、四角で囲われた数値「12 18 09 1A … 01 03 07 F0 …」が画像データを構成する画素値であり、丸で囲まれた数値「12 18 09 1A … 01 FC 15 D8 …」が2次元差分符号化処理で出力される出力値である。以下の説明では、主走査方向(図の横方向)に並ぶ画素を「ライン」と称する。
2次元差分符号化処理では、先ず、1ライン目の各画素値「12 18 09 1A …」については、そのまま出力する。また、主走査方向に隣接する画素値どうしの差分「18−12=06」「09−18=EF」…が算出される。ここで、例えば「09」から「18」を引き算した結果は負の数となり、9ビットで「1EF」と表わされるが、MSBの1ビットである「1」は省略し、下位8ビットである「EF」のみを出力する。
次に、2ライン目については、先頭の画素値「01」のみがそのまま出力され、主走査方向に隣接する画素値どうしの差分「03−01=02」「07−03=04」…が算出される。そして、1ライン目の差分「06 EF 11 …」と2ライン目の差分「02 04 E9 …」との更なる差分「02−06=FC」「04−EF=15」…が求められて出力される。
次に、3ライン目についても2ライン目と同様に処理されて、3ライン目の先頭の画素値「73」のみがそのまま出力され、主走査方向に隣接する画素値どうしの差分「60−73=ED」「40−60=E0」…が算出される。そして、2ライン目の差分「02 04 E9 …」と3ライン目の差分「ED E0 F0 …」との更なる差分「ED−02=EB」「E0−04=DC」…が求められて出力される。
以下、これと同じ演算を繰り返すことにより、図7で丸が付いた数値「12 18 09 1A … 01 FC 15 D8 …73 EB DC 07 … FF 07 BB 13 …」が出力される。
図1に示すインターフェース機器200では、このように2次元差分符号化されたデータを復号化するにあたり、図7の右側(パート(B))に示す演算が行なわれる。
先ず1ライン目の各画素値は「12 18 09 1A …」のそのままである。
また、2ライン目以降の各ラインの先頭画素値も「01」「73」「FF」…のそのままである。
ここで、2ライン目の2番目以降の差分値「FC 15 D8 …」を例として、差分値から元の画素値が復号化される手順について説明する。
画素値の復号化に際しては、対象画素に対し、同ラインの前位置(図の左側)の画素と、前ライン(図の上側)の同位置の画素と、前ラインの前位置の画素との3つの画素それぞれにおける3つの画素値が用いられる。
2ライン目の2番目の画素の差分値「FC」については、1ライン目の先頭画素の画素値「12」と、1ライン目の2番目の画素の画素値「18」と、2ライン目の先頭画素の画素値「01」が用いられ、まず、1ライン目の2番目と先頭との差分「18−12=06」が求められる。そして、その差分「06」が対象の差分値「FC」に加算された結果のうちの下位8ビットで表わされる「02」が得られ、その値「02」に2ライン目の先頭画素の画素値「01」が加算された結果のうちの下位8ビットで表わされる「03」が2ライン目の2番目の画素値として復号化される。
2ライン目の3番目の画素値は、差分値「15」に、1ライン目の3番目と2番目との差分「09−18=EF」が加算された結果のうちの下位8ビットで表わされる「04」に、更に2ライン目の2番目の画素値「03」が加算された結果のうちの下位8ビットで表わされる「07」である。
2ライン目の4番目の画素値は、差分値「D8」に、1ライン目の4番目3番目との差分「1A−09=11」が加算された結果のうちの下位8ビットで表わされる「E9」に、更に2ライン目の3番目の画素値「07」が加算された結果のうちの下位8ビットで表わされる「F0」である。
以下これと同様の演算を繰り返すことにより、各差分値が、2次元差分符号化を行なう前の画素値と同一の画素値に復号化される。
図3の差分符号化部510では、以上説明したような2次元差分符号化が画像データに施される。この2次元差分符号化によって得られるデータは、図3のオフセット部520に入力され、そのデータの各数値について所定のオフセット値が加算される。
ここで、このような差分符号化およびオフセットの効果について、具体的なCTの画像データを例に用いて説明する。
図8は、CTの画像データの例を示す図である。
この図8のパート(A)には、CTの画像データが表しているCT画像の一例としてモノクロの風景画像が示されており、本実施形態では、このようなCT画像の各画素における色の濃度が8ビットの数値で表現された画像データが用いられる。図8のパート(B)には、パート(A)に示す風景画像を表す画像データにおけるデータ値のヒストグラムが示されており、このヒストグラムの横軸はデータ値、縦軸はデータ数(画素数)を表している。CT画像では一般に、ヒストグラムの幅が広く、ヒストグラム中でデータ数の山谷は生じてもヒストグラムの途中にデータ数が「0」の領域が生じることは極めてまれである。
図9は、CTの画像データに対する差分符号化およびオフセットの効果を示す図である。
この図9のパート(A)には、図8に示したCTの画像データに対して差分符号化が施されて得られるデータのヒストグラムが示されており、このヒストグラムの横軸はデータ値、縦軸は出現頻度を表している。CTの画像データに対して、図6および図7で説明した差分符号化が施されると、データのヒストグラムは、一般に、この図9のパート(A)に示すような、最小データ値と最大データ値の双方に鋭いピークを有するヒストグラムとなる。そして、このようなデータに対してオフセットが施されると、データのヒストグラムは、図9のパート(B)に示すような、オフセット値のところに鋭いピークを持つヒストグラムとなる。本実施形態ではオフセット値として「8」が用いられており、オフセットの結果、値が「16」以上となるデータの頻度はほとんど「0」となっている。
このように差分符号化およびオフセットによってヒストグラムが変形されたデータは、図3のプレーン分割部530によって下位サブプレーンと上位サブプレーンとに分割される。
図10は、プレーン分割部530によるデータ分割の効果を説明する図である。
この図10には、図9のパート(B)に示すヒストグラムがデータ値「15」とデータ値「16」との間で切り離されたヒストグラムが示されており、図3のプレーン分割部530によるデータ分割は、まさにこのようなヒストグラムの分割に相当する効果を生じる。すなわち、本実施形態では、データを構成している8ビットの各数値が上位4ビットと下位4ビットとに分割されることで、下位4ビットが表す数値の連続からなる下位サブプレーンと上位4ビットが表す数値の連続からなる上位サブプレーンとが得られる。そして、下位サブプレーンを構成する4ビットの数値が値「0」から値「15」までの各数値をそのまま表現していて、上位サブプレーンを構成する4ビットの数値の場合は、値「16」から値「256」までの、16間隔16種類の数値を表現していると解釈すると、下位サブプレーンのヒストグラムは、この図10の左側に示されたヒストグラムとほぼ同じものとなり、上位サブプレーンのヒストグラムは、図10の右側に示されたヒストグラムとほぼ同じものとなる。ただし、上位サブプレーンのヒストグラムについては、図10の右側に示されたヒストグラムのデータ値「16」のところに、図10の左側に示されたヒストグラムの面積に等しい高さのピークが付加されたものとなる。
このような上位サブプレーンは、図3に示すHプレーン圧縮部550を構成するランレングス符号化部551に入力される。
本実施形態では、処理の都合上、ランレングス符号化部551で、上位サブプレーンを構成する連続した4ビットの数値が2つで1つの8ビットの数値として取り扱われ、16進数表示で値「00」から値「FF」までの数値の連続に対して以下の符号化処理が適用される。
この符号化処理では、複数の8ビットの数値のうちの特定の数値についてのみ符号化処理が行なわれる。このため、このランレングス符号化部551では、受け取ったデータの中から、符号化処理を行なう数値(ここでは、この数値を「圧縮対象数値」と称する)と、その圧縮対象数値の連続数が検出される。
本実施形態では、一例として、「01」、「FF」および「00」の3つの数値を圧縮対象数値としている。
図11は、図3に示すランレングス符号化部551での符号化の説明図である。
図11の上のラインは、上位サブプレーンを構成するデータ、下のラインは、ランレングス符号化部551での符号化処理を行なった後のデータである。
ここでは、図11の上のラインに示すように、量子化処理部551からは、
「06 02 02 02 01 01 01 01 04 05 00 … 」
なるデータが入力されたものとする。このとき、図3のランレングス符号化部551では、先頭の「06」は圧縮対象数値ではなく、次に続く「02 02 02」も圧縮対象数値ではなく、次に、圧縮対象数値である「01」が4つ連続していること、次に、圧縮対象数値ではない「04」、「05」を間に置いて、圧縮対象数値である「00」が32767個連続していることが検出される。
図12は、ランレングス符号化部における、圧縮対象数値を対象にした符号化のアルゴリズムを示す図である。
この図12中、Zは同一の圧縮対象数値の連続数、例えば図11の上のラインの「01」についてはZ=4、「00」についてはZ=32767である。
また、図12中、「YY」は、16進2桁で表わされた圧縮対象数値自体を表わしている。その「YY」に続く、「0」又は「1」は1ビットで表現された「0」又は「1」であり、さらにそれに続く「画像圧縮装置…」は、1つの「X」が1ビットを表わしており、この「画像圧縮装置…」でZの値を表現している。
すなわち、図12は、圧縮対象数値「YY」がZ<128連続するときは、1バイト目で圧縮対象数値「YY」を表現し、それに続く1バイトで、先頭ビットが「0」、それに続く7ビットでZの値を表現すること、また、圧縮対象数値「YY」がZ≧128連続するときは、1バイト目で圧縮対象数値「YY」を表現し、それに続く2バイト(16ビット)のうちの先頭の1ビットを「1」とすることで2バイトに跨って表現されていることを表現し、それに続く15ビットで、Zの値を表現することを意味している。
この図12に示す規則に従って図11に示す符号化の例について説明する。
図3のプレーン分割部530から入力されてきた上位サブプレーンのデータ(上のライン)を構成する先頭の数値「06」は圧縮対象数値ではないため、その「06」のまま出力される。また、それに続く「02 02 02」も、「02」は圧縮対象数値ではなく、これら3つの「02」もそのまま出力される。次に、圧縮対象数値である「01」が4個連続するため、「01 04」に符号化される。次の「04」及び「05」は圧縮対象数値ではないため、そのまま「04 05」が出力される。
次に「00」が32767個連続しているため、「00」を置き、次の1バイトのうちの先頭の1ビットを「1」とし、次いで15ビットで32767−128を表現することにより、「00 FF 7F」の3バイトで「00」が32767個連続していることを表現する。すなわち、連続数128は、最初のビット「1」を除き、「00 00」と表現される。
図13は、図3のランレングス符号化部551における、連続数に応じた符号化処理の例を示す図である。
・「00」が127個連続するときは、2バイトを用いて「00 7F」に符号化され、
・「00」が32767個連続するときは、3バイトを用いて「00 FF 7E」に符号化され、
・「00」が32895個連続するときは、3バイトを用いて「00 FF FF」に符号化され、
・「00」が128個連続するときは、3バイトを用いて「00 80 00」に符号化され、
・「FF」が4096個連続するときは、3バイトを用いて「FF 8F 80」に符号化される。
図3に示すランレングス符号化部551では、上記のような符号化処理が行なわれる。
本実施形態によるランレングス符号化部551によれば、最大圧縮率は、3/32895=1/10,965にまで向上する。また、このランレングス符号化部551が符号化処理の対象としている上位サブプレーンのデータは、図10のヒストグラムで説明したように、4ビットの数値のほとんどが、データ値「16」を表現した数値「0」であり、その4ビットの数値から作られる8ビットの数値も、多くが、16進数表示で数値「00」となる。このためランレングス符号化部551における符号化処理によって大幅なデータ圧縮が期待される。
図3のランレングス符号化部551で上記の符号化処理の行なわれた後のデータは、次に図3のHプレーン圧縮部550を構成するハフマン符号化部553に入力される。このハフマン符号化部553では、各画像データに最適化されたハフマンテーブルが用いられるがそのような最適化の手順についての説明は後に回し、ここでは、ハフマンテーブルの概念について説明する。
図14は、ハフマンテーブルにおける符号と数値の対応関係を表す概念図である。
ここでは、「A1」の出現頻度が最も強く、以下順に、「A2」、「A3」、「A4」、…の順であるとする。尚、これら「A1」、「A2」等は数値を直接表わしている訳ではなく、数値を表わす記号である。すなわち、「A1」は例えば数値「00」、「A2」は数値「FF」等である。また、ここでは、簡単のため、図3のランレングス符号化部551から送られてくるデータは全てのデータ値が「A1」〜「A16」の16個の数値のうちのいずれかの数値であるものとする。そして、このような16個の数値それぞれに対して、出現頻度に応じた符号が割り当てられてハフマンテーブルが作成されている。即ち、出現頻度の最も高い「A1」には、2ビットで表わされた符号「00」が割り当てられ、次の「A2」には、やはり2ビットで表わされた符号「01」が割り当てられ、次の「A3」、さらに次の「A4」には、3ビットで表わされる、それぞれ、符号「100」、符号「101」が割り当てられ、次の「A5」〜「A8」には、5ビットで表わされる各符号が割り当てられ、以下同様に、出現頻度が低い数値ほど多くのビット数で表わされた符号が割り当てられている。
図15は、ハフマンテーブルの概念を表す図である。
このハフマンテーブルは、図14と一致させてあり、出現頻度が高い数値ほど短かいビット数で表わされた符号に置き換えられるように並べられた、符号化前(置き換え前)の数値と符号化後(置き換え後)の数値との対応テーブルである。
図3のHプレーン圧縮部550を構成するハフマン符号化部553では、このようなハフマンテーブルに従ってデータの数値が符号化され、その結果、多くの数値が短かいビット数の符号に置き換えられることとなってデータ圧縮が実現される。
このように、図3のHプレーン圧縮部550に入力される上位サブプレーンD1Hについては、ランレングス符号化部551による符号化とハフマン符号化部553による符号化が施されることにより高い圧縮率で圧縮されて上位圧縮データD2Hとなる。
図3のLプレーン圧縮部540のハフマン符号化部541では、Hプレーン圧縮部550のランレングス符号化部551と同様に、4ビットの数値の2つ分が1つの8ビットの数値とみなされて処理される。また、このハフマン符号化部541による符号化処理では、Lプレーン用のハフマンテーブルが用いられる点を除いて、Hプレーン圧縮部550のハフマン符号化部553による符号化処理と同様な処理が実行される。この結果、下位サブプレーンD1Lは下位圧縮データD2Lとなる。
ここで、ハフマンテーブルを個々の画像データに対して最適化する手順と最適化の効果について説明する。
図3の最適ハフマンテーブル生成部560には、上述した差分符号化部510に入力された画像データと同じ画像データが入力される。
最適ハフマンテーブル生成部560に入力された画像データは、先ず、プレスキャン部561に渡され、そのプレスキャン部561では、その画像データから、画像の一部に相当する部分データを抽出する。部分データの抽出は、画像の各部に及ぶが1箇所から抽出される部分データは所定数の画素の塊(例えば8画素×8画素)となっている。本実施形態では、元の画像データの総画素のうち約100分の1程度の画素に相当する部分データが抽出される。そして、プレスキャン部561では、そのように抽出したその部分データに対して、上述した差分符号化部510、オフセット部520、およびプレーン分割部530における処理と同様の処理を施して上位データと下位データを作成する。また、上位データに対しては、上述したランレングス符号化部551の処理と同じ処理を施す。
このようにして得られた処理後の上位データと下位データは図3のヒストグラム解析部562に入力され、ヒストグラム解析部562では、各データ中に出現する全ての数値の出現頻度(ヒストグラム)が求められる。このヒストグラムは、元の画像データの約100分の1程度の部分データに基づいたものではあるが、その部分データは、元の画像データが表す画像の各部から抽出されたものであるので、個々の画像におけるデータ分布の特徴を十分に反映したものとなっている。ここで求められるデータヒストグラムは、個々の画像の特徴に応じて、ピークの幅や裾野の伸び方などが異なったものとなる。
ヒストグラム解析部562によって求められたデータヒストグラム(数値の出現頻度)はテーブル作成部563に渡され、テーブル作成部563では、そのデータヒストグラムにおけるデータ分布の特徴に適した符号列がハフマンテーブルに用意される。
図16および図17は、ハフマンテーブルに用意される符号列の例を示す図である。
図16は、データがピークに特に集中した場合の例で、図17は、ピークの裾野がやや広い場合の例である。
ここでは各符号列中の「,」よりも右側の一桁の数値がビット長を意味しており、その「,」の左から右側に向かってそのビット長分の2進符号が実際の符号を表わしている。例えば、図16の符号列の場合、左上の第1番目の符号は「11」の2ビット、次の2番目の符号は「011」の3ビット、その次の3番目の符号は「010」の3ビット、さらにその次の4番目の符号は「1010」の4ビットである。
図16の符号列の場合には、3番目までは3ビット以下の非常に短い符号であるが、12番目以降は9ビット以上の長い符号となっている。これに対し、図17の符号列の場合には、3ビット以下の非常に短い符号は1番目のみであるが、13番目までは6ビット以下のそれなりに短い符号となっている。
このような符号列が上位データと下位データのそれぞれについて用意され、次に、その符号列に対して数値が割り当てられてハフマンテーブルが完成する。この数値の割当の概念は図14を参照して説明した概念そのものであるので重複説明は省略する。
このような最適ハフマンテーブル生成部560によるハフマンテーブルの作成は、元のデータの100分の1程度の部分データに基づくので、短時間で実行される。また、画像データの圧縮は、通常、画像を8ライン毎に分けて順次に実行されるが、ハフマンテーブルとしては画像全体に対して1つのテーブルを用意することが必要である。上述の最適ハフマンテーブル生成部560によれば、いわば別ルートでハフマンテーブルが作成されるので、画像の最初の8ラインに対しても、画像全体の特徴が反映された最適なハフマンテーブルで符号化処理が可能となる。
このように最適ハフマンテーブル生成部560で作成されたハフマンテーブルが、Lプレーン圧縮部540およびHプレーン圧縮部550それぞれのハフマン符号化部541,553に渡されて、上述したようにハフマン符号化が行われる。
図18は、最適化されたハフマンテーブルが用いられることによるデータ圧縮の効果を示す図である。
この図18には、10種類の典型的なCT画像のデータに対する圧縮率が示されており、比較のために、従来の圧縮技術のうちで特に高い圧縮率が得られる圧縮方式として知られている、可逆圧縮方式のJPEG2000による圧縮率も示されている。また、この図18のパート(A)には、図16に示した符号列が固定的に用いられた場合の圧縮率が示されており、パート(B)には、各画像データに適した符号列が用いられた場合の圧縮率が示されている。なお、圧縮率は、元のデータを100%とする率で表現されており、いわゆる「高い圧縮率」とは、圧縮率の数値が小さいことを意味している。
図18のパート(A)に示すように、符号列が固定的である場合には、JPEG2000による圧縮率にかなり迫っているものの、5%〜10%程度の差が残っている。これに対し、各画像データに適した符号列が用いられた場合には、図18のパート(B)に示すように、JPEG2000による圧縮率に対してほぼ遜色のない程度にまで迫っており、可逆圧縮にもかかわらず高い圧縮率が実現されている。
以上説明したような各種の処理が図3に示す画像圧縮装置500の各部で実行されることにより、画像圧縮装置500は、画像データを可逆圧縮によって圧縮することができ、特にCT画像のデータについては大幅な圧縮が実現される。
なお、上記説明では、本発明の実施形態としてのデータ圧縮がCT画像のデータのみに施される例が示されているが、本発明のデータ圧縮装置は、CT画像とLW画像との双方のデータに対してデータ圧縮を施すものであってもよく、さらには、画像以外の情報を表したデータに対してデータ圧縮を施すものであってもよい。
また、上記説明では、本発明にいう差分生成部の一例として、2次元差分符号化処理を行うものが示されているが、本発明にいう差分生成部は、主走査方向や副走査方向の1次元的な差分を求めるものであってもよい。
データ圧縮技術が適用されたプリントシステムの一例を示す図である。 プリントシステムにおけるデータ処理の流れを示す図である。 本発明のデータ圧縮装置の一実施形態に相当する画像圧縮装置を示すブロック構成図である。 図1に示すホストコントローラのハードウェア構成図である。 本発明のデータ圧縮プログラムの一実施形態に相当する画像圧縮処理プログラムの模式構成図である。 図3のデータ圧縮装置に入力される入力画像ファイル中の画像データのデータ構造を示す図である。 図3のデータ圧縮装置を構成する差分符号化部における2次元差分符号化処理を例示して示す図である。 CTの画像データの例を示す図である。 CTの画像データに対する2次元差分符号化およびオフセットの効果を示す図である。 プレーン分割部によるデータ分割の効果を説明する図である。 図3に示すランレングス符号化部での符号化の説明図である。 ランレングス符号化部における、圧縮対象数値を対象にした符号化のアルゴリズムを示す図である。 図3のランレングス符号化部における、連続数に応じた符号化処理の例を示す図である。 ハフマンテーブルにおける符号と数値の対応関係を表す概念図である。 ハフマンテーブルの概念を示す図である。 ハフマンテーブルに用意される符号列の例を示す図である。 ハフマンテーブルに用意される符号列の別の例を示す図である。 最適化されたハフマンテーブルが用いられることによるデータ圧縮の効果を示す図である。
符号の説明
11 画像のデータ
12A,12B,13A,13B ビットマップデータ
14 非可逆の圧縮データ
15 可逆の圧縮データ
100 ホストコントローラ
140 CDROM
150 汎用インターフェースケーブル
200 インターフェース機器
250 専用インターフェースケーブル
300 プリンタ
500 画像圧縮装置
510 差分符号化部
520 オフセット部
530 プレーン分割部
540 Lプレーン圧縮部
541 ハフマン符号化部
542 モード切換部
550 Hプレーン圧縮部
551 ランレングス符号化部
552 データスキャニング部
553 ハフマン符号化部
560 最適ハフマンテーブル生成部
561 プレスキャン部
562 ヒストグラム解析部
563 テーブル作成部
600 画像圧縮プログラム
610 差分符号化部
620 オフセット部
630 プレーン分割部
640 Lプレーン圧縮部
650 Hプレーン圧縮部
660 最適ハフマンテーブル生成部

Claims (10)

  1. 所定の単位ビット数で表わされる数値の連続からなる被圧縮データにデータ圧縮処理を施すデータ圧縮装置において、
    被圧縮データを構成する数値の連続について隣接する数値どうしの差分を求めることにより該差分を表わす数値の連続からなる新たな被圧縮データを生成する差分生成部と、
    前記差分生成部によって生成された新たな被圧縮データを構成する各数値を所定値だけオフセットさせるオフセット部と、
    前記オフセット部によって数値がオフセットされた被圧縮データの各数値を、前記単位ビット数よりも小さい所定の分割ビット数のところで上位ビット部分と下位ビット部分とに分けることによって、該被圧縮データを、各数値における上位ビット部分の連続からなる上位データと各数値の下位ビット部分の連続からなる下位データとに分割する分割部と、
    前記分割部によって分割された上位データに対して可逆圧縮処理を施す上位データ圧縮部と、
    前記分割部によって分割された下位データに対して、符号と数値を対応づけるテーブルを用いてエントロピー符号化を施す符号化処理を含む可逆圧縮処理を施す下位データ圧縮部と、
    前記下位データ圧縮部における可逆圧縮処理に先だって、前記テーブルに、前記エントロピー符号化が施される被圧縮データ中で出現頻度の高い数値ほど符号長の短かい符号を割り当てる割当部とを備えたことを特徴とするデータ圧縮装置。
  2. 前記下位データ圧縮部が、前記符号化処理として、ハフマンテーブルを用いてハフマン符号化を施す符号化処理を行うものであり、
    前記割当部が、前記下位データ圧縮部のハフマンテーブルに符号を割り当てるものであることを特徴とする請求項1記載のデータ圧縮装置。
  3. 前記割当部が、画像を表す被圧縮データ中の、該画像の一部分に相当する数値を分析することによって前記出現頻度を求めるものであることを特徴とする請求項1記載のデータ圧縮装置。
  4. 前記割当部が、画像を表す被圧縮データ中の、該画像の一部分に相当する数値に対し、前記差分生成部、前記オフセット部、および前記分割部のそれぞれにおける処理と同等の処理を施して分析用データを作成し、その分析用データを分析することによって前記出現頻度を求めるものであることを特徴とする請求項1記載のデータ圧縮装置。
  5. 前記上位データ圧縮部が、前記上位データに対して、符号と数値を対応づけるテーブルを用いてエントロピー符号化を施す符号化処理を含む可逆圧縮処理を施すものであり、
    前記割当部が、画像を表す被圧縮データ中の、該画像の一部分に相当する数値を分析することによって、前記上位データ圧縮部および前記下位データ圧縮部の各被圧縮データにおける数値の出現頻度を求め、それらの出現頻度に基づいて、前記上位データ圧縮部と前記下位データ圧縮部とのそれぞれにおける前記テーブルに、出現頻度の高い数値ほど符号長の短かい符号を割り当てるものであることを特徴とする請求項1記載のデータ圧縮装置。
  6. 前記上位データ圧縮部が、前記上位データに対して、符号と数値を対応づけるテーブルを用いてエントロピー符号化を施す符号化処理を含む可逆圧縮処理を施すものであり、
    前記割当部が、画像を表す被圧縮データ中の、該画像の一部分に相当する数値に対し、前記差分生成部、前記オフセット部、および前記分割部のそれぞれにおける処理と同等の処理を施して分析用データを作成し、その分析用データを分析することによって、前記上位データ圧縮部および前記下位データ圧縮部の各被圧縮データにおける数値の出現頻度を求め、それらの出現頻度に基づいて、前記上位データ圧縮部と前記下位データ圧縮部とのそれぞれにおける前記テーブルに、出現頻度の高い数値ほど符号長の短かい符号を割り当てるものであることを特徴とする請求項1記載のデータ圧縮装置。
  7. 前記上位データ圧縮部が、前記符号化処理として、ハフマンテーブルを用いてハフマン符号化を施す符号化処理を行うものであり、
    前記割当部が、前記上位データ圧縮部のハフマンテーブルに符号を割り当てるものであることを特徴とする請求項5または6記載のデータ圧縮装置。
  8. 前記上位データ圧縮部が、上位データ中、1つもしくは複数の所定の圧縮対象数値を除く数値についてはそのまま出力するとともに、圧縮対象数値については、該圧縮対象数値と、該圧縮対象数値と同一の圧縮対象数値の連続数を表わす数値とに符号化して出力する第1の符号化部を備えたものであることを特徴とする請求項1記載のデータ圧縮装置。
  9. 前記下位データ圧縮部が、圧縮省略の指示を受けて下位データを無圧縮で出力するものであることを特徴とする請求項1記載のデータ圧縮装置。
  10. プログラムを実行する情報処理装置内に組み込まれて該情報処理装置に、所定の単位ビット数で表わされる数値の連続からなる被圧縮データに対するデータ圧縮処理を実行させるデータ圧縮プログラムにおいて、
    前記情報処理装置上に、
    被圧縮データを構成する数値の連続について隣接する数値どうしの差分を求めることにより該差分を表わす数値の連続からなる新たな被圧縮データを生成する差分生成部と、
    前記差分生成部によって生成された新たな被圧縮データを構成する各数値を所定値だけオフセットさせるオフセット部と、
    前記オフセット部によって数値がオフセットされた被圧縮データの各数値を、前記単位ビット数よりも小さい所定の分割ビット数のところで上位ビット部分と下位ビット部分とに分けることによって、該被圧縮データを、各数値における上位ビット部分の連続からなる上位データと各数値の下位ビット部分の連続からなる下位データとに分割する分割部と、
    前記分割部によって分割された上位データに対して可逆圧縮処理を施す上位データ圧縮部と、
    前記分割部によって分割された下位データに対して、符号と数値を対応づけるテーブルを用いてエントロピー符号化を施す符号化処理を含む可逆圧縮処理を施す下位データ圧縮部と、
    前記下位データ圧縮部における可逆圧縮処理に先だって、前記テーブルに、前記エントロピー符号化が施される被圧縮データ中で出現頻度の高い数値ほど符号長の短かい符号を割り当てる割当部とを構築することを特徴とするデータ圧縮プログラム。
JP2005091483A 2005-02-07 2005-03-28 データ圧縮装置およびデータ圧縮プログラム Active JP4377351B2 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2005091483A JP4377351B2 (ja) 2005-03-28 2005-03-28 データ圧縮装置およびデータ圧縮プログラム
US11/345,546 US7183950B2 (en) 2005-02-07 2006-02-02 Data compression apparatus, and data compression program storage medium

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2005091483A JP4377351B2 (ja) 2005-03-28 2005-03-28 データ圧縮装置およびデータ圧縮プログラム

Publications (2)

Publication Number Publication Date
JP2006279208A JP2006279208A (ja) 2006-10-12
JP4377351B2 true JP4377351B2 (ja) 2009-12-02

Family

ID=37213539

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2005091483A Active JP4377351B2 (ja) 2005-02-07 2005-03-28 データ圧縮装置およびデータ圧縮プログラム

Country Status (1)

Country Link
JP (1) JP4377351B2 (ja)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008147805A (ja) * 2006-12-07 2008-06-26 Nec Corp データ圧縮装置とその方法、データ伸張装置とその方法およびプログラム
JP2014082660A (ja) * 2012-10-17 2014-05-08 Dainippon Printing Co Ltd 配列データを圧縮/伸張する方法および装置

Also Published As

Publication number Publication date
JP2006279208A (ja) 2006-10-12

Similar Documents

Publication Publication Date Title
JP4689545B2 (ja) データ圧縮装置およびデータ圧縮プログラム
US7826670B2 (en) Data compression apparatus and data compression program storage medium
US7183950B2 (en) Data compression apparatus, and data compression program storage medium
JP2006121645A (ja) 画像圧縮装置および画像圧縮プログラム
JP2008311792A (ja) 画像符号化装置及びその制御方法
JP4633576B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP3872217B2 (ja) ディザ画像の2値表現処理方法、ディザ画像の圧縮2値表現圧縮解除方法、及びディザ画像の圧縮及び圧縮解除システム
JP4173505B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4377351B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4173498B2 (ja) データ圧縮装置およびデータ圧縮プログラム
US20080025620A1 (en) Data compression apparatus and data compressing program storage medium
JP4131970B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4131969B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4699307B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4579793B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4629512B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4377352B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4181147B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP2005277932A (ja) データ圧縮装置およびデータ圧縮プログラム
JP4435586B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP4741317B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP2005252531A (ja) データ圧縮装置およびデータ圧縮プログラム
JP2005260408A (ja) データ圧縮装置およびデータ圧縮プログラム
JP4633577B2 (ja) データ圧縮装置およびデータ圧縮プログラム
JP2006060490A (ja) 画像圧縮装置および画像圧縮プログラム

Legal Events

Date Code Title Description
A711 Notification of change in applicant

Free format text: JAPANESE INTERMEDIATE CODE: A712

Effective date: 20061215

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20070706

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20090903

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20090908

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20090910

R150 Certificate of patent or registration of utility model

Ref document number: 4377351

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120918

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130918

Year of fee payment: 4

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250