aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2010-04-22 10:15:29 +0200
committerThomas White <taw@physics.org>2010-04-22 10:15:29 +0200
commitf5eb3478dd760997237ba2567a081946a7f9613b (patch)
treea3c710035235c7f7640c43b941270dc3e88a5bbc
parent680991c561dcb8cb79c944cec93d3b70c5fb7e02 (diff)
render_hkl: Run multiple POV-ray instances in parallel
-rw-r--r--src/render_hkl.c69
1 files changed, 51 insertions, 18 deletions
diff --git a/src/render_hkl.c b/src/render_hkl.c
index b063743c..dbaf7e45 100644
--- a/src/render_hkl.c
+++ b/src/render_hkl.c
@@ -27,13 +27,17 @@
#include "reflections.h"
+#define MAX_PROC (256)
+
+
static void show_help(const char *s)
{
printf("Syntax: %s [options] <file.hkl>\n\n", s);
printf(
-"Render intensity lists using POVray.\n"
+"Render intensity lists using POV-ray.\n"
"\n"
-" -h, --help Display this help message.\n"
+" -h, --help Display this help message.\n"
+" -j <n> Run <n> instances of POV-ray in parallel.\n"
"\n");
}
@@ -50,8 +54,10 @@ int main(int argc, char *argv[])
double asx, asy, asz;
double bsx, bsy, bsz;
double csx, csy, csz;
- pid_t pid;
+ pid_t pids[MAX_PROC];
float max;
+ int nproc = 1;
+ int i;
/* Long options */
const struct option longopts[] = {
@@ -60,7 +66,7 @@ int main(int argc, char *argv[])
};
/* Short options */
- while ((c = getopt_long(argc, argv, "h", longopts, NULL)) != -1) {
+ while ((c = getopt_long(argc, argv, "hj:", longopts, NULL)) != -1) {
switch (c) {
case 'h' : {
@@ -68,6 +74,11 @@ int main(int argc, char *argv[])
return 0;
}
+ case 'j' : {
+ nproc = atoi(optarg);
+ break;
+ }
+
case 0 : {
break;
}
@@ -79,6 +90,11 @@ int main(int argc, char *argv[])
}
+ if ( (nproc > MAX_PROC) || (nproc < 1) ) {
+ ERROR("Number of processes is invalid.\n");
+ return 1;
+ }
+
infile = argv[optind];
cell = load_cell_from_pdb("molecule.pdb");
@@ -276,21 +292,38 @@ int main(int argc, char *argv[])
fprintf(fh, "\n");
fclose(fh);
- pid = fork();
- if ( !( (pid != 0) && (pid != -1) ) ) {
- if ( pid == -1 ) {
- fprintf(stderr, "fork() failed.\n");
- } else {
- /* Forked successfully, child process */
- execlp("povray", "", "+W320", "+H240",
- "+Irender.pov", "+Orender.png",
- "+KFI0", "+KFF499", "+KI0", "+KF499",
- // "+SF220", "+EF280",
- NULL);
- }
- } else {
+ for ( i=0; i<nproc; i++ ) {
+
+ pids[i] = fork();
+ if ( !( (pids[i] != 0) && (pids[i] != -1) ) ) {
+ if ( pids[i] == -1 ) {
+ ERROR("fork() failed.\n");
+ } else {
+
+ char minf[256];
+ char maxf[256];
+ int nf, xf, nsec;
+
+ nsec = 500 / nproc;
+ nf = nsec * i;
+ xf = (nsec * i + nsec)-1;
+
+ snprintf(minf, 255, "+SF%i", nf);
+ snprintf(maxf, 255, "+EF%i", xf);
+
+ /* Forked successfully, child process */
+ execlp("povray", "", "+W1024", "+H768",
+ "+Irender.pov", "+Orender.png",
+ "+KFI0", "+KFF499", "+KI0", "+KF499",
+ minf, maxf, NULL);
+
+ }
+ } /* else start the next one */
+ }
+
+ for ( i=0; i<nproc; i++ ) {
int r;
- waitpid(pid, &r, 0);
+ waitpid(pids[i], &r, 0);
}
return 0;