Table of Contents

Light Sources

Regarding light sources, GroIMP provides a complete set of possible implementations. They all implement the Light and LightBase interfaces, which makes them easy to handle and exchange. The standard light sources are: PointLight, SpotLight, and DirectionalLight.

The following code places the three light sources next to each other starting with a PointLight on the left, a SpotLight in the middle, and a DirectionalLight on the right.

protected void init () [
  Axiom ==> 
    [ Translate(0.0,0,0) 
      LightNode.(setLight(new PointLight())) 
      M(-0.6) TextLabel("PointLight")]
    [ Translate(0.75,0,0) 
      LightNode.(setLight(new SpotLight()))  
      M(-0.1) TextLabel("SpotLight")]
    [ Translate(1.5,0,0) 
      LightNode.(setLight(new DirectionalLight()))  
      M(-0.1) TextLabel("DirectionalLight")]
  ;
]

In the 3D View, they are visualized as a cone for a SpotLight, and as a single line for a DirectionalLight. The PointLight on the left has no visualization.

All light sources provide the functionality of visualizing the light rays emitted by them. To do so, the visualization just need to be activated. Additionally, the number of visualized light rays and their length can be set.

protected void init () [
  Axiom ==> 
    LightNode.(setLight(new PointLight().(
      setVisualize(true),
      setNumberofrays(400),
      setRaylength(0.5)
    )));
]

The output of the light ray visualization of the three light sources is given below.

PointLight

A PointLight is emitting light rays equally to all directions.

SpotLight

As a specialization of a PointLight, the SpotLight emits only light rays within a define opening angle.

DirectionalLight

The DirectionalLight emits parallel light rays equally over the whole scene. It adapts its size automatically to the size of the scene. In difference to the PointLight and SpotLight, the DirectionalLight does not has a setPower function but instead a setPowerDensity function to define the power that should be received by each square meter of the the scene.

AreaLight

An area light can be created using a parallelogram as base and transforming it to a light source. It will cast a diffuse distribution in the positive direction of the local z-axis of the parallelogram. Note, as for now, it does not (yet) support user defined physical light distribution.

module AreaLamp extends Parallelogram() {
  {
    setLight(new AreaLight().(setPower(100)));
    setLength(1); // 1m
    setAxis(0.5f, 0, 0);
  }
}

PhysicalLight

tbd

Power distribution over several light sources

The power of all light sources implemented within GroIMP are given/set in Watt. When the light model is executed, the number of light rays is distributed no equally over all light sources, but rather relative to their power! This has the consequence that when a light source with a high power and one with a very low power are together in a scene, the physical power distribution of the light source with the lower power will be very much underrepresented.

As an example, a scene with two light sources with a power of 10W and 90W, and a total number of 10.000 rays, the first light will create 1.000 rays, the second one 9.000 rays.