JPEG

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen
Logo
Ein Bild mit von links nach rechts abnehmenden Qualitätsstufen

JPEG([ˈdʒeɪpɛɡ]) ist die gebräuchliche Bezeichnung für die 1992 vorgestellteNormISO/IEC10918-1 bzw.CCITTRecommendation T.81, die verschiedene Methoden derBildkompressionbeschreibt. Die Bezeichnung „JPEG “geht auf das GremiumJoint Photographic Experts Groupzurück, das die JPEG-Norm entwickelte.[1]

JPEG schlägt verschiedene Komprimierungs- und Kodierungsmethoden vor, darunterverlustbehafteteundverlustfreie Kompression,verschiedeneFarbtiefensowie sequenzielle oder progressive Modi (normaler Bildaufbau bzw. allmähliche Verfeinerung). Weithin verbreitet ist nur die verlustbehaftete Komprimierung bei sequenziellem oder progressivem Modus und 8-Bit-Farbkanälen.

Die JPEG-Norm beschreibt lediglich Bildkompressionsverfahren, legt aber nicht fest, wie die so entstandenen Daten gespeichert werden sollen. Gemeinhin werden mit „JPEG-Dateien “oder „JPG-Dateien “Dateien imGrafikformatJPEG File Interchange Format(JFIF) bezeichnet. JFIF ist jedoch nureineArt, JPEG-Daten abzulegen;SPIFFundJNGsind weitere, wenn auch wenig gebräuchliche, Möglichkeiten.

JPEG/JFIF unterstützt eine maximale Bildgröße von 65.535 × 65.535 Pixel.[2]

Übersicht und Standards

Die JPEG-Norm ISO/IEC 10918-1 definiert folgende Modi, von denen nur die farbig unterlegten gebräuchlich sind:

Aufbau Sequenziell(Sequential) Progressiv(Progressive) Verlustfrei(Lossless) Hierarchisch(Hierarchical)
Kodierung Huffman Arithmetisch Huffman Arithmetisch Huffman Arithmetisch
Bittiefe 8 Bit 12 Bit 08 Bit 12 Bit 8 Bit 12 Bit 08 Bit 12 Bit 2-16 Bit 2-16 Bit Bittiefe je nach kombinierten Modi

Zusätzlich zum in ISO/IEC 10918-1 definierten verlustbehafteten Modus gibt es noch die verbesserte, verlustfreie KomprimierungsmethodeJPEG-LS,die in einer anderen Norm festgelegt wurde. Außerdem existiert noch dieJBIG-Norm zur Komprimierung von Schwarzweißbildern.

JPEG und JPEG-LS sind in den folgenden Standards definiert:

JPEG (verlustbehaftet und verlustfrei): ITU-T T.81(PDF; 1,1 MB), ISO/IEC IS 10918-1
JPEG (Erweiterungen): ITU-T T.84
JPEG-LS (verlustfrei, verbessert): ITU-T T.87, ISO/IEC IS 14495-1

Die JPEG-Norm trägt den offiziellen TitelInformation technology – Digital compression and coding of continuous-tone still images: Requirements and guidelines.Das „Joint “im Namen stammt von der Zusammenarbeit vonITU,IECundISO.

Die JPEG-Komprimierung

Die JPEG-Norm definiert 41 verschiedene Unterdateiformate, von denen aber meist nur eines unterstützt wird (und welches auch fast alle Anwendungsfälle abdeckt).

Die Kompression erfolgt in mehreren Verarbeitungsschritten, von denen vier verlustbehaftet sind.

Die Datenreduktion erfolgt durch die verlustbehafteten Verarbeitungsschritte in Zusammenwirken mit derEntropiekodierung.

Kompressionen bis etwa 1,5–2 Bit/Pixel sind visuell verlustfrei, bei 0,7–1 Bit/Pixel sind noch gute Ergebnisse erzielbar, unter 0,3 Bit/Pixel wird JPEG praktisch unbrauchbar, das Bild wird zunehmend von unübersehbarenKompressionsartefakten(Blockbildung, stufige Übergänge, Farbeffekte an Graukeilen) überdeckt. Der NachfolgerJPEG 2000ist wesentlich weniger für diese Art von Artefakten anfällig.

Sieht man als Quellformat 24-Bit-RGB-Dateien an, erhält man Kompressionsraten von 12 bis 15 für visuell verlustfreie Bilder und bis zu 35 für noch gute Bilder. Die Qualität hängt aber neben der Kompressionsrate noch von der Art der Bilder ab. Rauschen und regelmäßige feine Strukturen im Bild verringern die maximal mögliche Kompressionsrate.

Der JPEG Lossless Mode zur verlustfreien Kompression verwendet ein anderes Verfahren (prädiktiver KoderundEntropiekodierung).

Farbmodellumrechnung

Originalfarbbild oben und die Aufspaltung dieses Bildes in die Komponenten Y, Cb und Cr. Der geringe wahrgenommene Kontrast in den Farbkomponenten Cb und Cr macht anschaulich, warum die Farbinformation in der Auflösung reduziert werden kann (Unterabtastung), ohne den Bildeindruck wesentlich zu verschlechtern.

Das Ausgangsbild, welches meist alsRGB-Bild vorliegt, wird in dasYCbCr-Farbmodell umgerechnet. Grundsätzlich wird dabei dasYPbPr-Schema nachCCIR 601verwendet:

Da die R′G′B′-Werte bereits digital als 8-Bit-Zahlen im Bereich {0, 1,…, 255} vorliegen, müssen die YPbPr-Komponenten lediglich verschoben (renormiert) werden, wodurch die Komponenten Y′ (Luminanz), Cb (color blueness) und Cr (color redness) entstehen:

Die Komponenten liegen nun wiederum im Wertebereich {0, 1,…, 255}.

Bei der Umrechnung des Farbmodells entstehen die üblichen Rundungsfehler durch begrenzte Rechengenauigkeit.

Tiefpassfilterung der Farbdifferenzsignale

Die Farbabweichungssignale Cb und Cr werden meist in reduzierter Auflösung gespeichert. Dazu werden sietiefpassgefiltertundunterabgetastet(im einfachsten Fall durch eine Mittelwertbildung).

Meist wird eine vertikale und horizontale Unterabtastung jeweils um den Faktor 2 verwendet (YCbCr 4:2:0), die die Datenmenge um den Faktor 4 reduziert. Bei dieser Umwandlung wird die Tatsache ausgenutzt, dass die Ortsauflösung des menschlichen Auges für Farben deutlich geringer ist als für Helligkeitsübergänge.

Blockbildung und diskrete Kosinustransformation

Jede Komponente (Y, Cb und Cr) des Bildes wird in 8×8-Blöcke eingeteilt. Diese werden einer zweidimensionalendiskreten Kosinustransformation(DCT) unterzogen:

mit

Statt 64 Einzelpunkte wird jeder 8×8-Block alsLinearkombinationdieser 64 Blöcke dargestellt
In der Vergrößerung sind die komprimierten 8×8-Quadrate erkennbar.

Diese Transformation lässt sich unter Nutzung derschnellen Fourier-Transformation(FFT) mit sehr wenig Aufwand implementieren. Die DCT ist eineorthogonaleTransformation,weist gute Energiekompressionseigenschaften auf und es gibt eine inverse Transformation, die IDCT (was auch bedeutet, dass die DCT verlustfrei ist, es gingen keine Informationen verloren, da die Daten lediglich in eine für die weitere Verarbeitung günstigere Form gebracht wurden).

Quantisierung

Wie bei allen verlustbehafteten Kodierungsverfahren wird die eigentliche Datenreduktion (und Qualitätsverschlechterung) durch eine Quantisierung erreicht. Dazu werden die DCT-Koeffizienten durch die Quantisierungsmatrix geteilt (elementweise dividiert) und danach auf die nächstliegende Ganzzahl gerundet:

Bei diesem Rundungsschritt findet eineIrrelevanzreduktionstatt. Die Quantisierungsmatrix ist sowohl für die Qualität als auch für die Kompressionsrate verantwortlich. Sie ist in JPEG-Dateien im Header abgespeichert (DQT-Marker).

Optimal ist die Quantisierungsmatrix, wenn sie in etwa die Empfindlichkeit des Auges für die entsprechenden Ortsfrequenzen repräsentiert. Für grobe Strukturen ist das Auge empfindlicher, daher sind die Quantisierungswerte für diese Frequenzen kleiner als die für hohe Frequenzen.

Hier ein Beispiel für eine Quantisierungsmatrix und ihre Anwendung auf einen 8×8-Block aus DCT-Koeffizienten:

wobeiberechnet wird mit:

usw.

Umsortierung und Differenzkodierung des Gleichanteils

Zickzackförmige Reihenfolge der Bildkomponenten

Die 64 Koeffizienten der diskreten Cosinus-Transformation werden anhand derFrequenzsortiert. Dadurch ergibt sich einezickzackförmigeReihenfolge, beginnend mit dem Gleichanteil mit der Frequenz 0. Nach dem englischenDirect Current(fürGleichstrom) wird er mitDCabgekürzt, hier bezeichnet er die mittlere Helligkeit. Die Koeffizienten mit hohem Wert stehen nun meist zuerst und kleine Koeffizienten weiter hinten. Dies optimiert die Eingabe der nachfolgendenLauflängenkodierung.Die Umsortierreihenfolge sieht folgendermaßen aus:

1 2 6 7 15 16 28 29
3 5 8 14 17 27 30 43
4 9 13 18 26 31 42 44
10 12 19 25 32 41 45 54
11 20 24 33 40 46 53 55
21 23 34 39 47 52 56 61
22 35 38 48 51 57 60 62
36 37 49 50 58 59 63 64

Weiterhin wird der Gleichanteil noch einmal differentiell zum Block links daneben kodiert und auf diese Weise die Abhängigkeiten zwischen benachbarten Blöcken berücksichtigt.

Das obige Beispiel führt zu den folgenden umsortierten Koeffizienten

119…
78 3 -8 0 -4 7 -1 0 -1 0 0 0 -2 1 0 1 1 -1 0…
102 5 -5 0 3 -4 2 -1 0 0 0 0 1 1 -1 0 0 -1 0 0 0 0 0 0 0 1 0…
75 -19 2 -1 0 -1 1 -1 0 0 0 0 0 0 1…
132 -3 -1 -1 -1 0 0 0 -1 0…

Die Differenzkodierung des ersten Koeffizienten ergibt dann:

-41 3 -8 0 -4 7 -1 0 -1 0 0 0 -2 1 0 1 1 -1 0…
24 5 -5 0 3 -4 2 -1 0 0 0 0 1 1 -1 0 0 -1 0 0 0 0 0 0 0 1 0…
-27 -19 2 -1 0 -1 1 -1 0 0 0 0 0 0 1…
57 -3 -1 -1 -1 0 0 0 -1 0…

In strukturarmen Regionen (desselben Bildes) können die Koeffizienten auch so aussehen:

35 -2 0 0 0 1 0…
4 0 1 0…
0 0 2 0 1 0…
-13 0 -1…
8 1 0…
-2 0…

Diese Bereiche lassen sich besser kodieren als strukturreiche Gebiete, beispielsweise durch eine Lauflängenkodierung.

Die Zickzack-Umsortierung der DCT-Koeffizienten fällt zwar unter den Schutzbereich des im Jahre 1986 angemeldeten US-Patentes4,698,672 (und weiterer Anmeldungen und Patente in Europa und Japan).[3]Jedoch wurde 2002 herausgefunden, dass das beanspruchte Verfahren nach demStand der Techniknicht neu war, sodass die Ansprüche kaum durchsetzbar gewesen wären.[4]Inzwischen sind die Patente dieser Patentfamilie durch Zeitablauf erloschen, wie beispielsweise das EP-Patent 0 266 049 B1 im September 2007.

Entropiekodierung

AlsEntropiekodierungwird meist eineHuffman-Kodierungverwendet. Der JPEG-Standard erlaubt auch einearithmetische Kodierung.Obwohl diese zwischen 5 und 15 Prozent kleinere Dateien generiert, wird sie aus patentrechtlichen Gründen kaum verwendet, zudem ist diese Kodierung deutlich langsamer.

Die JPEG-Dekodierung

Die Dekompression (meist Dekodierung genannt) erfolgt invers zur Kompression:

  • Entropie-Dekodierung
  • Umsortierung
  • Requantisierung
  • Inverse Diskrete Kosinustransformation.
  • Überabtastung und Tiefpassfilterung der Farbdifferenzsignal U und V (verlustbehaftet)
  • Farbmodellumrechnung vomYCbCr-Farbmodellin den Zielfarbraum (meistRGB)

Die Dekompression ist zwar (weitgehend) verlustfrei, allerdings tritt dasInverse-Dekoder-Problemauf. Aus dekodierten Daten ist es nur schwierig möglich, die ursprüngliche Datei zu rekonstruieren. Ein Dekodier-Kodier-Vorgang verändert die Datei und ist damit nicht verlustfrei, es treten wie beim analogen Überspielen Generationsverluste auf.

DieGenerationsverlustevon JPEG sind allerdings vergleichsweise klein, wenn wieder die gleiche Quantisierungstabelle zum Einsatz kommt und die Blockgrenzen die gleichen sind. Bei geeigneten Randbedingungen kann man sie bei JPEG sogar vermeiden. Bei JPEG-2000 ist das nicht mehr der Fall (überlappende Transformationen, wie sie bei JPEG-2000 wie auch in derAudiodatenkompressionzum Einsatz kommen, erfordern dafür sehr große Rechenleistungen).

Inverse diskrete Kosinustransformation

Zur DCT existiert die inverse Transformation, die IDCT:

mit den gleichen Korrekturfaktorenwie bei der DCT.

Farbmodellumrechnung

Die Rückrechnung vom YCbCr-Farbmodell in den RGB-Farbraum erfolgt über dieinverse Matrixder Hinrechnung, sie lautet:

mit:

Progressives JPEG

Ein JPEG-Bild besteht aus Koeffizienten. Diese speichern keine Pixel, sondern Annäherungen des gesamten Bildinhalts eines 8×8-Bildblocks. Beim Progressive JPEG werden erst die ersten Koeffizienten jedes Bildblocks, dann die zweiten usw. der Reihe nach abgespeichert, so dass die Annäherung an das Originalbild immer besser wird.

Wie beim Interlacing, das bei GIF angewendet wird, liegt der Zweck darin, dem Benutzer, noch bevor die gesamte Datei geladen ist, schnell ein grobes Vorschaubild zu geben. Dies ist besonders dann sinnvoll, wenn das Laden eines Bildes länger als eine halbe bis ganze Sekunde dauert bzw. man nur ein Vorschaubild benötigt. Jedoch werden große Bilder trotzdem meistens im normalen JPEG-Modus zum Download angeboten.

Verlustfreie Nachbearbeitung von JPEG

Verlustfreie visuelle Nachbearbeitung

Verluste beim wiederholten Rotieren und Speichern eines JPEG-Bildes mit „krummer “Auflösung 1021 × 767 (nicht durch 16 teilbar).
Das wiederholte Rotieren von JPEG-Bildern mit durch 16 teilbarer Auflösung (z. B. 1024 × 768) bei Verwendung immer der gleichen Quantisierungsmatrix ist dagegen (bei ordnungsgemäßer Implementierung) verlustfrei.

Obwohl eine Dekodierung und Rekodierung meist verlustbehaftet ist, lassen sich einige Bildmanipulationen (prinzipiell) ohne unerwünschte Datenverluste durchführen:

  • Bilddrehungen um 90°, 180° und 270°
  • horizontale und vertikale Bildspiegelungen
  • Beschneiden von Rändern um Vielfache von 16 Pixeln (bzw. 8 Pixel bei Schwarzweißbildern oder Farbbildern ohne Unterabtastung)

Dazu ist die Entropiekodierung und die Zickzack-Umsortierung rückgängig zu machen. Die Operationen erfolgen dann auf Grundlage der DCT-Koeffizienten (Umsortieren, Weglassen nicht benötigter Blöcke). Danach erfolgen wieder die Zickzack-Umsortierung und die Entropiekodierung. Es erfolgenkeineverlustbehafteten Arbeitsschritte mehr. Nicht jedes Programm führt diese Operationen verlustfrei durch, es benötigt dazu spezielle dateiformatspezifische Verarbeitungsmodule. Die gängigenBildbearbeitungsprogrammebieten aber mittlerweile in aller Regel eine verlustfreie Drehung/Spiegelung an; daneben aber auch eine verlustbehaftete, bei der die Datei zunächst in ein Bitmuster dekodiert und dann mit diesen Daten gearbeitet wird. Drehungen um Winkel anders als 90°/180°/270° sind immer verlustbehaftet. Als Programmbeispiel sei das kostenloseIrfanViewfür Windows genannt.

Bilder, deren Auflösung nicht ein Vielfaches von 16 Pixeln (bzw. 8 Pixel bei Schwarzweißbildern oder Farbbildern ohne Unterabtastung) beträgt, sind problematisch. Sie weisen unvollständige Blöcke auf, das heißt, Blöcke, die nicht alle synthetisierten Pixel verwenden. JPEG erlaubt solche Blöcke aber nur am rechten und am unteren Bildrand. Einige dieser Operationen verlangen daher einmalig, dass diese Randstreifen verworfen werden.

Verlustfreie erweiterte Kompression der Daten

Die FirmaDropboxhat ein Programm entwickelt, welches mittelsarithmetischen Kodierensden Platzbedarf von bereits vorhandenen JPEG-Dateien nochmals um durchschnittlich ungefähr 20 Prozent verkleinert. Das Programm heißtLeptonund steht unter derApache-2.0-Lizenz,einerOpen-Source-Lizenz.[5]

Visuelle Qualität und verwandte Formate

Die JPEG-Kompression ist für natürliche (Raster-)Bilder entwickelt worden, wie man sie in der Fotografie oder beicomputergenerierten Bildernvorfindet.

Ungeeignet ist JPEG für

  • digitale Strichzeichnungen (z. B. Screenshots oder Vektorgrafiken), die viele hochfrequente Bildteile (harte Kanten) enthalten,
  • Schwarzweißbilder mit 1 Bit pro Bildpunkt,
  • gerasterte Bilder (Zeitungsdruck).

Für diese Bilder sind Formate wieGIF,PNGoderJBIGweitaus besser geeignet.

Ein nachträgliches Heraufsetzen des Qualitätsfaktors vergrößert zwar den Speicherbedarf der Bilddatei, bringt aber verlorene Bildinformation nicht mehr zurück. Die Quantisierungstabellen können beliebig gewählt werden und sind nicht genormt. Viele Bildbearbeitungsprogramme lassen aber den Benutzer einen pauschalen Qualitätsfaktor zwischen 0 und 100 auswählen, der gemäß einer Formel in der vom JPEG-Komitee herausgegebenen JPEG-Bibliothek in eine Quantisierungstabelle umgewandelt wird. Auch bei Qualitätsfaktoren wie „100 “oder „100 % “findet immer noch eine Quantisierung und damit ein – bei für JPEG ungeeigneten Bildern erheblicher – Qualitätsverlust statt.

Eine JPEG-Transformation ist im Allgemeinen nichtidempotent.Das Öffnen und anschließende Speichern einer JPEG-Datei führt zu einer neuen verlustbehafteten Kompression.

Bilder unterschiedlicher JPEG-Qualitätsstufen, von links nach rechts: „90 “, „60 “, „20 “, Detail („20 “)

Das Beispielbild vergleicht Aufnahmen, die mit unterschiedlichen Qualitätseinstellungen kodiert wurden. Die Porträt-Aufnahme besitzt eine Größe von 200 × 200 Pixeln. Bei einer Farbtiefe von 8 Bit pro Farbe und unkomprimierter Speicherung erzeugt dieses Bild eine 120 Kbyte große Datei (exklusive Header und anderer Meta-Informationen). Die Klötzchenbildung der 8 × 8 Pixel großen Quadrate stellt das rechte Teilbild vergrößert dar. Ein weiteres Problem neben der Klötzchenbildung ist das „Ringing“,eine Konsequenz des schlechten Verhaltens der DCT bei harten Farbübergängen.

Im Profi-Bereich wird JPEG wegen der verlustbehafteten Datenreduktion eher selten verwendet. Stattdessen werden Formate eingesetzt, die verlustfrei komprimieren, ungeachtet des großen Speicherbedarfs. Beispiele sindTIFF,BMP,TGAoderPNG(Vollfarbenmodus). Eine unkomprimierte Aufnahme von 6 Megapixel erfordert bei einer Farbtiefe von 16 Bit pro Grundfarbe und 3 Grundfarben einen Speicherbedarf von 36 Mbyte, der sich bei strukturreichen, körnigen oder verrauschten Bildern durch verlustlose Kompression nur mäßig verkleinern lässt (bei detailreichen Fotos sind Kompressionsraten auf ca. 50 % üblich).[6]

Es ist oft möglich, die Komprimierung vorhandener JPEG-Dateien ohne weitere Verluste zu optimieren und somit die Dateigröße etwas zu verringern. Neuere Versionen einigerPackprogrammesind in der Lage, JPEG-Bilder ohne weitere Verluste um bis zu 25 % zu komprimieren.[7]

Die BewegtbildkompressionsverfahrenMPEG-1(eng verwandt mit dem CodecMotion JPEG) sowieMPEG-2bauen auf dem JPEG-Standard auf. Ein Nachfolgeprojekt von JPEG zur Speicherung von Bildern istJPEG 2000,das über eine bessere Kompression und viele sinnvolle Eigenschaften verfügt, sich aber zumindest bis jetzt nicht in breitem Maße durchsetzen konnte. Ein weiteres potentielles Nachfolgeformat istJPEG XR,das auf dem vonMicrosoftentwickelten FormatHD Photobasiert, das jedoch bisher ebenfalls nur vereinzelt unterstützt wird.

JPEG XL

Daneben ist mitJPEG XLein weiteres Nachfolgeformat in Entwicklung.[8]Es integriert eine Reihe von Funktionen, für die bisher andere Bildformate verwendet wurden und bietet eine verbesserte Komprimierung, die auf den experimentellen Formaten PIK und FUIF basiert.[9]Im Januar 2021 wurde ein Format Freeze bekanntgegeben.[10]Bisher liegt aber noch keine als stabil gekennzeichnete Version des umfangreichen Gesamtprojekts vor (Stand April 2024).[11]

Patentfragen

Mehrere Firmen (s.Patent-Trolle) haben bereits versucht, aus ihren (zumeistzu Unrecht erteilten) Patenten Forderungen gegen Softwarehersteller zu erheben, deren Produkte JPEG-Dateien lesen oder erstellen können. Bisher wurden alle entsprechenden Patente nachträglich entzogen. Dennoch konnten die Forderer in außergerichtlichen Einigungen hohe Millionenbeträge einnehmen.

Implementierungen

Eine sehr wichtige Implementierung eines JPEG-Codecs ist die freie Programmbibliotheklibjpeg.Sie wurde 1991 erstmals veröffentlicht und war ein Schlüssel für den Erfolg des Standards.[12]Aus ihr entstanden auch die optimierten Abspaltungen libjpg-turbo und MozJPEG. Die Bibliothek und ihre Abkömmlinge werden in einer unüberschaubaren Anzahl von Anwendungen verwendet.

Im Mai 2019 publizierte ITU und ISO/IEC Referenzimplementierungen des JPEG Standards unter ISO/IEC 10918-7[13]und ITU-T T.873[14].Diese Referenzsoftware besteht aus zwei Implementierungen, nämlich der libjpeg-turbo[15]und einer von der ISO-Arbeitsgruppe SC29WG1 selbst gepflegten Referenzimplementierung und ITU-T T.873[16]die nicht nur den DCT-Prozess von JPEG, sondern auch die selten benutzten verlustlosen und hierarchischen Prozesse implementiert.

Im März 2017 hat Google mit „Guetzli “einen neuenOpen-Source-JPEG-Encoder vorgestellt. Dieser komprimiert Bilddateien besser als bisherige Methoden, so soll Guetzli laut Google um bis zu 35 Prozent kleinere JPEG-Dateien erzeugen als herkömmliche Encoder und dabei weniger störendeKompressionsartefaktebilden. Die Kodiergeschwindigkeit (~0,01 MPixel/s) liegt allerdings um etwa vier Größenordnungen unter der von Standard-JPEG-Encodern (100 MPixel/s) und ist damit in der Praxis nur für sehr häufig benutzte statische Bilder geeignet.[17][18]

Im April 2024 stellte GoogleJpeglivor, eine neue Implementierung mit erweiterten Möglichkeiten und einer (nach eigenen Angaben) 35 % Verbesserung der Kompressionseffizienz bei hohen Qualitätseinstellungen, wobei die Kodiergeschwindigkeit mit denen der Abspaltungmozjpegvergleichbar ist.[19]

Literatur

  • Heiner Küsters:Bilddatenkomprimierung mit JPEG und MPEG.Franzis, Poing 1995,ISBN 3-7723-7281-3.
  • Thomas W. Lipp:Grafikformate.Microsoft Press, Unterschleißheim 1997,ISBN 3-86063-391-0.
  • John Miano:Compressed Image File Formats.Addison-Wesley, Reading 2000,ISBN 0-201-60443-4(englisch).
  • William Pennebaker, Joan Mitchell:JPEG Still Image Data Compression Standard.Chapman & Hall, New York 1993,ISBN 0-442-01272-1(englisch).
  • Tilo Strutz:Bilddatenkompression, Grundlagen, Codierung, Wavelets, JPEG, MPEG.4., überarbeitete und ergänzte Auflage, Vieweg + Teubner, Wiesbaden 2009,ISBN 978-3-8348-0472-3.
Commons:JPEG– Sammlung von Bildern, Videos und Audiodateien

Einzelnachweise

  1. jpeg.org20:20, 30. Januar 2016
  2. Digital Compression And Coding Of Continuos-Tone Still Images–Requirements And Guidelines
  3. PatentEP0266049B1:Kodierungssystem zur Reduktion der Redundanz.Angemeldet am18. September 1987,veröffentlicht am9. März 1994,Anmelder: Compression Labs, Erfinder: Wen-Hsiung Chen, Daniel J. Klenke.
  4. Patent-Statement(Mementovom 30. Oktober 2014 imInternet Archive) von jpeg.org
  5. Sebastian Grüner:Komprimierung – Dropbox macht Jpeg-Bilder um fast ein Viertel kleiner.Golem.de,15. Juli 2016,abgerufen am 19. Juli 2016.
  6. Vergleich der Eigenschaften (auch Kompression) von BMP GIF PNG JPEG TIFF PCX TGA,abgerufen am 10. Oktober 2012
  7. maximumcompression
  8. JPEG - JPEG XL.Abgerufen am 11. Juli 2020.
  9. How JPEG XL Compares to Other Image Codecs.Abgerufen am 11. Juli 2020(englisch).
  10. heise online:JPEG XL soll JPEG, PNG, GIF und Webp beerben.Abgerufen am 9. Mai 2021.
  11. Releases · libjxl/libjxl.Abgerufen am 11. April 2024(englisch).
  12. jpeg.org
  13. ISO/IEC 10918-7:2021 – Information technology — Digital compression and coding of continuous-tone still images — Part 7: Reference software.1. September 2021,abgerufen am 2. Juni 2022(englisch).
  14. T.873: Information technology - Digital compression and coding of continuous-tone still images: Reference software.17. Februar 2022,abgerufen am 2. Juni 2022(englisch).
  15. https:// libjpeg-turbo.org/.3. Mai 2022,abgerufen am 2. Juni 2022(englisch).
  16. thorfdbg / libjpeg.Abgerufen am 2. Juni 2022(englisch).
  17. Robert Obryk und Jyrki Alakuijala:Announcing Guetzli: A New Open Source JPEG Encoder.Google Research Europe, 16. März 2017,abgerufen am 18. März 2017(englisch).
  18. Daniel Berger:Googles Guetzli-Encoder schrumpft JPEG-Bilder um ein Drittel.In:heise online.Heise Zeitschriften Verlag, 17. März 2017,abgerufen am 18. März 2017.
  19. Introducing Jpegli: A New JPEG Coding Library.In:Google Open Source Blog.Abgerufen am 10. April 2024.