I have noticed banding in JPG renders of images with featureless skies (with a slight vignette added to them) for some time in PWP8. I have finally had a chance to investigate. I took the same 48-bit tif image and rendered it as a 4:4:4 100% jpg in both PWP7 and PWP8. Then I used the brightness curve transformation to exaggerate the contrast in both jpgs. PWP7 does a good job with slight tonal variations in a featureless sky (with a slight vignette). PWP8 doesn't do as good a job, with visible banding showing in the resulting image. See attached images.
PWP 7 JPG render:
PWP 8 JPG render:
JPG banding issue
Moderator: jsachs
Re: JPG banding issue
PWP 7 used Leadtools libraries to read and write JPEGs while PWP 8 uses the Microsoft WIC libraries that are come with Windows, so I am not surprised there are small differences between them. JPEG is a rather loose standard and different implementations can produce different results, so this is not really unexpected. Not much I can do in any case since continuing to use Leadtools was not a viable option for PWP 8.
What you don't illustrate is how the original image (reduced to 8-bits/channel which is what JPEG uses) compares with the two JPEGs.
What you don't illustrate is how the original image (reduced to 8-bits/channel which is what JPEG uses) compares with the two JPEGs.
Jonathan Sachs
Digital Light & Color
Digital Light & Color
-
- Posts: 199
- Joined: December 1st, 2011, 1:39 pm
- What is the make/model of your primary camera?: Canon/5DMIII
Re: JPG banding issue
Here are the (high contrast) 8-bit/chan tiff's from PWP7 and PWP8 per your suggestion:
24bit tif from PWP7:
24bit tif from PWP8:
24bit tif from PWP7:
24bit tif from PWP8:
Re: JPG banding issue
Interesting.
Another problem with comparing JPEG implementations is that there is no standard for what different quality settings mean. One implementation's 95% may give a different compression ratio than another. What this looks like to me is that at 100%, the Microsoft JPEG code is throwing away slightly more information than the Leadtools code. The differences are mostly in the low order bits which, under normal viewing, are nearly impossible to see. Or possibly Leadtools is doing some extra smoothing or some other proprietary processing.
What about the file sizes of the two 100% JPEG versions?
Another problem with comparing JPEG implementations is that there is no standard for what different quality settings mean. One implementation's 95% may give a different compression ratio than another. What this looks like to me is that at 100%, the Microsoft JPEG code is throwing away slightly more information than the Leadtools code. The differences are mostly in the low order bits which, under normal viewing, are nearly impossible to see. Or possibly Leadtools is doing some extra smoothing or some other proprietary processing.
What about the file sizes of the two 100% JPEG versions?
Jonathan Sachs
Digital Light & Color
Digital Light & Color
-
- Posts: 199
- Joined: December 1st, 2011, 1:39 pm
- What is the make/model of your primary camera?: Canon/5DMIII
Re: JPG banding issue
The PWP7 file size of the JPEG is: 108,091 bytes
The PWP8 file size of the JPEG is: 119,252 bytes
(File size is actual file size, not "size on disk".)
JPEG rendered from same 48-bit tif using 4:4:4 100%Q. For PWP7, I unchecked "Include Profile" and "Include Comments".
For PWP8, I set Metadata to "None".
The PWP8 file size of the JPEG is: 119,252 bytes
(File size is actual file size, not "size on disk".)
JPEG rendered from same 48-bit tif using 4:4:4 100%Q. For PWP7, I unchecked "Include Profile" and "Include Comments".
For PWP8, I set Metadata to "None".
-
- Posts: 80
- Joined: April 25th, 2009, 12:35 pm
- What is the make/model of your primary camera?: Nokia N8-00
Re: JPG banding issue
JPEGsnoop is a good tool for analyzing JPEG characteristics and compression levels (open source, Windows executable, no installation required, but only for people who know all about the JPEG format, which I don't).
Anyway, I attach the output for the two jpeg images of the first post in this topic. (Can we have *.txt as an allowed file type for attachments? I had to zip these files to attach them...)
The overall compression for the PWP 8 image (Compression Ratio: 27.44:1 Bits per pixel: 0.87:1) is higher than the PWP 7 image (Compression Ratio: 15.93:1 Bits per pixel: 1.51:1). So, as you say, notions of what "100%" quality factor may mean in practice really do make a difference!
BTW, instead of using the Microsoft built-in JPEG routines for PWP8, why not try something like lib-jpeg-turbo which is an actively maintained, BSD licensed codec? There is even a NuGet package for recent Microsoft compilers https://www.nuget.org/packages/TurboJpegWrapper/ and in any case extensive documentation on the codec behaviour itself.
Anyway, I attach the output for the two jpeg images of the first post in this topic. (Can we have *.txt as an allowed file type for attachments? I had to zip these files to attach them...)
The overall compression for the PWP 8 image (Compression Ratio: 27.44:1 Bits per pixel: 0.87:1) is higher than the PWP 7 image (Compression Ratio: 15.93:1 Bits per pixel: 1.51:1). So, as you say, notions of what "100%" quality factor may mean in practice really do make a difference!
BTW, instead of using the Microsoft built-in JPEG routines for PWP8, why not try something like lib-jpeg-turbo which is an actively maintained, BSD licensed codec? There is even a NuGet package for recent Microsoft compilers https://www.nuget.org/packages/TurboJpegWrapper/ and in any case extensive documentation on the codec behaviour itself.
- Attachments
-
- JPEGsnoop_logs.zip
- Output of JPEGsnoop on first post's images.
- (6.57 KiB) Downloaded 372 times