Changes: 3.7#
General:
- -log_summary is deprecated, you should use -log_view 
- PetscViewerSetFormat() is deprecated, you should use PetscViewerPushFormat() followed after the viewing with PetscViewerPopFormat() 
- PetscMemoryShowUsage() and -memory_info changed to PetscMemoryView() and -memory_view 
- PetscOptionsSetValue() may now be called BEFORE PetscInitialize() and any options set then will be used in the initialization process. These options are overwritten by command line options. 
- The following routines now take an optional PetscOptions object as the first argument, use NULL to get the previous behavior. - PetscOptionsHasName(PetscOptions,const char[],const char[],PetscBool *); PetscOptionsGetInt(PetscOptions,const char[],const char [],PetscInt *,PetscBool *); PetscOptionsGetBool(PetscOptions,const char[],const char [],PetscBool *,PetscBool *); PetscOptionsGetReal(PetscOptions,const char[],const char[],PetscReal *,PetscBool *); PetscOptionsGetScalar(PetscOptions,const char[],const char[],PetscScalar *,PetscBool *); PetscOptionsGetIntArray(PetscOptions,const char[],const char[],PetscInt[],PetscInt *,PetscBool *); PetscOptionsGetRealArray(PetscOptions,const char[],const char[],PetscReal[],PetscInt *,PetscBool *); PetscOptionsGetScalarArray(PetscOptions,const char[],const char[],PetscScalar[],PetscInt *,PetscBool *); PetscOptionsGetBoolArray(PetscOptions,const char[],const char[],PetscBool [],PetscInt *,PetscBool *); PetscOptionsGetString(PetscOptions,const char[],const char[],char[],size_t,PetscBool *); PetscOptionsGetStringArray(PetscOptions,const char[],const char[],char*[],PetscInt*,PetscBool *); PetscOptionsGetEList(PetscOptions,const char[],const char[],const char*const*,PetscInt,PetscInt*,PetscBool *); PetscOptionsGetEnum(PetscOptions,const char[],const char[],const char*const*,PetscEnum*,PetscBool *); PetscOptionsGetEnumArray(PetscOptions,const char[],const char[],const char*const*,PetscEnum*,PetscInt *,PetscBool *); PetscOptionsSetAlias(PetscOptions,const char[],const char[]); PetscOptionsSetValue(PetscOptions,const char[],const char[]); PetscOptionsClearValue(PetscOptions,const char[]); PetscOptionsAllUsed(PetscOptions,PetscInt*); PetscOptionsUsed(PetscOptions,const char *,PetscBool*); PetscOptionsView(PetscOptions,PetscViewer); PetscOptionsInsert(PetscOptions,int*,char ***,const char[]); PetscOptionsInsertFile(MPI_Comm,PetscOptions,const char[],PetscBool ); PetscOptionsInsertString(PetscOptions,const char[]); PetscOptionsPrefixPush(PetscOptions,const char[]); PetscOptionsReject(PetscOptions,const char[],const char[]); PetscOptionsGetAll(PetscOptions,char*[]); 
- PetscLogBegin() is now PetscLogDefaultBegin(). 
Configure/Build:
- Added –download-packages-dir=directory to support easy use of –download-xxx behind firewalls 
- –download-package for externalpackage with a gitrepo will never be stale. Each time configure is invoked - it will do a ‘git fetch’ and ‘git checkout commit-id’. And if the commit-id changes from the previous build - the package will be rebuilt. To prevent this sync [and use previous snapshot] - one can use –download-package-commit=HEAD 
- Added –with-libpng/–with-giflib/–with-libjpeg and corresponding –download versions to support PNG/GIF/JPEG image generation 
- Removed support for AfterImage in favor of libpng/GIFLIB/libjpeg 
IS:
PetscDraw:
- Added option -draw_cmap to use a named colormap (e.g., hue (default), jet, coolwarm, parula, viridis) in the drawing of contour plots. 
- Support for saving images and movies was improved. Support for generating binary PPM images is built-in, but the format is uncompressed and images are large (640x480 pixels ~ 900 KiB). PETSc can optionally generate PNG/GIF/JPEG images using the libpng/GIFLIB/libjpeg packages (configure –with-package/–download-package). These libraries are popular, well maintained, and available through most packages managers (dnf/yum, apt, brew). For most users, PNG images should be enough. 
- Added routine PetscDrawSave(), users should explicitly call it to save images after configuring with PetscDrawSetSave(). 
- The PetscDrawSynchronizedXXX() routines were removed, the corresponding PetscDrawXXX() are now collective. 
PF:
Vec:
- For complex numbers VecNorm(v,NORM_1,) will return the traditional 1 norm of the 2 norm of the complex numbers; that is the 1 norm of the absolute values of the complex entries. Previously it returned the 1 norm of the 1 norm of the complex entries (what is returned by the BLAS routine asum()). Both are valid norms but most people expect the former. 
VecScatter:
PetscSection:
Mat:
PC:
- If the DM has a CreateRestriction() function the PCMG automatically uses that to create the restriction operator instead of defaulting to using the transpose of the interpolation 
- Added -pc_hypre_boomeramg_nodal_coarsen - where n is from 1 to 6 (see HYPRE_BOOMERAMGSetNodal()) 
- Added -pc_hypre_boomeramg_vec_interp_variant where v is from 1 to 4 (see HYPRE_BoomerAMGSetInterpVecVariant()) 
- see PCHYPRE to allow taking advantage of MatSetNearNullSpace() for hypre BoomerAMG 
- Added PCTelescope which supports running solvers on sub-communicators. This PC allows re-partitioning of coarse levels solves within PCMG when using Galerkin coarse level operators. 
KSP:
- KSPSetMonitor(KSPMonitorXXX, calls now require passing a viewer as the final argument, you can no longer pass a NULL) 
- -ksp_monitor_solution now takes arguments of the form [viewertype[:filename[:formatoption]]] allowing viewing the solution in many ways. To get back the previous behavior use -ksp_monitor_solution draw 
- A Flexible Conjugate Gradient (FCG) implementation has been added as KSPFCG. 
- New implementations for pipelined, flexible Krylov methods have been added as KSPPIPEFGMRES, KSPPIPEFCG, and KSPPIPEGCR. 
SNES:
- SNESSetMonitor(SNESMonitorXXX, calls now require passing a viewer as the final argument, you can no longer pass a NULL) 
- -snes_monitor_solution/residual/solution_update now takes arguments of the form [viewertype[:filename[:formatoption]]] allowing viewing the solution in many ways. To get back the previous behavior use -ksp_monitor_solution draw 
SNESLineSearch:
- -snes_linesearch_monitor now takes an optional [:filename] argument, changed SNESLineSearchSet/GetMonitor to SNESLineSearchSet/GetDefaultMonitor 
- Added SNESLineSearchMonitorSet() 
- Partial support for -snes_linesearch_monitor_solution_update 
TS:
- You must call TSSetExactFinalTime() or use the option -ts_exact_final_time before calling TSSolve() 
- TSSetMonitor(TSMonitorXXX, calls now require passing a viewer as the final argument, you can no longer pass a NULL) 
- -ts_monitor_solution now takes arguments of the form [viewertype[:filename[:formatoption]]] allowing viewing the solution in many ways. To get back the previous behavior use -ksp_monitor_solution draw 
- -ts_monitor_binary_solution filename should now be written as -ts_monitor_solution binary:filename 
- Renamed TSSetEventMonitor() to TSSetEventHandler(). Updated many TS implementations to support event detection. 
- Updated TSTHETA, TSBEULER, and TSCN to support time adaptivity by estimating the local truncation error with a BDF-2 formula. 
- Updated TSALPHA implementation. Removed TSAlphaSetAdapt() and TSAlphaAdaptDefault(), use TSAlphaUseAdapt() instead. 
- Added TSBDF, an implementation of backward difference formulas using constant order (1 to 6) and supporting time adaptivity. 
- Implemented new interface for second-order systems to avoid using a first-order system formulation. Added TSALPHA2 implementation (generalized-alpha, Chung & Hubert 1993) featuring user-controlled damping of high-frequency modes and time adaptivity through a BDF-2 formula. 
DM/DA:
- Added DMShellSetCreateRestriction 
- Added the generic option prefix interfaces: DMGetOptionsPrefix(), DMAppendOptionsPrefix() 
- DMLabel labels are now available to all DM objects, not just DMPlex object 
- DMClone() now handles copying the coordinates, so that DMCopyCoordinates() is no longer necessary 
DMPlex:
PetscViewer:
- Replaced PetscViewerASCIISynchronizedAllow() with PetscViewerASCIIPushSynchronized() PetscViewerASCIIPopSynchronized() 
SYS:
Tao:
- Removed convergence tolerances -tao_fatol and tao_frtol also remove these two parameters from TAOSetTolerance() and TaoGetTolerance() 
AO:
Sieve:
Fortran: