Ich möchte eine JPEG-Datei in Lightroom zuschneiden und diese zugeschnittene Datei in eine andere JPEG-Datei exportieren, damit ich sie per E-Mail versenden kann. Das exportierte JPEG sollte die gleiche Qualität wie das Original haben. Ich habe die RAW-Datei nicht mehr verfügbar.
Wenn ich die Datei exportiere, wähle ich JPEG als Exportformat. Aber jetzt frage ich mich, ob ich die Qualität auf die gleiche Qualität wie das ursprüngliche JPEG (= 80) oder auf 100 einstellen soll.
Ich bin nicht sicher, ob Lightroom die Komprimierung erneut auf das JPEG anwendet, dh:
RAW -> auf Qualität 80 komprimieren -> JPEG-Datei 1 -> auf Qualität 80 komprimieren -> JPEG-Datei 2
Oder dass es das JPEG dekomprimiert und erneut komprimiert, wodurch effektiv die gleiche Qualität erzielt wird:
RAW -> auf Qualität 80 komprimieren -> JPEG-Datei 1 -> auf Bitmap dekomprimieren -> auf Qualität 80 komprimieren -> JPEG-Datei 2
Wie geht Lightroom damit um?
quelle
Antworten:
Das Bild wird erneut komprimiert. Die beiden von Ihnen beschriebenen Szenarien sind tatsächlich identisch, da der verlustbehaftete Teil der JPEG-Komprimierung Informationen verwirft, die beim Dekomprimieren des Bildes nicht mehr vorhanden sind. (Daher verlustbehaftet.) Das bedeutet, dass das erneute Anwenden mit genau denselben Parametern weder in Bezug auf weitere Platzersparnisse noch in Bezug auf weitere Artefakte viel bewirken sollte . Die Unterschiede sind auf Präzisions- und Rundungsfehler zurückzuführen. (Dies ist in Lightroom dasselbe wie in jedem anderen Programm.)
Wenn Sie also mit exakt den gleichen Parametern recompress und haben Ihre Ernte ausgerichtet zu 8 × 8 - Blöcke, die Verschlechterung sollte minimal sein. Wenn Sie jedoch eine hohe Komprimierungsstufe verwenden (ich denke, 80% sind qualifiziert), sehen Sie möglicherweise tatsächlich einen Unterschied, da die durch die anfängliche Komprimierung eingeführten Artefakte permanente Änderungen am Bild sind und auch erneut komprimiert werden und möglicherweise mehr verursachen Artefakte.
Die Einstellung auf 100 ist sicherer, da neu hinzugefügte Artefakte schwer zu bemerken sind. Das Bild wird dadurch nicht besser , aber nicht wesentlich schlechter. Es werden jedoch Änderungen im gesamten Bild vorgenommen, während beim erneuten Speichern Änderungen hauptsächlich dort konzentriert werden, wo Artefakte bereits erkennbar sind. Dies bedeutet leider, dass Ihr Kilometerstand variieren wird.
Wenn Sie Ändern der Größe oder haben erhebliche manipuations gemacht, sind alle Wetten ab.
In dieser Antwort finden Sie Details dazu, wie schlimm diese Verschlechterung werden kann (und wie sie minimiert werden kann).
quelle
Wie Mattdm sagte, ist JPEG ein Bildformat, das nach jedem erneuten Speichern an Qualität verliert. Dies ist ein Preis, den wir für die resultierende kleine Bilddateigröße zahlen.
JPEG ermöglicht jedoch auch einen verlustfreien Betrieb, einschließlich Drehung (90, 180, 270 Grad), Spiegeln (horizontal oder vertikal) und Zuschneiden. Sie sind sich nicht sicher, ob LR das verlustfreie Speichern von JPEG-Bildern ermöglicht, aber es gibt einige Tools von Drittanbietern, die dies ermöglichen, z. B. FastStone Image und BetterJpeg.
Ein kleiner Nachteil: Beim verlustfreien Zuschneiden müssen Bilder mit Größen, die nicht ein Vielfaches des JPEG-Blocks sind (16 × 16 Pixel für Farbbilder, 8 × 8 Pixel für Graustufenbilder), auf die Blockgrenze zugeschnitten werden, was meistens nicht der Fall ist genau dort, wo Sie ausgewählt haben.
quelle
Wie funktioniert es theoretisch?
Wenn Sie auf die Schaltfläche Speichern klicken, erfolgt zunächst eine Konvertierung zwischen RGB- und YCrCb-Farbsystem. Wenn Sie dies schlecht implementieren, ist hier Ihr erster Schritt des Datenverlusts. Es gibt praktische Gründe, warum diese Konvertierung erforderlich ist, aber hier ist sie nicht entscheidend. Nach dieser Konvertierung wird von jedem Pixelwert der Wert 128 abgezogen, um ein Bild mit dem Mittelwert Null zu erzeugen .
Nachdem die Konvertierung von RGB in YCrCb abgeschlossen ist, wird Ihr Bild in Blöcke von 8 x 8 Pixel unterteilt, die als Blöcke oder MCU (Minimal Coded Unit) bezeichnet werden. Nachdem Ihr Bild in 8x8-Blöcke unterteilt wurde, wird die Forward Descreete Cosine-Transformation für jeden 8x8-Block ausgeführt. Die Formel der FDCT ist unten angegeben:
wobei M und N Dimensionen des 8x8-Blocks sind, in unserem Beispiel M = N = 8 und C (u), C (v) Konstanten sind, die im Bild unten angegeben sind:
"
F (u, v) ist das Ergebnis von FDCT, das ebenfalls eine Matrix / ein Block von 8 × 8 Pixeln ist, und F (u, v) -Elemente werden FDCT-Koeffizienten genannt und sind Frequenzdarstellungen des Bildes. Das erste Element F (0,0) wird als Gleichstromkoeffizient bezeichnet, andere als Wechselstromelemente. Das erste Element ist am wichtigsten, da es die meisten Daten des 8x8-Blocks enthält. Wenn wir etwas rechnen, können wir erhalten, dass das erste Element F (0,0) der Mittelwert aller anderen Knoten ist, multipliziert mit 8, was in den folgenden Formeln beschrieben wird.
und du bekommst
Genug der Mathematik :).
Wenn Sie mir folgen, sehen Sie, dass wir bis jetzt nicht so viele Daten verloren haben (wir können immer noch IDCT (I-inverse) ausführen und wir werden unser Startbild mit einigen Verlusten erhalten). Wo ist der Prozess, was ändert sich, wenn Sie beim Speichern von JPEG-Bildern die Größe Ihrer Photoshop / Lightroom-Qualität festlegen? Lass uns weitermachen.
Nehmen wir also an, wir haben ein Bild mit 16 x 16 Pixel. Wenn wir unser Bild in 8x8-Blöcke unterteilen, erhalten wir zwei 8x8-Blöcke. Nachdem wir die Farbkonvertierung durchgeführt haben, gelangen wir zu FDCT. Wir führen FDCT auf dem ersten 8x8-Block aus und erhalten als Ergebnis einen neuen 8x8-Block, der ein Produkt von FDCT ist. Dann führen wir FDCT auf dem zweiten 8x8-Block des Originalbilds aus, und als Ergebnis erhalten wir einen weiteren 8x8-Block FDCT. Insgesamt ist das Ergebnis der FDCT auf unserem 16x16-Bild / unserer Matrix eine neue 16x16-Matrix und wird als F- Matrix bezeichnet.
Jetzt ist die F-Matrix in 8 × 8-Blöcke unterteilt, und sie ist mit einer Quantisierungstabelle unterteilt, die eine Matrix von 8 × 8 Pixeln ist. Quantisierungstabellenwerte sind Konstanten / Zahlen, die durch experimentelle Ergebnisse am menschlichen Auge angegeben werden. Die klassische Quantisierungstabelle ist unten angegeben.
Diese Matrix, die als Q-Matrix bezeichnet wird, wird mit unserer F-Matrix geteilt, tatsächlich mit dem ersten 8x8-Block der F-Matrix, dann mit dem zweiten 8x8-Block der F-Matrix und so weiter. Warum? Um kleinere Zahlen zu erhalten, für die wir weniger Bits benötigen, um sie in einer digitalen Datei darzustellen. Wenn Sie den Wert 105 haben, benötigen Sie 8 Bit für die digitale Darstellung. Aber wenn Sie 105 mit 52 teilen, erhalten Sie 1,90. Sie nehmen nur einen ganzzahligen Teil, der 1,00 beträgt. Für die Dezimalzahl 1 benötigen Sie nur ein Bit, also haben Sie 7 Bits gespeichert. Stellen Sie sich nun Einsparungen für Bilder mit 4000x4000 Pixel vor :).
Dieser Prozess des Teilens der F-Tabelle mit der Q-Tabelle ist der Punkt, an dem ein JPEG-Verlust auftritt. Wenn Q-Elemente größer sind, ist der Verlust größer und umgekehrt. Wenn Sie also den Photoshop-Spinner von schlechter auf gute Qualität ändern, ändern Sie tatsächlich die Werte der Q-Tabelle.
Sie sehen auch, dass das erste Element der Q-Matrix, Q (0,0), das kleinste ist. Dies liegt daran, dass dieses Element durch das Element F (0,0) geteilt wird, das ein DC-Element ist (Element, das die meisten Daten enthält). Wenn wir es durch eine große Zahl teilen, sehen Sie in Ihrem Bild 8x8 Blöcke wie Sie kann es in Bildern sehen, die von @mattdm gepostet wurden.
Ihre Antwort ist ja es ist :)
Ich hoffe ich habe dir geholfen :)
quelle