xref: /petsc/src/ts/adapt/impls/cfl/adaptcfl.c (revision 5e4ed32f0140df3e357a2244cf5f0301f2d2ad78)
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