1bc952696SBarry Smith 2af0996ceSBarry Smith #include <petsc/private/tsimpl.h> /*I "petscts.h" I*/ 3bc952696SBarry Smith 4bc952696SBarry Smith #undef __FUNCT__ 5bc952696SBarry Smith #define __FUNCT__ "OutputBIN" 6bc952696SBarry Smith static PetscErrorCode OutputBIN(const char *filename, PetscViewer *viewer) 7bc952696SBarry Smith { 8bc952696SBarry Smith PetscErrorCode ierr; 9bc952696SBarry Smith 10bc952696SBarry Smith PetscFunctionBeginUser; 11bc952696SBarry Smith ierr = PetscViewerCreate(PETSC_COMM_WORLD, viewer);CHKERRQ(ierr); 12bc952696SBarry Smith ierr = PetscViewerSetType(*viewer, PETSCVIEWERBINARY);CHKERRQ(ierr); 13bc952696SBarry Smith ierr = PetscViewerFileSetMode(*viewer,FILE_MODE_WRITE);CHKERRQ(ierr); 14bc952696SBarry Smith ierr = PetscViewerFileSetName(*viewer, filename);CHKERRQ(ierr); 15bc952696SBarry Smith PetscFunctionReturn(0); 16bc952696SBarry Smith } 17bc952696SBarry Smith 18bc952696SBarry Smith #undef __FUNCT__ 19bc952696SBarry Smith #define __FUNCT__ "TSTrajectorySet_Basic" 20bc952696SBarry Smith PetscErrorCode TSTrajectorySet_Basic(TSTrajectory jac,TS ts,PetscInt stepnum,PetscReal time,Vec X) 21bc952696SBarry Smith { 22bc952696SBarry Smith PetscViewer viewer; 23bc952696SBarry Smith PetscInt ns,i; 24bc952696SBarry Smith Vec *Y; 25bc952696SBarry Smith char filename[PETSC_MAX_PATH_LEN]; 26bc952696SBarry Smith PetscReal tprev; 27bc952696SBarry Smith PetscErrorCode ierr; 286cd0a353SHong Zhang 29bc952696SBarry Smith PetscFunctionBeginUser; 30bc952696SBarry Smith if (stepnum == 0) { 31bc952696SBarry Smith #if defined(PETSC_HAVE_POPEN) 32*a8472d1cSHong Zhang ierr = TSGetTotalSteps(ts,&stepnum);CHKERRQ(ierr); 33bc952696SBarry Smith if (stepnum == 0) { 34bc952696SBarry Smith PetscMPIInt rank; 35bc952696SBarry Smith ierr = MPI_Comm_rank(PetscObjectComm((PetscObject)ts),&rank);CHKERRQ(ierr); 36bc952696SBarry Smith if (!rank) { 37bc952696SBarry Smith char command[PETSC_MAX_PATH_LEN]; 38bc952696SBarry Smith FILE *fd; 39bc952696SBarry Smith int err; 40bc952696SBarry Smith 41bc952696SBarry Smith ierr = PetscMemzero(command,sizeof(command));CHKERRQ(ierr); 42bc952696SBarry Smith ierr = PetscSNPrintf(command,PETSC_MAX_PATH_LEN,"rm -fr %s","SA-data");CHKERRQ(ierr); 43bc952696SBarry Smith ierr = PetscPOpen(PETSC_COMM_SELF,NULL,command,"r",&fd);CHKERRQ(ierr); 44bc952696SBarry Smith ierr = PetscPClose(PETSC_COMM_SELF,fd,&err);CHKERRQ(ierr); 45bc952696SBarry Smith ierr = PetscSNPrintf(command,PETSC_MAX_PATH_LEN,"mkdir %s","SA-data");CHKERRQ(ierr); 46bc952696SBarry Smith ierr = PetscPOpen(PETSC_COMM_SELF,NULL,command,"r",&fd);CHKERRQ(ierr); 47bc952696SBarry Smith ierr = PetscPClose(PETSC_COMM_SELF,fd,&err);CHKERRQ(ierr); 48bc952696SBarry Smith } 49bc952696SBarry Smith } 50bc952696SBarry Smith #endif 51*a8472d1cSHong Zhang ierr = TSGetTotalSteps(ts,&stepnum);CHKERRQ(ierr); 5226656371SHong Zhang ierr = PetscSNPrintf(filename,sizeof(filename),"SA-data/SA-%06d.bin",stepnum);CHKERRQ(ierr); 5326656371SHong Zhang ierr = OutputBIN(filename,&viewer);CHKERRQ(ierr); 5426656371SHong Zhang ierr = VecView(X,viewer);CHKERRQ(ierr); 5526656371SHong Zhang ierr = PetscViewerBinaryWrite(viewer,&time,1,PETSC_REAL,PETSC_FALSE);CHKERRQ(ierr); 56c186a807SHong Zhang ierr = PetscViewerDestroy(&viewer);CHKERRQ(ierr); 57bc952696SBarry Smith PetscFunctionReturn(0); 58bc952696SBarry Smith } 59bc952696SBarry Smith ierr = PetscSNPrintf(filename,sizeof(filename),"SA-data/SA-%06d.bin",stepnum);CHKERRQ(ierr); 60bc952696SBarry Smith ierr = OutputBIN(filename,&viewer);CHKERRQ(ierr); 61bc952696SBarry Smith ierr = VecView(X,viewer);CHKERRQ(ierr); 62c679fc15SHong Zhang ierr = PetscViewerBinaryWrite(viewer,&time,1,PETSC_REAL,PETSC_FALSE);CHKERRQ(ierr); 63bc952696SBarry Smith 64c679fc15SHong Zhang ierr = TSGetStages(ts,&ns,&Y);CHKERRQ(ierr); 65bc952696SBarry Smith for (i=0;i<ns;i++) { 66bc952696SBarry Smith ierr = VecView(Y[i],viewer);CHKERRQ(ierr); 67bc952696SBarry Smith } 68bc952696SBarry Smith 69c679fc15SHong Zhang ierr = TSGetPrevTime(ts,&tprev);CHKERRQ(ierr); 70c679fc15SHong Zhang ierr = PetscViewerBinaryWrite(viewer,&tprev,1,PETSC_REAL,PETSC_FALSE);CHKERRQ(ierr); 71c679fc15SHong Zhang 72bc952696SBarry Smith ierr = PetscViewerDestroy(&viewer);CHKERRQ(ierr); 73bc952696SBarry Smith PetscFunctionReturn(0); 74bc952696SBarry Smith } 75bc952696SBarry Smith 76bc952696SBarry Smith #undef __FUNCT__ 77bc952696SBarry Smith #define __FUNCT__ "TSTrajectoryGet_Basic" 7826656371SHong Zhang PetscErrorCode TSTrajectoryGet_Basic(TSTrajectory jac,TS ts,PetscInt stepnum,PetscReal *t) 79bc952696SBarry Smith { 80bc952696SBarry Smith Vec Sol,*Y; 81060da220SMatthew G. Knepley PetscInt Nr,i; 82bc952696SBarry Smith PetscViewer viewer; 83bc952696SBarry Smith PetscReal timepre; 84bc952696SBarry Smith char filename[PETSC_MAX_PATH_LEN]; 85bc952696SBarry Smith PetscErrorCode ierr; 866cd0a353SHong Zhang 87bc952696SBarry Smith PetscFunctionBeginUser; 88*a8472d1cSHong Zhang ierr = TSGetTotalSteps(ts,&stepnum);CHKERRQ(ierr); 8926656371SHong Zhang ierr = PetscSNPrintf(filename,sizeof filename,"SA-data/SA-%06d.bin",stepnum);CHKERRQ(ierr); 90bc952696SBarry Smith ierr = PetscViewerBinaryOpen(PETSC_COMM_WORLD,filename,FILE_MODE_READ,&viewer);CHKERRQ(ierr); 91bc952696SBarry Smith 92bc952696SBarry Smith ierr = TSGetSolution(ts,&Sol);CHKERRQ(ierr); 93bc952696SBarry Smith ierr = VecLoad(Sol,viewer);CHKERRQ(ierr); 94bc952696SBarry Smith 95c679fc15SHong Zhang ierr = PetscViewerBinaryRead(viewer,t,1,NULL,PETSC_REAL);CHKERRQ(ierr); 96bc952696SBarry Smith 9726656371SHong Zhang if (stepnum != 0) { 98bc952696SBarry Smith ierr = TSGetStages(ts,&Nr,&Y);CHKERRQ(ierr); 99bc952696SBarry Smith for (i=0;i<Nr ;i++) { 100bc952696SBarry Smith ierr = VecLoad(Y[i],viewer);CHKERRQ(ierr); 101bc952696SBarry Smith } 102c679fc15SHong Zhang ierr = PetscViewerBinaryRead(viewer,&timepre,1,NULL,PETSC_REAL);CHKERRQ(ierr); 103acaebbb6SHong Zhang ierr = TSSetTimeStep(ts,-(*t)+timepre);CHKERRQ(ierr); 10426656371SHong Zhang } 105bc952696SBarry Smith 10626656371SHong Zhang ierr = PetscViewerDestroy(&viewer);CHKERRQ(ierr); 107bc952696SBarry Smith PetscFunctionReturn(0); 108bc952696SBarry Smith } 109bc952696SBarry Smith 110bc952696SBarry Smith /*MC 1111c8c567eSBarry Smith TSTRAJECTORYBASIC - Stores each solution of the ODE/ADE in a file 112bc952696SBarry Smith 113bc952696SBarry Smith Level: intermediate 114bc952696SBarry Smith 115bc952696SBarry Smith .seealso: TSTrajectoryCreate(), TS, TSTrajectorySetType() 116bc952696SBarry Smith 117bc952696SBarry Smith M*/ 118bc952696SBarry Smith #undef __FUNCT__ 119bc952696SBarry Smith #define __FUNCT__ "TSTrajectoryCreate_Basic" 120bc952696SBarry Smith PETSC_EXTERN PetscErrorCode TSTrajectoryCreate_Basic(TSTrajectory ts) 121bc952696SBarry Smith { 122bc952696SBarry Smith PetscFunctionBegin; 123bc952696SBarry Smith ts->ops->set = TSTrajectorySet_Basic; 124bc952696SBarry Smith ts->ops->get = TSTrajectoryGet_Basic; 125bc952696SBarry Smith PetscFunctionReturn(0); 126bc952696SBarry Smith } 127