Electromagnetic field problems can be characterized by the field intensities and the flux densities described by the partial differential equations derived from Maxwell’s equations.

Maxwell’s equations define relations for the electromagnetic field quantities and the source elements, i.e. the electric and the magnetic field intensities, the electric and the magnetic flux densities, the charge and current distribution. Constitutive relations are added to Maxwell’s equations to describe the properties of the media.

Maxwell’s equations

Presentation of the Maxwell equations.

1. Differential form of Maxwell equations

The differential form of Maxwell’s equations reads:

\[\begin{aligned} \nabla \times \mathbf{H}(\mathbf{x},t) &= \mathbf{J}(\mathbf{x},t) + \frac{\partial \mathbf{D}(\mathbf{x},t)}{\partial t}\\ \nabla \times \mathbf{E}(\mathbf{x},t) & = - \frac{\partial \mathbf{B}(\mathbf{x},t)}{\partial t}\\ \nabla \cdot \mathbf{B}(\mathbf{x},t) & = 0\\ \nabla \cdot \mathbf{D}(\mathbf{x},t) & = \rho(\mathbf{x},t)\\ \mathbf{B}(\mathbf{x},t) &= \mu_0[\mathbf{H}(\mathbf{x}, t) + \mathbf{M}(\mathbf{x}, t)],\\ \mathbf{J}(\mathbf{x},t) &= \sigma[\mathbf{E}(\mathbf{x}, t) + \mathbf{E}_i(\mathbf{x}, t)] = \sigma \mathbf{E}(\mathbf{x}, t) + \mathbf{J}_i(\mathbf{x}, t)\\ \mathbf{D}(\mathbf{x},t) & = \epsilon_0 \mathbf{E}(\mathbf{x}, t) + \mathbf{P}(\mathbf{x}, t) \end{aligned}\]

1.1. Variables, symbols and units

The following table provides the names and units (in SI) of the symbols and variables above.

Table 1. Name and units of symbols and variables of the Maxwell’s equations
Notation Quantity Unit SI


magnetic field intensity

\(\)A\cdot m^{-1}\(\)

\(\)A\cdot m^{-1}\(\)


electric field intensity

\(\)V\cdot m^{-1}\(\)

\(\)kg\cdot m \cdot s^{-3}\cdot A^{-1}\(\)


magnetic flux density


\(\)kg\cdot s^{-2}\cdot A^{-1}\(\)


electric flux density

\(\)C\cdot m^{-2}\(\)

\(\)A\cdot s\cdot m^{-2}\(\)


magnetic potential vector

\(\)V\cdot s\cdot m^{-1}\(\)

\(\)kg\cdot m \cdot s^{-2}\cdot A^{-1}\(\)


electric current density

\(\)A\cdot m^{-2}\(\)

\(\)A\cdot m^{-2}\(\)


electric charge density

\(\)C\cdot m^{-3}\(\)

\(\)A\cdot s\cdot m^{-3}\(\)



\(\)A\cdot m^{-1}\(\)

\(\)A\cdot m^{-1}\(\)


impressed electric field

\(\)V\cdot m^{-1}\(\)

\(\)kg\cdot m \cdot s^{-3}\cdot A^{-1}\(\)


impressed electric current

\(\)A\cdot m^{-2}\(\)

\(\)A\cdot m^{-2}\(\)



\(\)C\cdot m^{-2}\(\)

\(\)A\cdot s\cdot m^{-2}\(\)


permeability of vacuum

\(\)H\cdot m^{-1}\(\)

\(\)kg\cdot m\cdot s^{-2}\cdot A^{-2}\(\)



\(\)S\cdot m^{-1}\(\)

\(\)kg^{-1}\cdot m^{-3}\cdot s^3\cdot A^2\(\)


permittivity of vacuum

\(\)F\cdot m^{-1}\(\)

\(\)kg^{-1}\cdot m^{-3}\cdot s^4\cdot A^2\(\)

The field quantities are depending on space \(\)\mathbf{x}\(\) and on time \(\)t\(\), we will omit later both in the notation and use e.g. \(\)\mathbf{H}, \mathbf{E}, \ldots\(\)

The sources of the electromagnetic fields are the electric current density \(\)\mathbf{J}\(\) and the electric charge density \(\)\rho\(\).

1.2. Constitutive relations

The last three equations in Maxwell’s equations above collect the constitutive relations, which – depending on the properties of the examined material – describe the relationship between field quantities.

In the simplest case these relations are linear, i.e. \(\) \mathbf{M} = \chi\mathbf{H},\quad \mathbf{E}_i=0,\quad \mathbf{P}=\epsilon_0\chi_d\mathbf{E} \(\)

where \(\)\chi\(\) and \(\)\chi_d\(\) are the magnetic and the dielectric susceptibility respectively and \(\) \mathbf{B} = \mu \mathbf{H},\quad \mathbf{J} = \sigma \mathbf{E}, \quad \mathbf{D} = \epsilon_0 \mathbf{E} \(\) where \(\) \mu = \mu_0(1 + \chi) = \mu_0\mu_r,\quad \epsilon = \epsilon_0(1 + \chi_d) = \epsilon_0\epsilon_r. \(\) Here \(\)\mu_r = 1 + \chi\(\) is the relative permeability, \(\)\epsilon_r = 1 + \chi_d\(\) is the relative permittivity of the material and the conductivity \(\)\sigma\(\) is constant. The equation \(\)\mathbf{J} = \sigma \mathbf{E}\(\) is the differential form of Ohm’s law.

The constitutive relations are nonlinear in general, that is the permeability, conductivity and permittivity depend on the associated field quantities, i.e.

\[\mu = \mu(\mathbf{H},\mathbf{B}),\quad \sigma = \sigma(\mathbf{E}, \mathbf{J}),\quad \epsilon = \epsilon(\mathbf{E}, \mathbf{D})\]

or equivalently

\[\mathbf{B} = \mathcal{B}(\mathbf{H}),\quad \mathbf{J} = \mathcal{J}(\mathbf{E}),\quad \mathbf{D} = \mathcal{D}(\mathbf{E})\]

where \(\)\mathcal{B}(·), \mathcal{J}(·) \text{ and } \mathcal{D}(·)\(\) are operators. We would actually need also the inverse operator, e.g.

\[\mathbf{H} = \mathcal{B}^{-1}(\mathbf{B})\]

1.3. Classification of Maxwell’s Equations

We now turn to the classification of the Maxwell’s equations.

Steady case

The simplest case corresponds to the steady case: the time variation of the field quantities can be neglected, i.e. \(\)\partial/\partial t = 0\(\). The corresponding fields are called static field. In this case the magnetic, the electric and the current fields can be treated independently because there are no interactions between them.

Time varying case

When \(\partial/\partial t = 0\), the magnetic and electric fields are coupled, we are then in the presence of eddy current fields and wave propagation of electrodynamics.

1.3.1. Static magnetic field

The time independent current density \(\mathbf{J} = \mathbf{J}(\mathbf{x})\) generates the time independent magnetic field intensity \(\mathbf{H} = \mathbf{H}(\mathbf{x})\) and the time independent magnetic flux density \(\mathbf{B} = \mathbf{B}(\mathbf{x})\).

the magnetostatic Maxwell’s equations read

\[\begin{aligned} \nabla \times \mathbf{H}(\mathbf{x}) &= \mathbf{J}(\mathbf{x}) \\ \nabla \cdot \mathbf{B}(\mathbf{x}) & = 0\\ \mathbf{B}(\mathbf{x}) &= \begin{cases} \mu_0 \mathbf{H}\,& \text{ in air}\\ \mu_0\mu_r \mathbf{H}\,& \text{ in magnetically linear media}\\ \mu_0[\mathbf{H} + \mathbf{M}]\,& \text{ in magnetically nonlinear media} \end{cases} \end{aligned}\]

In a nonlinear medium, the magnetization vector \(\mathbf{M} = \mathbf{M}(\mathbf{x})\) is depending on the magnetic field intensity vector, i.e. \(\mathbf{M} = \mathcal{H}(\mathbf{H})\).

The operator \(\mathcal{H}\) can be described by so-called hysteresis models denoted by \(\mathbf{B} = \mathcal{B}(\mathbf{H})\).

This constitutive relation has an inverse form which read

\[\mathbf{H} = \begin{cases} \nu_0 \mathbf{B}\,& \text{ in air}\\ \nu_0\nu_r \mathbf{B}\,& \text{ in magnetically linear media}\\ \mathcal{B}^{-1}(\mathbf{B})\,& \text{ in magnetically nonlinear media} \end{cases}\]

where \(\nu_0 = 1/\mu_0,\, \nu_r = 1/\mu_r\) are the reluctivity of vacuum and the relative reluctivity.

In magnetically nonlinear media, it can be represented by an inverse hysteresis operator, \(\mathbf{H} = \mathcal{B}^{-1}(\mathbf{B}).\)

The source current distribution is solenoidal, which reads \(\nabla \cdot \mathbf{J} = 0\) (take the divergence of the first Maxwell’s equation). This means that all current lines either close upon themselves, or start and terminate at infinity.
This case corresponds to magnetic fields generated by (i) coils carrying currents or (ii) the static behavior of electrical machines. When \(\)\mathbf{J}=0\(\), then a boundary value problem to simulate e.g. the field of magnetic poles.

2. Magnetostatic problem formulation

Denote \(\Omega_0\) the non-magnetic (e.g. air) part of \(\Omega\) (hence 0) and \(\Omega_m\) the magnetic part.

In the case of static magnetic field, the Maxwell’s equations read

\[\begin{aligned} \nabla \times \mathbf{H}(\mathbf{x}) &= \mathbf{J}(\mathbf{x}) \text{ in } \Omega_0 \cup \Omega_m\\ \nabla \cdot \mathbf{B}(\mathbf{x}) & = 0 \text{ in } \Omega_0 \cup \Omega_m\\ \mathbf{B}(\mathbf{x}) &= \begin{cases} \mu_0 \mathbf{H}\,& \text{ in air}\\ \mu_0\mu_r \mathbf{H}\,& \text{ in magnetically linear media}\\ \mathcal{B}(\mathbf{H}) = \mu_{\mathrm{o}} \mathbf{H}+\mathbf{R}\,& \text{ in magnetically nonlinear media} \end{cases} \end{aligned}\]

The constitutive relation has an inverse form

\[\begin{aligned} \mathbf{H}(\mathbf{x}) &= \begin{cases} \nu_0 \mathbf{B}\,& \text{ in air}\\ \nu_0\nu_r \mathbf{B}\,& \text{ in magnetically linear media}\\ \mathcal{B}^{-1}(\mathbf{B}) = \nu_{\mathrm{o}} \mathbf{B}+\mathbf{I}\,& \text{ in magnetically nonlinear media} \end{cases} \end{aligned}\]

where \(\mu_{\mathrm{o}}\) and \(\nu_{\mathrm{o}}\) are the optimal permeability and reluctivity respectively obtained using the polarisation method described below.

Only the tangential components of \(\mathbf{H}\) is continuous across the interface \(\Gamma_{0m}\) between \(\Omega_0\) and \(\Omega_m\). As to \(\mathbf{B}\), it is its normal component which is continuous across \(\Gamma_{0m}\).

3. Vector Potential formulation for magnetostatic

The magnetic vector potential \(\mathbf{A}\) is defined by

\[\mathbf{B} = \nabla \times \mathbf{A}\]

which satisfies \(\nabla \cdot \mathbf{B} = 0\) exactly, because of the identity \(\nabla \cdot \nabla \times \mathbf{v} = 0\) for any vector function \(\mathbf{v}\).

To ensure the uniqueness of the magnetic vector potential, its divergence can be selected according to Coulomb gauge,
\[\nabla \cdot \mathbf{A} = 0\]

This is useful, because the vector potential \(\mathbf{A}' = \mathbf{A} + \nabla \phi\) also satisfies the equations above, because of the identity \(\nabla \times \nabla \phi = \mathbf{0}\) where \(\phi\) is a scalar field. This is the reason why the magnetic vector potential is not unique.

Substituting the definition of \(\)\mathbf{A}\(\) into the first Maxwell’s equation and using the linearized constitutive relation, we get

\[\nabla \times (\nu_{\mathrm{o}} \nabla \times \mathbf{A} ) = \mathbf{J} - \nabla \times \mathbf{I}\quad \text{ in } \Omega\]

where \(\mathbf{J}\) is the source current density.

In case where the media is linear, the term \(-\nabla\times\mathbf{I}\) disappears.

The strategy to solve this equation is discussed in the Strategy Chapter.

3.1. Benchmark

We benchmark here our implementation.

We set - for convenience - \(\)\mu_{\mathrm{o}}\(\) to one in that convergence test.

Given a sinusoïdal solution, we compute - with no regularization terms (we are not interested in the potential vector but its curl) - the appropriate right hand side and use the exact solution a boundary condition.

\[\begin{aligned} \mathbf{J}&= \begin{pmatrix} 3 \pi^3 \cos(\pi x) \sin(\pi y)\sin(\pi z) \\ -6\pi^3 \sin(\pi x) \cos(\pi y) \sin(\pi z) \\ 3\pi^3 \sin(\pi x) \sin(\pi y) \cos(\pi z) \end{pmatrix} \\ \mathbf{A}_{exact}&=\begin{pmatrix} \pi \cos(\pi x) \sin(\pi y) \sin(\pi z)\\ -2\pi \sin(\pi x) \cos(\pi y) \sin(\pi z) \\ \pi \sin(\pi x) \sin(\pi y) \cos(\pi z)\end{pmatrix} \\ \mathbf{c}&=\begin{pmatrix}3 \pi^2 \cos(\pi z) \cos(\pi y)\sin(\pi x)\\0 \\-(3\pi^2) \sin(\pi z) \cos(\pi y)\cos(\pi x )\end{pmatrix} \end{aligned}\]

3.2. Regularized point system

\[\begin{aligned} \nabla \times \left(\frac{1}{\mu_{\mathrm{o}}} \nabla \times \mathbf{A} \right) + \epsilon \mathbf{A} &= \mathbf{J} \quad \text{ in } \Omega \\ \left.\mathbf{A}\right|_{\partial \Omega} &= \mathbf{A}_{exact} \\ \end{aligned}\]

3.3. Saddle point system

\[\begin{aligned} \nabla \times \left(\frac{1}{\mu_{\mathrm{o}}} \nabla \times \mathbf{A} \right) + \nabla p &= \mathbf{J} \quad \text{ in } \Omega \\ \nabla \cdot \mathbf{A} &= 0 \quad\text{ in } \Omega \\ \left.\mathbf{A}\right|_{\partial \Omega} &= \mathbf{A}_{exact} \\ \left.p\right|_{\partial \Omega} &= 0 \end{aligned}\]

The boundary condition can apply with penalization or elimination. We compare both results: Saddle Point system convergence

Resolution strategy

Resolution strategy for Maxwell equations

4. Polarisation method

Design and simulation of electrical engineering applications containing ferromagnetic parts require the accurate modeling of hysteresis characteristics and the implementation of the models and solve the nonlinear partial differential equations derived from Maxwell’s equations.

The partial differential equations are generally nonlinear because of the nonlinear characteristics of ferromagnetic materials.

The numerical analysis of electromagnetic fields can be characterized by the electric and magnetic field intensities and flux densities formulated by Maxwell’s equations, which are the collection of partial differential equations of the electric field intensity \(\)\mathbf{E}\(\), the magnetic field intensity \(\)\mathbf{H}\(\), the electric flux density \(\)\mathbf{D}\(\) and the magnetic flux density \(\)\mathbf{B}\(\).

Constitutive relations between the above quantities are defined to take into account the macroscopic properties of the medium.

We consider a constitutive relation between the magnetic field intensity and the magnetic flux density which is nonlinear , given by the operator \(\)\mathbf{B} = \mathcal{B}(\mathbf{H})\(\) or equivalently \(\)\mathbf{H} = \mathcal{B}^{−1}(\mathbf{B})\(\). These nonlinear characteristics can be reformulated by introducing the polarization method and the resulting system of nonlinear equations can be solved using fixed point iterations.

According to the polarization method, the magnetic flux density can be split in two parts as \(\) \mathbf{B} = \mu \mathbf{H} + \mathbf{R} \(\) where \(\)\mu \mathbf{H}\(\) is a linear term, \(\)\mu\(\) is constant and the nonlinearity is in the second term \(\)\mathbf{R}\(\). It is a magnetic flux density like quantity.

The question is the appropriate value of the parameter \(\)\mu\(\). This representation can be reformulated as \(\) \mathbf{R} = \mathbf{B}-\mu \mathbf{H} = \mathbf{B}-\mu \mathcal{B}^{-1}(\mathbf{B}) \(\) Here, the inverse type hysteresis characteristics are used.

It is important to note that the nonlinear equations are solved by iterative methods, the \(\)n\(\)-th iteration is denoted by the superscript \(\)(n)\(\) in the following. By using the various formula in the constitutive relations defined in Maxwell’s equations, the solution of the nonlinear partial differential equations with appropriate boundary conditions can be formulated as \(\) \mathbf{B}^{(n)} = \mathcal{M}(\mathbf{R}^{(n-1)}) \(\) where the operator \(\)\mathcal{M}\(\) represents the set of Maxwell’s equations and the boundary conditions. The starting \(\)\mathbf{R}^{(0)}\(\) is arbitrary. The value of electromagnetic field quantities in the \(\)n\(\)-th step are depending on the value of \(\)\mathbf{R}\(\) in the \(\)(n − 1)\(\)-th step and they represent source like quantities.

Note The source of electromagnetic fields (e.g. the electric current density \(\)\mathbf{J}\(\)) is not changing during fixed point iteration, i.e. the fixed point iteration has no particular physical meaning.

4.1. Abstract fixed point iteration

It may be better to use the reluctivity \(\)\nu\(\) when applying the inverse hysteresis model, because \(\)\nu(B) = \frac{\partial H}{\partial B}\(\). Let us now multiply the relation above by \(\)\nu_{\mathrm{o}} = 1/\mu_{\mathrm{o}}\(\), we have \(\) \nu_{\mathrm{o}} \mathbf{B} = \mathbf{H} + \nu_{\mathrm{o}}\mathbf{R}, \(\) hence \(\) \mathbf{H} = \nu_{\mathrm{o}} \mathbf{B} - \nu_{\mathrm{o}}\mathbf{R} = \nu_{\mathrm{o}} \mathbf{B} + \mathbf{I} \(\) where \(\)\mathbf{I}= -\nu_{\mathrm{o}}\mathbf{R}\(\), \(\)\nu_{\mathrm{o}}=\frac{\nu_{\mathrm{min}}+\nu_{\mathrm{max}}}{2}\(\) and \(\)\nu_{\mathrm{min}}\(\) and \(\)\nu_{\mathrm{max}}\(\) are the minimum and maximum slope of the inverse of the hysteresis characteristics. We have \(\)\nu_{\mathrm{min}} = 1/\mu_{\mathrm{max}}\(\) and \(\)\nu_{\mathrm{max}}=1/\mu_{\mathrm{min}}\(\).

The nonlinear fixed point iteration can be summarized as follows. The iteration can be started by an arbitrary value of \(\)\mathbf{I}^{(0)}\(\), then for \(\)n > 0\(\) we do,

  1. the magnetic flux density \(\)\mathbf{B}^{(n)}\(\) can be calculated by solving the partial differential equations obtained from Maxwell’s equations and using \(\)\mathbf{I}^{(n−1)}\(\), in other words, \(\) \mathbf{B}^{(n)} =\mathcal{M}({\mathbf{I}^{(n−1)}}), \(\)

  2. the magnetic field intensity \(\)\mathbf{H}^{(n)}\(\) can be calculated by applying the inverse type hysteresis model, \(\)\mathbf{H}^{(n)} = \mathcal{B}{−1}(\mathbf{B}{(n)}),\(\)

  3. the nonlinear residual term can be updated by using the magnetic flux density and magnetic field intensity, \(\) \mathbf{I}^{(n)} = \mathbf{H}^{(n)} − \nu_{\mathrm{o}} \mathbf{B}^{(n)} = \mathcal{B}{−1}({\mathbf{B}{(n)}}) − \nu_{\mathrm{o}} \mathbf{B}^{(n)} \(\)

  4. and the sequence defined by steps (i)–(iii) must be repeated until convergence.

Convergence criterion can be \(\)||\mathbf{I}^{(n)} − \mathbf{I}^{(n−1)}|| < \varepsilon\(\), where \(\)\varepsilon\(\) is the tolerance. Convergence criterion can be also defined by using the magnetic field intensity or the magnetic flux density.

4.2. Fixed point iteration for the \(\)A\(\) formulation

Recall that we have \(\) \nabla \times (\nu_{\mathrm{o}} \nabla \times \mathbf{A} ) = \mathbf{J} - \nabla \times \mathbf{I}\quad \text{ in } \Omega \(\) associated to proper boundary conditions for \(\)\mathbf{A}\(\). The fixed point iteration algorithm reads

We start with arbitrary \(\)\mathbf{I}^{(0)}\(\) and then for \(\)n > 0\(\)

  1. solve \(\) \nabla \times (\nu_{\mathrm{o}} \nabla \times \mathbf{A}^{(n)} ) = \mathbf{J} - \nabla \times \mathbf{I}^{(n-1)}\quad \text{ in } \Omega \(\)

  2. compute \(\) \mathbf{B}^{(n)}=\nabla \times \mathbf{A}^{(n)} \(\)

  3. compute the residual \(\) \mathbf{I}^{(n)} = \mathcal{B}{−1}({\mathbf{B}{(n)}}) − \nu_{\mathrm{o}} \mathbf{B}^{(n)} \(\)

  4. repeat steps i-iii until convergence, e.g. \(\) ||\mathbf{I}{(n)}-\mathbf{I}{(n-1)}|| < \varepsilon \(\)

5. Picard method

The main benefit for the polarization method is to keep the matrix constant. There is no need to rebuild a preconditioner and to assemble again and again the matrix. Actually, as long as the volume of the non linear concrete is small against the total volume, the gain is proportionnaly small.

Generaly, the non linear law links the magnetic field magnitude \(\)\mathbf{\| B\|}\(\) to the magnetic field intensity \(\)\mathbf{\| H\|}\(\). In other word, we have an isotropic concrete. That is we have the relation \(\)B = \mu(H) H\(\) instead of \(\)\mathbf{\| B\|} = \mu(\mathbf{\| H\|}) \mathbf{H}\(\).

One can write: \(\) \begin{aligned} B &= \mu(H) H, \\ &= \mu_r \mu_0 H, \end{aligned} \(\) where \(\)\mu_r\(\) is the relative magnetic permeability.

We denote with \(\)\mu(H)\(\) the interpolation of the data. It is defined thanks to a \(\)P_1\(\) or Akima’s interpolation of the dataset \(\)B-\frac{H}{B}\(\).

The Picard algorithm reads:

Given an initial \(\)\mu_r^{(0)}\(\) chosen arbitrarily:

  1. solve \(\) \nabla \times \left(\frac{1}{\mu_r^{(n)}} \nabla \times \mathbf{A}^{(n)} \right) = \mu_0 \mathbf{J}\quad \text{ in } \Omega \(\)

  2. compute \(\) B^{(n)}=\|\nabla \times \mathbf{A}^{(n)}\| \(\)

  3. compute \(\) H^{(n)} = \frac{B^{(n)}}{\mu_0 \mu_r^{(n)}} \(\)

  4. compute \(\) \mu_r^{(n+1)} = \frac{\mu(H^{(n)})}{\mu_0} \(\)

  5. repeat steps i-iii until convergence, e.g. \(\) ||\mathbf{B}{(n)}-\mathbf{B}{(n-1)}|| < \varepsilon \(\)

6. Linking Picard to the Polarization

The polarization method has some evident advantages. Our benchmarks (to come) has shown that algorithm is less robust than the Picard one.

We note here an idea we do not have yet implemented that should circumvent the Polarization problem.

We want to transfer from the right hand side to the matrix the non linearity. When a criteria we need to define is reached, we construct \(\)\mu_\(\) \(\) \begin{aligned} B &= \mu_0 \mu_{opt} H + I \\ &= \mu_0 \mu_ H \\ \mu_ &= \mu_{opt} + \frac{1}{\mu_0} \frac{I}{H} \end{aligned} \(\) And then we start a new Polarization algorithm with an initial \(\)\mathbf{I}\(\) set to zero.

7. Formulations

7.1. Saddle-point formulation

The first possibility is to add a constraint on the divergence using the Coulomb gauge, \(\) \nabla \cdot \mathbf{A} = 0 \(\). It is managed by a scalar Lagrange multiplier, giving the saddle-point problem: \(\) \begin{aligned} \nabla\times\nu_0\nabla\times\mathbf{A} + \nabla p &= \mathbf{J} - \nabla\times\mathbf{I} &\text{ in } \Omega\\ \nabla\cdot\mathbf{A} &= 0 &\text{ in } \Omega\\ \mathbf{A}\times\mathbf &= \mathbf{A}_D &\text{ on } \partial\Omega\\ p &= 0 &\text{ on } \partial\Omega \end{aligned} \(\)

7.1.1. Variational formulation

The variational formulation the consists in finding \(\)(\mathbf{A},p) \in ( X \subset H(\mathrm{curl},\Omega) \times H^1_0(\Omega))\(\) (see Notations) such that \(\) \begin{aligned} &\int_{\Omega}\nu_0(\nabla \times \mathbf{A}) \cdot (\nabla \times \mathbf{v}) + \int_{\delta \Omega}\nu_0 (\nabla \times \mathbf{A}) \cdot (\mathbf{v} \times \mathbf) + \int_{\Omega} \mathbf{v} \cdot \nabla p = \int_{\Omega} \mathbf{J} \cdot \mathbf{v}- \int_{\Omega} (\nabla \times \mathbf{I})\cdot \mathbf{v} ~~\forall \mathbf{v} \in Y \\ &\int_{\Omega} \mathbf{A} \cdot \nabla q = 0 ~~\forall q \in H^1_0(\Omega) \end{aligned} \(\)

The Dirichlet boundary condition on \(\)\mathbf{A}\(\) imposed on strong form vanishes the boundary term of and the condition is directly taken into account in the definition of the function space \(\)X = H_{\mathbf{A}_D}(\mathrm{curl},\Omega) = \{ \mathbf{v} \in H(\mathrm{curl},\Omega) \mid \mathbf{v} \times \mathbf = \mathbf{A}_D ~\text{on} ~\partial \Omega\}\(\). The variational formulation then consists in finding \(\)(\mathbf{A},p) \in ( H_{\mathbf{A}_D}(\mathrm{curl},\Omega) \times H^1_0(\Omega))\(\) such that \(\) \begin{aligned} & \int_{\Omega}\nu_0(\nabla \times \mathbf{A}) \cdot (\nabla \times \mathbf{v}) + \int_{\Omega} \mathbf{v} \cdot \nabla p = \int_{\Omega} \mathbf{J} \cdot \mathbf{v} - \int_{\Omega} (\nabla \times \mathbf{I})\cdot \mathbf{v} ~~\forall \mathbf{v} \in H_{0}(\mathrm{curl},\Omega) \\ & \int_{\Omega} \mathbf{A} \cdot \nabla q = 0 ~~\forall q \in H^1_0(\Omega) \end{aligned} \(\) We can also impose the Dirichlet boundary conditions on weak form, adding symetrization and penalisation terms and then avoiding to add condition in \(\)X\(\) function space, i.e. \(\)X = H(\mathrm{curl},\Omega)\(\). As previously, \(\)\gamma\(\) is the penalisation coefficient and \(\)h_s\(\) the mesh size. The variational formulation consists then in finding \(\)\mathbf{A} \in H(\mathrm{curl},\Omega)\(\) such that \(\)\forall (\mathbf{v},q) \in H(\mathrm{curl},\Omega)\times H^1_0(\Omega)\(\) \(\) \begin{align} \int_{\Omega}\nu(\nabla \times \mathbf{A}) \cdot (\nabla \times \mathbf{v}) + \int_{\delta \Omega}\nu (\nabla \times \mathbf{A}) \cdot (\mathbf{v} \times \mathbf)&\\ + \int_{\delta \Omega}\nu (\nabla \times \mathbf{v}) \cdot (\mathbf{A} \times \mathbf) + \int_{\delta \Omega} \frac{\gamma}{h_s} \nu (\mathbf{v} \times \mathbf) \cdot (\mathbf{A} \times \mathbf)& \\ + \int_{\Omega} \mathbf{v} \cdot \nabla p &= \int_{\Omega} \mathbf{J} \cdot \mathbf{v} - \int_{\Omega} (\nabla \times \mathbf{I})\cdot \mathbf{v}\\ &+ \int_{\delta \Omega}\nu (\nabla \times \mathbf{v}) \cdot \mathbf{A}_D + \int_{\delta \Omega} \frac{\gamma}{h_s} \nu (\mathbf{v} \times \mathbf) \cdot \mathbf{A}_D\\ \int_{\Omega} \mathbf{A} \cdot \nabla q &= 0 \end{align} \(\)

7.1.2. Discretization

Since \(\)\mathbf{A}\(\) must be in \(\)H(\mathrm{curl},\Omega)\(\), we need to use Nédélec elements, see Notations. On the strong form, the discrete problem becomes:
Find \(\)(\mathbf{A}_h,p_h)\in (H_{\mathbf{A}_D,h}(\mathrm{curl},\Omega)\times P_{c,h}^1(\Omega))\(\) such that \(\) \begin{aligned} & \int_{\Omega}\nu_0(\nabla \times \mathbf{A}_h) \cdot (\nabla \times \mathbf{v}_h) + \int_{\Omega} \mathbf{v}_h \cdot \nabla p_h = \int_{\Omega} \mathbf{J} \cdot \mathbf{v}_h - \int_{\Omega} (\nabla \times \mathbf{I})\cdot \mathbf{v}_h ~~\forall \mathbf{v}_h \in H_{0,h}(\mathrm{curl},\Omega) \\ & \int_{\Omega} \mathbf{A}_h \cdot \nabla q_h = 0 ~~\forall q_h \in P_{0,c,h}^1(\Omega) \end{aligned} \(\) On the weak form, the discrete problem becomes:
Find \(\)(\mathbf{A}_h,p_h)\in (H_{h}(\mathrm{curl},\Omega)\times P_{c,h}^1(\Omega))\(\) such that \(\)\forall (\mathbf{v}_h,q_h) \in H_h(\mathrm{curl},\Omega)\times P^1_{0,c,h}(\Omega)\(\) \(\) \begin{align} \int_{\Omega}\nu(\nabla \times \mathbf{A}_h) \cdot (\nabla \times \mathbf{v}_h) + \int_{\delta \Omega}\nu (\nabla \times \mathbf{A}_h) \cdot (\mathbf{v}_h \times \mathbf)&\\ + \int_{\delta \Omega}\nu (\nabla \times \mathbf{v}_h) \cdot (\mathbf{A}_h \times \mathbf) + \int_{\delta \Omega} \frac{\gamma}{h_s} \nu (\mathbf{v}_h \times \mathbf) \cdot (\mathbf{A}_h \times \mathbf)& \\ + \int_{\Omega} \mathbf{v}_h \cdot \nabla p_h &= \int_{\Omega} \mathbf{J} \cdot \mathbf{v}_h - \int_{\Omega} (\nabla \times \mathbf{I})\cdot \mathbf{v}_h\\ &+ \int_{\delta \Omega}\nu (\nabla \times \mathbf{v}_h) \cdot \mathbf{A}_D + \int_{\delta \Omega} \frac{\gamma}{h_s} \nu (\mathbf{v}_h \times \mathbf) \cdot \mathbf{A}_D\\ \int_{\Omega} \mathbf{A}_h \cdot \nabla q_h &= 0 \end{align} \(\)

7.2. Regularized formulation

The second way consists of considering the ungauged problem as a special case of the time harmonic Maxwell’s equations. Then using a Fourier transform, we can write the problem as: \(\) \begin{aligned} \nabla\times\nu_0\nabla\times\mathbf{A} + \varepsilon\mathbf{A} &= \mathbf{J} - \nabla\times\mathbf{I} &\text{ in } \Omega\\ \mathbf{A}\times\mathbf &= \mathbf{A}_D &\text{ on } \partial\Omega \end{aligned} \(\)

7.2.1. Variational formulation

The variational formulation obtained consists in finding \(\)\mathbf{A} \in X \subset H(\mathrm{curl},\Omega)\(\) such that \(\) \begin{aligned} \int_{\Omega}\nu_0(\nabla \times \mathbf{A}) \cdot (\nabla \times \mathbf{v}) + \int_{\delta \Omega}\nu_0 (\nabla \times \mathbf{A}) \cdot (\mathbf{v} \times \mathbf ) + \int_{\Omega}\varepsilon \mathbf{A} \cdot \mathbf{v} = \int_{\Omega} \mathbf{J} \cdot \mathbf{v} - \int_{\Omega} (\nabla \times \mathbf{I}) \cdot \mathbf{v} ~\forall \mathbf{v} \in Y \end{aligned} \(\) Imposing the Dirichlet boundary condition on strong form, removes the boundary term and the condition is inherent to he function space \(\)X = H(\mathbf{A}_D,\mathrm{curl},\Omega)\(\). The variational formulation becomes : Find \(\)\mathbf{A} \in H_{\mathbf{A}_D}(\mathrm{curl},\Omega)\(\) such that \(\) \begin{aligned} \int_{\Omega}\nu_0(\nabla \times \mathbf{A}) \cdot (\nabla \times \mathbf{v}) + \int_{\Omega}\varepsilon \mathbf{A} \cdot \mathbf{v} = \int_{\Omega} \mathbf{J} \cdot \mathbf{v} - \int_{\Omega} (\nabla \times \mathbf{I}) \cdot \mathbf{v} \quad \forall \mathbf{v} \in H_{0}(\mathrm{curl},\Omega) \end{aligned} \(\) We can also impose the Dirichlet boundary conditions on weak form, adding symetrization and penalisation terms and then avoiding to add condition in \(\)X\(\) function space, i.e. \(\)X = H(\mathrm{curl},\Omega)\(\). As previously, \(\)\gamma\(\) is the penalisation coefficient and \(\)h_s\(\) the mesh size. The variational formulation consists then in finding \(\)\mathbf{A} \in H(\mathrm{curl},\Omega)\(\) such that \(\)\forall \mathbf{v} \in H(\mathrm{curl},\Omega)\(\) \(\) \begin{align*} \int_{\Omega}\nu(\nabla \times \mathbf{A}) \cdot (\nabla \times \mathbf{v}) + \int_{\delta \Omega}\nu (\nabla \times \mathbf{A}) \cdot (\mathbf{v} \times \mathbf )&\\ + \int_{\delta \Omega}\nu (\nabla \times \mathbf{v}) \cdot (\mathbf{A} \times \mathbf ) + \int_{\delta \Omega} \frac{\gamma}{h_s} \nu (\mathbf{v} \times \mathbf ) \cdot (\mathbf{A} \times \mathbf )&\\ + \int_{\Omega}\alpha \mathbf{A} \cdot \mathbf{v} &= \int_{\Omega} \mathbf{J} \cdot \mathbf{v} - \int_{\Omega} (\nabla \times \mathbf{I}) \cdot \mathbf{v} \\ &+ \int_{\delta \Omega}\nu (\nabla \times \mathbf{v}) \cdot \mathbf{A}_D + \int_{\delta \Omega} \frac{\gamma}{h_s} \nu (\mathbf{v} \times \mathbf ) \cdot \mathbf{A}_D \end{align*} \(\)

7.2.2. Discretization

On strong form, the discrete problem is: find \(\)\mathbf{A}_h\in H_{\mathbf{A}_D,h}(\mathrm{curl},\Omega)\(\) such that \(\) \begin{aligned} \int_{\Omega}\nu_0(\nabla \times \mathbf{A}_h) \cdot (\nabla \times \mathbf{v}_h) + \int_{\Omega}\varepsilon \mathbf{A}_h \cdot \mathbf{v}_h = \int_{\Omega} \mathbf{J} \cdot \mathbf{v}_h - \int_{\Omega} (\nabla \times \mathbf{I}) \cdot \mathbf{v}_h \quad \forall \mathbf{v}_h \in H_{0,h}(\mathrm{curl},\Omega) \end{aligned} \(\) On weak form, the discrete problem is : find \(\)\mathbf{A}_h\in H(\mathrm{curl},\Omega)\(\) such that \(\)\forall \mathbf{v}_h \in H(\mathrm{curl},\Omega)\(\) \(\) \begin{align} \int_{\Omega}\nu(\nabla \times \mathbf{A}_h) \cdot (\nabla \times \mathbf{v}_h) + \int_{\delta \Omega}\nu (\nabla \times \mathbf{A}_h) \cdot (\mathbf{v}_h \times \mathbf )&\\ + \int_{\delta \Omega}\nu (\nabla \times \mathbf{v}_h) \cdot (\mathbf{A}_h \times \mathbf ) + \int_{\delta \Omega} \frac{\gamma}{h_s} \nu (\mathbf{v}_h \times \mathbf ) \cdot (\mathbf{A}_h \times \mathbf )& \\ + \int_{\Omega}\alpha \mathbf{A}_h \cdot \mathbf{v}_h &= \int_{\Omega} \mathbf{J} \cdot \mathbf{v}_h - \int_{\Omega} (\nabla \times \mathbf{I}) \cdot \mathbf{v}_h \\ &+ \int_{\delta \Omega}\nu (\nabla \times \mathbf{v}_h) \cdot \mathbf{A}_D + \int_{\delta \Omega} \frac{\gamma}{h_s} \nu (\mathbf{v}_h \times \mathbf ) \cdot \mathbf{A}_D \end{align} \(\)

8. Solver and Preconditionner

There are many methods available to solve the saddle-point formulation, using iterative solvers. Considering the number of non zero entries in the matrix to inverse due to the use of edge based finite elements, this method proves to be inefficient for this problem.

A block diagonal preconditioning approach for the time-harmonic Maxwell equations is introduced in Greif-Schötzau. Combined with a nodal auxiliary space preconditioning technique proposed in Hiptmair-Xu specifically designed for \(\)H(\mathrm{curl})\(\)-conforming finite element, this method gives attractive performance results detailed in Li.

This section describes the main ingredients of preconditioning method introduced in Li. Based on the saddle point formulation, the magnetostatic problem reads on the form \(\)\mathcal{K} \mathbf{x} = \mathbf{b}\(\) \(\) \underbrace{ \begin{pmatrix} \mathcal{A} & \mathcal{B}^{T} \\ \mathcal{B} & 0 \end{pmatrix} }_{\mathcal{K}} \underbrace{ \begin{pmatrix} \mathbf{A} \\ p \end{pmatrix} }_{x} = \underbrace{ \begin{pmatrix} \mathbf{f} \\ 0 \end{pmatrix} }_{b} \(\)

The solving of this system is performed at two solver "levels". An outer solver dealing with the resolution of the previous system with the block diagonal preconditioner Greif-Schötzau, and an inner solver dealing with the application of auxiliary space preconditioning technique Hiptmair-Xu to the first block of the latter.

8.1. Outer solver

The block diagonal preconditioner proposed in Greif-Schötzau consists in \(\) \mathcal{P}_{\mathcal{M},\mathcal{L}} = \begin{pmatrix} \mathcal{P}_{\mathcal{M}} & 0 \\ 0 & \mathcal{L} \end{pmatrix} \(\) where \(\) \mathcal{P}_{\mathcal{M}} = \mathcal{A} + \mathcal{M} ~\text{with} ~\mathcal{M}_{i,j} = \displaystyle{ \int_{\Omega} \psi_j \cdot \psi_i }, ~~1 \leqslant i,j \leqslant n \(\) and \(\)\mathcal{L}\(\) the scalar Laplacian on \(\)Q_h\(\) defined as \(\) \mathcal{L} = \displaystyle{ \int_{\Omega} \nabla \phi_j \cdot \nabla \phi_i }, ~~1 \leqslant i,j \leqslant m \(\)

The outer solver for \(\)\mathcal{K}\mathbf{x}=\mathbf{b}\(\) is a preconditioned MINRES, using previously defined \(\)\mathcal{P}_{\mathcal{M},\mathcal{L}}\(\) as preconditioner. The linear system to solve then reads \(\)\mathcal{P}_{\mathcal{M},\mathcal{L}} ~\mathcal{K} \mathbf{x} = \mathcal{P}_{\mathcal{M},\mathcal{L}} ~\mathbf{b}\(\) \(\) \underbrace{ \begin{pmatrix} \mathcal{P}_{\mathcal{M}} & 0 \\ 0 & \mathcal{L} \end{pmatrix} }_{\mathcal{P}_{\mathcal{M},\mathcal{L}}} \underbrace{ \begin{pmatrix} \mathbf{v} \\ q \end{pmatrix} }_{x_{out}} = \underbrace{ \begin{pmatrix} \mathbf \\ d \end{pmatrix} }_{b_{out}} \(\)

This linear system is solved block by block, using subspace solvers. The block \(\)(1,1)\(\) consists in the linear system \(\) \mathcal{P}_{\mathcal{M}} \mathbf{v} = \mathbf \(\) and the block \(\)(2,2)\(\) is the linear system \(\) \mathcal{L} q = d \(\)

The resolution of both systems gives the solution \(\)(\mathbf{v},q)\(\) from which we conclude current MINRES iteration updating \(\)\mathbf{x}\(\) in \(\)\mathcal{K}\mathbf{x}=\mathbf{b}\(\). The same process can then applied for each MINRES iteration, until convergence.

While the solving of the scalar elliptic problem \(\)\mathcal{L} q = d\(\) can be efficiently performed with standard methods, the \(\)H(\mathrm{curl})\(\)-conforming linear system \(\)\mathcal{P}_{\mathcal{M}} \mathbf{v} = \mathbf\(\) of the outer problem is more tricky. This bottleneck can be overcomed using a second level of preconditioning, applying the effective auxiliary space preconditioning method \cite{HiptmairXu} to the inner problem \(\)\mathcal{P}_{\mathcal{M}} \mathbf{v} = \mathbf\(\).

8.2. Inner solver

The preconditioning method proposed in \cite{HiptmairXu} is used to solve the linear system \(\)\mathcal{P}_{\mathcal{M}} \mathbf{v} = \mathbf\(\).

This system is solved using a preconditioned conjugate gradient (CG) and then reads \(\)\mathcal{P}_{V} \mathcal{P}_{\mathcal{M}} \mathbf{v} = \mathcal{P}_{V} \mathbf\(\), where \(\)\mathcal{P}_{V}\(\) is the preconditioner to be descibed. The linear system to solve then becomes \(\) \mathcal{P}_{V} \mathbf{w} = \mathbf{r} \(\)

The preconditioner \(\)\mathcal{P}_{V}\(\) is defined such that \(\) \mathcal{P}_{V}^{-1} = diag(\mathcal{P}_{\mathcal{M}})^{-1} + P(\bar{\mathcal{L}} + \bar{\mathcal{Q}}){-1}P{T} + C(\bar{\mathcal{L}}{-1})C{T} \(\)

where \(\) \bar{\mathcal{L}} = \frac{1}{\mu} diag(\mathcal{L},\mathcal{L},\mathcal{L}) \(\) and \(\) \bar{\mathcal{Q}} = diag(\mathcal{M},\mathcal{M},\mathcal{M}) \(\)

The matrix \(\)C\(\) is composed by the coefficients of the gradient of \(\)Q_h\(\) basis functions \(\)\phi_j\(\) in the \(\)H(\mathrm{curl})\(\)-conforming space \(\)V_h\(\) \(\) C = \{ C_{i,j} \} ~1 \leqslant i \leqslant n, ~1 \leqslant j \leqslant m ~\text{such that} ~ \nabla \phi_j = \sum \limits_{i=1}^ C_{i,j} \psi_i ~1 \leqslant j \leqslant m \(\) and the matrix \(\)P\(\) is the nodal interpolation operator \(\)\Pi_{h}^{\mathrm{curl}}\(\) from \(\)Q_h^3\(\) to \(\)V_h\(\).

From the definition of \(\)\mathcal{P}_V\(\), the linear system \(\)\mathcal{P}_{V} \mathbf{w} = \mathbf{r}\(\) gives \(\) \mathbf{w} = diag(\mathcal{P}_{\mathcal{M}})^{-1} \mathbf{r} + P\mathbf + C \mathbf{z} ~~\text{with} ~\mathbf = (\bar{\mathcal{L}} + \bar{\mathcal{Q}}){-1}P{T}\mathbf{r} ~~\text{and} ~\mathbf{z} = \bar{\mathcal{L}}^{-1} C^{T} \mathbf{r} \(\)

The terms \(\)\mathbf\(\) and \(\)\mathbf{z}\(\) are computed by solving two linear systems \(\) \begin{align} & (\bar{\mathcal{L}} + \bar{\mathcal{Q}}) \mathbf = P^{T}\mathbf{r} \\ & \mathcal{L} \mathbf{z} = C^{T} \mathbf{r} \end{align} \(\)

Then, \(\)\mathbf{w}\(\) can be updated by solving both systems which solves the linear system \(\)\mathcal{P}_{\mathcal{M}} \mathbf{v} = \mathbf\(\).