reinhardTonemap function

Image reinhardTonemap(
  1. Image hdr, {
  2. Image? mask,
  3. Channel maskChannel = Channel.luminance,
})

Applies Reinhard tone mapping to the hdr image, in-place.

Implementation

Image reinhardTonemap(Image hdr,
    {Image? mask, Channel maskChannel = Channel.luminance}) {
  const yw = [0.212671, 0.715160, 0.072169];

  // Compute world adaptation luminance, _Ywa_
  var ywa = 0.0;
  for (final p in hdr) {
    final r = p.r;
    final g = p.g;
    final b = p.b;
    final lum = yw[0] * r + yw[1] * g + yw[2] * b;
    if (lum > 1.0e-4) {
      ywa += log(lum);
    }
  }

  ywa = exp(ywa / (hdr.width * hdr.height));

  final invY2 = 1.0 / (ywa * ywa);

  for (final p in hdr) {
    final r = p.r;
    final g = p.g;
    final b = p.b;

    final lum = yw[0] * r + yw[1] * g + yw[2] * b;

    final s = (1.0 + lum * invY2) / (1.0 + lum);

    final msk = mask?.getPixel(p.x, p.y).getChannelNormalized(maskChannel);
    if (msk == null) {
      p
        ..r = r * s
        ..g = g * s
        ..b = b * s;
    } else {
      p
        ..r = mix(p.r, r * s, msk)
        ..g = mix(p.g, g * s, msk)
        ..b = mix(p.b, b * s, msk);
    }
  }

  return hdr;
}