Actual source code: adaptcfl.c
petsc-3.6.1 2015-08-06
1: #include <petsc/private/tsimpl.h> /*I "petscts.h" I*/
3: typedef struct {
4: PetscBool always_accept;
5: PetscReal safety; /* safety factor relative to target error */
6: } TSAdapt_CFL;
10: static PetscErrorCode TSAdaptChoose_CFL(TSAdapt adapt,TS ts,PetscReal h,PetscInt *next_sc,PetscReal *next_h,PetscBool *accept,PetscReal *wlte)
11: {
12: TSAdapt_CFL *cfl = (TSAdapt_CFL*)adapt->data;
13: PetscErrorCode ierr;
14: PetscReal hcfl,cfltime;
15: PetscInt stepno,ncandidates;
16: const PetscInt *order;
17: const PetscReal *ccfl;
20: TSGetTimeStepNumber(ts,&stepno);
21: TSGetCFLTime(ts,&cfltime);
22: TSAdaptCandidatesGet(adapt,&ncandidates,&order,NULL,&ccfl,NULL);
24: hcfl = cfl->safety * cfltime * ccfl[0];
25: if (hcfl < adapt->dt_min) {
26: PetscInfo4(adapt,"Cannot satisfy CFL constraint %g (with %g safety) at minimum time step %g with method coefficient %g, proceding anyway\n",(double)cfltime,(double)cfl->safety,(double)adapt->dt_min,(double)ccfl[0]);
27: }
29: if (h > cfltime * ccfl[0]) {
30: if (cfl->always_accept) {
31: 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[0],(double)cfltime);
32: } else {
33: 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[0],(double)cfltime);
34: *next_sc = 0;
35: *next_h = PetscClipInterval(hcfl,adapt->dt_min,adapt->dt_max);
36: *accept = PETSC_FALSE;
37: }
38: }
40: *next_sc = 0;
41: *next_h = PetscClipInterval(hcfl,adapt->dt_min,adapt->dt_max);
42: *accept = PETSC_TRUE;
43: *wlte = -1; /* Weighted local truncation error was not evaluated */
44: return(0);
45: }
49: static PetscErrorCode TSAdaptDestroy_CFL(TSAdapt adapt)
50: {
54: PetscFree(adapt->data);
55: return(0);
56: }
60: static PetscErrorCode TSAdaptSetFromOptions_CFL(PetscOptions *PetscOptionsObject,TSAdapt adapt)
61: {
62: TSAdapt_CFL *cfl = (TSAdapt_CFL*)adapt->data;
66: PetscOptionsHead(PetscOptionsObject,"CFL adaptive controller options");
67: PetscOptionsReal("-ts_adapt_cfl_safety","Safety factor relative to target error","",cfl->safety,&cfl->safety,NULL);
68: PetscOptionsBool("-ts_adapt_cfl_always_accept","Always accept the step regardless of whether local truncation error meets goal","",cfl->always_accept,&cfl->always_accept,NULL);
69: if (!cfl->always_accept) SETERRQ(PetscObjectComm((PetscObject)adapt),PETSC_ERR_SUP,"step rejection not implemented yet");
70: PetscOptionsTail();
71: return(0);
72: }
76: /*MC
77: TSADAPTCFL - CFL adaptive controller for time stepping
79: Level: intermediate
81: .seealso: TS, TSAdapt, TSSetAdapt()
82: M*/
83: PETSC_EXTERN PetscErrorCode TSAdaptCreate_CFL(TSAdapt adapt)
84: {
86: TSAdapt_CFL *a;
89: PetscNewLog(adapt,&a);
90: adapt->data = (void*)a;
91: adapt->ops->choose = TSAdaptChoose_CFL;
92: adapt->ops->setfromoptions = TSAdaptSetFromOptions_CFL;
93: adapt->ops->destroy = TSAdaptDestroy_CFL;
95: a->safety = 0.9;
96: a->always_accept = PETSC_FALSE;
97: return(0);
98: }