Postprocessing is only done for geometrical design variables. The postprocessing procedure is coded in sensi_coor.c and feasibledirection.c and consists of the following steps:
Now the steps are treated in more detail:
![]() |
(955) |
The continuous gradient field is the sensitivity with respect to a Dirac delta
function perturbation of the design surface at the node at stake. Both fields are coupled by the surface mesh mass matrix . Therefore, to
get the continuous gradient field the calculated sensitivities are multiplied
with the inverse of the surface mesh mass matrix:
![]() |
(957) |
Since a change in control field does not alter the geometry and hence the
design response G, the partial derivative
. The
expression
can be regarded as a smoothing operator
(filter) between the design variables and the control field. In vertex
morphing this filtering operation has to be done twice. First, after the
sensitivity analysis (sensi_coor.c), called backward filtering, in order to
transform the sensitivities calculated at the design variables to the control
field. The output in the frd file is the unfiltered sensitivity at the design
variables as well as the filtered one, which can be interpreted as the
sensitivity on the control field. And a second time to map the final feasible
direction back to the nodal design variables, called forward filtering, which
is done in feasibledirection.c. Again, two output fields are written in the frd
file: the feasible direction calculated on the control field and the forward
filtered feasible direction on the nodal design variables.
For the filtering itself two different filters are available, an explicit and an implicit one. Ragarding the explicit filter, independent if backward or forward filtering is done, the sensitivity values at a given node are thereby replaced by a weighted sum of the sensitivities of the nodes within a sphere with a user-defined radius. The weighting function is 1 at the node at stake and decreases radially in a user-defined way to zero at the edge of the sphere:
where is the resulting smoothing matrix mapping field
into a
smoother field
.
The filtering can also be performed implicitly by elliptic partial
differential equations whose inverse operator is a local smoother:
leading to (through the chain rule):
Notice that field is smoother than field
and, consequently, field
is smoother than field
.
is a scalar
penalizing high spatial variations and is also called the filter radius. Applying a standard finite element
discretization scheme leads to:
![]() |
(961) |
where
![]() |
(962) |
and
![]() |
(963) |
The gradient is to be projected into the design faces. As in the explicit filter method, the filter radius is a user-defined parameter controlling the smoothness of the filtered sensitivities. A complete filtering cycle than consists of:
For the complete derivation of the explicit and implicit filtering methods the interested user is referred to [7]. If the parameter DIRECTION WEIGHTING is active on the *FILTER card the sensitivity values at a node i are replaced by a weighted sum of the sensitivities at the nodes j within the sphere multiplied by the scalar product of the normal vector at j and the normal vector at i.