1e5c89e4eSSatish Balay 2c6db04a5SJed Brown #include <petscsys.h> 3e5c89e4eSSatish Balay 4e5c89e4eSSatish Balay /*@C 5e3c5b3baSBarry Smith PetscStartMatlab - starts up MATLAB with a MATLAB script 6e5c89e4eSSatish Balay 7d083f849SBarry Smith Logically Collective, 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 FILE *fd; 31e5c89e4eSSatish Balay char command[512]; 32e5c89e4eSSatish Balay #if defined(PETSC_HAVE_UCBPS) && defined(PETSC_HAVE_POPEN) 33e5c89e4eSSatish Balay char buf[1024],*found; 34e5c89e4eSSatish Balay PetscMPIInt rank; 35e5c89e4eSSatish Balay #endif 36e5c89e4eSSatish Balay 37e5c89e4eSSatish Balay PetscFunctionBegin; 38e5c89e4eSSatish Balay #if defined(PETSC_HAVE_UCBPS) && defined(PETSC_HAVE_POPEN) 39e3c5b3baSBarry Smith /* check if MATLAB is not already running */ 40*9566063dSJacob Faibussowitsch PetscCall(PetscPOpen(comm,machine,"/usr/ucb/ps -ugxww | grep matlab | grep -v grep","r",&fd)); 41*9566063dSJacob Faibussowitsch PetscCallMPI(MPI_Comm_rank(comm,&rank)); 42dd400576SPatrick Sanan if (rank == 0) found = fgets(buf,1024,fd); 43*9566063dSJacob Faibussowitsch PetscCallMPI(MPI_Bcast(&found,1,MPI_CHAR,0,comm)); 44*9566063dSJacob Faibussowitsch PetscCall(PetscPClose(comm,fd)); 45e5c89e4eSSatish Balay if (found) PetscFunctionReturn(0); 46e5c89e4eSSatish Balay #endif 47e5c89e4eSSatish Balay 48e5c89e4eSSatish Balay if (script) { 49e3c5b3baSBarry Smith /* the remote machine won't know about current directory, so add it to MATLAB path */ 50e5c89e4eSSatish Balay /* the extra \" are to protect possible () in the script command from the shell */ 51e5c89e4eSSatish Balay sprintf(command,"echo \"delete ${HOMEDIRECTORY}/matlab/startup.m ; path(path,'${WORKINGDIRECTORY}'); %s \" > ${HOMEDIRECTORY}/matlab/startup.m",script); 52e5c89e4eSSatish Balay #if defined(PETSC_HAVE_POPEN) 53*9566063dSJacob Faibussowitsch PetscCall(PetscPOpen(comm,machine,command,"r",&fd)); 54*9566063dSJacob Faibussowitsch PetscCall(PetscPClose(comm,fd)); 55e5c89e4eSSatish Balay #endif 56e5c89e4eSSatish Balay } 57e5c89e4eSSatish Balay #if defined(PETSC_HAVE_POPEN) 58*9566063dSJacob Faibussowitsch PetscCall(PetscPOpen(comm,machine,"xterm -display ${DISPLAY} -e matlab -nosplash","r",fp)); 59e5c89e4eSSatish Balay #endif 60e5c89e4eSSatish Balay PetscFunctionReturn(0); 61e5c89e4eSSatish Balay } 62