1af0996ceSBarry Smith #include <petsc/private/tsimpl.h> /*I "petscts.h" I*/ 28d59e960SJed Brown 38d59e960SJed Brown typedef struct { 41566a47fSLisandro Dalcin PetscReal safety; /* safety factor relative to target CFL constraint */ 58d59e960SJed Brown PetscBool always_accept; 68d59e960SJed Brown } TSAdapt_CFL; 78d59e960SJed Brown 88d59e960SJed Brown #undef __FUNCT__ 98d59e960SJed Brown #define __FUNCT__ "TSAdaptChoose_CFL" 10*5e4ed32fSEmil Constantinescu static PetscErrorCode TSAdaptChoose_CFL(TSAdapt adapt,TS ts,PetscReal h,PetscInt *next_sc,PetscReal *next_h,PetscBool *accept,PetscReal *wlte,PetscReal *wltea,PetscReal *wlter) 118d59e960SJed Brown { 128d59e960SJed Brown TSAdapt_CFL *cfl = (TSAdapt_CFL*)adapt->data; 138d59e960SJed Brown PetscErrorCode ierr; 141566a47fSLisandro Dalcin PetscReal hcfl,cfltimestep,ccfl; 151566a47fSLisandro Dalcin PetscInt ncandidates; 161566a47fSLisandro Dalcin const PetscReal *ccflarray; 178d59e960SJed Brown 188d59e960SJed Brown PetscFunctionBegin; 191566a47fSLisandro Dalcin ierr = TSGetCFLTime(ts,&cfltimestep);CHKERRQ(ierr); 201566a47fSLisandro Dalcin ierr = TSAdaptCandidatesGet(adapt,&ncandidates,NULL,NULL,&ccflarray,NULL);CHKERRQ(ierr); 211566a47fSLisandro Dalcin ccfl = (ncandidates > 0) ? ccflarray[0] : 1.0; 228d59e960SJed Brown 231566a47fSLisandro Dalcin /* Determine whether the step is accepted of rejected */ 241566a47fSLisandro Dalcin *accept = PETSC_TRUE; 251566a47fSLisandro Dalcin if (h > cfltimestep * ccfl) { 268d59e960SJed Brown if (cfl->always_accept) { 271566a47fSLisandro Dalcin ierr = PetscInfo3(adapt,"Step length %g with scheme of CFL coefficient %g did not satisfy user-provided CFL constraint %g, proceeding anyway\n",(double)h,(double)ccfl,(double)cfltimestep);CHKERRQ(ierr); 288d59e960SJed Brown } else { 291566a47fSLisandro Dalcin ierr = PetscInfo3(adapt,"Step length %g with scheme of CFL coefficient %g did not satisfy user-provided CFL constraint %g, step REJECTED\n",(double)h,(double)ccfl,(double)cfltimestep);CHKERRQ(ierr); 308d59e960SJed Brown *accept = PETSC_FALSE; 318d59e960SJed Brown } 328d59e960SJed Brown } 338d59e960SJed Brown 341566a47fSLisandro Dalcin /* The optimal new step based purely on CFL constraint for this step. */ 351566a47fSLisandro Dalcin hcfl = cfl->safety * cfltimestep * ccfl; 361566a47fSLisandro Dalcin if (hcfl < adapt->dt_min) { 371566a47fSLisandro Dalcin ierr = PetscInfo4(adapt,"Cannot satisfy CFL constraint %g (with %g safety) at minimum time step %g with method coefficient %g, proceding anyway\n",(double)cfltimestep,(double)cfl->safety,(double)adapt->dt_min,(double)ccfl);CHKERRQ(ierr); 381566a47fSLisandro Dalcin } 391566a47fSLisandro Dalcin 408d59e960SJed Brown *next_sc = 0; 418d59e960SJed Brown *next_h = PetscClipInterval(hcfl,adapt->dt_min,adapt->dt_max); 420b99f514SJed Brown *wlte = -1; /* Weighted local truncation error was not evaluated */ 43*5e4ed32fSEmil Constantinescu *wltea = -1; /* Weighted absolute local truncation error was not evaluated */ 44*5e4ed32fSEmil Constantinescu *wlter = -1; /* Weighted relative local truncation error was not evaluated */ 458d59e960SJed Brown PetscFunctionReturn(0); 468d59e960SJed Brown } 478d59e960SJed Brown 488d59e960SJed Brown #undef __FUNCT__ 498d59e960SJed Brown #define __FUNCT__ "TSAdaptDestroy_CFL" 508d59e960SJed Brown static PetscErrorCode TSAdaptDestroy_CFL(TSAdapt adapt) 518d59e960SJed Brown { 528d59e960SJed Brown PetscErrorCode ierr; 538d59e960SJed Brown 548d59e960SJed Brown PetscFunctionBegin; 558d59e960SJed Brown ierr = PetscFree(adapt->data);CHKERRQ(ierr); 568d59e960SJed Brown PetscFunctionReturn(0); 578d59e960SJed Brown } 588d59e960SJed Brown 598d59e960SJed Brown #undef __FUNCT__ 608d59e960SJed Brown #define __FUNCT__ "TSAdaptSetFromOptions_CFL" 614416b707SBarry Smith static PetscErrorCode TSAdaptSetFromOptions_CFL(PetscOptionItems *PetscOptionsObject,TSAdapt adapt) 628d59e960SJed Brown { 638d59e960SJed Brown TSAdapt_CFL *cfl = (TSAdapt_CFL*)adapt->data; 648d59e960SJed Brown PetscErrorCode ierr; 658d59e960SJed Brown 668d59e960SJed Brown PetscFunctionBegin; 67e55864a3SBarry Smith ierr = PetscOptionsHead(PetscOptionsObject,"CFL adaptive controller options");CHKERRQ(ierr); 681566a47fSLisandro Dalcin ierr = PetscOptionsReal("-ts_adapt_cfl_safety","Safety factor relative to target CFL constraint","",cfl->safety,&cfl->safety,NULL);CHKERRQ(ierr); 691566a47fSLisandro Dalcin ierr = PetscOptionsBool("-ts_adapt_cfl_always_accept","Always accept the step regardless of whether CFL constraint meets goal","",cfl->always_accept,&cfl->always_accept,NULL);CHKERRQ(ierr); 70c524d1a0SJed Brown /* The TS implementations do not currently communicate CFL information to the controller. There is a placeholder, but 71c524d1a0SJed Brown * we do not believe it to provide sufficiently rich information. That means the CFL adaptor is incomplete and 72c524d1a0SJed Brown * unusable. Do not delete the guard below unless you have finished the implementation. */ 73c524d1a0SJed Brown if (!cfl->always_accept) SETERRQ(PetscObjectComm((PetscObject)adapt),PETSC_ERR_SUP,"Step rejection not implemented. The CFL implementation is incomplete/unusable"); 748d59e960SJed Brown ierr = PetscOptionsTail();CHKERRQ(ierr); 758d59e960SJed Brown PetscFunctionReturn(0); 768d59e960SJed Brown } 778d59e960SJed Brown 788d59e960SJed Brown #undef __FUNCT__ 798d59e960SJed Brown #define __FUNCT__ "TSAdaptCreate_CFL" 808d59e960SJed Brown /*MC 818d59e960SJed Brown TSADAPTCFL - CFL adaptive controller for time stepping 828d59e960SJed Brown 838d59e960SJed Brown Level: intermediate 848d59e960SJed Brown 858d59e960SJed Brown .seealso: TS, TSAdapt, TSSetAdapt() 868d59e960SJed Brown M*/ 878cc058d9SJed Brown PETSC_EXTERN PetscErrorCode TSAdaptCreate_CFL(TSAdapt adapt) 888d59e960SJed Brown { 898d59e960SJed Brown PetscErrorCode ierr; 908d59e960SJed Brown TSAdapt_CFL *a; 918d59e960SJed Brown 928d59e960SJed Brown PetscFunctionBegin; 93b00a9115SJed Brown ierr = PetscNewLog(adapt,&a);CHKERRQ(ierr); 948d59e960SJed Brown adapt->data = (void*)a; 951566a47fSLisandro Dalcin 968d59e960SJed Brown adapt->ops->choose = TSAdaptChoose_CFL; 978d59e960SJed Brown adapt->ops->setfromoptions = TSAdaptSetFromOptions_CFL; 988d59e960SJed Brown adapt->ops->destroy = TSAdaptDestroy_CFL; 998d59e960SJed Brown 1008d59e960SJed Brown a->safety = 0.9; 1018d59e960SJed Brown a->always_accept = PETSC_FALSE; 1028d59e960SJed Brown PetscFunctionReturn(0); 1038d59e960SJed Brown } 104