ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/src/util/rcode2bmp.pl
Revision: 2.6
Committed: Thu Oct 3 18:45:27 2024 UTC (12 months, 3 weeks ago) by greg
Content type: text/plain
Branch: MAIN
CVS Tags: rad6R0, HEAD
Changes since 2.5: +3 -3 lines
Error occurred while calculating annotation data.
Log Message:
perf(rcode2bmp): Minor optimization for ID files

File Contents

# Content
1 #!/usr/bin/perl
2 # RCSid $Id: rcode2bmp.pl,v 2.5 2024/10/03 18:35:53 greg Exp $
3 #
4 # Convert one or more rtpict outputs into BMP for convenient viewing
5 #
6
7 use strict;
8 use warnings;
9
10 my $xres=0;
11 my $yres=0;
12 my $pfilt="";
13
14 # Get options, which must precede input maps
15 while ($#ARGV >= 0 && "$ARGV[0]" =~ /^-[a-zA-Z]/) {
16 if ("$ARGV[0]" eq '-x') {
17 shift @ARGV;
18 $xres = shift(@ARGV);
19 } elsif ("$ARGV[0]" eq '-y') {
20 shift @ARGV;
21 $yres = shift(@ARGV);
22 } else {
23 die "Bad option: $ARGV[0]\n";
24 }
25 }
26 # Set up resizing operation if requested
27 if ($xres > 0 && $yres > 0) {
28 $pfilt = "pfilt -x $xres -y $yres -pa 1 -1 -r .6";
29 }
30 # Load/convert each file
31 INPUT_MAP:
32 while ($#ARGV >= 0) {
33 if ("$ARGV[0]" =~ /\.bmp$/i) {
34 print STDERR "Skipping file '$ARGV[0]' already in BMP format\n";
35 shift @ARGV;
36 next INPUT_MAP;
37 }
38 my $format = `getinfo < '$ARGV[0]' | sed -n 's/^FORMAT= *//p'`;
39 chomp $format;
40 die "Cannot get format from $ARGV[0]\n" if ( $? || ! $format );
41 my ($dest) = ("$ARGV[0]" =~ /^([^.]+)/);
42 $dest .= ".bmp";
43 my $cmd="";
44 if ("$format" =~ /^32-bit_rle_(rgb|xyz)e *$/ || "$format" =~ /^Radiance_spectra *$/) {
45 if ($pfilt) {
46 $cmd = $pfilt . " '$ARGV[0]' | ra_bmp -e auto - '$dest'";
47 } else {
48 $cmd = "ra_bmp -e auto '$ARGV[0]' '$dest'";
49 }
50 } elsif ("$format" =~ /^16-bit_encoded_depth *$/) {
51 $cmd = "rcode_depth -r -ff -ho -Ho '$ARGV[0]' ";
52 $cmd .= q{| rcalc -if -of -e 'cond=9e9-$1;$1=$1' | total -if -u};
53 my $dmax=`$cmd`;
54 $dmax = 2**(int(log($dmax)/log(2))+1);
55 my $unit=`getinfo < '$ARGV[0]' | sed -n 's/^REFDEPTH= *[0-9.]*[^a-zA-Z]*//p'`;
56 chomp $unit;
57 $unit="Depth" if ( ! $unit );
58 $cmd = "rcode_depth -r -ff '$ARGV[0]' | pvalue -r -df -b ";
59 $cmd .= "| $pfilt " if ($pfilt);
60 $cmd .= "| falsecolor -l '$unit' -m 1 -s $dmax | ra_bmp - '$dest'";
61 } elsif ("$format" =~ /^[1-9][0-9]*-bit_indexed_name *$/) {
62 $cmd = "rcode_ident -r -n '$ARGV[0]' " .
63 "| getinfo +d -c rcalc -of -e 'cc(x):(.1+.8*rand(x))^2' " .
64 q{-e '$1=cc(.398*$1-11.2);$2=cc(-1.152*$1+41.7);$3=cc(8.571*$1-8.15)' } .
65 "| pvalue -r -df ";
66 $cmd .= "| $pfilt " if ($pfilt);
67 $cmd .= "| ra_bmp - '$dest'";
68 } elsif ("$format" =~ /^32-bit_encoded_normal *$/) {
69 $cmd = "rcode_norm -r -ff '$ARGV[0]' | getinfo +d -c " .
70 "rcalc -if3 -of -e `vwright v < '$ARGV[0]'` " .
71 q{-e 'dot(vx,vy,vz)=vx*$1+vy*$2+vz*$3' } .
72 "-e 'h=dot(vhx,vhy,vhz)' " .
73 "-e 'v=dot(vvx,vvy,vvz)' " .
74 "-e 'n=-dot(vdx,vdy,vdz)' " .
75 "-f hsv_rgb.cal -e 'hue=mod(180/PI*atan2(v,h),360)' " .
76 "-e 'sat=sqrt(h*h+v*v)' -e 'val=if(n,1,1+n)' " .
77 q{-e '$1=R(hue,sat,val);$2=G(hue,sat,val);$3=B(hue,sat,val)' } .
78 "| pvalue -r -df ";
79 $cmd .= "| $pfilt " if ($pfilt);
80 $cmd .= "| ra_bmp - '$dest'";
81 }
82 if ($cmd) {
83 system $cmd;
84 die "Cannot convert $ARGV[0]\n" if ( $? );
85 print "Converted $ARGV[0] to $dest\n";
86 } else {
87 print STDERR "Skipping unsupported format '$format' for input '$ARGV[0]'\n";
88 }
89 shift @ARGV;
90 }
91 # EOF