The paper reviews options for structural design sensitivity analysis, including global finite differences, continuum derivatives, discrete derivatives, and computational or automated differentiation. The objective is to put these different approaches to design sensitivity analysis in the context of accuracy and consistency, computational cost, and implementation options and effort. Linear static analysis and transient dynamic analysis are reviewed. In a separate appendix, special attention is paid to the semi-analytical method. A future paper will address design sensitivity analysis in nonlinear structural problems.
There are currently four broad categories of methods in common use for obtaining the derivatives of performance measures with respect to structural parameters: (a) overall finite differences; (b) discrete derivatives; (c) continuum derivatives; and (d) computational or automatic differentiation. The differences between these methods are particularly important for shape sensitivities, because shape design variables change the discretization, i.e. mesh or grid, when numerical techniques such as finite element, boundary element, or meshfree methods are used. In this paper, the sensitivity is defined as a derivative of a performance measure with respect to a design variable.
Except for the finite differences option, the other three come in direct and adjoint methods (called the reverse mode for automatic differentiation). In the direct mode, one obtains the derivatives of the entire structural response, and often of intermediate quantities as well. The sensitivities of performance measures can then be obtained from the chain rule of differentiation. In the adjoint mode, one defines an adjoint problem, which depends on the performance measure. The sensitivities of performance measures can then be obtained using the structural and adjoint responses. Thus not all system response sensitivities are required, which is particularly advantageous in cases with many design variables, but few performance measures of interest.
One criterion for choosing a class of methods is accuracy. Clearly, accuracy of the sensitivities may influence the optimization solution, the required number of optimization cycles and premature convergence. Unfortunately, accuracy is subjective, and here we differentiate between accuracy and consistency. We define accuracy to be the difference between the derivatives we obtain and the exact derivatives obtained from an exact solution of the governing continuum equations. Obviously such an exact solution is not known for most practical problems and can only be approximated by sufficiently accurate numerical models. We define consistency as the difference between the derivatives we obtain and the exact derivatives of the numerical model. Thus, in the context of consistency the accuracy of the underlying (numerical) model used for the response functions is irrelevant. The difference between consistency and accuracy is due to the fact that the accuracy of the numerical solution changes over the design space, and different discretizations may be used for evaluating response functions and derivatives. These definitions are illustrated in Fig. 1 for a noiseless response (a), as well as a noisy response (b). This noise could, for example, be the result of remeshing.
Full-size image (27 K)
Fig. 1.
Sketch of response and different sensitivities for a nearly noisefree simulation (a) and a noisy (possibly due to remeshing) simulation (b). The curves labeled “A” correspond to the exact solution of the governing continuum equations. The computational counterparts are denoted “B”. The differences between these curves is the modeling error, denoted “C”. Exact derivatives are identified with “D”. Consistent derivatives are labeled “E”, whereas non-exact and non-consistent COMPUTED derivatives are denoted by “F”.
Figure options
The choice between the different options for calculating derivatives is also influenced by two other criteria: computational cost and implementation effort. The objective of the present paper is to focus on papers that provide guidance on the choice of methods based on the three criteria: accuracy and consistency, computational costs and implementation efforts.
Design sensitivity analysis has been addressed in other survey papers. We first refer to the review by Haftka and Adelman [1], which is already somewhat dated. Kwak [2] and Hsu [3] summarize available techniques in computational shape optimization. The review of Ref. [4] is focused on aerodynamic optimization and related (multidisciplinary) complexities. Kleijnen [5] describes the use of sensitivities in a broad sense.
In order to achieve a maximum level of coherence we limit ourselves to linear static and transient analyses. One important area not discussed is the sensitivity of bifurcation, limit loads, and vibration problems that lead to eigenvalue problems. The methods used for calculating sensitivity of eigenvalues are quite specialized and are difficult to integrate in this paper. The interested reader may refer to Refs. [6] and [7].
Other areas not discussed herein include coupled multidisciplinary problems, such as system sensitivity using Sobieski’s global sensitivity equations [8], [9], [10] and [11], fracture [12], [13] and [14], and structural-acoustics [15], [16] and [17].
Section 2 introduces the four methods herein. Section 3 compares them for linear static analysis, while Section 4 compares them for transient analysis. The semi-analytical method is discussed briefly in Section 3 and Appendix A provides much more detail. Finally, in Appendix B an index to the references in this paper is given.
The calculation of sensitivities usually requires the solution of systems of algebraic equations. Throughout the paper a direct solver is assumed unless specified otherwise. For a more detailed discussion on iterative matrix solver in sensitivity analysis, the reader is referred to Refs. [18], [19], [20], [21], [22], [23], [24], [25] and [26].