fbpx
维基百科

JPEG

JPEG或稱JPG,是一種針對相片影像而廣泛使用的失真壓縮標準方法,由聯合圖像專家小組(英語:Joint Photographic Experts Group)開發。此團隊創立於1986年,1992年發布了JPEG的標準而在1994年獲得了ISO 10918-1的認定。JPEG與視訊音訊壓縮標準的MPEGMoving Picture Experts Group)很容易混淆,但兩者是不同的組織及標準。

JPEG
由左至右,压缩率越来越高的照片。
扩展名.JPEG, .jpg, .jpe
.jfif, .jfi, .jif(容器)
互联网媒体类型image/JPEG
类型代码英语Type codeJPEG
统一类型标识public.JPEG
开发者聯合圖像專家小組英语Joint Photographic Experts Group
初始版本1992年9月18日,​31年前​(1992-09-18
格式类型破壞性图像格式
网站www.jpeg.org

JPEG本身只有描述如何將一個影像轉換為字节的數據串流(streaming),但並沒有說明這些位元組如何在任何特定的儲存媒體上受封存起來。JPEG的壓縮方式通常是有损压缩,即在壓縮過程中圖像的品質會遭受到可見的破壞,有一種以JPEG為基礎的標準Lossless JPEG是採用無失真的壓縮方式,但Lossless JPEG並沒有受到廣泛的支援。

一個由C-Cube Microsystems等公司所建立的額外標準,稱為JFIFJPEG File Interchange FormatJPEG檔案交換格式,聯合圖像專家小組檔案交換格式)詳細說明如何從一個JPEG串流,產出一個適合於電腦儲存和傳輸(像是在網際網路上)的檔案。在普遍的用法,當有人稱呼一個"JPEG檔案",一般而言他是意指一個JFIF檔案,或有時候是一個Exif JPEG檔案。然而,也有其他以JPEG為基礎的檔案格式,像是JNG

使用JPEG格式壓縮的圖片檔案一般也稱為JPEG Files,最普遍使用的副檔名格式為.jpg,其他常用的副檔名還包括.JPEG.jpe.jfif以及.jifJPEG格式的資料也能受嵌進其他類型的檔案格式中,像是TIFF類型的檔案格式。

JPEG/JFIF全球資訊網上最普遍的用來儲存和傳輸照片的格式。它並適合於線條繪圖(drawing)和其他文字或圖示iconic)的圖形,因為它的壓縮方法用在這些类型的圖形上,得到的結果并不好(PNGGIF通常是用來存储这类的圖形;GIF每个像素只有8位元,並不很適合於存储彩色照片,PNG可以無失真地儲存照片,但是檔案太大的缺点讓它不太适合在網路上传输)。

對於JFIFMIME媒體类型是image/JPEG(定義于RFC 1341)。

JPEG编/解码器示例 编辑

編碼 编辑

JPEG標準中许多選項很少使用,大多数图像软件在创建JPEG文件时使用更简单的JFIF格式。當應用到一個擁有每個像素24位元(24 bits per pixel,紅、藍、綠各有八位元)的輸入時,這邊只有針對更多普遍編碼方法之一的簡潔描述。這個特定的選擇是一種失真資料壓縮方法。

色彩空間轉換 编辑

首先,影像由RGB(紅綠藍)轉換為一種稱為YUV的不同色彩空間。这与模拟PAL制式彩色电视传输所使用的色彩空间相似,但是更类似于MAC电视传输系统运作的方式。但不是模拟NTSC,模拟NTSC使用的是YIQ色彩空间。

YUV分量可以由PAL制系统中归一化(经过伽马校正)的R',G',B'经过下面的计算得到:

  • Y=0.299R'+0.587G'+0.114B'
  • U=-0.147R'-0.289G'+0.436B'
  • V=0.615R'-0.515G'-0.100B'

這種編碼系統非常有用,因為人眼對亮度差異的敏感度高於色彩變化。在此前提下可以设计更加高效压缩图像的編碼器(encoder)。

縮減取樣(Downsampling) 编辑

经过RGB到YUV颜色空间的转换后,开始进行缩减采样来減少U和V的成份(稱為"縮減取樣"或"色度抽样"(chroma subsampling)。在JPEG上這種縮減取樣的比例可以是4:4:4(無縮減取樣),4:2:2(在水平方向2的倍數中取一個),以及最普遍的4:2:0(在水平和垂直方向2的倍數中取一個)。對於壓縮過程的剩餘部份,Y、U、和V都是以非常類似的方式來個別地處理。

離散餘弦變換(Discrete cosine transform) 编辑

 
以8-位元灰階所顯示的8x8子影像

下一步,將影像中的每個成份(Y, U, V)生成三個區域,每一個區域再劃分成如瓷磚般排列的一個個的8×8子區域,每一子區域使用二維的離散餘弦變換(DCT)轉換到頻率空間。

如果有一個如這樣的8×8的8-位元(0~255)子區域:

 

接著推移128,使其範圍變為 -128~127,得到結果為

 

且接著使用離散餘弦變換,和捨位取最接近的整數,得到結果為

 

左上角之相當大的數值称为DC係數(直流系数);其他63个值称为AC系数(交流系数)。下面将对所有8×8表格中的DC系数使用差分编码,对AC系数使用行程编码[1]

量化(Quantization) 编辑

人类眼睛在一個相對大範圍區域,辨別亮度上細微差異是相當的好,但是在一個高頻率亮度變動之確切強度的分辨上,卻不是如此地好。這個事實讓我們能在高頻率成份上極佳地降低資訊的數量。簡單地把頻率領域上每個成份,除以一個對於該成份的常數就可完成,且接著捨位取最接近的整數。這是整個過程中的主要失真運算。以這個結果而言,經常會把很多更高頻率的成份捨位成為接近0,且剩下很多會變成小的正或負數。

一個普遍的量化矩陣是:

 

使用這個量化矩陣與前面所得到的DCT係數矩陣逐項相除,得到結果為:

 

舉個例子,使用−415(DC係數)且捨位得到最接近的整數

 

熵編碼技術(entropy coding) 编辑

 
Z字型掃描矩陣的順序

熵編碼是無失真資料壓縮的一個特別形式。它牽涉到將影像成份以Z字型(zigzag)排列,把相似頻率群組在一起(矩陣中往左上方向是越低頻率之係數,往右下較方向是較高頻率之係數),插入長度編碼的零,且接著對剩下的使用霍夫曼編碼。 JPEG標準也允許(但是並不要求)在數學上優於霍夫曼編碼的算术编码之使用。然而,這個特色幾乎很少獲使用,因為它被專利所涵蓋,且它相較於霍夫曼編碼在編碼和解碼上會更慢。使用算術編碼一般會讓檔案更小約5%。

對於前者量化的係數所作的Z字型序列會是:

−26,
−3, 0,
−3, −2, −6,
2, −4, 1, −3,
1, 1, 5, 1, 2,
−1, 1, −1, 2, 0, 0,
0, 0, 0, −1, −1, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0,
0, 0, 0, 0,
0, 0, 0,
0, 0,
0

當剩下的所有係數都是零,對於過早結束的序列,JPEG有一個特別的霍夫曼編碼用詞。使用這個特殊的編碼用詞,EOB,該序列變為

−26,
−3, 0,
−3, −2, −6,
2, −4, 1 −3,
1, 1, 5, 1, 2,
−1, 1, −1, 2, 0, 0,
0, 0, 0, −1, −1, EOB

壓縮比率與不自然痕跡(artifact) 编辑

 
失真壓縮導致的人為現象(上)與原圖(下),200%放大

按:artifact在這個領域又解釋為赝像、非自然信號、人為現象。

在量化階段時,依照除數的不同,會使結果的壓縮比率可能有很多變化。10:1通常可得到無法使用肉眼分辨與原圖差異的影像。100:1壓縮通常是可行的,但與原圖相較,會看出明顯的不自然痕跡。壓縮的適當等級是依據要壓縮那一種影像而定。

使用全球資訊網的人,可能熟悉這種出現在JPEG數位影像,已知壓縮人為現象的不規則現象。這是由於JPEG演算法的量化步驟所造成的結果。這種現象在臉部照片中的眼睛四周特別明顯。他們可以藉由選擇壓縮的較低水平(使用較低的壓縮率)來減少這種現象;他們可能藉由使用無失真檔案格式來儲存一個影像來消除這種現象,然而針對照片影像,這樣通常會使檔案大小增加。

解碼 编辑

解碼來顯示影像,包含反向作以上所有的過程

取DCT係數矩陣(在把DC係數差異加回去之後)

 

且以前面的量化矩陣乘以它,得到

 

左上角的部份與原本DCT係數矩陣非常接近地相似。使用反向DCT得到一個有數值的影像(仍然受移位128)

 
 
注意原來(上)與解壓縮影像(下)的些微差異,在角落处可以輕易地看出來
 

且對每一個項目加上128

 

這是解壓縮的子影像,且可以用來与原本子影像相比(也可以看右方的影像),藉由取兩者之間的差異(原本—解壓縮)得到誤差值。

 

每個像素大約是5的平均絕對誤差,也就是說, 。誤差在左下角顯而易見,左下方的像素變得比它鄰近右方的像素還更暗。

用法 编辑

JPEG在色調及顏色平滑變化的相片或是寫實繪畫(painting)上可以達到它最佳的效果。在這種情況下,它通常比完全無失真方法作得更好,仍然可以產生非常好看的影像(事實上它會比其他一般的方法像是GIF產生更高品質的影像,因為GIF對於線條繪畫(drawing)和圖示的圖形是無失真,但針對全彩影像則需要極困難的量化)。

照片 编辑

JPEG壓縮的不自然現象可以很好地調和到細微非均勻材質的相片中,因此允許得到更高的壓縮率。

 
低品質(10%),檔案大小為1.7 KB。
 
中等品質(50%),檔案大小為5.7 KB。
 
最高品質(100%),檔案大小為36 KB。

附註:以上的影像並不是IEEE/CCIR/EBU測試影像,且壓縮編碼器的設定並沒有指明或是可以得到。

中等品質的相片只有六分之一的儲存空間,但是幾乎沒有明顯的細節損失或是看得到的人為效果。然而,一旦超過一個某整的壓縮限度,壓縮的影像逐漸地顯現出可以看得到的瑕疵。參考比率失真理論rate distortion theory)的文章有針對這種限度效果的數學上之解釋。

醫學影像:少見的JPEG 12位元支援模式 编辑

有很多醫學的影像系統可以建立和處理12位元JPEG影像。12位元JPEG格式已經是JPEG規格的一部份,但是非常少商业软件程序(或網頁瀏覽器)支援這種不常使用的JPEG格式。

其他失真壓縮的編碼格式 编辑

更新的失真方法,尤其是小波壓縮(wavelet compression),在這些情況下甚至能作得更好。然而,JPEG是一種建立得相當好的標準,擁有很多可使用的軟體,包含自由軟體,因此到2005年它持續獲大量使用。很多小波演算法受到專利保護,要在很多軟體專案中自由地使用他們是困難或是不可能的。

JPEG委員會現在也已經建立其自有的小波基礎標準-JPEG 2000,希望最終能取代原來的JPEG標準。

潛在的專利爭議 编辑

在2002年Forgent Networks主張他擁有且將會履行在JPEG技術上的專利權,起因於一個在1986年已經歸檔的專利(美國專利第4,698,672号)。這個公告已經引起一陣大騷動,令人想起Unisys試圖主張對於GIF影像壓縮標準的權利。

JPEG委員會審慎調查這個在2002年所主張的專利,且發現他們因為前案而無效作廢[2]。其他的也已推斷Forgent並無擁有涵蓋JPEG的專利[3]。儘管如此,在2002年和2004年之間,Forgent藉由把他們的專利授權給某些30家公司,而獲得大約9千萬美元。在2004年4月,Forgent控告31家其他公司來強求更多的授權支付。同年的七月,21家較大的電腦公司組成的協會提出反控告,包含使該專利無效的目標。然而,到2005年7月的時候,這場官司仍然持續中。

JPEG委員會在他的明確目標中有一項,是他們的標準在不支付授權金之下是可以受實作的,且他們已從超過20個大型組織中,得到適當的授權權利給他們即將到來的JPEG 2000標準。

专利案结束 编辑

经过数年的纠缠,于2006年11月,JPEG专利持有者Forgent Networks终于与30家PC厂商结束了侵权官司,代价是PC厂商向Forgent赔款800万美元,而不是Forgent期望的1亿美元。

在与PC厂商大打官司之前,Forgent已经与60多家公司和解,获得的专利费用总额高达1.1亿美元。包括雅虎在内的45家PC厂商拒绝就4698672号专利问题和解,而是选择了对簿公堂,不过其中15家在此之前已经与Forgent和解。

虽然还是赔了款,但PC厂商们并没有输掉官司;虽然没能得到自己想要的大笔美金,Forgent也没有彻底失败。在非盈利性组织美国公共专利基金会(PPF)的协助下,他们设法获得了美国专利和商标局(USPTO)的认可,对Forgent专利的有效性在2月和6月两次重新进行了鉴定,最终法庭限制了Forgent专利的应用范围。而从另一方面看,Forgent的专利也得到了一定的维护,这要比被彻底推翻好得多,Forgent也表示对结果感到很满意。

Forgent CEO Richard Snyder称:“在'672专利的有效期内,我们已经获得了1.1亿多美元。很快,Forgent还会再次有所行动。我们的精力现在已经转移到'746专利上,并等待2007年5月的陪审团裁决,同时我们还会继续促进(分公司)NetSimplicity的软件业务。”[4]

無損耗旋轉(lossless JPEG rotation) 编辑

雖然任何對JPEG圖像的處理都有可能導致因為解壓後再壓縮而引起的損耗,然而,對於簡單的旋轉動作,數學上是可以有辦法使圖像得以旋轉而無損圖像本身的資料。也就是說,有一種方法可以在無需把圖像解壓後才可以旋轉。這是因為JPEG的檔案格式本身是以一個個模塊為單位來壓縮,所以,只需要把模塊重排,再對每個模塊旋轉,就可以達至無損耗的旋轉。

使用者在操作上加以注意。例如:在Adobe Photoshop裡,用戶若要作無損耗旋轉前,必須在載入圖像之後立刻用“Save As...”功能儲存一個備份。然後當圖像旋轉過後,由於Photoshop已掌握了圖像的基本資料,所以在儲存時得以使用原來的設定。若沒有作事先儲存,Photoshop就會把旋轉後的圖像重新計算各項參數,並重新對圖像進行壓縮處理。這樣就會造成資料的損耗。

压缩标准 编辑

JPEG是由国际标准组织(ISO)国际电话电报咨询委员会(CCITT)为静态图像所建立的第一个国际数字图像压缩标准,也是至今一直在使用的、应用最广的图像压缩标准。JPEG由于可以提供有损压缩,因此压缩比可以达到其他传统压缩算法无法比拟的程度。

JPEG的压缩模式有以下几种:

  •  顺序式编码(Sequential Encoding)
 一次将图像由左到右、由上到下顺序处理。
  •  递增式编码(Progressive Encoding)
 当图像传输的时间较长时,可将图像分数次处理,以从模糊到清晰的方式来传送图像(效果类似GIF在网络上的传输)。
  •  无失真编码(Lossless Encoding)
  •  阶梯式编码(Hierarchical Encoding)
 图像以数种分辨率来压缩,其目的是为了让具有高分辨率的图像也可以在较低分辨率的设备上显示。

在Independent JPEG Group所提供的源碼上,有jpegtran程式,就提供了優化Huffman,轉成漸進式,鏡射,旋轉這些無損耗轉換。

參看:無損耗JPEG旋轉程式列表 (页面存档备份,存于互联网档案馆)(英語)

參見 编辑

參考來源 编辑

  1. ^ 吕凤军. 数字图像处理编程入门. 清华大学出版社. 1999. 
  2. ^ . [2011-05-29]. (原始内容存档于2007-07-14). 
  3. ^ 存档副本. [2004-08-17]. (原始内容于2004-08-17). 
  4. ^ JPEG: PC厂商向JPEG专利持有者赔偿800万美元_第三媒体频道. [2013-07-21]. (原始内容于2014-01-08). 

外部連結 编辑

jpeg, 此條目需要补充更多来源, 2012年12月3日, 请协助補充多方面可靠来源以改善这篇条目, 无法查证的内容可能會因為异议提出而被移除, 致使用者, 请搜索一下条目的标题, 来源搜索, 网页, 新闻, 书籍, 学术, 图像, 以检查网络上是否存在该主题的更多可靠来源, 判定指引, 此條目翻譯品質不佳, 翻譯者可能不熟悉中文或原文語言, 也可能使用了機器翻譯, 請協助翻譯本條目或重新編寫, 并注意避免翻译腔的问题, 明顯拙劣的翻譯請改掛, href, template, html, class, redir. 此條目需要补充更多来源 2012年12月3日 请协助補充多方面可靠来源以改善这篇条目 无法查证的内容可能會因為异议提出而被移除 致使用者 请搜索一下条目的标题 来源搜索 JPEG 网页 新闻 书籍 学术 图像 以检查网络上是否存在该主题的更多可靠来源 判定指引 此條目翻譯品質不佳 翻譯者可能不熟悉中文或原文語言 也可能使用了機器翻譯 請協助翻譯本條目或重新編寫 并注意避免翻译腔的问题 明顯拙劣的翻譯請改掛 a href Template D html class mw redirect title Template D d a a href Wikipedia CSD html G13 class mw redirect title Wikipedia CSD G13 a 提交刪除 JPEG或稱JPG 是一種針對相片影像而廣泛使用的失真壓縮標準方法 由聯合圖像專家小組 英語 Joint Photographic Experts Group 開發 此團隊創立於1986年 1992年發布了JPEG 的標準而在1994年獲得了ISO 10918 1 的認定 JPEG 與視訊音訊壓縮標準的MPEG Moving Picture Experts Group 很容易混淆 但兩者是不同的組織及標準 JPEG由左至右 压缩率越来越高的照片 扩展名 tt span lang en JPEG span tt tt span lang en jpg span tt tt span lang en jpe span tt br tt span lang en jfif span tt tt span lang en jfi span tt tt span lang en jif span tt 容器 互联网 媒体类型 tt span lang en image JPEG span tt 类型代码 英语 Type code JPEG统一类型标识public JPEG开发者聯合圖像專家小組 英语 Joint Photographic Experts Group 初始版本1992年9月18日 31年前 1992 09 18 格式类型破壞性图像格式网站www wbr jpeg wbr orgJPEG 本身只有描述如何將一個影像轉換為字节的數據串流 streaming 但並沒有說明這些位元組如何在任何特定的儲存媒體上受封存起來 JPEG 的壓縮方式通常是有损压缩 即在壓縮過程中圖像的品質會遭受到可見的破壞 有一種以JPEG 為基礎的標準Lossless JPEG是採用無失真的壓縮方式 但Lossless JPEG 並沒有受到廣泛的支援 一個由C Cube Microsystems 等公司所建立的額外標準 稱為JFIF JPEG File Interchange Format JPEG 檔案交換格式 聯合圖像專家小組檔案交換格式 詳細說明如何從一個JPEG 串流 產出一個適合於電腦儲存和傳輸 像是在網際網路上 的檔案 在普遍的用法 當有人稱呼一個 JPEG 檔案 一般而言他是意指一個JFIF 檔案 或有時候是一個Exif JPEG 檔案 然而 也有其他以JPEG 為基礎的檔案格式 像是JNG 使用JPEG 格式壓縮的圖片檔案一般也稱為JPEG Files 最普遍使用的副檔名格式為 jpg 其他常用的副檔名還包括 JPEG jpe jfif 以及 jif JPEG 格式的資料也能受嵌進其他類型的檔案格式中 像是TIFF類型的檔案格式 JPEG JFIF 是全球資訊網上最普遍的用來儲存和傳輸照片的格式 它並不適合於線條繪圖 drawing 和其他文字或圖示 iconic 的圖形 因為它的壓縮方法用在這些类型的圖形上 得到的結果并不好 PNG和GIF通常是用來存储这类的圖形 GIF 每个像素只有8位元 並不很適合於存储彩色照片 PNG 可以無失真地儲存照片 但是檔案太大的缺点讓它不太适合在網路上传输 對於JFIF 的MIME媒體类型是image JPEG 定義于RFC 1341 目录 1 JPEG编 解码器示例 1 1 編碼 1 1 1 色彩空間轉換 1 1 2 縮減取樣 Downsampling 1 1 3 離散餘弦變換 Discrete cosine transform 1 1 4 量化 Quantization 1 1 5 熵編碼技術 entropy coding 1 1 6 壓縮比率與不自然痕跡 artifact 1 2 解碼 2 用法 2 1 照片 2 2 醫學影像 少見的JPEG 12位元支援模式 3 其他失真壓縮的編碼格式 4 潛在的專利爭議 4 1 专利案结束 5 無損耗旋轉 lossless JPEG rotation 6 压缩标准 7 參見 8 參考來源 9 外部連結JPEG编 解码器示例 编辑編碼 编辑 JPEG標準中许多選項很少使用 大多数图像软件在创建JPEG文件时使用更简单的JFIF格式 當應用到一個擁有每個像素24位元 24 bits per pixel 紅 藍 綠各有八位元 的輸入時 這邊只有針對更多普遍編碼方法之一的簡潔描述 這個特定的選擇是一種失真資料壓縮方法 色彩空間轉換 编辑 首先 影像由RGB 紅綠藍 轉換為一種稱為YUV的不同色彩空間 这与模拟PAL制式彩色电视传输所使用的色彩空间相似 但是更类似于MAC电视传输系统运作的方式 但不是模拟NTSC 模拟NTSC使用的是YIQ色彩空间 Y成份表示一個像素的亮度 U和V成份一起表示色調與飽和度 YUV分量可以由PAL制系统中归一化 经过伽马校正 的R G B 经过下面的计算得到 Y 0 299R 0 587G 0 114B U 0 147R 0 289G 0 436B V 0 615R 0 515G 0 100B 這種編碼系統非常有用 因為人眼對亮度差異的敏感度高於色彩變化 在此前提下可以设计更加高效压缩图像的編碼器 encoder 縮減取樣 Downsampling 编辑 经过RGB到YUV颜色空间的转换后 开始进行缩减采样来減少U和V的成份 稱為 縮減取樣 或 色度抽样 chroma subsampling 在JPEG上這種縮減取樣的比例可以是4 4 4 無縮減取樣 4 2 2 在水平方向2的倍數中取一個 以及最普遍的4 2 0 在水平和垂直方向2的倍數中取一個 對於壓縮過程的剩餘部份 Y U 和V都是以非常類似的方式來個別地處理 離散餘弦變換 Discrete cosine transform 编辑 nbsp 以8 位元灰階所顯示的8x8子影像下一步 將影像中的每個成份 Y U V 生成三個區域 每一個區域再劃分成如瓷磚般排列的一個個的8 8子區域 每一子區域使用二維的離散餘弦變換 DCT 轉換到頻率空間 如果有一個如這樣的8 8的8 位元 0 255 子區域 52 55 61 66 70 61 64 73 63 59 55 90 109 85 69 72 62 59 68 113 144 104 66 73 63 58 71 122 154 106 70 69 67 61 68 104 126 88 68 70 79 65 60 70 77 68 58 75 85 71 64 59 55 61 65 83 87 79 69 68 65 76 78 94 displaystyle begin bmatrix 52 amp 55 amp 61 amp 66 amp 70 amp 61 amp 64 amp 73 63 amp 59 amp 55 amp 90 amp 109 amp 85 amp 69 amp 72 62 amp 59 amp 68 amp 113 amp 144 amp 104 amp 66 amp 73 63 amp 58 amp 71 amp 122 amp 154 amp 106 amp 70 amp 69 67 amp 61 amp 68 amp 104 amp 126 amp 88 amp 68 amp 70 79 amp 65 amp 60 amp 70 amp 77 amp 68 amp 58 amp 75 85 amp 71 amp 64 amp 59 amp 55 amp 61 amp 65 amp 83 87 amp 79 amp 69 amp 68 amp 65 amp 76 amp 78 amp 94 end bmatrix nbsp 接著推移128 使其範圍變為 128 127 得到結果為 76 73 67 62 58 67 64 55 65 69 73 38 19 43 59 56 66 69 60 15 16 24 62 55 65 70 57 6 26 22 58 59 61 67 60 24 2 40 60 58 49 63 68 58 51 60 70 53 43 57 64 69 73 67 63 45 41 49 59 60 63 52 50 34 displaystyle begin bmatrix 76 amp 73 amp 67 amp 62 amp 58 amp 67 amp 64 amp 55 65 amp 69 amp 73 amp 38 amp 19 amp 43 amp 59 amp 56 66 amp 69 amp 60 amp 15 amp 16 amp 24 amp 62 amp 55 65 amp 70 amp 57 amp 6 amp 26 amp 22 amp 58 amp 59 61 amp 67 amp 60 amp 24 amp 2 amp 40 amp 60 amp 58 49 amp 63 amp 68 amp 58 amp 51 amp 60 amp 70 amp 53 43 amp 57 amp 64 amp 69 amp 73 amp 67 amp 63 amp 45 41 amp 49 amp 59 amp 60 amp 63 amp 52 amp 50 amp 34 end bmatrix nbsp 且接著使用離散餘弦變換 和捨位取最接近的整數 得到結果為 415 30 61 27 56 20 2 0 4 22 61 10 13 7 9 5 47 7 77 25 29 10 5 6 49 12 34 15 10 6 2 2 12 7 13 4 2 2 3 3 8 3 2 6 2 1 4 2 1 0 0 2 1 3 4 1 0 0 1 4 1 0 1 2 displaystyle begin bmatrix 415 amp 30 amp 61 amp 27 amp 56 amp 20 amp 2 amp 0 4 amp 22 amp 61 amp 10 amp 13 amp 7 amp 9 amp 5 47 amp 7 amp 77 amp 25 amp 29 amp 10 amp 5 amp 6 49 amp 12 amp 34 amp 15 amp 10 amp 6 amp 2 amp 2 12 amp 7 amp 13 amp 4 amp 2 amp 2 amp 3 amp 3 8 amp 3 amp 2 amp 6 amp 2 amp 1 amp 4 amp 2 1 amp 0 amp 0 amp 2 amp 1 amp 3 amp 4 amp 1 0 amp 0 amp 1 amp 4 amp 1 amp 0 amp 1 amp 2 end bmatrix nbsp 左上角之相當大的數值称为DC係數 直流系数 其他63个值称为AC系数 交流系数 下面将对所有8 8表格中的DC系数使用差分编码 对AC系数使用行程编码 1 量化 Quantization 编辑 人类眼睛在一個相對大範圍區域 辨別亮度上細微差異是相當的好 但是在一個高頻率亮度變動之確切強度的分辨上 卻不是如此地好 這個事實讓我們能在高頻率成份上極佳地降低資訊的數量 簡單地把頻率領域上每個成份 除以一個對於該成份的常數就可完成 且接著捨位取最接近的整數 這是整個過程中的主要失真運算 以這個結果而言 經常會把很多更高頻率的成份捨位成為接近0 且剩下很多會變成小的正或負數 一個普遍的量化矩陣是 16 11 10 16 24 40 51 61 12 12 14 19 26 58 60 55 14 13 16 24 40 57 69 56 14 17 22 29 51 87 80 62 18 22 37 56 68 109 103 77 24 35 55 64 81 104 113 92 49 64 78 87 103 121 120 101 72 92 95 98 112 100 103 99 displaystyle begin bmatrix 16 amp 11 amp 10 amp 16 amp 24 amp 40 amp 51 amp 61 12 amp 12 amp 14 amp 19 amp 26 amp 58 amp 60 amp 55 14 amp 13 amp 16 amp 24 amp 40 amp 57 amp 69 amp 56 14 amp 17 amp 22 amp 29 amp 51 amp 87 amp 80 amp 62 18 amp 22 amp 37 amp 56 amp 68 amp 109 amp 103 amp 77 24 amp 35 amp 55 amp 64 amp 81 amp 104 amp 113 amp 92 49 amp 64 amp 78 amp 87 amp 103 amp 121 amp 120 amp 101 72 amp 92 amp 95 amp 98 amp 112 amp 100 amp 103 amp 99 end bmatrix nbsp 使用這個量化矩陣與前面所得到的DCT係數矩陣逐項相除 得到結果為 26 3 6 2 2 1 0 0 0 2 4 1 1 0 0 0 3 1 5 1 1 0 0 0 3 1 2 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 displaystyle begin bmatrix 26 amp 3 amp 6 amp 2 amp 2 amp 1 amp 0 amp 0 0 amp 2 amp 4 amp 1 amp 1 amp 0 amp 0 amp 0 3 amp 1 amp 5 amp 1 amp 1 amp 0 amp 0 amp 0 3 amp 1 amp 2 amp 1 amp 0 amp 0 amp 0 amp 0 1 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 end bmatrix nbsp 舉個例子 使用 415 DC係數 且捨位得到最接近的整數 r o u n d 415 16 r o u n d 25 9375 26 displaystyle mathrm round left frac 415 16 right mathrm round left 25 9375 right 26 nbsp 熵編碼技術 entropy coding 编辑 nbsp Z字型掃描矩陣的順序熵編碼是無失真資料壓縮的一個特別形式 它牽涉到將影像成份以Z字型 zigzag 排列 把相似頻率群組在一起 矩陣中往左上方向是越低頻率之係數 往右下較方向是較高頻率之係數 插入長度編碼的零 且接著對剩下的使用霍夫曼編碼 JPEG標準也允許 但是並不要求 在數學上優於霍夫曼編碼的算术编码之使用 然而 這個特色幾乎很少獲使用 因為它被專利所涵蓋 且它相較於霍夫曼編碼在編碼和解碼上會更慢 使用算術編碼一般會讓檔案更小約5 對於前者量化的係數所作的Z字型序列會是 26 3 0 3 2 6 2 4 1 3 1 1 5 1 2 1 1 1 2 0 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0當剩下的所有係數都是零 對於過早結束的序列 JPEG有一個特別的霍夫曼編碼用詞 使用這個特殊的編碼用詞 EOB 該序列變為 26 3 0 3 2 6 2 4 1 3 1 1 5 1 2 1 1 1 2 0 0 0 0 0 1 1 EOB 壓縮比率與不自然痕跡 artifact 编辑 nbsp 失真壓縮導致的人為現象 上 與原圖 下 200 放大按 artifact在這個領域又解釋為赝像 非自然信號 人為現象 在量化階段時 依照除數的不同 會使結果的壓縮比率可能有很多變化 10 1通常可得到無法使用肉眼分辨與原圖差異的影像 100 1壓縮通常是可行的 但與原圖相較 會看出明顯的不自然痕跡 壓縮的適當等級是依據要壓縮那一種影像而定 使用全球資訊網的人 可能熟悉這種出現在JPEG數位影像 已知壓縮人為現象的不規則現象 這是由於JPEG演算法的量化步驟所造成的結果 這種現象在臉部照片中的眼睛四周特別明顯 他們可以藉由選擇壓縮的較低水平 使用較低的壓縮率 來減少這種現象 他們可能藉由使用無失真檔案格式來儲存一個影像來消除這種現象 然而針對照片影像 這樣通常會使檔案大小增加 解碼 编辑 解碼來顯示影像 包含反向作以上所有的過程取DCT係數矩陣 在把DC係數差異加回去之後 26 3 6 2 2 1 0 0 0 2 4 1 1 0 0 0 3 1 5 1 1 0 0 0 3 1 2 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 displaystyle begin bmatrix 26 amp 3 amp 6 amp 2 amp 2 amp 1 amp 0 amp 0 0 amp 2 amp 4 amp 1 amp 1 amp 0 amp 0 amp 0 3 amp 1 amp 5 amp 1 amp 1 amp 0 amp 0 amp 0 3 amp 1 amp 2 amp 1 amp 0 amp 0 amp 0 amp 0 1 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 end bmatrix nbsp 且以前面的量化矩陣乘以它 得到 416 33 60 32 48 40 0 0 0 24 56 19 26 0 0 0 42 13 80 24 40 0 0 0 42 17 44 29 0 0 0 0 18 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 displaystyle begin bmatrix 416 amp 33 amp 60 amp 32 amp 48 amp 40 amp 0 amp 0 0 amp 24 amp 56 amp 19 amp 26 amp 0 amp 0 amp 0 42 amp 13 amp 80 amp 24 amp 40 amp 0 amp 0 amp 0 42 amp 17 amp 44 amp 29 amp 0 amp 0 amp 0 amp 0 18 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 amp 0 end bmatrix nbsp 左上角的部份與原本DCT係數矩陣非常接近地相似 使用反向DCT得到一個有數值的影像 仍然受移位128 nbsp nbsp 注意原來 上 與解壓縮影像 下 的些微差異 在角落处可以輕易地看出來 66 63 71 68 56 65 68 46 71 73 72 46 20 41 66 57 70 78 68 17 20 14 61 63 63 73 62 8 27 14 60 58 58 65 61 27 6 40 68 50 57 57 64 58 48 66 72 47 53 46 61 74 65 63 62 45 47 34 53 74 60 47 47 41 displaystyle left begin array rrrrrrrr 66 amp 63 amp 71 amp 68 amp 56 amp 65 amp 68 amp 46 71 amp 73 amp 72 amp 46 amp 20 amp 41 amp 66 amp 57 70 amp 78 amp 68 amp 17 amp 20 amp 14 amp 61 amp 63 63 amp 73 amp 62 amp 8 amp 27 amp 14 amp 60 amp 58 58 amp 65 amp 61 amp 27 amp 6 amp 40 amp 68 amp 50 57 amp 57 amp 64 amp 58 amp 48 amp 66 amp 72 amp 47 53 amp 46 amp 61 amp 74 amp 65 amp 63 amp 62 amp 45 47 amp 34 amp 53 amp 74 amp 60 amp 47 amp 47 amp 41 end array right nbsp 且對每一個項目加上128 62 65 57 60 72 63 60 82 57 55 56 82 108 87 62 71 58 50 60 111 148 114 67 65 65 55 66 120 155 114 68 70 70 63 67 101 122 88 60 78 71 71 64 70 80 62 56 81 75 82 67 54 63 65 66 83 81 94 75 54 68 81 81 87 displaystyle left begin array rrrrrrrr 62 amp 65 amp 57 amp 60 amp 72 amp 63 amp 60 amp 82 57 amp 55 amp 56 amp 82 amp 108 amp 87 amp 62 amp 71 58 amp 50 amp 60 amp 111 amp 148 amp 114 amp 67 amp 65 65 amp 55 amp 66 amp 120 amp 155 amp 114 amp 68 amp 70 70 amp 63 amp 67 amp 101 amp 122 amp 88 amp 60 amp 78 71 amp 71 amp 64 amp 70 amp 80 amp 62 amp 56 amp 81 75 amp 82 amp 67 amp 54 amp 63 amp 65 amp 66 amp 83 81 amp 94 amp 75 amp 54 amp 68 amp 81 amp 81 amp 87 end array right nbsp 這是解壓縮的子影像 且可以用來与原本子影像相比 也可以看右方的影像 藉由取兩者之間的差異 原本 解壓縮 得到誤差值 10 10 4 6 2 2 4 9 6 4 1 8 1 2 7 1 4 9 8 2 4 10 1 8 2 3 5 2 1 8 2 1 3 2 1 3 4 0 8 8 8 6 4 0 3 6 2 6 10 11 3 5 8 4 1 0 6 15 6 14 3 5 3 7 displaystyle left begin array rrrrrrrr 10 amp 10 amp 4 amp 6 amp 2 amp 2 amp 4 amp 9 6 amp 4 amp 1 amp 8 amp 1 amp 2 amp 7 amp 1 4 amp 9 amp 8 amp 2 amp 4 amp 10 amp 1 amp 8 2 amp 3 amp 5 amp 2 amp 1 amp 8 amp 2 amp 1 3 amp 2 amp 1 amp 3 amp 4 amp 0 amp 8 amp 8 8 amp 6 amp 4 amp 0 amp 3 amp 6 amp 2 amp 6 10 amp 11 amp 3 amp 5 amp 8 amp 4 amp 1 amp 0 6 amp 15 amp 6 amp 14 amp 3 amp 5 amp 3 amp 7 end array right nbsp 每個像素大約是5的平均絕對誤差 也就是說 1 64 x 1 8 y 1 8 e x y 4 8750 displaystyle frac 1 64 sum x 1 8 sum y 1 8 e x y 4 8750 nbsp 誤差在左下角顯而易見 左下方的像素變得比它鄰近右方的像素還更暗 用法 编辑JPEG在色調及顏色平滑變化的相片或是寫實繪畫 painting 上可以達到它最佳的效果 在這種情況下 它通常比完全無失真方法作得更好 仍然可以產生非常好看的影像 事實上它會比其他一般的方法像是GIF產生更高品質的影像 因為GIF對於線條繪畫 drawing 和圖示的圖形是無失真 但針對全彩影像則需要極困難的量化 照片 编辑 JPEG壓縮的不自然現象可以很好地調和到細微非均勻材質的相片中 因此允許得到更高的壓縮率 nbsp 低品質 10 檔案大小為1 7 KB nbsp 中等品質 50 檔案大小為5 7 KB nbsp 最高品質 100 檔案大小為36 KB 附註 以上的影像並不是IEEE CCIR EBU測試影像 且壓縮編碼器的設定並沒有指明或是可以得到 中等品質的相片只有六分之一的儲存空間 但是幾乎沒有明顯的細節損失或是看得到的人為效果 然而 一旦超過一個某整的壓縮限度 壓縮的影像逐漸地顯現出可以看得到的瑕疵 參考比率失真理論 rate distortion theory 的文章有針對這種限度效果的數學上之解釋 醫學影像 少見的JPEG 12位元支援模式 编辑 有很多醫學的影像系統可以建立和處理12位元JPEG影像 12位元JPEG格式已經是JPEG規格的一部份 但是非常少商业软件程序 或網頁瀏覽器 支援這種不常使用的JPEG格式 其他失真壓縮的編碼格式 编辑更新的失真方法 尤其是小波壓縮 wavelet compression 在這些情況下甚至能作得更好 然而 JPEG是一種建立得相當好的標準 擁有很多可使用的軟體 包含自由軟體 因此到2005年它持續獲大量使用 很多小波演算法受到專利保護 要在很多軟體專案中自由地使用他們是困難或是不可能的 JPEG委員會現在也已經建立其自有的小波基礎標準 JPEG 2000 希望最終能取代原來的JPEG標準 潛在的專利爭議 编辑在2002年Forgent Networks主張他擁有且將會履行在JPEG技術上的專利權 起因於一個在1986年已經歸檔的專利 美國專利第4 698 672号 這個公告已經引起一陣大騷動 令人想起Unisys試圖主張對於GIF影像壓縮標準的權利 JPEG委員會審慎調查這個在2002年所主張的專利 且發現他們因為前案而無效作廢 2 其他的也已推斷Forgent並無擁有涵蓋JPEG的專利 3 儘管如此 在2002年和2004年之間 Forgent藉由把他們的專利授權給某些30家公司 而獲得大約9千萬美元 在2004年4月 Forgent控告31家其他公司來強求更多的授權支付 同年的七月 21家較大的電腦公司組成的協會提出反控告 包含使該專利無效的目標 然而 到2005年7月的時候 這場官司仍然持續中 JPEG委員會在他的明確目標中有一項 是他們的標準在不支付授權金之下是可以受實作的 且他們已從超過20個大型組織中 得到適當的授權權利給他們即將到來的JPEG 2000標準 专利案结束 编辑 经过数年的纠缠 于2006年11月 JPEG专利持有者Forgent Networks终于与30家PC厂商结束了侵权官司 代价是PC厂商向Forgent赔款800万美元 而不是Forgent期望的1亿美元 在与PC厂商大打官司之前 Forgent已经与60多家公司和解 获得的专利费用总额高达1 1亿美元 包括雅虎在内的45家PC厂商拒绝就4698672号专利问题和解 而是选择了对簿公堂 不过其中15家在此之前已经与Forgent和解 虽然还是赔了款 但PC厂商们并没有输掉官司 虽然没能得到自己想要的大笔美金 Forgent也没有彻底失败 在非盈利性组织美国公共专利基金会 PPF 的协助下 他们设法获得了美国专利和商标局 USPTO 的认可 对Forgent专利的有效性在2月和6月两次重新进行了鉴定 最终法庭限制了Forgent专利的应用范围 而从另一方面看 Forgent的专利也得到了一定的维护 这要比被彻底推翻好得多 Forgent也表示对结果感到很满意 Forgent CEO Richard Snyder称 在 672专利的有效期内 我们已经获得了1 1亿多美元 很快 Forgent还会再次有所行动 我们的精力现在已经转移到 746专利上 并等待2007年5月的陪审团裁决 同时我们还会继续促进 分公司 NetSimplicity的软件业务 4 無損耗旋轉 lossless JPEG rotation 编辑雖然任何對JPEG圖像的處理都有可能導致因為解壓後再壓縮而引起的損耗 然而 對於簡單的旋轉動作 數學上是可以有辦法使圖像得以旋轉而無損圖像本身的資料 也就是說 有一種方法可以在無需把圖像解壓後才可以旋轉 這是因為JPEG的檔案格式本身是以一個個模塊為單位來壓縮 所以 只需要把模塊重排 再對每個模塊旋轉 就可以達至無損耗的旋轉 使用者在操作上加以注意 例如 在Adobe Photoshop裡 用戶若要作無損耗旋轉前 必須在載入圖像之後立刻用 Save As 功能儲存一個備份 然後當圖像旋轉過後 由於Photoshop已掌握了圖像的基本資料 所以在儲存時得以使用原來的設定 若沒有作事先儲存 Photoshop就會把旋轉後的圖像重新計算各項參數 並重新對圖像進行壓縮處理 這樣就會造成資料的損耗 压缩标准 编辑JPEG是由国际标准组织 ISO 和国际电话电报咨询委员会 CCITT 为静态图像所建立的第一个国际数字图像压缩标准 也是至今一直在使用的 应用最广的图像压缩标准 JPEG由于可以提供有损压缩 因此压缩比可以达到其他传统压缩算法无法比拟的程度 JPEG的压缩模式有以下几种 顺序式编码 Sequential Encoding 一次将图像由左到右 由上到下顺序处理 递增式编码 Progressive Encoding 当图像传输的时间较长时 可将图像分数次处理 以从模糊到清晰的方式来传送图像 效果类似GIF在网络上的传输 无失真编码 Lossless Encoding 阶梯式编码 Hierarchical Encoding 图像以数种分辨率来压缩 其目的是为了让具有高分辨率的图像也可以在较低分辨率的设备上显示 在Independent JPEG Group所提供的源碼上 有jpegtran程式 就提供了優化Huffman 轉成漸進式 鏡射 旋轉這些無損耗轉換 參看 無損耗JPEG旋轉程式列表 页面存档备份 存于互联网档案馆 英語 參見 编辑數位相機 數位相框 影像壓縮 JPEG LS非失真壓縮標準 JPEG 2000 JPEG XR Motion JPEG 影像編輯程式 独立JPEG小组 Independent JPEG Group 的Libjpeg參考來源 编辑 吕凤军 数字图像处理编程入门 清华大学出版社 1999 存档副本 2011 05 29 原始内容存档于2007 07 14 存档副本 2004 08 17 原始内容存档于2004 08 17 JPEG PC厂商向JPEG专利持有者赔偿800万美元 第三媒体频道 2013 07 21 原始内容存档于2014 01 08 外部連結 编辑Official JPEG官方網站 页面存档备份 存于互联网档案馆 JPEG常見問題與回答 FAQ 页面存档备份 存于互联网档案馆 Wotsit org在JPEG格式的進入點 ITU T 81 JPEG壓縮 页面存档备份 存于互联网档案馆 PDF JFIF檔案格式 页面存档备份 存于互联网档案馆 PDF JPEG静态图像压缩标准 Gregory K Wallace简编 永久失效連結 JPEG壓縮 Gernot Hoffmann JPEG資源的開放列表 页面存档备份 存于互联网档案馆 Jpeg Decoder Open Source Code Copyright C 1995 1997 Thomas G Lane 页面存档备份 存于互联网档案馆 取自 https zh wikipedia org w index php title JPEG amp oldid 79256392, 维基百科,wiki,书籍,书籍,图书馆,

文章

,阅读,下载,免费,免费下载,mp3,视频,mp4,3gp, jpg,jpeg,gif,png,图片,音乐,歌曲,电影,书籍,游戏,游戏。