xref: /petsc/src/sys/fileio/smatlab.c (revision c6db04a5321582041def2b1e244c75985478b3ef)
1e5c89e4eSSatish Balay 
2*c6db04a5SJed Brown #include <petscsys.h>
3e5c89e4eSSatish Balay 
4e5c89e4eSSatish Balay #undef __FUNCT__
5e5c89e4eSSatish Balay #define __FUNCT__ "PetscStartMatlab"
6e5c89e4eSSatish Balay /*@C
7e3c5b3baSBarry Smith     PetscStartMatlab - starts up MATLAB with a MATLAB script
8e5c89e4eSSatish Balay 
93f9fe445SBarry Smith     Logically Collective on MPI_Comm, but only processor zero in the communicator does anything
10e5c89e4eSSatish Balay 
11e5c89e4eSSatish Balay     Input Parameters:
12e5c89e4eSSatish Balay +     comm - MPI communicator
13e3c5b3baSBarry Smith .     machine - optional machine to run MATLAB on
14e5c89e4eSSatish Balay -     script - name of script (without the .m)
15e5c89e4eSSatish Balay 
16e5c89e4eSSatish Balay     Output Parameter:
17e5c89e4eSSatish Balay .     fp - a file pointer returned from PetscPOpen()
18e5c89e4eSSatish Balay 
19e5c89e4eSSatish Balay     Level: intermediate
20e5c89e4eSSatish Balay 
21e5c89e4eSSatish Balay     Notes:
22e5c89e4eSSatish Balay      This overwrites your matlab/startup.m file
23e5c89e4eSSatish Balay 
24e3c5b3baSBarry Smith      The script must be in your MATLAB path or current directory
25e5c89e4eSSatish Balay 
26e5c89e4eSSatish Balay      Assumes that all machines share a common file system
27e5c89e4eSSatish Balay 
28e5c89e4eSSatish Balay .seealso: PetscPOpen(), PetscPClose()
29e5c89e4eSSatish Balay @*/
307087cfbeSBarry Smith PetscErrorCode  PetscStartMatlab(MPI_Comm comm,const char machine[],const char script[],FILE **fp)
31e5c89e4eSSatish Balay {
32e5c89e4eSSatish Balay   PetscErrorCode ierr;
33e5c89e4eSSatish Balay   FILE           *fd;
34e5c89e4eSSatish Balay   char           command[512];
35e5c89e4eSSatish Balay #if defined(PETSC_HAVE_UCBPS) && defined(PETSC_HAVE_POPEN)
36e5c89e4eSSatish Balay   char           buf[1024],*found;
37e5c89e4eSSatish Balay   PetscMPIInt    rank;
38e5c89e4eSSatish Balay #endif
39e5c89e4eSSatish Balay 
40e5c89e4eSSatish Balay   PetscFunctionBegin;
41e5c89e4eSSatish Balay 
42e5c89e4eSSatish Balay #if defined(PETSC_HAVE_UCBPS) && defined(PETSC_HAVE_POPEN)
43e3c5b3baSBarry Smith   /* check if MATLAB is not already running */
44e5c89e4eSSatish Balay   ierr = PetscPOpen(comm,machine,"/usr/ucb/ps -ugxww | grep matlab | grep -v grep","r",&fd);CHKERRQ(ierr);
45e5c89e4eSSatish Balay   ierr = MPI_Comm_rank(comm,&rank);CHKERRQ(ierr);
46e5c89e4eSSatish Balay   if (!rank) {
47e5c89e4eSSatish Balay     found = fgets(buf,1024,fd);
48e5c89e4eSSatish Balay   }
49e5c89e4eSSatish Balay   ierr = MPI_Bcast(&found,1,MPI_CHAR,0,comm);CHKERRQ(ierr);
50e5c89e4eSSatish Balay   ierr = PetscPClose(comm,fd);CHKERRQ(ierr);
51e5c89e4eSSatish Balay   if (found) PetscFunctionReturn(0);
52e5c89e4eSSatish Balay #endif
53e5c89e4eSSatish Balay 
54e5c89e4eSSatish Balay   if (script) {
55e3c5b3baSBarry Smith     /* the remote machine won't know about current directory, so add it to MATLAB path */
56e5c89e4eSSatish Balay     /* the extra \" are to protect possible () in the script command from the shell */
57e5c89e4eSSatish Balay     sprintf(command,"echo \"delete ${HOMEDIRECTORY}/matlab/startup.m ; path(path,'${WORKINGDIRECTORY}'); %s  \" > ${HOMEDIRECTORY}/matlab/startup.m",script);
58e5c89e4eSSatish Balay #if defined(PETSC_HAVE_POPEN)
59e5c89e4eSSatish Balay     ierr = PetscPOpen(comm,machine,command,"r",&fd);CHKERRQ(ierr);
60e5c89e4eSSatish Balay     ierr = PetscPClose(comm,fd);CHKERRQ(ierr);
61e5c89e4eSSatish Balay #endif
62e5c89e4eSSatish Balay   }
63e5c89e4eSSatish Balay #if defined(PETSC_HAVE_POPEN)
64e5c89e4eSSatish Balay   ierr = PetscPOpen(comm,machine,"xterm -display ${DISPLAY} -e matlab -nosplash","r",fp);CHKERRQ(ierr);
65e5c89e4eSSatish Balay #endif
66e5c89e4eSSatish Balay 
67e5c89e4eSSatish Balay   PetscFunctionReturn(0);
68e5c89e4eSSatish Balay }
69e5c89e4eSSatish Balay 
70