Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

JPEG XL image format #700

Open
Schweinepriester opened this issue Sep 17, 2024 · 20 comments
Open

JPEG XL image format #700

Schweinepriester opened this issue Sep 17, 2024 · 20 comments
Labels
focus-area-proposal Focus Area Proposal

Comments

@Schweinepriester
Copy link

Schweinepriester commented Sep 17, 2024

Description

Same as last year, see #430 and the year before #176.

Specification

https://jpeg.org/jpegxl/documentation.html; ISO/IEC 18181

Additional Signals

@Mouvedia
Copy link

Mouvedia commented Sep 18, 2024

see also https://issues.chromium.org/issues/40168998 and https://connect.mozilla.org/t5/ideas/support-jpeg-xl/idi-p/18433

@conradsrc
Copy link

Here's a different, related Chromium ticket with a lot of activity about reopening the JXL issue.

I'll also copy a comment I recently left there that summarizes some recent coordination between the JPEG-XL team at Google Research, the Firefox team at Mozilla, and the jxl-oxide maintainer.

Adding onto the recent news that Mozilla is considering a Rust implementation of JPEG-XL, here's a comment from someone on the Google Research JPEG-XL team from last October's Interop discussion where they confirm that they could make a high-quality Rust decoder within several months, as well as the fact that they've already made the Chromium interfacing code for the C++ reference implementation.

If having a high quality Rust decoder implementation would arise as the only gating factor for choosing JPEG XL into interop 2024, the JPEG XL developer team in Google Research can deliver such by the end of Q2 2024. We have been successfully developing and maintaining Brotli and WOFF2 codecs for almost 10 years and would be able to do this too, safely and professionally, as well as supporting for the HDR needs there (such as ultra HDR, PQ, HLG and others).

We can also create the interfacing code for the browsers, including Chrome, Edge and Mozilla. We already have a version of C++ JPEG XL reference implementation interface code for Chrome and Edge ready for deployment, and could do the same for the possible Rust version.

Here's a follow-up comment 3 weeks later from Jon Sneyers, the JPEG-XL lead. Jon confirms the already-existing jxl-oxide Rust decoder fully confirms to the spec and passes all conformance tests:

We have tested conformance of the jxl-oxide decoder (which is implemented in Rust) and it is a fully conforming alternative implementation of JPEG XL. It correctly decodes all conformance test bitstreams and passes the conformance thresholds described in ISO/IEC 18181-3.

Three days ago, the owner of jxl-oxide confirmed they were coordinating with the core JPEG-XL devs to figure out how to potentially incorporate his project/efforts:

I'm in contact with some of the core devs in the JPEG XL community Discord server, and whether to use jxl-oxide as a base for the support in Firefox is yet to be decided (more work is needed, especially to match performance requirements, at least).

Meanwhile, Apple has continued to develop its JXL support on their product lines. Earlier today, Apple confirmed iPhone 16 Pros will be able to use JPEG-XL compression for ProRAW photos:

Apple and its various software iterations have supported JPEG XL for at least a year, including in Finder, Preview, Final Cut Pro, Pages, Photos, Mail, Safari, and more. Adobe has also supported the format for a while, including in Adobe Camera Raw and Lightroom Classic.

As for why it is including JPEG XL in the iPhone 16 Pro, Apple tells PetaPixel that the format promises two primary benefits over standard JPEG format: improved image quality and better compression performance. If there’s a 32MB JPEG image, that same photo will be 24MB in lossless JPEG XL and, even more impressively, about five megabytes in perceptually lossless format.

Apple has wrapped JPEG XL photos inside a DNG container, enabling ProRAW files to retain their flexibility while being significantly smaller — up to nearly five times smaller.

image

@hachahbar
Copy link

This year we must demand an explanation if the proposition is turned down again. No more backroom shenanigans.

@gordonfreeman01
Copy link

gordonfreeman01 commented Sep 19, 2024

This year we must demand an explanation if the proposition is turned down again. No more backroom shenanigans.

Agreed, unless there's a valid explanation for this format not being accepted through this platform (which is unlikely), its rejection after clearing due process is wholly unacceptable.

@andrews05
Copy link

As much as I would love to see Chrome forced to implement JPEG XL, I'm afraid these comments making "demands" are based on a misunderstanding of who and what Interop is. The Interop team is based on voluntary participation from the browser makers and has no authority to force anyone to do anything. If the Interop team approves a proposal that a browser maker has no intention of implementing, then it still won't be implemented and the process serves no purpose.

See the Team Charter for more info. A key quote:

The team makes decisions based on consensus. A decision has consensus if it has support from at least two participating organizations and no opposition.

Basically, if Chrome opposes JPEG XL then it won't be approved, period.

@hachahbar
Copy link

How do we know that Chrome blocks the adoption of JPEG XL within Interop? We don't know for sure who blocks it because the whole thing is opaque for us plebeians, so you can only assume. This is what I am talking about. We need transparency, if the chrome team blocks JXL, it needs to be known. The more a company abuses its position the more likely for it to be considered a monopoly and broken up. Last month, Google's search engine was found to be an illegal monopoly and the judge is considering forcing Google to spin off the Chrome browser. Another anti-trust lawsuit will look into Google's ad business this month. Hopefully this will knock some sense into them.

@Patronics
Copy link

Patronics commented Sep 20, 2024

Description

Same as last year, see #430 and the year before #176.

Given some comments last year suggested including the description in that comment thread, rather than just linking to a previous discussion, perhaps someone should do the same this year, ensuring there's a clear explanation of what JPEG-XL is and why it matters, allowing this proposal to stand on its own?

As a start I'll note that JPEG-XL's interop proposal for 2024 received far more community support than any other proposals, with nearly 700 "👍" reactions on the proposal's first message. Combined with the over 200 "👍" reactions from this year's proposal, accumulated over just the last 3 days, it's clear that the developer community is very interested in this proposal.

@BearCooder
Copy link

During last years biggest performance meetup, PerfNow, at the pre-conference meetup, there was a very convincing song live played. Give JXL a Chance - https://www.youtube.com/watch?v=VJaa1Le4W7c

Also unrelated to the song I think this sums it up pretty good:

jpge xl

@jyrkialakuijala
Copy link

jyrkialakuijala commented Sep 23, 2024

Dear JPEG XL and Interop communities, let's focus on the future of JPEG XL in Interop 2025. I have two suggestions to help move forward:

  1. Focus on solutions, not blame: The Interop team works hard within their process. Let's not dwell on last year's decision.
  2. Provide context for newcomers: Copy relevant information from last year's discussions and other sources for those unfamiliar with the issue. Describe JPEG XL benefits broadly, especially those functions that are not covered by existing modern solutions. Feel free to reuse my old positions.

Since the reason for excluding JPEG XL in Interop 2024 is "We did not have consensus to include this proposal." and not a more precisely communicated specific issue, we need a general overview of the format, its benefits and its current positioning and future plans in browsers and other digital platforms (including the slight adjustment in Mozilla's position) rather than to address a specific technical issue.

There might be a connection to the Rust decoder issue we discussed last year. To address this, and Mozilla's recently adjusted position on JPEG XL, volunteers and the JPEG XL developers at Google are working on jxl-rs, a new Rust-based decoder.

Key Points:

  • We want to be constructive in moving forward with JPEG XL for Interop 2025.
  • Broad and detailed background information will be helpful for those new to the discussion.
  • A new Rust decoder is under development by the JPEG XL team at Google, which could be relevant to Interop 2025.

@mtom55
Copy link

mtom55 commented Oct 10, 2024

To the JPEG XL community:

One of the key issues that affect JPEG XLs inclusion is the lack of transparency in the Interop process. We (Open Web Advocacy) believe that we should require this transparency.

We are pushing for transparency via this issue Interop Lack of Transparency & Accountability

@jacob-willden
Copy link

As far as Rust decoders for JPEG-XL go, there's not only jxl-rs, but also jxl-oxide. I'm not sure which one is more complete at this point, but it appears that either could be used in the future by Mozilla to support JPEG-XL.

@conradsrc
Copy link

DICOM, or Digital Imaging and Communications in Medicine is a worldwide standard for the storage and transfer of medical imaging data, with "a near universal level of acceptance among medical imaging equipment vendors and healthcare IT organizations". They just updated their standard to adopt JPEG-XL as a payload codec.

Here are some slides covering the decision. Some snippets:

  • Ability to forward migrate into JPEG XL without any loss of fidelity with
    existing JPEG, as a safe migration option with full backwards compatibility
  • As DICOMweb response is multiframe at much higher quality than gif
  • As lossless web response, is much smaller than PNG and easier to decode
  • Works well for both natural and synthetic images
  • No visual difference from what is seen, with 50-60% smaller
  • Profiling results show that JPEG XL is fast enough for decoding/encoding, but
    is not as fast as JPEG
  • WSI scanner vendors are interested in trying to generate JPEG XL directly
  • Reduction in artifacts is important for algorithms processing, and is better with
    JPEG XL
  • Streaming of data to both algorithms and viewers is important and better with
    JPEG XL
  • Can render portions of a tile that are important first (progressive)
  • May well be able to reduce quality to reduce size further without reducing
    machine or user quality as JPEG XL has lots of options with very few artifacts
  • JPEG XL is a logical extension to baseline JPEG, especially if easily
    supported in browsers.

They of course mention that incomplete web browser support is a downside but have gone ahead anyway. And based on what we've heard from Mozilla recently (detailed above), there's a fair chance that the "incomplete" support will be "most Chromium-based browsers" in the near future.

Also of note from the standard:

A JPEG Baseline image losslessly re-coded to JPEG XL is not a derived image unless the original JPEG image was a derived image.

Here's an IEEE proposal from a conference in June 2023 that was advocating for DICOM to adopt JXL's lossless compression as "a universal replacement for medical file size reduction."

@tif-calin
Copy link

Mozilla's concern is stated clearly

the increased attack surface of the reference decoder (currently behind a pref in Firefox Nightly), which weighs in at more than 100,000 lines of multithreaded C++

Chrome's position is also often misrepresented/reduced to just "not enough interest" (blatantly false ofc), but also

The new image format does not bring sufficient incremental benefits over existing formats to warrant enabling it by default

I think Mozilla's position is entirely reasonable. They are working with Google to develop a rust-based decoder that could resolve their concerns. I don't think it's fair to push them when they're actively looking into a solution that addresses their concerns

Chrome's position needs further elaboration and could probably be argued against.

@Best-HeyGman
Copy link

This issue is even more important than people commonly think. There will be a successor to JPEG, but JPEG-XL is the only candidate that allows a lossless transcoding from JPEG to JPEG-XL with a ~20% size reduction (according to my own tests).

Images on the web have already degraded due to generation loss from recompression. With WEBP, AVIF or HEIC you don't have any other choice than to recompress again with a loss, if you want to get any size reduction when switching to these formats.

I do think we owe it to the people that come after us to choose the successor to JPEG wisely and to consider the impact that our choice has on the preservation of images that already exist right now. It would be a shame to see them reduced to a porridge of pixels by the time they would be used to teach history lessons.

@AngelaDMerkel
Copy link

Images on the web have already degraded due to generation loss from recompression. With WEBP, AVIF or HEIC you don't have any other choice than to recompress again with a loss, if you want to get any size reduction when switching to these formats.

One of the advantages of JXL is that even in JXL to JXL recompression, the standard is designed to limit generation loss as we see in the JPEG to JPEG recompression. This is a huge advantage in some kinds of web communities

@jonnyawsom3
Copy link

Depending on the site, data usage can be limited by simply partially downloading JXL files.
For thumbnails, 0.1% is enough to load a file depending on the image. 20% for a low quality preview, ect. All without any extra data being transferred, only the rest of the file being requested.
Other formats require multiple different sizes or qualities to be stored in excess, adding processing time that you get for free with JPEG XL.

Legacy clients can still be served transcoded files, as the overhead is under 60ms to revert back to JPEG, further reducing storage costs.

Google's own saliency demo shows that regions of images can be prioritised, improving responsiveness with the aforementioned partial requests. Showing the focus first and the background last.

It's also redundant to data loss or corruption, albeit not currently enabled in libjxl. The image can still be rendered with missing AC or DC blocks, so long as the header is intact.
(If AC is corrupt, the underlying DC colors will be shown. If DC is corrupt, the overlayed AC texture will still be applied to a black/estimated DC color)

I think others have already said the common use cases and examples. The Spec is also being updated to allow UltraHDR transcoding, further futureproofing the format and retaining backwards compatibility.

@mo271
Copy link

mo271 commented Dec 18, 2024

Good news! The jxl-rs project (a safe and fast JPEG XL decoder implementation in Rust) is progressing well. We are currently on track to deliver the following milestones:

End of February 2025: Initial decoding capabilities and a preliminary API.
~April 2025: Aiming for a conforming decoder implementation, fully compliant with the JPEG XL specification.
~July 2025: Critical code paths fully SIMDified and with a finalized API.
This anticipated timeline should allow jxl-rs to be ready for browser integration in alignment with Interop 2025 goals.

We are also prepared to integrate jxl-rs into the main browsers.

We appreciate the community's continued interest and support. Please remember to treat each other with respect in all project discussions. A positive and collaborative environment is crucial for the success of JPEG XL.

@mchv
Copy link

mchv commented Dec 31, 2024

On the last day of this year, I thought it would be helpful to share an update from theguardian.com as we have publicly voiced support for the format, and reiterate that we would like browser engineering teams to focus on supporting this image format.

Earlier this year, in the summer, we started serving JPEG XL images to our readers when supported by their browsers. We were the first customer of our CDN image service to do so, and you can see impact on their global requests breakdown by format for them:

Screenshot 2024-12-31 at 13 40 03

We are impatiently waiting for an increased support by browsers and image processing software, as we aim to be able to use JPEG XL end-to-end from photographer’s camera to end users. We therefore consider Mozilla's new position an excellent news!

We would also appreciate it if Webkit could support progressive decoding and in general better support progressive images rendering while loading.

Finally as we’ve seen with AVIF, codecs improve over time. We think the best way for them all to reach their full potential is to allow them to compete by ensuring fair support.

@o-t-w
Copy link

o-t-w commented Dec 31, 2024

@mo271 will it include support for animated JPEG XL? It’s a shame that the Safari implementation doesn’t include animation.

There are use cases that require both animation and transparency. Hopefully Interop will be for all features of JPEG-XL. It's partly its feature set that makes JPEG-XL a worthwhile format in the first place.

@kanashimia
Copy link

@o-t-w jxl-rs can already read animations to some basic degree.
But Firefox and Safari use libjxl AFAIK, which can obviously work for decoding animations, they just don't integrate it well enough, which is a different problem. Firefox and Safari also had problems with transparency and progressive decoding last time I checked. So it will be up to the consumers of the library to integrate it with all of its features.
This is based on my understanding, can correct me on this.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
focus-area-proposal Focus Area Proposal
Projects
Status: No status
Development

No branches or pull requests