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

KHR_environment_map #1956

Open
wants to merge 29 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
a2dbf75
Initial commit for environment light extension
rsahlin Mar 16, 2021
5e7ec02
Update schema
rsahlin Mar 16, 2021
e44c245
Simplify by using KTX2 for cubemaps
rsahlin Mar 16, 2021
2b2a174
Remove rotation and update to use specularCubemaps
rsahlin Mar 16, 2021
0370801
Add KTX2 float formats
rsahlin Mar 16, 2021
c2df7bb
Clarify use of other KHR extensions
rsahlin Mar 17, 2021
6612a00
Updates according to review comments
rsahlin Apr 7, 2021
3b3e9be
Updated wording related to KTX
rsahlin Apr 8, 2021
905350a
Updates, reference KHR_texture_ktx
rsahlin Apr 9, 2021
0df13f2
Update to open issues
rsahlin Apr 9, 2021
fdc5e5b
Clarification for cubemap filtering
rsahlin Apr 30, 2021
20d55ca
Clarification for cubemap filtering
rsahlin Apr 30, 2021
70653fe
Remove resolved issues
rsahlin May 20, 2021
0f553ce
Updated light properties
rsahlin May 26, 2021
4706330
Update specularCubemap description
rsahlin May 26, 2021
3744d7e
Moved `lights` into extension
rsahlin May 26, 2021
71d8f3a
Updates to use local cubemap, clarifications
rsahlin Oct 15, 2021
73b3133
Add bbox min/max, use luminance and texture ref
rsahlin Oct 15, 2021
6f2b3fc
Remove KHR_texture ktx extension
rsahlin Oct 18, 2021
904937b
Add KHR_texture_ktx to textures array
rsahlin Oct 18, 2021
a596a69
Clarification of light contribution
rsahlin Oct 21, 2021
d2ffe33
Remove luminance factor
rsahlin Oct 21, 2021
a8c21ec
Remove luminance from schema
rsahlin Oct 21, 2021
3232a99
Add contributor
rsahlin Oct 21, 2021
00b3730
Clarification of pre-filtered maps, add references
rsahlin Oct 22, 2021
590c2ac
Remove dependency to KHR_texture_ktx
rsahlin Dec 8, 2021
bdbd58d
Schema update
rsahlin Dec 13, 2021
0b849a7
Rename extension to KHR_environment_map
rsahlin Jun 14, 2023
c6241f9
Update README.md
rsahlin Jun 20, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
174 changes: 174 additions & 0 deletions extensions/2.0/Khronos/KHR_lights_environment/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,174 @@

# KHR_lights_environment

## Contributors

* Norbert Nopper, <mailto:nopper@ux3d.io>
* Rickard Sahlin, <mailto:rickard.sahlin@ikea.com>
* Gary Hsu, Microsoft, <mailto:garyhsu@microsoft.com>
* Mike Bond, Adobe, <mailto:mbond@adobe.com>
* Ben Houston, ThreeKit, <mailto:bhouston@threekit.com>

## Status

Draft

## Dependencies

Written against the glTF 2.0 spec.
This extension may use KHR_texture_basisu, KHR_texture_float_bc6h or KHR_texture_float_f16
rsahlin marked this conversation as resolved.
Show resolved Hide resolved

## Overview
This extension provides the ability to define image-based lights in a glTF scene.
Image-based lights consist of an environment map that represents specular radiance for the scene as well as irradiance information.
This can be used on it's own - ie a glTF asset with only environment map data - for a usecase where the IBL needs to be distributed.
It can also be used together with model data, for usecases where a model shall be displayed in a defined environment.

Many 3D tools and engines support image-based global illumination but the exact technique and data formats employed vary.
Using this extension, tools can export and engines can import image-based lights and the result should be highly consistent.

This extension specifies exactly one way to format and reference the environment map to be used, the goals of this are two-fold.
First, it makes implementing support for this extension easier.
Secondly, it ensures that rendering of the image-based lighting is consistent across runtimes.

A conforming implementation of this extension must be able to load the image-based environment data and render the PBR materials using this lighting.

The environment light is defined by a cubemap, this is to simplify realtime implementations as these are likely to use cubemap texture format.
Cubemaps can be supplied pre-filtered, by including the pre-filtered mip-levels, where each mip-level corresponds to increasing roughness values.
If cubemap does not include mip-levels then filtering will be performed at load time.
If a compressed texture format is used then pre-filtered mip-levels must be included.

## Declaring an environment light

The KHR_lights_environment extension defines an array of image-based lights at the root of the glTF and then each scene can reference one.
Each environment light definition consists of a single cubemap that describes the specular radiance of the scene, the l=2 spherical harmonics coefficients for diffuse irradiance and intensity values.
The cubemap is defined by texture references to a KTX2 file containing a cubemap.
These files can contain compressed textures using KHR_texture_basisu or use a float texture format as defined by KHR_texture_float_bc6h or KHR_texture_float_f16

When the extension is used, it's mandated to use value image/ktx2 for the mimeType property of (cubemap) images that are referenced by the `specularCubemap` property of KHR_lights_environment extension object.

The following will load the environment light using KHR_texture_basisu on clients that supports that extension, otherwise fall back to using KTX2 using VK_FORMAT_R8G8B8_SRGB.

TODO: Clarify what KTX2 formats, if any, are supported by default.
Should a separate extension be created to enable ktx2 as image source?


```json
"textures": [
{
"source": 0,
"extensions": {
"KHR_texture_basisu": {
"source": 1
}
}
}
],
"images": [
{
"name": "environment cubemap 0",
"uri": "cubemap0.ktx2",
"mimeType": "image/ktx2"
},
{
"name": "environment cubemap basisu",
"uri": "cubemap_basisu.ktx2",
"mimeType": "image/ktx2"
}
],
"extensions": {
"KHR_lights_environment" : {
"lights": [
{
"intensity": 1.0,
"irradianceCoefficients": [...3 x 9 array of floats...],
rsahlin marked this conversation as resolved.
Show resolved Hide resolved
"specularCubemaps": [0],
}
]
}
}
```

## Specular Radiance Cubemaps

The cubemap used for specular radiance is defined as a cubemap containing separate images for each cube face.
The mip levels shall evenly map to roughness values from 0 to 1 in the PBR material and should be generated with a principled multi-scatter GGX normal distribution. The data in the maps represents illuminance in candela per square meter (nit).
rsahlin marked this conversation as resolved.
Show resolved Hide resolved

If mip-levels are not included, then the entire mip chain of images should not be generated.
Instead, the lowest-resolution mip should have sufficient size to represent the maximally-blurred radiance map corresponding to roughness=1.
The texture references defines the largest dimension of mip 0 and should give the loading runtime the information it needs to generate the remainder of the mip chain and sample the appropriate mip level in the shader.

Cube faces are defined in the KTX2 format specification, users of this extension must follow the KTX2 cubemap specification.

## Implementation Note
This section is non-normative

The cubemap textures are used both as direct light contribution and as source for reflection.
A performant way of achieving this is to store the reflection at different roughness values in mip-levels,
where mip-level 0 is for a mirror like reflection (roughness = 0) and the last mip-level is for maximum roughness (roughness = 0).
It is recommended to map roughness = 1 to a mip-level size that is larger than 1 * 1 pixels to avoid blockiness, it is generally enough to stop at 16 * 16 pixels.
To avoid oversampling of flat surfaces (low roughness values) it is recommended to use a 3D cubemap when possible.

[Runtime filtering of mip-levels](https://developer.nvidia.com/gpugems/gpugems3/part-iii-rendering/chapter-20-gpu-based-importance-sampling)


## Irradiance Coefficients

This extension may use spherical harmonic coefficients to define irradiance used for diffuse lighting.
Coefficients are calculated for the first 3 SH bands (l=2) and take the form of a 9x3 array.

## Implementation Note
This section is non-normative

Implementations may calculate the irradiance cubemap from the specular radiance cubemap and use instead.
One possible benefit with spherical harmonics is that it is generally enough evaluate the harmonics on a per vertex basis, instead of sampling a cubemap on a per fragment basis.

[Realtime Image Based Lighting using Spherical Harmonics](https://metashapes.com/blog/realtime-image-based-lighting-using-spherical-harmonics/)
[An Efficient Representation for Irradiance Environment Maps](http://graphics.stanford.edu/papers/envmap/)

### Using the environment light

The environment light is utilized by a scene.
Each scene can have a single environment light attached to it by defining the `extensions.KHR_lights_environment` property and, within that, an index into the `lights` array using the `light` property.
rsahlin marked this conversation as resolved.
Show resolved Hide resolved

```json
"scenes": [
{
"nodes": [
0
],
"extensions": {
"KHR_lights_environment": {
"light": 0
}
}
}
]
```


### Environment Light Properties

| Property | Description | Required |
|:-----------------------|:------------------------------------------| :--------------------------|
| `name` | Name of the light. | No |
| `intensity` | Brightness multiplier for environment. | No, Default: `1.0` |
| `irradianceCoefficients` | Declares spherical harmonic coefficients for irradiance up to l=2. This is a 9x3 array. | :white_check_mark: Yes |
| `specularCubemaps` | Cubemap texture | :white_check_mark: Yes |




## glTF Schema Updates

- [glTF.KHR_lights_environment.schema.json](schema/glTF.KHR_lights_environment.schema.json)
- [environment.schema.json](schema/environment.schema.json)
- [scene.KHR_lights_environment.schema.json](schema/scene.KHR_lights_environment.schema.json)

## Known Implementations

* `TODO: Add implementations`

## Reference

[Irradiance Environment Maps](https://graphics.stanford.edu/papers/ravir_thesis/chapter4.pdf)
Loading