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