Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
Color conversion with ICC profiles #1567
base: main
Are you sure you want to change the base?
Color conversion with ICC profiles #1567
Changes from 1 commit
16179b3
eeb40f5
8b96d37
aa2f1e9
3debb26
0812085
1094dc6
759f053
4cde4ef
a973713
33339d0
cdb495c
5f7acc1
7e2bc20
dc166a7
dcc8147
73c8d8f
d229fed
0a08da0
daf366b
54856ff
eee14c6
f60d4b8
8de137e
fb8003c
9f0f9cb
ece11eb
bd7257b
9a21485
ba76964
98d1758
66554cb
e90f165
8c580a7
a81dac9
902ed99
e3aa452
0dd68fe
6e3dc81
b7833a4
c3984aa
0fff06d
f1c05ee
3be31c3
6c2ee90
20e9b7f
d6fbc01
67ed4ce
b036cc3
52f88c8
ed47678
10bea86
5b131ad
ed8091b
6225db3
a65c599
60f3d9d
c940b86
a567613
3e06687
c1ebbfe
d89d8c5
63c89ca
3389d7a
7b0ff3b
29ed2b4
5f975e5
79f5dfa
b88b2a9
bca4cad
6e2c29c
5b374da
441f07e
6654218
21fec4e
fd2e8a9
19ff69d
3cd7d67
0327dca
9de3935
8e92f20
312b55e
44aae40
df3d230
d20fddb
d60ac76
cfa2760
369bf5f
7d4a742
f4e9509
9ceed23
f21c0c2
f147aad
7492109
630df8a
54143df
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Amusingly the matrix is applied to the actual XYZ not the scaled XYZ. Is there a better way to descale this? (Apologies for my rookie vector wrangling)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmmmm… this means we are scaling then descaling each pixel. Do all other calculators use scaled values? If so can we avoid the initial scaling or update this to match?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the only calculator I've encountered so far that requires the non-scaled values. Won't be sure until we find profiles with the other types of curves but it's likely to be just this one, for the matrix multiplication to apply correctly.
We might be able to do something similar to the
Is16BitLutEntry
check and avoid scaling XYZ if we know we're usingColorTrcCalculator
, or add aIVector4Calculator.NeedsScaled
property for calculators themselves to define? It would add more complexity to the target PCS calculation but save on a couple of potential scaling roundtrips.Also, I'm aware that in general I'm flopping between e.g.
Vector
andCieXyz
quite a bit, is that problematic?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should try to avoid switching between the types where possible as that causes per-pixel overhead. Perhaps we should be trying to provide this information up-front? It's tricky...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm a little confused by this comment?
How does the calculator know how to descale the output from the scaled input?
Also doesn't the Gray TRC caclulator require the same?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure I follow your question but I'm still getting my head around it myself. Does it help if I say...
I've experimented with a different approach that might make things clearer, moving the responsibility of knowing about this from
ColorTrcCalculator
toColorProfileConverter
. The downside is you can't "just use" the calculator, but that's true of ICC transforms generally anyway once you start looking closely.Imagine
ColorTrcCalculator
doesn't have these changes, and insteadColorProfileConverter
has these extra steps:I can't tell if it feels better or worse. Depends what mood I'm in when I look!
As for Gray TRC, I can't see any evidence that it does the same thing, just multiplies the scaled monochrome by scaled D50.
💡 If that matrix multiplication in
LutEntryCalculator
does indeed need fixing, then presumably the matrix multiplication inColorTrcCalculator
does too.