Note: Palace is under active initial development, pre-v1.0. Functionality and interfaces may change rapidly as development progresses.
The format of this changelog is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- Fixed a small regression bug for boundary postprocessing when specifying
"Side": "LargerRefractiveIndex"
, introduced as part of v0.13.0. - Added an improvement to numeric wave ports to avoid targetting evanescent modes at
higher operating frequencies. Also finite conductivity boundaries
(
config["Boundaries"]["Conductivity"]
) are automatically marked as PEC for the wave port mode solve (previously these were marked as PMC unless specified under"WavePortPEC"
). - Fixed a bug in divergence-free projection for problems without essential or mixed boundary conditions.
- Added
"MakeSimplex"
and"MakeHexahedral"
mesh options to convert an input mesh to all tetrahedra or all hexahedra. Also adds"SerialUniformLevels"
option toconfig["Model"]["Refinement"]
for testing or debugging. - Added
config["Model"]["CrackInternalBoundaryElements"]
which will separate or "crack" the mesh along all internal boundaries. This improves the performance of error estimation and AMR as the recovered smooth fields do not enforce additional erroneous continuity at internal boundaries. This will change the default behaviour in the case of internal impedance boundary conditions, and can be disabled by setting this option to false. - Added support for exact periodic boundary conditions, these can be specified as part of
the mesh file (where supported by the format) or by specification of
"DonorAttributes"
and"ReceiverAttributes"
inconfig["Boundaries"]["Periodic"]
which will attempt to match the mesh on the boundaries specified by the donor and receiver attributes. This is only possible the mesh on the donor and receiver match exactly, non-matching meshes are not supported. - Exposed configuration linear solver and eigen solver options for the wave port
subproblem. These can now be specified as part of the
config["Boundaries"]["WavePort"]
configuration. The defaults align with the previously hardcoded values. - Nonconformal adaptation is now supported for WavePort boundary conditions. This was
achieved through a patch applied to MFEM to support
mfem::ParSubMesh
on external nonconformal surface subdomains. - Added adaptive time-stepping capability for transient simulations. The new ODE integrators
rely on the SUNDIALS library and can be specified by setting the
config["Solver"]["Transient"]["Type"]
option to"CVODE"
or"ARKODE"
. - Added an option to use the complex-valued system matrix for the coarse level solve (sparse
direct solve) instead of the real-valued approximation. This can be specified with
config["Solver"]["Linear"]["ComplexCoarseSolve"]
.
- Changed default value of
config["Solver"]["PartialAssemblyOrder"]
in order to activate operator partial assembly by default for all operators in all simulation types. - Changed the normalization of computed eigenmodes for consistency across different domain decompositions. Eigenvectors are now normalized with respect to the mass matrix for unit domain electric field energy.
- Added documentation for various timer categories and improved timing breakdown of various sections of a simulation.
- Changed mesh files for the cavity and CPW examples, including prism, hexahedral, and tetrahedral meshes for the cylindrical cavity and correcting the wave port dimensions for the coplanar wave guide.
- Fixed a few bugs and issues in the implementation of numeric wave ports for driven simulations.
- Added GPU support for Palace via its dependencies, and added the
config["Solver"]["Device"]
andconfig["Solver"]["Backend"]
options for runtime configuration of the MFEM device ("CPU"
or"GPU"
) and libCEED backend, with suitable defaults for users. - Added a new section to the documentation on Parallelism and GPU support.
- Removed use of
mfem::SparseMatrix
and replaced with HYPRE'shypre_CSRMatrix
when needed for full assembly, wrapped aspalace::hypre::HypreCSRMatrix
. - Added
"Active"
configuration file parameter for lumped and wave port boundaries to disable the associated boundary condition and only use the surface for postprocessing. - Changed the smooth flux space for the electrostatic error estimator to fix performance on problems with material interfaces.
- Fixed error estimation bug affecting time-dependent simulation types (driven, transient, eigenmode) where the recovery of the electric flux density also needs to be taken into account in addition to the magnetic field.
- Fixed a bug related to mesh cleaning for unspecified domains and mesh partitioning.
- Change computation of domain energy postprocessing for electrostatic and magnetostatic simulation types in order to improve performance.
- Fixed a bug when computing the energy associated with lumped elements with more than one nonzero R, L, or C. This also affects the inductive EPR for lumped inductors with and associated parallel capacitance.
- Fixed a bug for coaxial lumped ports which led to incorrect extraction of the geometric parameters, especially when coarsely-meshed or non-axis-aligned.
- Added boundary postprocessing functionality for surface flux including electric,
magnetic, and power given by the Poynting vector. This results in some breaking changes
to the configuration file interface, see
config["Boundaries"]["Postprocessing"]["SurfaceFlux"]
andconfig["Boundaries"]["Postprocessing"]["Dielectric"]
. In addition, related configuration file keyword changes to for consistency were made toconfig["Domains"]["Postprocessing"]["Probe"]
andconfig["Model"]["Refinement"]["Boxes"]
. - Fixed a bug in MFEM for nonconformal AMR meshes with internal boundaries affecting non-homogeneous Dirichlet boundary conditions for electrostatic simulations (see #236).
- Added support for operator partial assembly for high-order finite element spaces based
on libCEED for mixed and non-tensor product element meshes. This option is disabled by
default, but can be activated using
config["Solver"]["PartialAssemblyOrder"]
set to some number less than or equal to"Order"
. - Added flux-based error estimation, reported in
error-estimate.csv
. This computes the difference between the numerical gradient (electrostatics) or curl (otherwise) of the solution, and a smoother approximation obtained through a global mass matrix inversion. The results are reported inerror-estimates.csv
within the"Output"
folder. - Added Adaptive Mesh Refinement (AMR), specified in the
config["Model"]["Refinement"]
, for all problem types aside from transient. To enable AMR, a user must specify"MaxIts"
, while all other options have reasonable defaults. Nonconformal (all mesh types) and conformal (simplex meshes) refinement are supported. - Added support for non-axis-aligned lumped ports and current sources. Key words
"X"
,"Y"
,"Z"
and"R"
, with optional prefix"+"
or"-"
still work, but now directions can be specified as vectors with 3 components. Users will be warned, and ultimately errored, if the specified directions do not agree with axis directions discovered from the geometry. - Added output of lumped port voltage and current for eigenmode simulations.
- Added dimensionalized output for energies, voltages, currents, and field values based on a choice of the characteristic magnetic field strength used for nondimensionalization.
- Added output of electric and magnetic field energies and participation ratios in regions
of the domain, specified with
config["Domains"]["Postprocessing"]["Energy"]
and written todomain-E.csv
. This replacesconfig["Domains"]["Postprocessing"]["Dielectric"]
anddomain-Q.csv
. - Added improved
Timer
andBlockTimer
classes with more timing categories for reporting simulation runtime. - Changed implementation of complex-valued linear algebra to use new
ComplexVector
andComplexOperator
types, which are based on the underlyingmfem::Vector
andmfem::Operator
classes, instead of PETSc. PETSc is now fully optional and only required when SLEPc eigenvalue solver support is requested. Krylov solvers for real- and complex-valued linear systems are implemented via the built-inIterativeSolver
classes. - Changed implementation of PROMs for adaptive fast frequency sweep to use the Eigen library for sequential dense linear algebra.
- Changed implementation of numeric wave ports to use MFEM's
SubMesh
functionality. As of #3379 in MFEM, this has full ND and RT basis support. For now, support for nonconforming mesh boundaries is limited. - Added build dependencies on libCEED, including LIBXSMM and MAGMA to support CPU- and GPU-based operator partial assembly.
- Added unit test framework for all integrators based on Catch2, which also includes some automated benchmarking capabilities for operator assembly and application.
- Added improved OpenMP support in
palace
wrapper script and CI tests. - Added Apptainer/Singularity container build definition for Palace.
- Fixed bugs related to thread-safety for OpenMP builds and parallel tetrahedral meshes in the upstream MFEM library.
- Fixed a regression bug affecting meshes which have domain elements which are not assigned material properties in the configuration file.
- Changed layout and names of
palace/
source directory for better organization. - Added many updates to build system: Removed use of Git submodules to download
dependencies relying instead directly on CMake's ExternalProject, patch GSLIB dependency
for shared library builds, add CI tests with ARPACK-NG instead of SLEPc, update all
dependency versions including MFEM to incorporate bug fixes and improvements. This
affects the Spack package recipe, so a new recipe is distributed as part of Palace in
in
spack/
which will keep compatibility withmain
while changes are upstreamed to the built-in Spack repository. - Added a basic Makefile with some useful targets for development.
- Fixed a bug for interface dielectric loss postprocessing including when using
--dry-run
. - Fixed a regression bug affecting second-order absorbing boundary conditions.
- Fixed a bug when the number of processors was large enough that some subdomains own no true dofs.
- Fixed memory bug in destruction of SuperLU solver.
- Fixed some typos in the documentation.
- Fixed a bug in the cavity convergence study example for the coarsest hexahedral mesh
case, as well as some other minor Julia fixes in the
examples/
andscripts/
directories. - Added updates to superbuild including better ARPACK support, though still experimental compared to SLEPc.
- Added updated submodules for superbuild.
- Initial public release on GitHub.
- Added support for anisotropic materials through the use of
"MaterialAxes"
under"Materials"
. These material axes allow for specifying symmetric material property tensors through a sum of weighted outer products of normal vectors. This can be used in conjunction with scalar material properties or multiple different anisotropic properties, though all properties are required to use the same set of basis vectors. Demonstration given for the coplanar waveguide example which now utilizes a sapphire substrate. - Added to default postprocessing outputs: Bulk and interface dielectric loss writes
energy-participation ratios in addition to quality factors associated with lossy
regions, IO coupling
$\kappa$ in addition to quality factor for eigenmode simulations, lumped element energy for transient simulations similar to eigenmode and frequency domain driven simulations. - Changed configuration file syntax to simplify support for multielement lumped ports,
where each index for a multielement port should now use the
"Elements"
object to describe the attributes for each port element. - Changed configuration file keywords to better reflect meaning:
config["Boundaries"]["Current"]
=>config["Boundaries"]["SurfaceCurrent"]
, and"UseGMG"
,"UsePCShifted"
,"MGCycleIts"
, and"MGSmoothIts"
underconfig["Solver"]["Linear"]
. - Changed geometric multigrid implementation to generalize across problem types (added for electrostatics) and use Jacobi-preconditioned Chebyshev smoothing with optional auxiliary space smoothing at each multigrid level as well. The auxiliary space matrices are constructed directly in H1 now to allow for matrix-free/partial-assembly support eventually. Geometric multigrid is turned on by default.
- Added structured simulation metadata output in the form of a JSON file
palace.json
written to the directory specified byconfig["Problem"]["Output"]
. - Added JSON Schema files for the configuration file format as well as a helper script to check a provided configuration file against the schema.
- Added optional interface to GSLIB library which enables
"Probe"
functionality to sample the computed electric and magnetic fields at points in space. - Added preliminary support for builds using Spack. This includes an option in the build system for user-supplied dependencies as an alternative to the superbuild configuration.
- Added updated submodules for superbuild, fixing a bug in SuperLU_DIST solver causing communication hangs for certain numbers of processors.
- Added interfaces to ARPACK and FEAST eigenvalue solvers.
- Added divergence-free projection for eliminating spurious DC modes for eigenmode solves.
- Added option for visualizing fields on mesh boundaries, output alongside the full 3D solution fields for ParaVeiew visualization.
- Added real and imaginary fields output for complex-valued phasors, and electric and magnetic energy density fields.
- Added convergence study for the cavity example application, and example Julia code for automated mesh generation, running of the solver, and postprocessing.
- Fixed bugs in mesh preprocessing related to precision of nodal coordinates when distributing a serial mesh to each process.
- Added option for
"Driven"
and"Transient"
simulations to accelerate postprocessing by only considering port boundaries. - Added
-dry-run
/--dry-run
command line option to check configuration file for errors and exit. - Changed dependency build process to rely less on PETSc build system, no longer give option to build BLAS/LAPACK libraries from source, added detection for OpenBLAS and AMD Optimizing CPU Libraries (AOCL) blis/libflame.
- Fixed issues when compiling with Intel or Clang compilers.
- Added CI test builds to test various build options and added easier default build options in CMake configuration.
- Added
clang-format
andJuliaFormatter
configurations for automated C++, Julia, and Markdown code formatting.
- Added region-based mesh refinement with box or sphere refinement regions.
- Added new sparse direct solver interfaces to SuperLU_DIST and STRUMPACK libraries, to complement the existing MUMPS interface.
- Changed configuration file keywords for linear solver and preconditioner parameters to make more options available to the user and clarify them.
- Added check that all external boundary surface attributes must have an associated
boundary condition specified in the configuration file (adds new
"PMC"
and"ZeroCharge"
boundaries for natural boundary conditions). - Added advanced configuration options for GMRES/FGMRES/SLEPc eigenvalue solver orthogonalization, making CGS2 (classical GS with iterative refinement) the default.
- Added new comprehensive example applications and detailed tutorials in the documentation.
- Added CI pipeline for build and regression testing.
- Fixed bugs for shared library builds, which are now the default for dependency builds.
- Added complex lumped port voltage and current output for computing impedance and admittance parameters from frequency domain driven simulations.
- Fixed a bug in mesh parsers for COMSOL and Nastran formats for high-order hexahedra, prism, and pyramid element types.
- Changed adaptive frequency sweep implementation to introduce optimizations which, in particular, speed up driven simulations with wave ports.
- Fixed bug related to domain dielectric postprocessing and surface dielectric loss postprocessing now automatically detects correct side for substrate-air interfaces (always evaluates on vacuum side).
- Added adaptive fast frequency sweep implementation for frequency domain driven
simulations, activated with
config["Solver"]["Driven"]["AdaptiveTol"] > 0.0
. - Changed ASCII file postprocessing to write out .csv files instead of generic whitespace delimited .txt for easier parsing.
- Changed field output postprocessing for visualization to save the mesh in the original mesh length units (rather than nondimensionalized ones).
- Added electric and magnetic field energy output to files as function of mode, frequency,
time, or solution step, in
domain-E.csv
. - Added option to specify circuit R/L/C parameters for lumped port boundaries as an alternative to the surface Rs/Ls/Cs ones.
- Added improved and expanded documentation.
- Added new MFEM features, including support for ND and RT spaces on wedge or prism elements and bug fixes.
- Changed implementation of boundary conditions and excitations to do a better job separating spatial discretization and algebraic operators. This is also in preparation for future additions of boundary conditions which are not quadratic in the frequency such as wave ports, as well as linear algebra improvements.
- Added a
config["Boundaries"]["Current"]
configuration file parameter to specify a surface current excitation, and removed the lumped port"Termination"
option as it is no longer relevant. Magnetostatics simulations use this"Current"
excitation rather than"Port"
now. - Changed lumped port and surface current excitations to now use a unit circuit voltage and circuit current excitation, rather than unit electric field or surface current density.
- Added numeric wave port boundaries for frequency domain driven simulations. To
differentiate, lumped port boundaries are now specified using the keyword
"LumpedPort"
instead of just"Port"
in the configuration file. - Fixed farfield boundaries to account for non-vacuum materials at the boundary and added second-order option for absorbing boundary condition (ABC).
- Added finite conductivity surface impedance boundary condition, with optional thickness correction.
- Added dielectric loss calculation specializations for metal-air, metal-substrate, and substrate-air interfaces in accordance with this paper.
- Changed implementation of frequency domain linear algebra to eliminate the use of PETSc matrix types, relying instead on wrappers of the real and imaginary Hypre matrices making up a complex operator.
- Added geometric multigrid AMS solvers (in two variants) using h- or p-coarsening, which employs either a specialized smoother for Nedelec space coarsening or geometric coarsening for the auxiliary space solves.
- Changed build process to include PETSc as a submodule and configure as part the standard CMake build process.
- Changed postprocessing implementation which leads to some configuration file changes,
namely
config["Domains"]["Postprocessing"]
andconfig["Boundaries"]["Postprocessing"]
. - Changed some filenames for postprocessed quantities to be more intuitive.
- Added dielectric (bulk and interface) loss calculations for all simulation types.
Correctly handles two-sided internal surfaces using
"Side"
specification. - Added mutual capacitance matrix extraction to electrostatic solver.
- Added built-in mesh support for COMSOL (
.mphbin
and.mphtxt
) and Nastran (.nas
and.bdf
) mesh formats. - Removed Gmsh dependency for mesh format conversion.
- Added some improvements to the default build flags and dependency build options.
- Added
"Capacitance"
and"Inductance"
options to extract surface charges and fluxes in frequency and time domain simulation types. - Changed
"Transient"
solver implementation to use real-valued scalars (user must use a domain electrical conductivity as opposed to a loss tangent for loss modeling), for a roughly 2x performance improvement. - Added new MFEM features, including upgrades to high-order Nedelec element spaces on tetrahedra which no longer require global dof reordering.
- Changed system matrix assembly to use Hypre P^T A P within MFEM and keep the full dense
element matrices when the coefficient is nonzero (
skip_zeros = 0
always). The stiffness and mass matrices thus always share the same sparsity pattern now.
- Added electrostatic solver for capacitance matrix extraction.
- Added
"Termination"
option for ports to allow for open or short circuiting but still enabling port postprocessing. - Changed timer to separate out time spent for disk I/O during initialization and postprocessing.
- Added options to job wrappers for new instance types and subnet ID option.
- Added changes from Hypre and MFEM dependencies to include improvements and bug fixes from those libraries.
- Added a proper changelog for the project.
- Added time domain solver with various excitation options to accompany existing frequency domain driven and eigenmode simulation types.
- Added wrapper scripts in
bin/
for launching parallel simulations either interactively or as batch jobs using PBS. - Changed JSON configuration file keywords for frequency and time intervals.
- Added domain conductivity models for normal and superconducting metals.
- Fixed a bug for coaxial lumped port postprocessing.
- Added visualization of surface currents on domain boundaries to accompany existing
$\bm {E}$ - and$\bm{B}$ -field visualization. - Changed default length scale for nondimensionalization.
- Changed default filenames for port-related postprocessed quantities.
- Fixed many smaller issues and added various other improvements.
- Initial development release.