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