bin/falsecolor.pl
author Axel Jacobs <axel@jaloxa.eu>
Sun, 15 Dec 2013 18:06:17 +0000
changeset 47 6856591c4c7c
parent 34 b32315c3402e
child 75 e02e199c8c71
permissions -rwxr-xr-x
New example EPW weather file
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
     1
#!/usr/bin/perl -w
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
     2
# RCSid $Id: falsecolor.pl,v 2.4 2011/03/23 21:57:11 greg Exp $
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
     3
34
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
     4
######################################################################
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
     5
#
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
     6
# Please don't tinker with falsecolor.pl
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
     7
# This is an old version. The most recent version is in Radiance HEAD.
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
     8
#
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
     9
# Axel, Dec 2011
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
    10
#
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
    11
######################################################################
b32315c3402e Added warning about old version to falsecolor
Axel Jacobs <axel@jaloxa.eu>
parents: 1
diff changeset
    12
1
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    13
use strict;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    14
use File::Temp qw/ tempdir /;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    15
use POSIX qw/ floor /;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    16
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    17
my $mult = 179.0;    # Multiplier. Default W/sr/m2 -> cd/m2
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    18
my $label = 'cd/m2';    # Units shown in legend
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    19
my $scale = 1000;    # Top of the scale
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    20
my $decades = 0;    # Default is linear mapping
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    21
my $redv = 'def_red(v)';    # Mapping function for R,G,B
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    22
my $grnv = 'def_grn(v)';
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    23
my $bluv = 'def_blu(v)';
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    24
my $ndivs = 8;    # Number of lines in legend
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    25
my $picture = '-';
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    26
my $cpict = '';
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    27
my $legwidth = 100;   # Legend width and height
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    28
my $legheight = 200;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    29
my $docont = '';    # Contours
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    30
my $loff = 0;    # Offset to align with values
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    31
my $doextrem = 0;    # Don't mark extrema
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    32
my $needfile = 0;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    33
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    34
while ($#ARGV >= 0) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    35
	# Options with qualifiers
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    36
    if ("$ARGV[0]" eq '-lw') {    # Legend width
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    37
        $legwidth = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    38
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    39
    } elsif ("$ARGV[0]" eq '-lh') {    # Legend height
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    40
        $legheight = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    41
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    42
    } elsif ("$ARGV[0]" eq '-m') {    # Multiplier
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    43
        $mult = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    44
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    45
    } elsif ("$ARGV[0]" eq '-s') {    # Scale
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    46
        $scale = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    47
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    48
        if ($scale =~ m/[aA].*/) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    49
            $needfile = 1;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    50
        }
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    51
    } elsif ("$ARGV[0]" eq '-l') {    # Label
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    52
        $label = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    53
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    54
    } elsif ("$ARGV[0]" eq '-log') {    # Logarithmic mapping
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    55
        $decades = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    56
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    57
    } elsif ("$ARGV[0]" eq '-r') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    58
        $redv = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    59
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    60
    } elsif ("$ARGV[0]" eq '-g') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    61
        $grnv = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    62
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    63
    } elsif ("$ARGV[0]" eq '-b') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    64
        $bluv = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    65
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    66
    } elsif ("$ARGV[0]" eq '-pal') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    67
	$redv = "$ARGV[1]_red(v)";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    68
	$grnv = "$ARGV[1]_grn(v)";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    69
	$bluv = "$ARGV[1]_blu(v)";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    70
	shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    71
    } elsif ("$ARGV[0]" eq '-i') {    # Image for intensity mapping
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    72
        $picture = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    73
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    74
    } elsif ("$ARGV[0]" eq '-p') {    # Image for background
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    75
        $cpict = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    76
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    77
    } elsif ("$ARGV[0]" eq '-ip' || "$ARGV[0]" eq '-pi') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    78
        $picture = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    79
        $cpict = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    80
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    81
    } elsif ("$ARGV[0]" eq '-n') {    # Number of contour lines
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    82
        $ndivs = $ARGV[1];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    83
        shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    84
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    85
	# Switches
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    86
    } elsif ("$ARGV[0]" eq '-cl') {    # Contour lines
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    87
        $docont = 'a';
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    88
        $loff = 0.48;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    89
    } elsif ("$ARGV[0]" eq '-cb') {    # Contour bands
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    90
        $docont = 'b';
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    91
        $loff = 0.52;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    92
    } elsif ("$ARGV[0]" eq '-e') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    93
        $doextrem = 1;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    94
        $needfile = 1;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    95
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    96
	# Oops! Illegal option
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    97
    } else {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    98
        die("bad option \"$ARGV[0]\"\n");
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
    99
    }
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   100
    shift @ARGV;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   101
}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   102
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   103
# Temporary directory. Will be removed upon successful program exit.
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   104
my $td = tempdir( CLEANUP => 1 );
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   105
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   106
if ($needfile == 1 && $picture eq '-') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   107
	# Pretend that $td/stdin.rad is the actual filename.
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   108
    $picture = "$td/stdin.hdr";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   109
    open(FHpic, ">$picture") or
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   110
            die("Unable to write to file $picture\n");
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   111
	# Input is from STDIN: Capture to file.
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   112
	while (<>) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   113
		print FHpic;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   114
	}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   115
    close(FHpic);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   116
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   117
	if ($cpict eq '-') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   118
		$cpict =  "$td/stdin.hdr";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   119
	}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   120
}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   121
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   122
# Find a good scale for auto mode.
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   123
if ($scale =~ m/[aA].*/) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   124
	my @histo = split(/\s/, `phisto $picture| tail -2`);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   125
	# e.g. $ phisto tests/richmond.hdr| tail -2
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   126
	# 3.91267	14
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   127
	# 3.94282	6
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   128
	my $LogLmax = $histo[0];
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   129
    $scale = $mult / 179 * 10**$LogLmax;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   130
}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   131
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   132
my $pc0 = "$td/pc0.cal";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   133
open(FHpc0, ">$pc0");
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   134
print FHpc0 <<EndOfPC0;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   135
PI : 3.14159265358979323846 ;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   136
scale : $scale ;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   137
mult : $mult ;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   138
ndivs : $ndivs ;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   139
gamma : 2.2;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   140
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   141
or(a,b) : if(a,a,b);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   142
EPS : 1e-7;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   143
neq(a,b) : if(a-b-EPS,1,b-a-EPS);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   144
btwn(a,x,b) : if(a-x,-1,b-x);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   145
clip(x) : if(x-1,1,if(x,x,0));
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   146
frac(x) : x - floor(x);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   147
boundary(a,b) : neq(floor(ndivs*a+.5),floor(ndivs*b+.5));
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   148
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   149
spec_red(x) = 1.6*x - .6;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   150
spec_grn(x) = if(x-.375, 1.6-1.6*x, 8/3*x);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   151
spec_blu(x) = 1 - 8/3*x;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   152
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   153
pm3d_red(x) = sqrt(x) ^ gamma;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   154
pm3d_grn(x) = x*x*x ^ gamma;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   155
pm3d_blu(x) = clip(sin(2*PI*x)) ^ gamma;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   156
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   157
hot_red(x) = clip(3*x) ^ gamma;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   158
hot_grn(x) = clip(3*x - 1) ^ gamma;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   159
hot_blu(x) = clip(3*x - 2) ^ gamma;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   160
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   161
interp_arr2(i,x,f):(i+1-x)*f(i)+(x-i)*f(i+1);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   162
interp_arr(x,f):if(x-1,if(f(0)-x,interp_arr2(floor(x),x,f),f(f(0))),f(1));
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   163
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   164
def_redp(i):select(i,0.18848,0.05468174,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   165
0.00103547,8.311144e-08,7.449763e-06,0.0004390987,0.001367254,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   166
0.003076,0.01376382,0.06170773,0.1739422,0.2881156,0.3299725,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   167
0.3552663,0.372552,0.3921184,0.4363976,0.6102754,0.7757267,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   168
0.9087369,1,1,0.9863);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   169
def_red(x):interp_arr(x/0.0454545+1,def_redp);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   170
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   171
def_grnp(i):select(i,0.0009766,2.35501e-05,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   172
0.0008966244,0.0264977,0.1256843,0.2865799,0.4247083,0.4739468,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   173
0.4402732,0.3671876,0.2629843,0.1725325,0.1206819,0.07316644,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   174
0.03761026,0.01612362,0.004773749,6.830967e-06,0.00803605,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   175
0.1008085,0.3106831,0.6447838,0.9707);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   176
def_grn(x):interp_arr(x/0.0454545+1,def_grnp);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   177
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   178
def_blup(i):select(i,0.2666,0.3638662,0.4770437,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   179
0.5131397,0.5363797,0.5193677,0.4085123,0.1702815,0.05314236,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   180
0.05194055,0.08564082,0.09881395,0.08324373,0.06072902,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   181
0.0391076,0.02315354,0.01284458,0.005184709,0.001691774,
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   182
2.432735e-05,1.212949e-05,0.006659406,0.02539);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   183
def_blu(x):interp_arr(x/0.0454545+1,def_blup);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   184
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   185
isconta = if(btwn(0,v,1),or(boundary(vleft,vright),boundary(vabove,vbelow)),-1);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   186
iscontb = if(btwn(0,v,1),btwn(.4,frac(ndivs*v),.6),-1);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   187
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   188
ra = 0;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   189
ga = 0;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   190
ba = 0;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   191
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   192
in = 1;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   193
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   194
ro = if(in,clip($redv),ra);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   195
go = if(in,clip($grnv),ga);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   196
bo = if(in,clip($bluv),ba);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   197
EndOfPC0
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   198
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   199
my $pc1 = "$td/pc1.cal";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   200
open(FHpc1, ">$pc1");
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   201
print FHpc1 <<EndOfPC1;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   202
norm : mult/scale/le(1);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   203
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   204
v = map(li(1)*norm);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   205
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   206
vleft = map(li(1,-1,0)*norm);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   207
vright = map(li(1,1,0)*norm);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   208
vabove = map(li(1,0,1)*norm);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   209
vbelow = map(li(1,0,-1)*norm);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   210
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   211
map(x) = x;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   212
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   213
ra = ri(nfiles);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   214
ga = gi(nfiles);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   215
ba = bi(nfiles);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   216
EndOfPC1
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   217
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   218
my $pc0args = "-f $pc0";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   219
my $pc1args = "-f $pc1";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   220
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   221
# Contour lines or bands
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   222
if ($docont ne '') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   223
    $pc0args .= " -e 'in=iscont$docont'";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   224
}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   225
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   226
if ($cpict eq '') {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   227
    $pc1args .= " -e 'ra=0;ga=0;ba=0'";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   228
} elsif ($cpict eq $picture) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   229
    $cpict = '';
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   230
}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   231
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   232
# Logarithmic mapping
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   233
if ($decades > 0) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   234
    $pc1args .= " -e 'map(x)=if(x-10^-$decades,log10(x)/$decades+1,0)'";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   235
}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   236
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   237
# Colours in the legend
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   238
my $scolpic = "$td/scol.hdr";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   239
# Labels in the legend
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   240
my $slabpic = "$td/slab.hdr";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   241
my $cmd;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   242
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   243
if (($legwidth > 20) && ($legheight > 40)) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   244
	# Legend: Create the text labels
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   245
    my $sheight = floor($legheight / $ndivs + 0.5);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   246
    $legheight = $sheight * $ndivs;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   247
    $loff = floor($loff * $sheight + 0.5);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   248
    my $text = "$label";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   249
    for (my $i=0; $i<$ndivs; $i++) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   250
        my $imap = ($ndivs - 0.5 - $i) / $ndivs;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   251
		my $value = $scale;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   252
        if ($decades > 0) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   253
            $value *= 10**(($imap - 1) * $decades);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   254
        } else {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   255
            $value *= $imap;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   256
        }
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   257
        # Have no more than 3 decimal places
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   258
        $value =~ s/(\.[0-9]{3})[0-9]*/$1/;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   259
        $text .= "\n$value";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   260
    }
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   261
    $cmd = "echo '$text' | psign -s -.15 -cf 1 1 1 -cb 0 0 0";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   262
    $cmd .= " -h $sheight > $slabpic";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   263
    system $cmd;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   264
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   265
	# Legend: Create the background colours
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   266
    $cmd = "pcomb $pc0args -e 'v=(y+.5)/yres;vleft=v;vright=v'";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   267
    $cmd .= " -e 'vbelow=(y-.5)/yres;vabove=(y+1.5)/yres'";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   268
    $cmd .= " -x $legwidth -y $legheight > $scolpic";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   269
    system $cmd;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   270
} else {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   271
	# Legend is too small to be legible. Don't bother doing one.
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   272
    $legwidth = 0;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   273
    $legheight = 0;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   274
    $loff = 0;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   275
	# Create dummy colour scale and legend labels so we don't
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   276
	# need to change the final command line.
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   277
    open(FHscolpic, ">$scolpic");
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   278
    print FHscolpic "\n-Y 1 +X 1\naaa\n";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   279
    close(FHscolpic);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   280
    open(FHslabpic, ">$slabpic");
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   281
    print FHslabpic "\n-Y 1 +X 1\naaa\n";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   282
    close(FHslabpic);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   283
}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   284
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   285
# Legend: Invert the text labels (for dropshadow)
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   286
my $slabinvpic = "$td/slabinv.hdr";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   287
$cmd = "pcomb -e 'lo=1-gi(1)' $slabpic > $slabinvpic";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   288
system $cmd;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   289
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   290
my $loff1 = $loff - 1;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   291
# Command line without extrema
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   292
$cmd = "pcomb $pc0args $pc1args $picture $cpict";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   293
$cmd .= "| pcompos $scolpic 0 0 +t .1 $slabinvpic 2 $loff1";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   294
$cmd .= " -t .5 $slabpic 0 $loff - $legwidth 0";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   295
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   296
if ($doextrem == 1) {
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   297
	# Get min/max image luminance
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   298
    my $cmd1 = 'pextrem -o ' . $picture;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   299
    my $retval = `$cmd1`;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   300
    # e.g.
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   301
    # x   y   r            g            b
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   302
    # 193 207 3.070068e-02 3.118896e-02 1.995850e-02
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   303
    # 211 202 1.292969e+00 1.308594e+00 1.300781e+00
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   304
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   305
    my @extrema = split(/\s/, $retval);
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   306
    my ($lxmin, $ymin, $rmin, $gmin, $bmin, $lxmax, $ymax, $rmax, $gmax, $bmax) = @extrema;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   307
	$lxmin += $legwidth;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   308
	$lxmax += $legwidth;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   309
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   310
	# Weighted average of R,G,B
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   311
    my $minpos = "$lxmin $ymin";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   312
    my $minval = ($rmin * .27 + $gmin * .67 + $bmin * .06) * $mult;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   313
    $minval =~ s/(\.[0-9]{3})[0-9]*/$1/;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   314
    my $maxpos = "$lxmax $ymax";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   315
    my $maxval = ($rmax * .27 + $gmax * .67 + $bmax * .06) * $mult;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   316
    $maxval =~ s/(\.[0-9]{3})[0-9]*/$1/;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   317
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   318
	# Create the labels for min/max intensity
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   319
    my $minvpic = "$td/minv.hdr";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   320
    $cmd1 = "psign -s -.15 -a 2 -h 16 $minval > $minvpic";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   321
    system $cmd1;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   322
    my $maxvpic = "$td/maxv.hdr";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   323
    $cmd1 = "psign -s -.15 -a 2 -h 16 $maxval > $maxvpic";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   324
    system $cmd1;
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   325
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   326
	# Add extrema labels to command line
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   327
    $cmd .= " $minvpic $minpos $maxvpic $maxpos";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   328
}
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   329
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   330
# Process image and combine with legend
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   331
system "$cmd";
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   332
869909d14a39 Added latest falsecolor.pl from Radiance HEAD.
Axel Jacobs <axel@jaloxa.eu>
parents:
diff changeset
   333
#EOF