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

Remove aligned block format and do all calculations in the standard raster coefficient format #59

Merged
merged 17 commits into from
Apr 10, 2024

Conversation

mcroomp
Copy link
Collaborator

@mcroomp mcroomp commented Apr 5, 2024

The original lepton library used an order of the 64 coefficients that was

0..48 middle (7x7)
49 DC (0,0)
50 - 56 upper row (7)
57 - 63 left column (7)

This was designed to simplify some of the operations, but it turns out that it was more expensive to move back and forth between the aligned format and the normal JPEG block layout, especially since after vectorizing the operations many of the advantages of the layout disappeared for the middle blocks.

The main benefit goes to the IDCT operations which no longer need to shuffle the coordinates around, which speeds up the IDCT operations by about 30%


Also added AVX2 version to build, which is about 20% faster overall

@mcroomp mcroomp requested a review from gbrovman April 5, 2024 08:41
@mcroomp mcroomp merged commit 6bbb0ef into main Apr 10, 2024
2 checks passed
@mcroomp mcroomp deleted the removealigned branch April 10, 2024 04:27
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants