POV-Ray : Newsgroups : povray.beta-test : POV-Ray 3.7 gamma - status Server Time
23 Jan 2025 14:03:23 EST (-0500)
  POV-Ray 3.7 gamma - status (Message 1 to 10 of 17)  
Goto Latest 10 Messages Next 7 Messages >>>
From: clipka
Subject: POV-Ray 3.7 gamma - status
Date: 15 Sep 2009 12:43:20
Message: <4aafc428@news.povray.org>
So, here is the current status of what I'm busy implementing:

* Philosophy

- POV-Ray shall always operate in a linear RGB color space based on 
light intensity (as opposed to perceived brightness), to properly 
compute physical effects. (In the long run, this should also include a 
clear definition of the RGB primaries and white point, but at present 
this definition is limited to gamma issues.)

- In General, all image-format input files sall be converted to 
POV-Ray's operating color space before any further processing. (In the 
long run, this should include full color profile handling; however, at 
present it is limited to gamma correction.)

- For file formats with an official specification of gamma handling (and 
later also regarding color profile handling), conversion shall be based 
on that definition or recommendation. For any other files, conversion 
shall be based on a common assumed input file color space, which shall 
be configurable in the scene file and default to sRGB.

- Image-format input files used immediately in certain language 
constructs obviously indicating that they are mere data containers (e.g. 
height fields) shall be exempt from the aforementioned conversion, and 
the raw encoded values used instead. (Note however that this does not 
apply to indirect use of input image files.)

- For any individual image input file (including files otherwise exempt 
from conversion), the user shall be able to override the conversion 
rules via SDL, in order to handle files not adhering to standards, or 
adapt to the intended use of the file.

- To the extent possible in the framework designed to achieve these 
goals, reasonable effort shall be made to emulate POV-Ray 3.6 behaviour 
for legacy scenes. However, where such behaviour is obscure and/or 
difficult to emulate consistently, backwards compatibility shall not be 
preserved.


* Syntax:

- The assumed input file gamma (to be used for all input file formats 
lacking a proper definition or recommendation) can be set in the 
global_settings section as follows:

     global_settings {
         file_gamma GAMMA
     }

where GAMMA is either the keyword 'srgb' (to indicate that input files 
are assumed to match sRGB) or a numeric expression (to indicate that 
input files are assumed to be pre-corrected for displays with the 
specified gamma value).

(Note that sRGB is /not/ perfectly equivalent to a gamma 2.2 
pre-correction, though it comes very close.)

At present, the setting is global, and should therefore /not/ be messed 
with in "library" include files.

- The input file gamma of a particular file can be overriden by 
specifying "file_gamma GAMMA" after the file name, e.g.:

     image_map {
         exr "foobar.exr" file_gamma 1.8
         interpolate 2
     }

(Note that for parser design reasons, the "file_gamma" statement must 
/immediately/ follow the file name.)

This will bypass any gamma or gamma-alike adjustment normally performed 
according to the file format standards, and use a decoding gamma curve 
as specified by the user instead.


* Legacy Behaviour:

- In the presence of an 'assumed_gamma 1.0' statement, gamma correction 
of input files is always turned on, but global file_gamma defaults to 
1.0, effectively disabling gamma correction of input files /by default/ 
(for most file types; see below).

- In the presence of an 'assumed_gamma 2.2' statement (or whatever 
happens to be the hard-coded default Display_Gamma on the particular 
machine), gamma correction of input files is always turned /off/. The 
file_gamma statement can still be used on individual files to enforce 
gamma-adjustment, in order to allow for some flexibility, but it will 
/not/ automatically compensate for the assumed overall scene gamma.

- Any other value of 'assumed_gamma' will be ignored (matching the 
behaviour of all recent betas).

- Global 'file_gamma' and 'assumed_gamma' will not mix; if both are 
encountered, 'assumed_gamma' will be ignored.

- In POV-Ray 3.6, non-paletted PNG files with gAMA chunks were the 
/only/ input files which were ever gamma-adjusted, and these were 
/always/ gamma-adjusted (unless used in a data-container context). This 
will be changed even for legacy scenes; fortunately, this will not give 
different results for standard PNG files; however, it /will/ change the 
look of PNG files with a gAMA of 1.0.


* Related Changes:

- 8-bit paletted PNG files will now be gamma-adjusted (or not) just like 
ordinary 24/32-bit PNG fils.

- An sRGB chunk in PNG files will now take precedence over a gAMA chunk, 
and will actually cause the sRGB transport function to be applied 
instead of a plain 2.2 power law gamma; this is likely to cause minor 
differences in the look of most PNG input images, but will be "more 
correct".

- Gamma adjustment of files is now exclusively performed /after/ 
conversion to floating-point format, in order to improve quality.

- Several bugs in the file readers have been eliminated.

- "Out-of-the box" transparency support for GIF files has been added.


* Implementation

- High dynamic range images (presently only OpenEXR and Radiance HDR) 
are gamma-corrected "on the fly" while reading the file.

- Paletted images are gamma-corrected by adjusting their palette data 
accordingly.

- Non-paletted integer images are kept in "native" format without 
applying gamma adjustment, in order to save memory. Gamma correction is 
instead applied at render time, using a pre-computed lookup table in 
hope of gaining a bit of a speed advantage. (Lookup tables are shared 
between images with the same gamma curve of course.)


Hmm... did I forget to mention anything? Probably yes, but I guess I 
can't help it :-)


Post a reply to this message

From: clipka
Subject: Re: POV-Ray 3.7 gamma - status
Date: 15 Sep 2009 13:34:36
Message: <4aafd02c@news.povray.org>
clipka schrieb:
> * Legacy Behaviour:
> [...]
> - In POV-Ray 3.6, non-paletted PNG files with gAMA chunks were the 
> /only/ input files which were ever gamma-adjusted, and these were 
> /always/ gamma-adjusted (unless used in a data-container context). This 
> will be changed even for legacy scenes; fortunately, this will not give 
> different results for standard PNG files; however, it /will/ change the 
> look of PNG files with a gAMA of 1.0.
> [...]
> 
> Hmm... did I forget to mention anything? Probably yes, but I guess I 
> can't help it :-)

Ah yes, one more thing:

The above claim that results will not differ for most PNG files does 
/not/ hold true if assumed_gamma is not specified at all. In that case, 
POV-Ray 3.6 applied some particularly mental gamma-'correction', which 
will /not/ be matched by the new behaviour.


Post a reply to this message

From: Warp
Subject: Re: POV-Ray 3.7 gamma - status
Date: 15 Sep 2009 16:55:48
Message: <4aafff54@news.povray.org>
Sounds good to me. One minor thing, though:

clipka <ano### [at] anonymousorg> wrote:
> - The assumed input file gamma (to be used for all input file formats 
> lacking a proper definition or recommendation) can be set in the 
> global_settings section as follows:

>      global_settings {
>          file_gamma GAMMA
>      }

  I think the keyword is a bit confusing because it doesn't make clear
whether it affects input files or output files. Could perhaps a more
unambiguous keyword be chosen, something like "input_gamma"?

-- 
                                                          - Warp


Post a reply to this message

From: Thorsten Froehlich
Subject: Re: POV-Ray 3.7 gamma - status
Date: 15 Sep 2009 17:12:36
Message: <4ab00344@news.povray.org>
Warp wrote:
>   Sounds good to me. One minor thing, though:
> 
> clipka <ano### [at] anonymousorg> wrote:
>> - The assumed input file gamma (to be used for all input file formats 
>> lacking a proper definition or recommendation) can be set in the 
>> global_settings section as follows:
> 
>>      global_settings {
>>          file_gamma GAMMA
>>      }
> 
>   I think the keyword is a bit confusing because it doesn't make clear
> whether it affects input files or output files. Could perhaps a more
> unambiguous keyword be chosen, something like "input_gamma"?

Globals are evil. I would instead recommend making this a bitmap only 
feature, not supplying a global setting.

	Thorsten


Post a reply to this message

From: clipka
Subject: Re: POV-Ray 3.7 gamma - status
Date: 15 Sep 2009 17:14:32
Message: <4ab003b8@news.povray.org>
Warp schrieb:
>   I think the keyword is a bit confusing because it doesn't make clear
> whether it affects input files or output files. Could perhaps a more
> unambiguous keyword be chosen, something like "input_gamma"?

I think that would be even more ambiguous, as it might be taken to 
include color values as well.

It also allows for using the same keyword both for individual files as 
well as the fallback setting.


But I'm thining about moving it to the "default" section instead anyway. 
Aside from appearing to be more fitting there, I guess that would also 
reduce the risk of people expecting it to affect the output file.


Post a reply to this message

From: clipka
Subject: Re: POV-Ray 3.7 gamma - status
Date: 15 Sep 2009 17:44:16
Message: <4ab00ab0$1@news.povray.org>
Thorsten Froehlich schrieb:
> Globals are evil.

Why is that?

We're not talking about C global variables here I guess :-)


Post a reply to this message

From: clipka
Subject: Re: POV-Ray 3.7 gamma - status
Date: 15 Sep 2009 19:36:28
Message: <4ab024fc@news.povray.org>
Thorsten Froehlich schrieb:
> Globals are evil. I would instead recommend making this a bitmap only 
> feature, not supplying a global setting.

I think a global setting (not necessarily in the global_settings block - 
the default block would do as well) should be made available.

Suppose some guy who prefers to work with images having a gamma 
pre-correction of 1.8 for whatever reason, in some file format that 
isn't linear by default: Why shouldn't we make his life easier?

If we'd want to force users to change their standard processes to match 
the sRGB color space, then why is there a File_Gamma INI file setting to 
adjust the output file gamma?


Post a reply to this message

From: Le Forgeron
Subject: Re: POV-Ray 3.7 gamma - status
Date: 16 Sep 2009 11:53:55
Message: <4ab10a13@news.povray.org>
Le 15/09/2009 23:12, Thorsten Froehlich nous fit lire :
> Warp wrote:
>>   Sounds good to me. One minor thing, though:
>>
>> clipka <ano### [at] anonymousorg> wrote:
>>> - The assumed input file gamma (to be used for all input file formats
>>> lacking a proper definition or recommendation) can be set in the
>>> global_settings section as follows:
>>
>>>      global_settings {
>>>          file_gamma GAMMA
>>>      }
>>
>>   I think the keyword is a bit confusing because it doesn't make clear
>> whether it affects input files or output files. Could perhaps a more
>> unambiguous keyword be chosen, something like "input_gamma"?
> 
> Globals are evil. I would instead recommend making this a bitmap only
> feature, not supplying a global setting.
> 
>     Thorsten

OMHG... I'm agreeing with Thorsten.
That's a parallel univers, I will wake up soon.

More seriously, put it where it is needed: near the file picture!
That's a setting which is really tuned to the related file.

A global would have no more purpose than a global setting for text (you
can always justify the usage of a global text font setting... but nobody
ever came so far with such suggestion)


Post a reply to this message

From: clipka
Subject: Re: POV-Ray 3.7 gamma - status
Date: 16 Sep 2009 13:08:41
Message: <4ab11b99$1@news.povray.org>
Le_Forgeron schrieb:
> More seriously, put it where it is needed: near the file picture!
> That's a setting which is really tuned to the related file.

You didn't pay much of attention, did you? There /is/ an (optional) 
per-file setting.

But I can well imagine that there are people out there who prefer to 
/consistently/ work with files pre-corrected for some other gamma space 
than sRGB for one reason or the other, hence the additional global 
setting: To customize the default.

> A global would have no more purpose than a global setting for text (you
> can always justify the usage of a global text font setting... but nobody
> ever came so far with such suggestion)

Maybe that's because the text{} statement /requires/ you to specify a 
font, and there's no default that a user could possibly hope to customize.

You could just as well argue that there's not much purpose in a default 
{ finish {...} } statement - after all, don't the finish settings belong 
to the individual material?


Post a reply to this message

From: Christoph Hormann
Subject: Re: POV-Ray 3.7 gamma - status
Date: 17 Sep 2009 08:39:45
Message: <4ab22e11$1@news.povray.org>
clipka schrieb:
> - Image-format input files used immediately in certain language 
> constructs obviously indicating that they are mere data containers (e.g. 
> height fields) shall be exempt from the aforementioned conversion, and 
> the raw encoded values used instead. (Note however that this does not 
> apply to indirect use of input image files.)

It would OTOH be nice if POV-Ray would treat images the same way 
everywhere (it does not in 3.6 either but that's a different story).

> 
> - Non-paletted integer images are kept in "native" format without 
> applying gamma adjustment, in order to save memory. Gamma correction is 
> instead applied at render time, using a pre-computed lookup table in 
> hope of gaining a bit of a speed advantage. (Lookup tables are shared 
> between images with the same gamma curve of course.)

A dynamic caching scheme for converted values would be an alternative - 
significantly more complex to implement of course.

As long as this is only about gamma correction this is probably 
unnecessary but with color space conversions on-the-fly conversion might 
be too expensive.

-- Christoph


Post a reply to this message

Goto Latest 10 Messages Next 7 Messages >>>

Copyright 2003-2023 Persistence of Vision Raytracer Pty. Ltd.