ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/rt/rxpiece.cpp
(Generate patch)

Comparing ray/src/rt/rxpiece.cpp (file contents):
Revision 2.5 by greg, Tue Sep 17 16:29:09 2024 UTC vs.
Revision 2.12 by greg, Wed Jun 4 20:32:25 2025 UTC

# Line 14 | Line 14 | static const char      RCSid[] = "$Id$";
14  
15   #include  "platform.h"
16   #include  "RpictSimulManager.h"
17 + #include  "func.h"
18   #include  "ambient.h"
19   #include  "pmapray.h"
20   #include  "random.h"
21  
21 extern char  *progname;                 /* argv[0] */
22   const char  *sigerr[NSIG];              /* signal error messages */
23  
24   VIEW  ourview = STDVIEW;                /* global view parameters */
# Line 37 | Line 37 | double  mblur = 0.;                    /* motion blur parameter (unused
37  
38   double  dblur = 0.;                     /* depth-of-field blur parameter */
39  
40 < int  nproc = 1;                         /* number of processes to run */
40 > int  nproc = 1;                         /* number of processes to run (-1 in child) */
41  
42   RpictSimulManager       myRPmanager;    // global simulation manager
43  
# Line 56 | Line 56 | static RenderDataType rpiece(char *pout, RenderDataTyp
56                  "AdaptiveShadowTesting\nOutputs=v,l\n" \
57                  "OutputCS=RGB,XYZ,prims,spec\n"
58  
59 <
60 < // We could call myRPmanager.Cleanup() but why waste time
61 < // unwinding data structures when the whole frame is going away?
59 > // Exit program
60   void
61   quit(int code)                          /* quit program */
62   {
63 <        ambsync();                      // flush ambient cache
63 >        exit(code);                     // don't bother to free data structs
64 > }
65  
66 <        ray_done_pmap();                /* PMAP: free photon maps */
67 <
68 <        exit(code);
66 > /* Set default options */
67 > static void
68 > default_options(void)
69 > {
70 >        shadthresh = .05;
71 >        shadcert = .5;
72 >        srcsizerat = .25;
73 >        directrelay = 1;
74 >        ambacc = 0.2;
75 >        ambres = 64;
76 >        ambdiv = 512;
77 >        ambssamp = 128;
78 >        maxdepth = 7;
79   }
80  
72
81   int
82   main(int  argc, char  *argv[])
83   {
# Line 90 | Line 98 | main(int  argc, char  *argv[])
98          int  outfmt = 'c';
99          int  rval;
100          int  i;
101 <                                        /* global program name */
102 <        progname = argv[0];
101 >                                        /* set global program name */
102 >        fixargv0(argv[0]);
103                                          /* feature check only? */
104          strcat(RFeatureList, RXPIECE_FEATURES);
105          if (argc > 1 && !strcmp(argv[1], "-features"))
106                  return feature_status(argc-2, argv+2);
107 +                                        /* initialize calcomp routines */
108 +        initfunc();
109 +                                        /* set defaults */
110 +        default_options();
111                                          /* option city */
112          for (i = 1; i < argc; i++) {
113                                                  /* expand arguments */
# Line 323 | Line 335 | main(int  argc, char  *argv[])
335                                          // render tiles
336          dtype = rpiece(outfile, dtype, zfile);
337  
338 +        ambsync();                      // flush ambient cache
339 +
340 +        ray_done_pmap();                /* PMAP: free photon maps */
341 +
342          quit(dtype==RDTnone);           // status is 1 on failure
343  
344   badopt:
# Line 340 | Line 356 | wputs(                         /* warning output function */
356          const char      *s
357   )
358   {
359 +        if (!erract[WARNING].pf)
360 +                return;         // warnings were disabled!
361          int  lasterrno = errno;
362          eputs(s);
363          errno = lasterrno;
# Line 507 | Line 525 | children_finished()
525  
526          if (cpid == 0) {                // children render tiles
527                  sleep(nproc - cnt);     // avoid race conditions
528 +                nproc = -1;             // flag as child
529                  return false;
530          }
531          cow_doneshare();                // parent frees memory and waits
# Line 612 | Line 631 | rpiece(char *pout, RenderDataType dt, char *zout)
631          } else {
632                  dt = myRPmanager.ReopenOutput(pdfp, pout, zout);
633                  if (dt == RDTnone)
634 <                        quit(1);
634 >                        return RDTnone;
635                  if (!fscnresolu(&hresolu, &vresolu, pdfp[0]))
636                          error(USER, "missing picture resolution");
637                  pixaspect = .0;                 // need to leave this as is
638                  myRPmanager.NewHeader(pout);    // get prev. header info
639                  const char *    tval = myRPmanager.GetHeadStr("TILED=");
640 <                if (tval) sscanf(tval, "%d %d", &tileGrid[0], &tileGrid[1]);
640 >                if (!tval || sscanf(tval, "%d %d", &tileGrid[0], &tileGrid[1]) != 2)
641 >                        error(USER, "existing picture must be tiled");
642                  CHECK(myRPmanager.GetView()==NULL,
643                                  USER, "missing view in picture file");
644                  ourview = *myRPmanager.GetView();
# Line 642 | Line 662 | rpiece(char *pout, RenderDataType dt, char *zout)
662                  myRPmanager.AddHeader(buf);
663                  dt = myRPmanager.NewOutput(pdfp, pout, dt, zout);
664                  if (dt == RDTnone)
665 <                        quit(1);
665 >                        return RDTnone;
666                  fprtresolu(hresolu, vresolu, pdfp[0]);
667                  fflush(pdfp[0]);
668                  if (RDTdepthT(dt) == RDTdshort) {
# Line 727 | Line 747 | rpiece(char *pout, RenderDataType dt, char *zout)
747                  ndone++;
748          }
749          if (!ndone)
750 <                error(WARNING, "no tiles need rendering, exit");
750 >                error(WARNING, "no tiles to render, exiting");
751          /*
752          munmap(pixMap, pmlen);                  // technically unnecessary...
753          if (zdMap) munmap(zdMap, zmlen);

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines