Hiptmair–Xu preconditioner explained

In mathematics, Hiptmair–Xu (HX) preconditioners[1] are preconditioners for solving

H(\operatorname{curl})

and

H(\operatorname{div})

problems based on the auxiliary space preconditioning framework.[2] An important ingredient in the derivation of HX preconditioners in two and three dimensions is the so-called regular decomposition, which decomposes a Sobolev space function into a component of higher regularity and a scalar or vector potential. The key to the success of HX preconditioners is the discrete version of this decomposition, which is also known as HX decomposition. The discrete decomposition decomposes a discrete Sobolev space function into a discrete component of higher regularity, a discrete scale or vector potential, and a high-frequency component.

HX preconditioners have been used for accelerating a wide variety of solution techniques, thanks to their highly scalable parallel implementations, and are known as AMS[3] and ADS[4] precondition. HX preconditioner was identified by the U.S. Department of Energy as one of the top ten breakthroughs in computational science[5] in recent years. Researchers from Sandia, Los Alamos, and Lawrence Livermore National Labs use this algorithm for modeling fusion with magnetohydrodynamic equations.[6] Moreover, this approach will also be instrumental in developing optimal iterative methods in structural mechanics, electrodynamics, and modeling of complex flows.

HX preconditioner for

H(\operatorname{curl})

Consider the following

H(\operatorname{curl})

problem: Find

u\inHh(\operatorname{curl})

such that

(\operatorname{curl}~u,\operatorname{curl}~v)+\tau(u,v)=(f,v),\forallv\inHh(\operatorname{curl}),

with

\tau>0

.

The corresponding matrix form is

A\operatorname{curl

} u = f.

The HX preconditioner for

H(\operatorname{curl})

problem is defined as

B\operatorname{curl

} = S_ + \Pi_h^ \, A_^ \, (\Pi_h^)^T + \operatorname \, A_^ \, (\operatorname)^T,

where

S\operatorname{curl

} is a smoother (e.g., Jacobi smoother, Gauss–Seidel smoother),
\operatorname{curl
\Pi
h
} is the canonical interpolation operator for

Hh(\operatorname{curl})

space,

Avgrad

is the matrix representation of discrete vector Laplacian defined on
n
[H
h(\operatorname{grad})]
,

grad

is the discrete gradient operator, and

A\operatorname{grad

} is the matrix representation of the discrete scalar Laplacian defined on

Hh(\operatorname{grad})

. Based on auxiliary space preconditioning framework, one can show that

\kappa(B\operatorname{curl

} A_) \leq C,

where

\kappa(A)

denotes the condition number of matrix

A

.

In practice, inverting

Avgrad

and

Agrad

might be expensive, especially for large scale problems. Therefore, we can replace their inversion by spectrally equivalent approximations,

Bvgrad

and

B\operatorname{grad

}, respectively. And the HX preconditioner for

H(\operatorname{curl})

becomes

B\operatorname{curl

} = S_ + \Pi_h^ \, B_ \, (\Pi_h^)^T + \operatorname B_ (\operatorname)^T.

HX Preconditioner for

H(\operatorname{div})

Consider the following

H(\operatorname{div})

problem: Find

u\inHh(\operatorname{div})

(\operatorname{div}u,\operatorname{div}v)+\tau(u,v)=(f,v),\forallv\inHh(\operatorname{div}),

with

\tau>0

.

The corresponding matrix form is

A\operatorname{div

} \,u = f.

The HX preconditioner for

H(\operatorname{div})

problem is defined as

B\operatorname{div

} = S_ + \Pi_h^ \, A_^ \, (\Pi_h^)^T + \operatorname \, A_^ \, (\operatorname)^T,

where

S\operatorname{div

} is a smoother (e.g., Jacobi smoother, Gauss–Seidel smoother),
\operatorname{div
\Pi
h
} is the canonical interpolation operator for

H(\operatorname{div})

space,

Avgrad

is the matrix representation of discrete vector Laplacian defined on
n
[H
h(\operatorname{grad})]
, and

\operatorname{curl}

is the discrete curl operator.

Based on the auxiliary space preconditioning framework, one can show that

\kappa(B\operatorname{div

} A_) \leq C.

For

A\operatorname{curl

}^ in the definition of

B\operatorname{div

}, we can replace it by the HX preconditioner for

H(\operatorname{curl})

problem, e.g.,

B\operatorname{curl

}, since they are spectrally equivalent. Moreover, inverting

Avgrad

might be expensive and we can replace it by a spectrally equivalent approximations

Bvgrad

. These leads to the following practical HX preconditioner for

H(\operatorname{div})

problem,

B\operatorname{div

} = S_ + \Pi_h^ B_ (\Pi_h^)^T + \operatorname B_ (\operatorname)^T = S_ + \Pi_h^ B_ (\Pi_h^)^T + \operatorname S_ (\operatorname)^T + \operatorname \Pi_h^ B_ (\Pi_h^)^T (\operatorname)^T.

Derivation

The derivation of HX preconditioners is based on the discrete regular decompositions for

Hh(\operatorname{curl})

and

Hh(\operatorname{div})

, for the completeness, let us briefly recall them.

Theorem:[Discrete regular decomposition for <math>H_h(\operatorname{curl})</math>]

Let

\Omega

be a simply connected bounded domain. For any function

vh\inHh(\operatorname{curl}\Omega)

, there exists a vector

\tilde{v}h\inHh(\operatorname{curl}\Omega)

,

\psih\in[Hh(\operatorname{grad}\Omega)]3

,

ph\inHh(\operatorname{grad}\Omega)

, such that

vh=\tilde{v}h+\Pi

\operatorname{curl
h
}\psi_+ \operatorname p_h and

\Verth-1\tilde{v}h\Vert+\Vert\psih\Vert1+\Vertph\Vert1\lesssim\Vertvh\VertH(\operatorname{curl)}

Theorem:[Discrete regular decomposition for <math>H_{h}(\operatorname{div})</math>]Let

\Omega

be a simply connected bounded domain. For any function

vh\inHh(\operatorname{div}\Omega)

, there exists a vector

\widetilde{v}h\inHh(\operatorname{div}\Omega)

,

\psih\in[Hh(\operatorname{grad}\Omega)]3,

wh\inHh(\operatorname{curl}\Omega),

such that

vh=\widetilde{v}h+\Pi

\operatorname{div
h
}\psi_h+ \operatorname \, w_h, and

\Verth-1\widetilde{v}h\Vert+\Vert\psih\Vert1+\Vertwh\Vert1\lesssim\Vertvh\VertH(\operatorname{div)}

Based on the above discrete regular decompositions, together with the auxiliary space preconditioning framework, we can derive the HX preconditioners for

H(\operatorname{curl})

and

H(\operatorname{div})

problems as shown before.

Notes and References

  1. Hiptmair . Ralf . Xu . Jinchao . 2007-01-01 . spaces . 2020-07-06 . SIAM J. Numer. Anal. . . 2483 . 10.1137/060660588.
  2. J.Xu, The auxiliary space method and optimal multigrid preconditioning techniques for unstructured grids. Computing. 1996;56(3):215–35.
  3. T. V. Kolev, P. S. Vassilevski, Parallel auxiliary space AMG for H (curl) problems. Journal of Computational Mathematics. 2009 Sep 1:604–23.
  4. T.V. Kolev, P.S. Vassilevski. Parallel auxiliary space AMG solver for H(div) problems. SIAM Journal on Scientific Computing. 2012;34(6):A3079–98.
  5. Report of The Panel on Recent Significant Advancements in Computational Science, https://science.osti.gov/-/media/ascr/pdf/program-documents/docs/Breakthroughs_2008.pdf
  6. E.G. Phillips, J. N. Shadid, E.C. Cyr, S.T. Miller, Enabling Scalable Multifluid Plasma Simulations Through Block Preconditioning. In: van Brummelen H., Corsini A., Perotto S., Rozza G. (eds) Numerical Methods for Flows. Lecture Notes in Computational Science and Engineering, vol 132. Springer, Cham 2020.