petsc-3.9.4 2018-09-11
Documentation: Changes: 2.1.6
General:
- Added support for Cray X1
-
Added option '-suggest' to petscarch script. It suggests some
possible PETSC_ARCHes to use
- Installation instructions are rewritten
Vec:
- VecNorm now caches NORM_2
- Added VecStrideScale(), VecStrideGather(), VecStrideScatter()
- Added VecBlockNorm(),VecBlockMax(),VecBlockMin(),VecBlockScale()
Mat:
-
The interface to external packages that support direct solvers has
been reorganized. This is implemented using new matrix types
MATSEQAIJSPOOLES, MATMPIAIJSPOOLES, MATSEQSBAIJSPOOLES,
MATMPISBAIJSPOOLES, MATSUPERLU, MATSUPERLU_DIST, MATUMFPACK,MATESSL,
MATLUSOL, MATAIJMUMPS, MATSBAIJMUMPS, MATDSCPACK
-
Added new convenience matrix types which automatically switch between
Seq and MPI implementations depending on the size of the communicator
used during creation: MATAIJ, MATBAIJ, MATSBAIJ, MATMAIJ, MATDENSE,
MATBDIAG
-
Changed default matrix-free compute h to use WP since it uses fewer
reductions
- Replace the datatypes MatLUInfo and MatILUInfo by MatFactorInfo
- Added cholesky support to SeqAIJ
- Added support for SUBSET_NONZERO_PATTERN with MatAXPY for AIJ & BAIJ
- Added MatIsSymmetric() for AIJ
- Added LDA support in SeqDense
- The ncols argument made optional in MatGetRow()
- Added MAT_KEEP_ZEROED_ROWS for MPIROWBS
- Removed -aij_oneindex support from AIJ code
- Added MatPartitioningSetPartitionWeights() - useable with ParMetis
- MatGetSubMatrices() now works for ROWBS
PC:
- Added PCICCSetDamping() or -pc_icc_damping
- Added -pc_constant_null_space
- Added PCILUSetShift() or -pc_ilu_shift to support damping using the identity
- Added PCLUSetShift() or -pc_lu_shift to support damping using the identity
- Added PCICCSetShift() or -pc_icc_shift to support damping using the identity
KSP:
- Added a new ksp_type LGMRES
- Added KSPSetComputeSingularValues() support to ksp_type FGMRES
TS:
- Added support for Runge-Kutta using ts_type TS_RUNGE_KUTTA
DMMG:
- -dmmg_jacobian_period -1 => jacobian is frozen after initial construction
DA:
- Allow user preallocation of jacobian using DASetGetMatrix()
- DAGetMatrix now correctly returns the requested type.
- -mat_type typename overloads the requested type for DAGetMatrix
SYS:
- Added new viewer_type PETSC_VIEWER_NETCDF, PETSC_VIEWER_HDF4
- PETSc error handlers now trap many more signals.
Fortran:
- PetscPushErrorHandler() and PetscPopErrorHandler() now supported
- PetscPrintf() and PetscSynchronizedPrintf() now work in fortran with a single string
External Packages:
- Added TSPVodeGetParameters()
- Parmetis-3 support added using MatPartitionSetNParts(), ISPartitionCount()
- MUMPS support added, including complex (using mat_type MATAIJMUMPS, MATSBAIJMUMPS)
- Updated SuperLU_DIST interface to SuperLU_DIST_2.0
- Added Spooles complex support
- Added Spooles cholesky for SeqAIJ
-
ADIC: ad_GRAD_MAX is now set in the application and compiled into
code when compiling appplication
-
The following variable names - in the buildsystem are changed - that
correspond with SuperLU_DIST SUPERLUDIST_INCLUDE ->
SUPERLU_DIST_INCLUDE SUPERLUDIST_LIB -> SUPERLU_DIST_LIB
PETSCHAVE_SUPERLU -> PETSC_HAVE_SUPERLU