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