Skip to content

Scene radiance

Brian Wandell edited this page May 16, 2018 · 45 revisions

Scene Scripts and tutorials


Simple scenes

The isetcam scene structure is a simplified description of the scene spectral radiance. The basic scene describes the spectral radiance at a set of points at different distances, and each point is assumed to emit light uniformly in all of the directions that reach the camera aperture. We can describe such a scene spectral radiance by the spectral power distribution at each visible point, with units of quanta/s/sr/nm/m^2. A simple scene representation is useful for many of calculations, such as a scene with all points at a distance or a scene with mainly a planar surface (e.g., test chart). This approximation suffices for many simple scenes used in image quality metrics and camera evaluation, and many users never need more than this basic structure.

Creating 3D scenes

A more complete scene description represents multiple parameters of the rays in every direction every point (light field). To fully account for the scene depth isetcam calculations use the related iset3d toolbox. This toolbox uses computer graphics to trace rays through a model of the camera optics. The 3D scene rendering methods in iset3d calculate this full set of rays so that the rendered image at the sensor correctly accounts for depth and related optics effects (e.g., depth of field).

The iset3d methods also extend the calculations to non-uniform emissions (bidirectional reflectance distribution functions) from each point and even retroreflective materials. These methods can also be used to simulate light field cameras based on microlens arrays.

When using iset3d it is typical to specify a lens and use the calculation to create an optical image. The iset3d code returns a scene structure only if the user specifies a pinhole camera.

Basic scene functions

Like other ISETCAM structures, the scene has these basic methods

  • sceneCreate - Method that produces many different types of scenes for testing
  • sceneSet - Set scene parameters (e.g., field of view, or mean luminance)
  • sceneGet - Get scene parameters
  • scenePlot - Plot scene functions and parameters
  • sceneWindow - Open up the scene graphical user interface (GUI), which can hold a collection of scenes

More information about the scene parameters and programming with scenes can be found in the scene programming wiki pages, and in the scene Scripts and tutorials.

sceneFromFile

In addition to the many test functions implemented in sceneCreate, the ISETCAM function sceneFromFile can read an RGB image and return a scene radiance structure. This enables you to test camera features using almost any image as an input to the simulation.

The scene returned from an RGB image is not a physically precise description of the scene; it is just a useful way to produce a rough approximation. The algorithm implemented in sceneFromFile creates the scene spectral radiance that one would measure if (a) the RGB data are displayed on a monitor, and (b) the scene illumination is the monitor white point. Hence, factors that depend on the true scene spectral radiance or on depth will not be properly represented in the scene. Spatial patterns, light levels, and related effects will be represented.

Here is the sceneFromFile code in action.

d = displayCreate('LCD-Apple');
meanLuminance = 100;
scene = sceneFromFile('eagle.jpg','rgb',meanLuminance,d);
ieAddObject(scene); sceneWindow;

Notice that the scene depends on the display model, and these can differ substantially. Here is a comparison between two different displays.

d = displayCreate('LCD-Apple'); meanLuminance = 100;
scene = sceneFromFile('eagle.jpg','rgb',meanLuminance,d);
rgb1 = sceneGet(scene,'rgb'); imshow(rgb1);

d = displayCreate('CRT-Dell');
scene = sceneFromFile('eagle.jpg','rgb',meanLuminance,d);
rgb2 = sceneGet(scene,'rgb'); imshow(rgb2);

Clone this wiki locally