| 71 |  | } | 
| 72 |  | # Check that we're actually being asked to do something | 
| 73 |  | die "Must have at least one of +forward or +backward\n" if (!$doforw && !$doback); | 
| 74 | – | # Name our own persist file? | 
| 75 | – | my $persistfile; | 
| 76 | – | if ( $tensortree && $nproc > 1 && "$rtargs" !~ /-PP /) { | 
| 77 | – | $persistfile = "$td/pfile.txt"; | 
| 78 | – | $rtargs = "-PP $persistfile $rtargs"; | 
| 79 | – | } | 
| 74 |  | # Get scene description and dimensions | 
| 75 |  | my $radscn = "$td/device.rad"; | 
| 76 |  | my $mgfscn = "$td/device.mgf"; | 
| 152 |  |  | 
| 153 |  | #-------------- End of main program segment --------------# | 
| 154 |  |  | 
| 161 | – | #++++++++++++++ Kill persistent rtrace +++++++++++++++++++# | 
| 162 | – | sub persist_end { | 
| 163 | – | if ( $persistfile && open(PFI, "< $persistfile") ) { | 
| 164 | – | while (<PFI>) { | 
| 165 | – | s/^[^ ]* //; | 
| 166 | – | kill('ALRM', $_); | 
| 167 | – | last; | 
| 168 | – | } | 
| 169 | – | close PFI; | 
| 170 | – | } | 
| 171 | – | } | 
| 172 | – |  | 
| 155 |  | #++++++++++++++ Tensor tree BSDF generation ++++++++++++++# | 
| 156 |  | sub do_tree_bsdf { | 
| 175 | – | # Get sampling rate and subdivide task | 
| 176 | – | my $ns2 = $ns; | 
| 177 | – | $ns2 /= 2 if ( $tensortree == 3 ); | 
| 178 | – | my $nsplice = $nproc; | 
| 179 | – | $nsplice *= 10 if ($nproc > 1); | 
| 180 | – | $nsplice = $ns2 if ($nsplice > $ns2); | 
| 181 | – | $nsplice = 999 if ($nsplice > 999); | 
| 182 | – | @pdiv = (0, int($ns2/$nsplice)); | 
| 183 | – | my $nrem = $ns2 % $nsplice; | 
| 184 | – | for (my $i = 1; $i < $nsplice; $i++) { | 
| 185 | – | my $nv = $pdiv[$i] + $pdiv[1]; | 
| 186 | – | ++$nv if ( $nrem-- > 0 ); | 
| 187 | – | push @pdiv, $nv; | 
| 188 | – | } | 
| 189 | – | die "Script error 1" if ($pdiv[-1] != $ns2); | 
| 157 |  | # Shirley-Chiu mapping from unit square to disk | 
| 158 |  | $sq2disk = ' | 
| 159 |  | in_square_a = 2*in_square_x - 1; | 
| 196 |  | print "\t<DataDefinition>\n"; | 
| 197 |  | print "\t\t<IncidentDataStructure>TensorTree$tensortree</IncidentDataStructure>\n"; | 
| 198 |  | print "\t</DataDefinition>\n"; | 
| 199 | < | # Fork parallel rtcontrib processes to compute each side | 
| 200 | < | my $npleft = $nproc; | 
| 201 | < | if ( $doback ) { | 
| 202 | < | for (my $splice = 0; $splice < $nsplice; $splice++) { | 
| 203 | < | if (! $npleft ) { | 
| 237 | < | wait(); | 
| 238 | < | die "rtcontrib process reported error" if ( $? ); | 
| 239 | < | $npleft++; | 
| 240 | < | } | 
| 241 | < | bg_tree_rtcontrib(0, $splice); | 
| 242 | < | $npleft--; | 
| 243 | < | } | 
| 244 | < | while (wait() >= 0) { | 
| 245 | < | die "rtcontrib process reported error" if ( $? ); | 
| 246 | < | $npleft++; | 
| 247 | < | } | 
| 248 | < | persist_end(); | 
| 249 | < | ttree_out(0); | 
| 250 | < | } | 
| 251 | < | if ( $doforw ) { | 
| 252 | < | for (my $splice = 0; $splice < $nsplice; $splice++) { | 
| 253 | < | if (! $npleft ) { | 
| 254 | < | wait(); | 
| 255 | < | die "rtcontrib process reported error" if ( $? ); | 
| 256 | < | $npleft++; | 
| 257 | < | } | 
| 258 | < | bg_tree_rtcontrib(1, $splice); | 
| 259 | < | $npleft--; | 
| 260 | < | } | 
| 261 | < | while (wait() >= 0) { | 
| 262 | < | die "rtcontrib process reported error" if ( $? ); | 
| 263 | < | $npleft++; | 
| 264 | < | } | 
| 265 | < | persist_end(); | 
| 266 | < | ttree_out(1); | 
| 267 | < | } | 
| 199 | > |  | 
| 200 | > | # Start rcontrib processes for compute each side | 
| 201 | > | do_tree_rtcontrib(0) if ( $doback ); | 
| 202 | > | do_tree_rtcontrib(1) if ( $doforw ); | 
| 203 | > |  | 
| 204 |  | }       # end of sub do_tree_bsdf() | 
| 205 |  |  | 
| 206 | < | # Run rtcontrib process in background to generate tensor tree samples | 
| 207 | < | sub bg_tree_rtcontrib { | 
| 272 | < | my $pid = fork(); | 
| 273 | < | die "Cannot fork new process" unless defined $pid; | 
| 274 | < | if ($pid > 0) { return $pid; } | 
| 206 | > | # Run rcontrib process to generate tensor tree samples | 
| 207 | > | sub do_tree_rtcontrib { | 
| 208 |  | my $forw = shift; | 
| 276 | – | my $pn = shift; | 
| 277 | – | my $pbeg = $pdiv[$pn]; | 
| 278 | – | my $plen = $pdiv[$pn+1] - $pbeg; | 
| 209 |  | my $matargs = "-m $bmodnm"; | 
| 210 | < | if ( !$forw || !$doback ) { $matargs .= " -m $fmodnm"; } | 
| 211 | < | my $cmd = "rtcontrib $rtargs -h -ff -fo -c $nsamp " . | 
| 210 | > | if ( !$forw || !$doback || $tensortree==3 ) { $matargs .= " -m $fmodnm"; } | 
| 211 | > | my $cmd = "rcontrib $rtargs -h -ff -fo -n $nproc -c $nsamp " . | 
| 212 |  | "-e '$disk2sq' -bn '$ns*$ns' " . | 
| 213 |  | "-b '$ns*floor(out_square_x*$ns)+floor(out_square_y*$ns)' " . | 
| 214 | < | "-o $td/%s_" . sprintf("%03d", $pn) . ".flt $matargs $octree"; | 
| 214 | > | "-o $td/%s.flt $matargs $octree"; | 
| 215 |  | if ( $tensortree == 3 ) { | 
| 216 |  | # Isotropic BSDF | 
| 217 | < | $cmd = "cnt $plen $ny $nx " . | 
| 218 | < | "| rcalc -e 'r1=rand(($pn+.8681)*recno-.673892)' " . | 
| 219 | < | "-e 'r2=rand(($pn-5.37138)*recno+67.1737811)' " . | 
| 220 | < | "-e 'r3=rand(($pn+3.17603772)*recno+83.766771)' " . | 
| 221 | < | "-e 'Dx=1-2*($pbeg+\$1+r1)/$ns;Dy:0;Dz=sqrt(1-Dx*Dx)' " . | 
| 217 | > | my $ns2 = $ns / 2; | 
| 218 | > | $cmd = "cnt $ns2 $ny $nx " . | 
| 219 | > | "| rcalc -e 'r1=rand(.8681*recno-.673892)' " . | 
| 220 | > | "-e 'r2=rand(-5.37138*recno+67.1737811)' " . | 
| 221 | > | "-e 'r3=rand(+3.17603772*recno+83.766771)' " . | 
| 222 | > | "-e 'Dx=1-2*(\$1+r1)/$ns;Dy:0;Dz=sqrt(1-Dx*Dx)' " . | 
| 223 |  | "-e 'xp=(\$3+r2)*(($dim[1]-$dim[0])/$nx)+$dim[0]' " . | 
| 224 |  | "-e 'yp=(\$2+r3)*(($dim[3]-$dim[2])/$ny)+$dim[2]' " . | 
| 225 |  | "-e 'zp=$dim[5-$forw]' -e 'myDz=Dz*($forw*2-1)' " . | 
| 230 |  | # Anisotropic BSDF | 
| 231 |  | # Sample area vertically to improve load balance, since | 
| 232 |  | # shading systems usually have bilateral symmetry (L-R) | 
| 233 | < | $cmd = "cnt $plen $ns $ny $nx " . | 
| 234 | < | "| rcalc -e 'r1=rand(($pn+.8681)*recno-.673892)' " . | 
| 235 | < | "-e 'r2=rand(($pn-5.37138)*recno+67.1737811)' " . | 
| 236 | < | "-e 'r3=rand(($pn+3.17603772)*recno+83.766771)' " . | 
| 237 | < | "-e 'r4=rand(($pn-2.3857833)*recno-964.72738)' " . | 
| 238 | < | "-e 'in_square_x=($pbeg+\$1+r1)/$ns' " . | 
| 233 | > | $cmd = "cnt $ns $ns $ny $nx " . | 
| 234 | > | "| rcalc -e 'r1=rand(.8681*recno-.673892)' " . | 
| 235 | > | "-e 'r2=rand(-5.37138*recno+67.1737811)' " . | 
| 236 | > | "-e 'r3=rand(3.17603772*recno+83.766771)' " . | 
| 237 | > | "-e 'r4=rand(-2.3857833*recno-964.72738)' " . | 
| 238 | > | "-e 'in_square_x=(\$1+r1)/$ns' " . | 
| 239 |  | "-e 'in_square_y=(\$2+r2)/$ns' -e '$sq2disk' " . | 
| 240 |  | "-e 'xp=(\$4+r3)*(($dim[1]-$dim[0])/$nx)+$dim[0]' " . | 
| 241 |  | "-e 'yp=(\$3+r4)*(($dim[3]-$dim[2])/$ny)+$dim[2]' " . | 
| 245 |  | "| $cmd"; | 
| 246 |  | } | 
| 247 |  | # print STDERR "Starting: $cmd\n"; | 
| 248 | < | exec($cmd);             # no return; status report to parent via wait | 
| 249 | < | die "Cannot exec: $cmd\n"; | 
| 250 | < | }       # end of bg_tree_rtcontrib() | 
| 248 | > | system "$cmd" || die "Failure running rcontrib"; | 
| 249 | > | ttree_out($forw); | 
| 250 | > | }       # end of do_tree_rtcontrib() | 
| 251 |  |  | 
| 252 |  | # Simplify and output tensor tree results | 
| 253 |  | sub ttree_out { | 
| 254 |  | my $forw = shift; | 
| 255 |  | my $side = ("Back","Front")[$forw]; | 
| 256 |  | my $cmd; | 
| 257 | < | # Only output one transmitted distribution, preferring backwards | 
| 258 | < | if ( !$forw || !$doback ) { | 
| 257 | > | # Only output one transmitted anisotropic distribution, preferring backwards | 
| 258 | > | if ( !$forw || !$doback || $tensortree==3 ) { | 
| 259 |  | print | 
| 260 |  | '       <WavelengthData> | 
| 261 |  | <LayerNumber>System</LayerNumber> | 
| 263 |  | <SourceSpectrum>CIE Illuminant D65 1nm.ssp</SourceSpectrum> | 
| 264 |  | <DetectorSpectrum>ASTM E308 1931 Y.dsp</DetectorSpectrum> | 
| 265 |  | <WavelengthDataBlock> | 
| 266 | < | <WavelengthDataDirection>Transmission</WavelengthDataDirection> | 
| 267 | < | <AngleBasis>LBNL/Shirley-Chiu</AngleBasis> | 
| 266 | > | '; | 
| 267 | > | print "\t\t\t<WavelengthDataDirection>Transmission $side</WavelengthDataDirection>\n"; | 
| 268 | > | print | 
| 269 | > | '                       <AngleBasis>LBNL/Shirley-Chiu</AngleBasis> | 
| 270 |  | <ScatteringDataType>BTDF</ScatteringDataType> | 
| 271 |  | <ScatteringData> | 
| 272 |  | '; | 
| 273 |  | $cmd = "rcalc -if3 -e 'Omega:PI/($ns*$ns)' " . | 
| 274 |  | q{-e '$1=(0.265*$1+0.670*$2+0.065*$3)/Omega' }; | 
| 275 |  | if ($pctcull >= 0) { | 
| 276 | < | $cmd .= "-of $td/" . ($bmodnm,$fmodnm)[$forw] . "_???.flt " . | 
| 276 | > | $cmd .= "-of $td/" . ($bmodnm,$fmodnm)[$forw] . ".flt " . | 
| 277 |  | "| rttree_reduce -a -h -ff -t $pctcull -r $tensortree -g $ttlog2"; | 
| 278 |  | system "$cmd" || die "Failure running rttree_reduce"; | 
| 279 |  | } else { | 
| 280 | < | $cmd .= "$td/" . ($bmodnm,$fmodnm)[$forw] . "_???.flt"; | 
| 280 | > | $cmd .= "$td/" . ($bmodnm,$fmodnm)[$forw] . ".flt"; | 
| 281 |  | print "{\n"; | 
| 282 |  | system "$cmd" || die "Failure running rcalc"; | 
| 283 |  | for (my $i = ($tensortree==3)*$ns*$ns*$ns/2; $i-- > 0; ) { | 
| 309 |  | $cmd = "rcalc -if3 -e 'Omega:PI/($ns*$ns)' " . | 
| 310 |  | q{-e '$1=(0.265*$1+0.670*$2+0.065*$3)/Omega' }; | 
| 311 |  | if ($pctcull >= 0) { | 
| 312 | < | $cmd .= "-of $td/" . ($fmodnm,$bmodnm)[$forw] . "_???.flt " . | 
| 312 | > | $cmd .= "-of $td/" . ($fmodnm,$bmodnm)[$forw] . ".flt " . | 
| 313 |  | "| rttree_reduce -a -h -ff -t $pctcull -r $tensortree -g $ttlog2"; | 
| 314 |  | system "$cmd" || die "Failure running rttree_reduce"; | 
| 315 |  | } else { | 
| 316 | < | $cmd .= "$td/" . ($fmodnm,$bmodnm)[$forw] . "_???.flt"; | 
| 316 | > | $cmd .= "$td/" . ($fmodnm,$bmodnm)[$forw] . ".flt"; | 
| 317 |  | print "{\n"; | 
| 318 |  | system "$cmd" || die "Failure running rcalc"; | 
| 319 |  | for (my $i = ($tensortree==3)*$ns*$ns*$ns/2; $i-- > 0; ) { | 
| 337 |  | $tcal = ' | 
| 338 |  | DEGREE : PI/180; | 
| 339 |  | sq(x) : x*x; | 
| 340 | < | Kpola(r) : select(r+1, -5, 5, 15, 25, 35, 45, 55, 65, 75, 90); | 
| 340 | > | Kpola(r) : select(r+1, 0, 5, 15, 25, 35, 45, 55, 65, 75, 90); | 
| 341 |  | Knaz(r) : select(r, 1, 8, 16, 20, 24, 24, 24, 16, 12); | 
| 342 |  | Kaccum(r) : if(r-.5, Knaz(r) + Kaccum(r-1), 0); | 
| 343 |  | Kmax : Kaccum(Knaz(0)); | 
| 381 |  | kbin = kbin2(Acos(abs(Dz)),Atan2(Dy,Dx)); | 
| 382 |  | '; | 
| 383 |  | my $ndiv = 145; | 
| 384 | < | # Compute scattering data using rtcontrib | 
| 384 | > | # Compute scattering data using rcontrib | 
| 385 |  | my @tfarr; | 
| 386 |  | my @rfarr; | 
| 387 |  | my @tbarr; | 
| 388 |  | my @rbarr; | 
| 389 |  | my $cmd; | 
| 390 | < | my $rtcmd = "rtcontrib $rtargs -h -ff -fo -n $nproc -c $nsamp " . | 
| 390 | > | my $rtcmd = "rcontrib $rtargs -h -ff -fo -n $nproc -c $nsamp " . | 
| 391 |  | "-e '$kcal' -b kbin -bn $ndiv " . | 
| 392 |  | "-o '$td/%s.flt' -m $fmodnm -m $bmodnm $octree"; | 
| 393 |  | my $rccmd = "rcalc -e '$tcal' " . | 
| 404 |  | system "$cmd" || die "Failure running: $cmd\n"; | 
| 405 |  | @tfarr = `$rccmd $td/$fmodnm.flt`; | 
| 406 |  | die "Failure running: $rccmd $td/$fmodnm.flt\n" if ( $? ); | 
| 407 | + | chomp(@tfarr); | 
| 408 |  | @rfarr = `$rccmd $td/$bmodnm.flt`; | 
| 409 |  | die "Failure running: $rccmd $td/$bmodnm.flt\n" if ( $? ); | 
| 410 | + | chomp(@rfarr); | 
| 411 |  | } | 
| 412 |  | if ( $doback ) { | 
| 413 |  | $cmd = "cnt $ndiv $ny $nx | rcalc -of -e '$tcal' " . | 
| 432 |  | <AngleBasis> | 
| 433 |  | <AngleBasisName>LBNL/Klems Full</AngleBasisName> | 
| 434 |  | <AngleBasisBlock> | 
| 435 | < | <Theta>0</Theta> | 
| 436 | < | <nPhis>1</nPhis> | 
| 437 | < | <ThetaBounds> | 
| 438 | < | <LowerTheta>0</LowerTheta> | 
| 439 | < | <UpperTheta>5</UpperTheta> | 
| 440 | < | </ThetaBounds> | 
| 441 | < | </AngleBasisBlock> | 
| 442 | < | <AngleBasisBlock> | 
| 443 | < | <Theta>10</Theta> | 
| 444 | < | <nPhis>8</nPhis> | 
| 445 | < | <ThetaBounds> | 
| 446 | < | <LowerTheta>5</LowerTheta> | 
| 447 | < | <UpperTheta>15</UpperTheta> | 
| 448 | < | </ThetaBounds> | 
| 449 | < | </AngleBasisBlock> | 
| 450 | < | <AngleBasisBlock> | 
| 451 | < | <Theta>20</Theta> | 
| 452 | < | <nPhis>16</nPhis> | 
| 453 | < | <ThetaBounds> | 
| 454 | < | <LowerTheta>15</LowerTheta> | 
| 455 | < | <UpperTheta>25</UpperTheta> | 
| 456 | < | </ThetaBounds> | 
| 457 | < | </AngleBasisBlock> | 
| 458 | < | <AngleBasisBlock> | 
| 459 | < | <Theta>30</Theta> | 
| 460 | < | <nPhis>20</nPhis> | 
| 461 | < | <ThetaBounds> | 
| 462 | < | <LowerTheta>25</LowerTheta> | 
| 463 | < | <UpperTheta>35</UpperTheta> | 
| 464 | < | </ThetaBounds> | 
| 465 | < | </AngleBasisBlock> | 
| 466 | < | <AngleBasisBlock> | 
| 467 | < | <Theta>40</Theta> | 
| 468 | < | <nPhis>24</nPhis> | 
| 469 | < | <ThetaBounds> | 
| 470 | < | <LowerTheta>35</LowerTheta> | 
| 471 | < | <UpperTheta>45</UpperTheta> | 
| 472 | < | </ThetaBounds> | 
| 473 | < | </AngleBasisBlock> | 
| 474 | < | <AngleBasisBlock> | 
| 475 | < | <Theta>50</Theta> | 
| 476 | < | <nPhis>24</nPhis> | 
| 477 | < | <ThetaBounds> | 
| 478 | < | <LowerTheta>45</LowerTheta> | 
| 479 | < | <UpperTheta>55</UpperTheta> | 
| 480 | < | </ThetaBounds> | 
| 481 | < | </AngleBasisBlock> | 
| 482 | < | <AngleBasisBlock> | 
| 483 | < | <Theta>60</Theta> | 
| 484 | < | <nPhis>24</nPhis> | 
| 485 | < | <ThetaBounds> | 
| 486 | < | <LowerTheta>55</LowerTheta> | 
| 487 | < | <UpperTheta>65</UpperTheta> | 
| 488 | < | </ThetaBounds> | 
| 489 | < | </AngleBasisBlock> | 
| 490 | < | <AngleBasisBlock> | 
| 491 | < | <Theta>70</Theta> | 
| 492 | < | <nPhis>16</nPhis> | 
| 493 | < | <ThetaBounds> | 
| 494 | < | <LowerTheta>65</LowerTheta> | 
| 495 | < | <UpperTheta>75</UpperTheta> | 
| 496 | < | </ThetaBounds> | 
| 497 | < | </AngleBasisBlock> | 
| 498 | < | <AngleBasisBlock> | 
| 499 | < | <Theta>82.5</Theta> | 
| 500 | < | <nPhis>12</nPhis> | 
| 501 | < | <ThetaBounds> | 
| 502 | < | <LowerTheta>75</LowerTheta> | 
| 503 | < | <UpperTheta>90</UpperTheta> | 
| 504 | < | </ThetaBounds> | 
| 435 | > | <Theta>0</Theta> | 
| 436 | > | <nPhis>1</nPhis> | 
| 437 | > | <ThetaBounds> | 
| 438 | > | <LowerTheta>0</LowerTheta> | 
| 439 | > | <UpperTheta>5</UpperTheta> | 
| 440 | > | </ThetaBounds> | 
| 441 | > | </AngleBasisBlock> | 
| 442 | > | <AngleBasisBlock> | 
| 443 | > | <Theta>10</Theta> | 
| 444 | > | <nPhis>8</nPhis> | 
| 445 | > | <ThetaBounds> | 
| 446 | > | <LowerTheta>5</LowerTheta> | 
| 447 | > | <UpperTheta>15</UpperTheta> | 
| 448 | > | </ThetaBounds> | 
| 449 | > | </AngleBasisBlock> | 
| 450 | > | <AngleBasisBlock> | 
| 451 | > | <Theta>20</Theta> | 
| 452 | > | <nPhis>16</nPhis> | 
| 453 | > | <ThetaBounds> | 
| 454 | > | <LowerTheta>15</LowerTheta> | 
| 455 | > | <UpperTheta>25</UpperTheta> | 
| 456 | > | </ThetaBounds> | 
| 457 | > | </AngleBasisBlock> | 
| 458 | > | <AngleBasisBlock> | 
| 459 | > | <Theta>30</Theta> | 
| 460 | > | <nPhis>20</nPhis> | 
| 461 | > | <ThetaBounds> | 
| 462 | > | <LowerTheta>25</LowerTheta> | 
| 463 | > | <UpperTheta>35</UpperTheta> | 
| 464 | > | </ThetaBounds> | 
| 465 | > | </AngleBasisBlock> | 
| 466 | > | <AngleBasisBlock> | 
| 467 | > | <Theta>40</Theta> | 
| 468 | > | <nPhis>24</nPhis> | 
| 469 | > | <ThetaBounds> | 
| 470 | > | <LowerTheta>35</LowerTheta> | 
| 471 | > | <UpperTheta>45</UpperTheta> | 
| 472 | > | </ThetaBounds> | 
| 473 | > | </AngleBasisBlock> | 
| 474 | > | <AngleBasisBlock> | 
| 475 | > | <Theta>50</Theta> | 
| 476 | > | <nPhis>24</nPhis> | 
| 477 | > | <ThetaBounds> | 
| 478 | > | <LowerTheta>45</LowerTheta> | 
| 479 | > | <UpperTheta>55</UpperTheta> | 
| 480 | > | </ThetaBounds> | 
| 481 | > | </AngleBasisBlock> | 
| 482 | > | <AngleBasisBlock> | 
| 483 | > | <Theta>60</Theta> | 
| 484 | > | <nPhis>24</nPhis> | 
| 485 | > | <ThetaBounds> | 
| 486 | > | <LowerTheta>55</LowerTheta> | 
| 487 | > | <UpperTheta>65</UpperTheta> | 
| 488 | > | </ThetaBounds> | 
| 489 | > | </AngleBasisBlock> | 
| 490 | > | <AngleBasisBlock> | 
| 491 | > | <Theta>70</Theta> | 
| 492 | > | <nPhis>16</nPhis> | 
| 493 | > | <ThetaBounds> | 
| 494 | > | <LowerTheta>65</LowerTheta> | 
| 495 | > | <UpperTheta>75</UpperTheta> | 
| 496 | > | </ThetaBounds> | 
| 497 | > | </AngleBasisBlock> | 
| 498 | > | <AngleBasisBlock> | 
| 499 | > | <Theta>82.5</Theta> | 
| 500 | > | <nPhis>12</nPhis> | 
| 501 | > | <ThetaBounds> | 
| 502 | > | <LowerTheta>75</LowerTheta> | 
| 503 | > | <UpperTheta>90</UpperTheta> | 
| 504 | > | </ThetaBounds> | 
| 505 |  | </AngleBasisBlock> | 
| 506 |  | </AngleBasis> | 
| 507 |  | </DataDefinition> |