Airfoil Aerodynamic Optimization
Airfoil Aerodynamic Optimization
Airfoil Aerodynamic Optimization
by
MASTEROF APPLIEDSCIENCE
in the Department of Mechanical Engineering.
University of Victoria All rights reserved. This thesis may not be reproduced in whole or in part, by photocopy or other means, without the permission of the author.
Abstract
A design tool for aerodynamic shape optimization is developed by coupling a CFD solver and a gradient-based optimization package. The aerodynamic solver is a parallel viscous Navier-Stokes solver with a Spallart-Allmaras one-equation turbulence model t o account for turbulence. The optimization package contains three optimization algorithms: the modified method of feasible directions, sequential linear programming and sequential quadratic programming. The developed tool is used t o obtain minimum drag airfoils subject t o a minimum lift requirement. The results show a 20% reduction in drag with respect t o the initial airfoil. The same optimization problem is solved using the three optimization algorithms. The sequential quadratic programming algorithm is found t o outperform the other two algorithms, even though they all converge t o a similar solution. Finally, the developed design tool is used for the preliminary design of a set of airfoils for an airfoil aircraft.
Table of Contents
Abstract List of Tables List of Figures
1 Introduction 1.1 Motivation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.2 Background . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.2.1 Optimization Theory . . . . . . . . . . . . . . . . . . . . . . . 1.2.2 Aerodynamic Shape Optimization . . . . . . . . . . . . . . . . 1.3 Scope of the Thesis . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.4 Structure of the Thesis . . . . . . . . . . . . . . . . . . . . . . . . . . 2 Optimization Theory 2.1 Preliminaries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.2 Modified Method of Feasible Directions . . . . . . . . . . . . . . . . . 2.2.1 Infeasible Initial Point . . . . . . . . . . . . . . . . . . . . . . 2.2.2 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . 2.3 Sequential Linear Programming . . . . . . . . . . . . . . . . . . . . . 2.3.1 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . 2.4 Sequential Quadratic Programming . . . . . . . . . . . . . . . . . . . 2.4.1 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . .
11
..
vi vii
1 2 4 4 8 11 12 14 15 21 31 35 36 39 40 46
3 Aerodynamic Optimization 3.1 Shape Representation . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.1.1 Uniform Cubic B-Spline Airfoil Representation . . . . . . . . . 3.2 Fluid Flow Analysis . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.3 Fluid Mesh Deformation . . . . . . . . . . . . . . . . . . . . . . . . . 3.4 Sensitivity Analysis . . . . . . . . . . . . . . . . . . . . . . . . . . . .
47 49 52 57 60 67
TABLE OF CONTENTS
3.5 Implementation
4 Applications 4.1 Grid Study . . . . . . . . . . . . . . . . . . 4.2 Study of the Step Size Used to Compute the 4.3 Drag Minimization . . . . . . . . . . . . . . 4.4 Airfoil Morphing . . . . . . . . . . . . . . .
5 Conclusions and Future Work
81 . . . . . . . . . . . . . . 82 Gradient . . . . . . . . . 85 . . . . . . . . . . . . . . 90 . . . . . . . . . . . . . . 106
117
List of Tables
Lift and drag values for different grid refinements a t a = 0". Re, = 2 x lo5 83 Lift and drag values for different grid refinements a t a = 4". Re, = 2 x lo5 83 Geometric constraints of the design problem . . . . . . . . . . . . . . 93 Lower and Upper bounds of the design variables . . . . . . . . . . . . 94 Aerodynamic characteristics of the initial and optimal solution a t Re = 500. 000 and a = 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97 Value of the geometric constraint a t the optimal solution . . . . . . . 97 Value of the design variables a t the optimal solution . . . . . . . . . . 98 Number of function and gradient evaluations before optimum . . . . . 103 Characteristics and requirements a t each stage of flight . . . . . . . . 107 Aerodynamic Characteristics of the initial and optimal airfoils a t cruise conditions. Re = 1.450. 000 and a = 2 . . . . . . . . . . . . . . . . . 108 Aerodynamic characteristics of the initial and optimal airfoils a t loiter conditions. Re = 582. 000 and a = 2 . . . . . . . . . . . . . . . . . . . 108 Value of the geometric constraint a t the optimal solution . . . . . . . 110 Value of the design variables a t the optimal solution . . . . . . . . . . 116
vii
List of Figures
Design space, active and inactive constraints . . . . . . . . . . . . . . Obtained search direction using -1 5 d 5 1 as a constraing, dl, or , dTd 5 1, d2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . B-Spline basis function . . . . . . . . . . . . . . . . . . . . . . . . . . Basis functions used to create the initial segment of the curve Q ( u ) . B-spline representation of a E66 airfoil using 15 control points . . . . Example of a two-dimensional multiblock fluid mesh around an airfoil Original (above) and deformed (below) mesh around an airfoil . . . . Flow chart of the aerodynamic shape optimization design tool . . . . Turbulent to laminar eddy viscosity ratio contour plot close to the Eppler 64 airfoil at a 4 degree angle of attack for grids 3 (above) and grid 4 (below) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Grid 4 around the Eppler 64 airfoil . . . . . . . . . . . . . . . . . . . Detail of grid 4 around the Eppler 64 airfoil . . . . . . . . . . . . . . Detail of the grid around the leading edge of the Eppler 64 airfoil . . Value of the drag coefficient gradient with respect to the decimal logarithm of the step size used to compute the gradient using forward differences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Value of the lift coefficient gradient with respect to the decimal logarithm of the step size used to compute the gradient using forward differences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . B-spline representation of the Eppler 66 airfoil used a t the initial airfoil for the optimization algorithm . . . . . . . . . . . . . . . . . . . . . . Initial and optimal airfoil shapes for MMFD, SLP and SQP . . . . . Pressure coefficient distribution at Re = 500,000 and a = 2 over the surface of the Eppler 66 and optimal airfoils using MMFD, SLP and SQP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
LIST O F FIGURES
4.10 Contour plot of the pressure coefficient distribution at Re = 500,000 and cr = 2 over the Eppler 66 airfoil (above) and the optimal SQP airfoil (below) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.11 Friction coefficient distribution at Re = 500,000 and cr = 2 over the surface of the Eppler 66 and the optimal airfoils using MMFD, SLP andSQP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.12 Contour plot of the velocity distribution a t Re = 500,000 and cr = 2 over the Eppler 66 airfoil (above) and the optimal SQP airfoil (below) 4.13 Convergence history plot of the drag minimization problem solved using MMFD, SLP and SQP algorithms . . . . . . . . . . . . . . . . . . 4.14 Shape of the initial design and the optimal cruise and loiter airfoils . 4.15 Pressure coefficient over the initial and optimal UAV cruise airfoil surface at Re = 1,450,000 and cr = 2 . . . . . . . . . . . . . . . . . . . . 4.16 Friction coefficient over the initial and optimal UAV cruise airfoil surface at Re = 1,450,000 and cr = 2 . . . . . . . . . . . . . . . . . . . . 4.17 Pressure coefficient over the initial and optimal UAV loiter airfoil surface at Re = 582,000 and cr = 2 . . . . . . . . . . . . . . . . . . . . . 4.18 Friction coefficient over the initial and optimal UAV loiter airfoil surface at Re = 582,000 and cr = 2 . . . . . . . . . . . . . . . . . . . . .
Vlll
...
Acknowledgements
I would like to thank my supervisor Dr.Afza1 Suleman for giving me a chance to be part of his research group and for his support and encouragement throughout my graduate studies, especially during the initial stages of my thesis. It is difficult to transition from electrical t o mechanical engineering, and his support was crucial in making this transition a successful one. I would also like to thank Dr. Ned Djilali for his many insightful comments about computational fluid dynamics (CFD); they were essential to my understanding of CFD. Finally, I would like to thank Dr. W.-S. Lu; his course in optimization motivated me to work in this challenging area, and he helped to set a solid foundation for further understanding of the subject. Among my fellow graduate students, I would like to give special thanks to Gonqalo Pedro for his helpful comments and discussions concerning the computational fluid dynamics solver, SPARC, and on the mesh deformation algorithm. I would also like to thank Bart Stockdill for his useful insights on grid generation, and Pedro Gamboa for the many helpful discussions on aircraft morphing and design. Finally, thanks to all members of our research group: Dr. Suleman, Gonqalo Pedro, Bart Stockdill, Pedro Gamboa, Diogo Santos, Luis Falciio, David Cruz, Joana Rocha, Scott Bumpus, Ernest Ng, Sandra Makosinski, Geoff Woods, and, Ahmad Kermani. Thank you for sharing your enthusiasm for research and your expertise with me. Your support and companionship made these two years of graduate school an amazing experience. Last but not least, I thank my wife, Tabitha Gillman, for her emotional support and my parents, Josep and Concepci6, for giving me the encouragement and opportunities to learn. Without you this thesis would never have been written.
To my family
Chapter 1 Introduction
In the past, the design process for engineering systems such as aircraft was a trialand-error process based on the experience of the designers. As designed systems have become more complex, the trial-and-error process has become an expensive and tedious task. To aid in the design of complex engineering systems, new design methods are necessary that rely on numerical tools to select the most efficient parameters for a desired design. In the last two decades, increases in computing power, and new advances in the areas of computational fluid dynamics (CFD) and computational structural dynamics (CSD) have allowed engineers t o model and analyze complex systems in a reasonable amount of computational time. Numerical methods for optimization have also emerged that are able to optimize a certain performance index with respect t o a specified set of parameters. As a result of these advances it is now possible to couple an analysis tool, such as CFD and CSD, with a numerical optimization technique in order t o obtain engineering design tools for optimal design. In this thesis, a numerical optimization technique is coupled with a CFD solver
CHAPTER 1. INTRODUCTION
t o develop a design tool for aerodynamic shape optimization. The motivation of the thesis is described in detail in the next section. The most recent advances in the areas of numerical optimization and aerodynamic shape optimization are then reviewed in sections 1.2.1 and 1.2.2. The scope of the thesis is presented in section 1.3. Finally, a description of the forthcoming chapters is presented in 1.4.
Motivation
The demand for surveillance unmanned aerial vehicles (UAVs) during the last few years has increased the amount of research being done in the development of efficient low Reynolds number airfoils, since most UAVs fly a t a Reynolds number in the range of 100,000 t o 1,000,000 [I]. In the past two decades, airfoil shape optimization using CFD codes has been applied t o transonic airfoils and wings [2, 31. However, shape optimization using CFD has seldom been applied t o airfoils a t low Reynolds numbers because of the complexity of the fluid flow a t low Reynolds numbers [4]. Low Reynolds number airfoils have different aerodynamic characteristics than transonic and supersonic airfoils because the viscous forces have a larger impact on the aerodynamics of the airfoils. Therefore, in order t o accurately predict the aerodynamic characteristics, an aerodynamic solver that takes into account the viscosity of the fluid is necessary in order t o properly predict the aerodynamic characteristics of such airfoils. In this thesis, a fully viscous solver is used t o compute the aerodynamic characteristics so that aerodynamic shape optimization can be performed a t this low Reynolds number. Surveillance UAVs have a large flight envelope. They are expected to: fly a t high speeds in order t o arrive at the surveillance area in the shortest amount of time possible, fly a t low speed in the surveillance area and, takeoff and land within
CHAPTER 1. INTRODUCTION
the minimum amount of space possible. These requirements are difficult t o meet efficiently with a conventional single airfoil configuration, and it is necessary t o achieve a compromise between the different stages of flight. A possible solution t o increase the efficiency of UAVs in all stages of flight is t o develop an aircraft with a morphing airfoil. The morphing airfoil would be able t o adapt its shape t o the various mission requirements [5, 61. To achieve this goal, a design tool must be developed t o obtain optimal airfoils for each of the different stages of flight, so that the systems t o deform the airfoil and a prototype aircraft can be designed and tested. In the area of aerodynamic shape optimization, research has centered on reducing the amount of computational time needed t o evaluate the functions and gradients for optimization. This is because the evaluation of aerodynamic objective function and constraints involves the solution of a set of partial differential equations (PDE) and therefore, it is the most time consuming task during the optimization process. Usually an optimization method is chosen a priori, and all the results are reported using this algorithm. A good selection of the optimization algorithm can reduce the amount of iterations necessary t o obtain the optimum and, thereby, reducing the number of function and gradient evaluations and as a result reducing the computational time. However, the study of different optimizaiton algorithms used t o solve aerodynamic shape optimization problems has not received the necessary attention. Only in [7] is an aerodynamic shape optimization problem solved using genetic algorithms and quasi-Newton method and the performance is compared. It is not known by the author that rates of convergence of different first-order optimization methods have been compared when solving an aerodynamic shape optimization problem using an accurate CFD analysis. The comparison of several first-order optimization methods is problem dependent and has yielded interesting results when applied t o structural optimization [8]. This issue will also be addressed in this thesis.
CHAPTER 1. INTRODUCTION
Finally, aerodynamic shape optimization is an essential part of a multidisciplinary design optimization (MDO) tool for aerospace applications [9]. The development of an aerodynamic shape optimization tool in this thesis is an important step toward the understanding and development of an MDO application for aircraft design. This thesis has provided the necessary background for a future PhD thesis in MDO, which will involve the coupled optimization of aerodynamics and structures t o obtain more realistic results.
1.2
1.2.1
Background
Optimization Theory
Advances in digital computer technology during the early fifties led t o an incredible advance in the area of numerical methods for optimization. Since then, active research has produced a variety of methods for unconstrained and constrained optimization
[lo, 11, 121.
Engineering applications for optimization usually involve solving a nonlinear constrained optimization problem. Nonlinear constrained optimization problems involve the search for a minimum of a nonlinear objective function subject t o a set of nonlinear constraints, and it is common for this optimization problem t o have multiple extrema. Due t o this difficulty, two different approaches have emerged in the area of nonlinear constraint optimization: local methods and global methods. Local methods aim t o obtain a local minimum, and they cannot guarantee that the minimum obtained is the absolute minimum. These methods are usually first-order methods, i.e. they require information about the gradient of the objective function and the constraints. On the other hand, global methods aim t o obtain the absolute minimum
CHAPTER 1. INTRODUCTION
of the function. They do not need any information about the gradient, and they are mostly based on stochastic procedures. Local constrained methods can be classified into sequential methods and transformationbased methods. Sequential methods aim to solve the nonlinear constrained problem by iteratively solving a more simple constrained optimization problem. The most commonly used local sequential methods are: the method of feasible directions (MFD) and modified method of feasible directions (MMFD) [lo, 13, 141, sequential linear programming (SLP) [13, 10, 151, sequential quadratic programming (SQP) [ll, 161, and response surface approximation methods (RSM) [17, 181. The MMFD is based on obtaining a sequence of feasible directions, i.e. directions that reduce the objective function and satisfy the constraints. Then, the design is moved in these directions until convergence t o the optimum is achieved. The main drawback of this method is that it performs poorly if the constraints are highly nonlinear or discontinuous. The SLP method solves iteratively a linear programming subproblem obtained by linearizing the objective function and the constraints. Because linear approximations are only valid in the neighborhood of the linearization point, the norm of the search vector used t o improve the design needs to be constrained. This constraint is achieved by imposing limits to the maximum allowable change on the design variables. These limits are known as move limits. The main drawback of SLP methods is the choice of the move limits; if the move limits are large, the method leads t o oscillations on the convergence and it may not converge. On the other hand, if the move limits are too small, the SLP presents a low convergence rate. The main advantages of SLP methods are: they are simple t o implement because they only involve the solution of a linear programming problem (LP) and, they are proved t o yield good results if the move limits are properly adjusted [19]. Similarly, SQP methods are based on a second-order approximation of the objective function
CHAPTER 1. INTRODUCTION
and a linearization of the constraints [lo] or on a second-order approximation of the Lagrangian of the original problem [ll]. SQP methods are robust, have a fast convergence rate and are the most frequently used local nonlinear constrained optimization method. Finally, response surface approximation methods use interpolation models t o model the objective function and constraints of the original problem. The interpolation model, usually a quadratic model, is then used t o optimize the problem. The problem is solved iteratively and the approximation model is updated with the last solution. Local transformation-based methods transform the original nonlinear optimization problem into an unconstrained optimization problem by adding a penalty function t o the objective function. When the constraints are not satisfied, the penalty function increases its value thereby increasing the value of the objective function. Once the constrained problem has been transformed into an unconstrained problem, any unconstrained optimization algorithm can be used t o solve the transformed problem. For example, a Quasi-Newton method or a conjugate-gradient method can be used 113, 10, 14, 111. The most commonly used local transformation-based methods are: penalty methods 113, 101 and augmented Lagrangian methods 113, 10,141. The former eliminates the constraints by adding a penalty function t o the objective function. The penalty function increases the value of the objective function when the constraints are violated. The main drawback with these methods is that the penalty functions are dependent on the problem a t hand and, thereby making it difficult t o generalize. On the other hand, Lagrangian methods solve the optimization problem by introducing a set of Lagrange multipliers that control the penalty function and make the Lagrange multipliers variables in the optimization program. All penalty methods have a main drawback; due t o the introduced penalty, the objective function becomes highly nonlinear and this makes it difficult for the unconstrained methods t o obtain
CHAPTER 1. INTRODUCTION
the minimum. To conclude this description on local constrained methods, it is important to note that, although local methods do not aim for the global optima, they can be used t o obtain such global optima. Several approaches can be used t o continue searching once a local minimum has been obtained, thereby enabling the identification of all local minimum and, therefore, also the global minimum. Some of these methods based on a stochastic approach are: random multi-start methods [20, 211 and ant colony searches [22]. In the former method, once a minimum has been obtained, it restarts the optimizer with a new, randomly generated initial point. The second method uses the information from search agents (ants) in order t o find the global minimum. Some other methods introduce a deterministic approach. For example, in the local-minimum penalty method [23] the objective function is penalized if the algorithm tends t o go t o an already known local minima. The other group of constrained methods, the global methods, can be classified as direct or transformation-based. Direct methods solve the problem without transforming it into a simple problem. Transformation-based methods transform the initial constrained optimization problem into an unconstrained problem. Direct methods include covering methods and pure random searches. Covering methods follow a deterministic approach where regions of the design space are tested and eliminated if specific design criteria are not met. The most common of these methods are the interval methods [24]. Pure random searches evaluate randomly generated points until a minimum is obtained. The main drawback of both these methods is that they require a large number of function evaluations and are therefore computationally expensive. Global transformation-based methods start by transforming the original problem into an unconstrained problem. Then, global unconstrained techniques are used t o obtain the global minima. Popular unconstrained global methods are: genetic algo-
CHAPTER 1. INTRODUCTION
rithms [25], evolutionary algorithms [26] and simulated annealing [27]. These methods have the same drawback as the global direct methods; they require a large number of objective function evaluations, therefore the computational cost of the method becomes excessive when the evaluation of objective function and constraints is time consuming.
1.2.2
During the late seventies Hicks et al. published one of the first papers on aerodynamic shape optimization [28]. In [28], Hicks used a first-order optimization technique in conjunction with a fully-potential inviscid flow solver in order t o determine the optimal shape of a wing with respect t o a certain performance criteria. Since [28], aerodynamic shape optimization has become an increasingly active area of research and several innovative methods for aerodynamic shape optimization of airfoils and wings [29, 30, 311, full aircraft configurations [2, 31, and even aero-structural optimization of full aircraft configurations [32] have been published. In general, t o solve an aerodynamic or airfoil shape optimization problem it is necessary to: Develop a set of parameters that represents the airfoil shape. Develop tools that, given a set of parameters, will compute the objective function and constraints of the optimization problem. This involves an aerodynamic analysis tool and algorithms t o transform the set of parameters into the input necessary for the analysis tool. Develop tools that, given the design variables, objective function and constraints, will obtain a new aerodynamic shape close t o the optimal or, the optimal shape itself.
CHAPTER 1. INTRODUCTION
0
Develop tools that, given a set of design parameters, will compute the gradients of objective function and constraints with respect to these parameters.
The way each one of these problems is solved will influence the optimization process and the results. Therefore, in the following paragraphs, the most used techniques for items one, two and four are described. Item three was the focus of attention in the previous subsection. Some of the parametrization techniques to represent an aerodynamic shape that have been applied t o optimal shape optimization are: discrete parametrization, analytical parametrization, polynomial parametrization, spline parametrization and, CAD-based parametrization [33, 341. A description of these methods is undertaken in section 3.1. In general, the ideal airfoil shape representation method is one that, with a small set of parameters can define any possible airfoil shape. If the parameterization technique is not able to represent all possible airfoil shapes, then the optimal solution is constrained by the shape parametrization, and a true optimal shape cannot be obtained [35]. On the other hand, if the number of parameters is large, the optimization problem becomes unnecessarily large and this will result in the need for excessive computational time in order to obtain the optimum. Given an airfoil shape, the solution of the flow field yields the objective function and the constraints of the optimization problem. There are mainly four types of analysis codes used to solve the fluid flow: the fully potential flow solvers [36], the coupled boundary-layer potential flow solvers [37], Euler solvers [38], and the viscous Navier-Stokes flow solvers [38, 391. Potential flow and Euler solvers solve the fluid flow by assuming that the viscosity effects are negligible. The coupled boundary-layer potential flow solvers assume that the viscous effects are only important in the neighborhood of the aerodynamic shape. Finally, the viscous Navier-Stokes flow solvers consider the viscous effects to be everywhere in the fluid, and they solve the Navier-
C H A P T E R 1. INTRODUCTION
10
Stokes equations or the Reynolds Averaged Navier-Stokes (RANS) equations of the fluid flow. Viscous Navier-Stokes flow solvers are the most accurate solvers of those mentioned above. However, they are computationally more expensive than the other analysis codes and, for this reason, their use in aerodynamic shape optimization has been limited [31]. In aerodynamic optimization Euler solvers are the most commonly used. Euler and viscous Navier-Stokes flow solvers use a discrete decomposition of the fluid domain, called fluid mesh, t o solve the fluid flow. During an optimization process, the optimizer will change the aerodynamic shape a t each iteration. Assuming that an initial mesh has been determined for the initial aerodynamic shape, when the shape of the body changes, the mesh must also change in order t o adapt to the new shape. This is the third part of the optimization algorithm. A methodology is needed that will modify or reconstruct the fluid mesh everytime the aerodynamic shape changes. This is a one way fluid-structure interaction problem. Basically, two solutions have been applied to this problem: the mesh can be rebuilt each time the shape changes [40] or, the mesh is deformed with the body [41, 421. In aerodynamic shape optimization, the second method is the one most commonly used. Finally, if a first-order optimization algorithms is used, the gradients of objective function and constraints are needed for the optimization process. Since most of the computational time is used t o obtain the gradients, this is one of the most critical parts of the optimization algorithm. In order to avoid having t o find the gradients, non-gradient based methods can be used. However, the amount of function evaluations that these algorithms require in order t o find the optimum, defeats the initial purpose. Several methods are available to obtain the gradients: analytical differentiation [43, 32, 441, finite-differences [32], complex-step derivative [32, 451, and automatic differentiation [46]. These methods are described in detail in section 3.4. Analytical
CHAPTER 1. INTRODUCTION
11
differentiation, also known as the adjoint method, is the most computationally efficient. The solution of the flow field and the gradient of the objective function are obtained in approximately twice the amount of time used t o solve the flow field alone, independent of the number of design variables. On the other hand, finite-differences, complex-step derivatives and forward automatic differentiation are all more expensive methods of computing the derivatives because the computational time depends on the number of design variables. However, these methods are easier t o implement and can be used as a black-box.
1.3
In this thesis, a code for two-dimensional, single element, aerodynamic shape optimization is developed. Given the fluid flow characteristics, the developed code is able t o obtain an airfoil that optimizes certain performance criteria while satisfying certain constraints. For example, it can minimize the airfoil drag subject t o a certain minimum lift requirement. The obtained airfoil has optimal aerodynamic performance for the fluid flow conditions specified; however, there is no guarantee that the airfoil will perform optimally away from the specified flow characteristics. The design of optimal airfoils for multiple fluid flow conditions, usually called robust airfoil optimization, is outside of the scope of this thesis, and it is part of the future work in our research group. The design tool has the capabilities t o optimize airfoils at subsonic, transonic and supersonic speeds, however, only subsonic airfoils are of interest in this thesis. As will be described in chapter 3, the design tool uses a spline representation of the airfoil, a viscous Navier-Stokes solver, a mesh adaptation method based on deforming the initial grid, and forward-differentiation t o compute the gradients. The use of a spline representation is chosen because it reduces the number of design variables
CHAPTER 1. INTRODUCTION
necessary t o represent the airfoil and it guarantees an almost free-form airfoil. The viscous Navier-Stokes solver is used because it guarantees accurate solutions at low Reynolds numbers where the viscous effects are important. Notice that the design tool has the capabilities of also using an Euler solver. Finally, forward-difference is used because of its ease of implementation. The gradient-based sequential local constrained methods implemented in the commercial package DOT [47] are used for the optimization. The optimization methods used are: the modified method of feasible direction, sequential linear programming and sequential quadratic programming. These three methods were proven to yield good results in the area of structural optimization [8]. In this thesis, the three methods are analyzed t o evaluate their performance and t o determine the optimization algorithm that better adapts t o aerodynamic shape optimization problems. These methods are local methods, therefore the design tool does not guarantee that the optimal shape is a global optimum.
CHAPTER 1. INTRODUCTION
13
used, the viscous Navier-Stokes solver, the mesh deformation technique, the method used to compute the gradients and, finally, the implementation of the aerodynamic shape optimization design tool. Once the design tool has been described, chapter 4 shows several applications of the design tool. The design tool is first applied to solve a constrained drag minimization problem. To solve the optimization problem the three optimization algorithms are used. Then, the results are used to validate the program and to compare the different optimization algorithms and their performance. The design tool is then applied to the design of an airfoil morphing aircraft. Finally, chapter
5 contains concluding remarks and points out areas for future development in the
areas of aerodynamic shape optimization and multidisciplinary design optimization.
Preliminaries
In general, a nonlinear unconstrained optimization problem aims t o Minimize f (x) w.r.t. xk where the function t o be minimized, f (x),is known as the objective function. The objective function depends on a set of variables, x, that can take arbitrary values. These variables are known as the design variables. The aim of the optimization algorithm is t o obtain the value of the variables, x, that makes the objective function minimal. This point is known as the solution of the optimization problem and is represented by x*. It is important t o notice that maximizing a function, m(x), is equivalent t o minimizing the function f (x) = -m(x). Therefore any unconstrained maximization problem can be solved using an algorithm t o solve the standard optimization problem in (2.1). The same argument holds for constrained optimization. For this reason, it is assumed in that follows that the optimization problem is a minimization problem. The nonlinear constraint optimization problem is slightly different than (2.1) be-
16
cause the design variables cannot be arbitrarily chosen. The design variables must satisfy certain constraints. In genera1,the aim in a nonlinear constraint optimization problem is Minimize f (x) w.r.t. xk subject to: hi(x) = 0 SAX) I 0 for k = 1 , 2 , (2.2a)
...,n
In (2.2), f (x) is the objective function, x is the vector of design variables, n is the number of design variables, {hi(x) = 0 for i = 1 , 2 , . . . ,p) are the equality constraints and {gj(x) 5 0 for j = 1 , 2 , .. . , q) are the inequality constraints. Furthermore, it is assumed that functions f (x), h(x), g(x) are nonlinear, continuous and have continuous first and second order derivatives. ) As discussed, the design variables must satisfy equations ( 2 . 2 ~ and (2.2d). Then, the design space or feasible region of (2.2), R, is defined as R = { x : h i ( x ) = O f o r i = 1 , 2 , . . . ,p and g j ( x ) < O f o r j = 1 , 2 , . . . , q) (2.3)
A point inside, x E R is considered a feasible point. In a constrained optimization problem the minimum must be in the feasible region. An unconstrained problem can be understood as a constrained problem with an unbounded or infinite feasible region. Equality constraints are a set of equations that explicitly or implicitly relate some design variables with other design variables. Therefore, the number of equality constraints must be smaller than the number of design variables, p 5 n. Furthermore, if the number of design variables and the number of equality constraints are the same,
17
the design space will be a finite set of points and the solution of the problem is trivial. Since equality constraints introduce a relation between design variables, in an equality constrained problem only n
-p
rest of the variables are obtained from the value of the arbitrarily chosen variables and the equality constraints. Inequality constraints are a set of equations that impose bounds on the design variables. Unlike equality constraints, the number of inequality constraints is unlimited. Inequality constraint~can be active or inactive. For a feasible point, x, if gk(x) = 0 the inequality constraint gk(x) is considered t o be active. Equality constraints must be considered as active constraints. The feasible point x satisfying an active constraint is at a limit of the design space and not all its neighboring points are in the feasible region. On the other hand, for a feasible point x, if gk(x) < 0 the inequality constraint is inactive. In this case, all its neighboring points are feasible and this inequality constraint does not need t o be considered when looking for a new design point from X I . As an example, consider the problem in figure 2.1. The dashed region corresponds t o the feasible region where gl(x) 5 0, g2(x) 5 0 and g3(x) 5 0. At the feasible point xl, only constraint g2(x1) is equal t o zero. Therefore, only this constraint is active. The other constraints are inactive. So far the constraint optimization problem and its components have been described. However, it still remains t o known how t o solve the optimization problem in (2.2). Before the problem can be solved, it is necessary t o know the properties of a minimizer. Minimizers can be classified as local minimizers and global minimizers.
x,
For a point x* to be a local minimizer, it needs to satisfy the Karush-Kuhn-Tucker (KKT) conditions. These conditions are outlined here without proof, because they are the basis of all constrained optimization methods. For proof see [ I l l .
Theorem 2.1.1 (Karush-Kuhn-Tucker (KKT) conditions) If x* is a local m i n -
imizer of the optimization problem (2.2) and the gradient of all active constraints at
(2.4d) (2.4e)
where
(2.5)
where NT(x*) is a matrix whose columns are the basis of the subspace N . Furthermore,
N is the null space of the space whose basis is formed b y the gradient of all
active constraints.
All constrained optimization algorithms are obtained from the definitions and theorems described above. Therefore, in the following sections, the concepts discussed above are used t o derive the algorithms implemented in the optimization package DOT [47]. To derive the algorithms in DOT, the nonlinear optimization problem below will be considered because this was the problem used t o derive the equation implemented in the optimization package. Minimize f (x) w.r.t. x k subject to: gj(x) 5 0 f o r k = 1 , 2 , ...,n for j = 1 , 2 , . . . , q (2.6a) (2.6b) (2.6~)
where f (x) is the objective function, x is the vector of the design variables, n is the number of design variables and {gj(x) 5 0 for j = 1 , 2 , . . . ,q} are the inequality constraints. It is also assumed that functions f (x) and g ( x ) are nonlinear, continuous and have continuous first and second order derivatives. The equality constraints are not taken into consideration in the optimization problem because the authors of the optimization package considered them uncommon in engineering applications. Equality constraints can be introduced into the problem as two inequality constraints and the code is proved t o yield good results. However, this method is not efficient compared with working with equality constraints directly inside the code.
xk
+ a d k . This process
point is infeasible, an initial subproblem must be solved prior t o the application of this procedure, t o obtain an initial feasible point. Assuming the current design point, x, is a feasible point of the problem in (2.6), then the desired search direction should rapidly reduce the objective function while maintaining a feasible design. In order t o reduce the objective function, the search direction should be a t an angle of 90" t o 270" with respect t o the gradient of the objective function. Mathematically this condition is equivalent t o
where x is the actual design point and d is the search direction. A search direction satisfying (2.7) is called a usable direction. The search direction must maintain the design in the feasible region, away from the constraints. In order t o guarantee this condition, the search direction should also be a t an angle of 90" t o 270" with respect t o the gradient of the constraints.
where gi(x) E J, J = {gi(x) : CT 5 gi(x) 5 C T M I N for i = 1 , 2 , . . . , q,) is the set of active inequality constraints and, CT is a small negative number (for example -0.0001), C T M I N is a small positive number (for example 0.0001) and q, is the number of active constraints. A search direction, dl satisfying (2.8) is called a feasible direction. In the case of (2.8) being smaller than zero, the search direction points toward the feasible region. If (2.8) is exactly zero, the search direction is tangent t o the constraint. Then, it is necessary t o take special care during the one-dimensional search, because if the constraint is convex, any design point following the search direction would become infeasible. In conclusion, the desired search direction should be a usable and feasible direction. Since the main goal is t o obtain the maximum possible reduction of the objective function, the desired search direction can be obtained by solving the optimization problem
f Maximize - vT (x)d
subject to: vTgi(x)d5 0
dTd 5 1
where gi E J, J is the set of active constraints. In matrix form and transforming the maximization problem into a minimization problem the aforementioned problem
dTd 5 1
where
c E Rnxl, d E Rnxl, A E
Rqax n ,
number of active inequality constraints. Since only the active constraints are used t o compute the search direction in (2.9), bounds on the design variables are introduced to guarantee a bounded solution to the problem. In this case, quadratic constraints are used t o bound the solution instead of a linear constraint. The reason can easily be seen in figure 2.2 where the search direction is obtained using linear and quadratic constraints. If linear constraints are used for each design variable, the optimization algorithm will look for a direction that ends a t one of the edges of the square (in n dimensions, hypersquare). This allows for a longer vector, resulting in a greater reduction in the objective function. Therefore, the constraints added t o bound the problem would affect the solution. In order t o guarantee that the constraints added t o bound the solution do not affect the solution of the problem, the constraints should guarantee that the vectors are all the same length in all directions. This is achieved with a quadratic constraint. Then, all vectors are inscribed in a sphere (or a hypersphere in n dimensions).
X2+
f(x,)
f(x3
f(x3
<
The introduction of quadratic constraints to bound the solution changes the optimization problem from a linear programming problem to a more complex problem. To solve the problem, let us consider the Karush-Kuhn-Tucker conditions. The KKT conditions for (2.10) require that,
25
and where p E RQaX1 fi E R are the Lagrange multipliers for the inequality constraints of the problem. Multiplying ( 2 . 1 1 ~ by A , )
where
A = -AAT
and I is the identity matrix. To find the optimal solution, a vector that satisfies the system of equations (2.14) needs to be found. If bi
>0
is a solution of the system of equations in (2.14). However, if any bi < 0, then the vector in (2.15) does not satisfy that v case, a solution is found by obtaining
max - ; Aii
26
and letting k = i for i, which satisfies (2.16), and replace vk by uk. This is done by pivoting on a k k . Repeat the process until all bi the definition of
Once a solution of (2.14) is obtained, the search direction is found using (2.11c),
Since only the direction of d is of interest, because a line search will be performed in the search direction t o find the optimal magnitude of the vector, unity. In this way, the search direction is obtained. Once a search direction has been found, the next step is t o find the parameter a*such that
xk+l
fi can be set t o
=xk
is a feasible point.
= If the set T = {gi : vTgid 0 for i = 1 , . . . , t ) is null, then the line search is
straightforward. However, if the set T is not empty, the search direction is tangent t o the constraints inside the set. This means that there is a risk of obtaining an TO infeasible design point, ~ k + ~ . prevent this, in the line search the constraint is forced t o also be active in the next iteration. Assuming that the set T is empty. Then, before performing any one-dimensional search in parameter a, upper and lower bounds for the parameter are needed. Since, the search direction satisfies that
zero so that the inequality does not change sign. The upper bound is more difficult t o obtain. If in the k
~) approximation of f ( x ~ +holds,
where the absolute value guarantees that a is positive. Following the same idea, the gradients of the constraints can be used t o find the a that will make the inactive constraints active a t the next iteration. Notice that, since the constraints that are inactive are not part of the optimization in (2.9), the search direction can move toward For a ) ~ ~ + ~ them, i.e. it is possible that v ~ ~ ~ 2(0 .x ~ constraint gi(xkS1),the value of alpha that makes the constraint active a t the next iteration can be found using a linear approximation of the constraint,
Since it is desired t o reduce the function by 10% and a t the same time obtain a feasible point, the upper limit for a is obtained using
aU= min
-0.ll.f
( ~ k )
vTf( x k ) d k + l
for i = 1,. . . , q
(2.21)
Once the upper and lower bounds have been obtained, a quadratic or cubic polynomial interpolation is used t o approximate the objective function and the constraints inside the bounds. Then, using basic calculus, a set of values of the parameter a is obtained. One value, a f minimizes the objective function and the other values ai for
i = 1, ..., q make each one of the constraints active. Finally, the optimum value of a
28
that reduces the objective function as much as possible and creates a feasible point is
(2.22)
where a*is the optimal parameter for a . Now, the design variables are updated and the algorithm can proceed to the next iteration.
= To end this discussion, the case where the set T = {gi : vTgid 0 for i =
1 , . . . , t ) is not empty must be studied. The constraints inside the set T are tangent to the search direction. This means that if the design variables are updated following the search direction, there is a risk of obtaining an infeasible design point at the next iteration,
~ k + that ~ ,
in the line search the constraints in T are forced to be active in the next iteration, thereby, introducing a set of equality constraints into the line search. Because equality constraints are equivalent t o relations between design variables, taking a first-order Taylor expansion of the constraints in T and taking into account that they are active a t iteration k and must be active a t iteration k design variables can be obtained,
where gi(xk) E T and dktl = a d k + l . Using the relations between variables obtained from (2.23), the search vector can be divided into dependent and independent
where dD = aDdD, = aIdI. Notice that since G has more columns than rows, $ it is usually easy t o obtain a nonsingular matrix D. The matrix D can be obtained using row operations t o transform G into its Row-Echelon Normal Form as described in [50]. G will be divided into a set of columns that form an identity matrix and other columns. The columns that form the identity matrix can be used as D. The remaining columns will be N. Then, given the update vector of the independent design variables, dI, the relationship in equation (2.26) can be used t o obtain the update vector of the dependent design variables that guarantees that the constraints in T are active at the next iteration, k
+ 1.
update vector for the independent variables and the independent design variables are
Then, the value dg+')is found using equation (2.26). Since the relation between variables given by equation (2.26) is derived from a first-order approximation of gi(xk+l), the relation cannot be used to find an accurate value for dg"), since the constraints are nonlinear. Therefore, the values from equation (2.26) are used as an initial guess and a method similar t o the Newton-Raphson method 1511 is used t o obtain the exact value for
dg'').
Step 1 Determine
with T null.
Step 2 Determine initial guess for dg+') using equation (2.26) Step 3 Update design variables using x("') =
If gi(x(k+')) CTMIN stop. If not continue. = and compute gi (~("'1).
and go t o step 3. At this point, if an initial feasible point is known, the optimization problem in
31
(2.6) can already be solved. The only problem that remains t o be solved is how t o obtain a feasible initial point. This will be discussed in the next section.
2.2.1
The method of feasible direction assumes that an initial feasible point is known. The optimization process then searches for new feasible points that reduce the objective function until the optimal is found. However, it is sometimes difficult t o obtain a feasible point; therefore, a technique for obtaining a feasible point is described in what follows. To obtain a feasible point, a optimization problem similar t o (2.9) can be formulated in order t o obtain a search direction pointing toward the feasible region.
- qw
VTf (4 d
lPTf( 1 41
I I v T g i (x)I I
VTgi(x) d + Oiw 5 0
where gi(x) E J, J is the set of active and violated constraints, q and Oi are positive constants. If the value of the constant q is large, the first term of the objective function dominates the minimization, since the vector
vT (x) is normalized. f
To
minimize the objective function w must be as large as possible. On the other hand, from (2.31b), if w is large, vTgi(x)dshould be a negative large number, thereby obtaining a direction that satisfies the constraints. The second term in the objective function, (2.3la), is introduced t o try t o obtain a direction that will also reduce the objective function of the original problem f (x); but as discussed earlier, this is not
If q is large, the second term in (2.31a) influences the optimization problem marginally, thereby giving total priority t o obtaining a direction that will reach the feasible region, i.e. a direction perpendicular t o the constraints. However, if q is small, then the first term will have a greater influence on the optimization problem, and the obtained direction will be a compromise between a direction that reduces the objective function and that points toward the feasible direction. In DOT, q is initialized with the value 5.0. If the obtained search direction does not return a feasible point, q is increased by a factor of 10 and a new direction is obtained. q is allowed t o increase up t o 1000 where an upper limit is set t o avoid numerical ill-conditioning of the problem. The selection process for the parameters Oi follows a similar idea. These parameters are known as push-off factors. For large values of Oi, the dot product vTgi(x)d has t o be large and negative. Because of this requirement, the search direction is more perpendicular t o the constraint, i.e. the search direction points more toward the feasible direction. In DOT, the parameters Oi are chosen as
with Oi
< 50 and where CT is a small negative constant that represents the minimum
requirement t o make the constraint inactive. To solve the optimization problem in (2.31), the problem is first written in matrix
dTd 5 1
where
c E Rn+' 'l, d E Rn+' 'I, A E RQaXn+l, is the number of design variables of the n
initial problem and q, is the number of active and violated inequality constraints. The problem in (2.33) has the same structure as (2.10). Therefore, the method outlined in the last section can be used to solve the optimization problem in (2.33). Once the search direction has been obtained, a line search using the parameter
a is performed in the search direction. As in the last section, the first step is to
determine the bounds of the parameter a. Again, the lower bound is zero because the search direction points toward the feasible direction, and a negative sign in a would result in a change in the direction of the vector. The upper bound, however, is obtained differently here respect to the feasible design case. In this case, the value of
a needs t o guarantee that all constraints are satisfied. Therefore, it must guarantee
that the violated constraints will not be violated in the next step and, at the same
34
time, it must guarantee that none of the satisfied constraints becomes violated. This can be achieved using
a, = min (max
(V
-gi
(x) gi(xk)d
), (
min
-gj
(4
vTgj(4d
))
where i = 1 , . . . , q,; j = 1 , . . . , q,; q, is the number of violated constraints, and q, is the number of active and satisfied constraints. If the objective function increases in the search direction, the value of a given by equation (2.34) is the final upper bound. However, if the objective function decreases in the search direction, a larger value may exist for the upper bound of a than the one given by (2.34), that will satisfy the constraint and decrease the objective function. Then, a, is found using -gi (4 (max ( v T g i ( x k ) d
-"'If
("'1)
,
min
= min
vTf( x ) d
(v T g j ( x ) d))
gjix)
(2.35)
where again i = 1,.. . , q,; j = 1 , . . . ,q,; q, is the number of violated constraints and
q, is the number of active and satisfied constraints.
Once the upper and lower bounds have been obtained, a quadratic or cubic polynomial interpolation is used t o approximate the objective function and the constraints inside the bounds. Then, using basic calculus, optimal values of the parameter a are obtained for the objective function and each one of the constraints. The optimum value of a that reduces the objective function as much as possible and creates a feasible points is
a* =
where a f minimizes the objective function, ai for i = 1,..., q, makes the violated
35
for j = 1,..., q, makes the active and
inactive constraints active the next iteration. Then, using the optimal parameter a* the design variables are updated. If the design point is infeasible, the process described above is repeated until a feasible point is obtained. Once a feasible design is obtained the algorithm proceeds as described in 2.2.
2.2.2
Implementation
The modified method of feasible directions described in the preceding two sections can be simplified using the following set of steps:
Step 1 Start k = 0 and xk = xo Step 2 Evaluate f (xk) and g(xk) Step 3 If g ( x k )5 0, continue. If not, xk is an infeasible design and the steps in section
2.2.1 must be followed until a feasible design is obtained.
Step 5 Evaluate gradient of objective function and active constraints Step 6 Determine search direction by solving the optimization problem in (2.10) Step 7 Identify the constraints in the set T = { g i : V T gid = 0 for i = 1,. . . , t ) .
Perform the appropriate one-dimensional search t o find a* depending on if set
T is empty or not.
Step 8 Update the design point,
Xk+1
= xk
+ a*dk
36
di
< 0.001
+ 1. Go t o step 2.
The main advantages of the modified method of feasible directions are: all the designs after a full cycle are feasible, gradient calculations are infrequent and the gradient calculations involve only active constraints. Its main disadvantages are:
infeasible designs occur during line search calculations and, the Newton's method used t o bring the design to the feasible region during a line search sometimes does not converge. Note that, if an efficient way t o compute the gradients exists, the aforementioned advantage of infrequent gradient calculation becomes a drawback.
2.3
Sequential Linear Programming is considered to be one of the simplest methods to implement; the only necessary requirement is an efficient linear programming solver. To solve the nonlinear programming problem in (2.6), a linear programming subproblem is created by linearizing the original objective function and constraints at each iteration. The L P problem is then solved using a linear programming method t o obtain an increment of the design variables that moves toward the optimal solution. Then, the design variables are updated. This process is repeated iteratively until the solution is found. To transform the nonlinear programming problem (2.6) into a L P problem a Taylor series expansion of the objective function and constraints is used. In the neighborhood of the design variables a t the Ic iteration, xk, the objective function and constraints
where
X~+I xk =
+ d and i = 1,.. . , q .
Using the linear approximation in (2.37), a linear programming problem can be formulated t o obtain a vector, d, that achieves a new design point, x ~ + Iwhich reduces ,
< the objective function f (xkS1) f (xk)and satisfies the constraints in (2.37b). Unfortunately, there is a problem, the error produced by using the approximation in (2.37) is proportional t o lld(I2. Therefore, the norm of d must be limited t o small values. Constraining the norm of d introduces second order equations t o the optimization problem. These new equations defeat the purpose of the linear approximation, since an LP subproblem cannot be created. Therefore, in order t o keep the optimization problem linear, instead of limiting the norm of the update vector, d , the components of the vector are limited. The constraints on the components of vector d are known as move limits. Their selection is critical, and will be discussed below. Finally, the LP subproblem a t iteration k can be formulated as Minimize
vT (xk)d f
+ vTgi(xk)d 0 I
Id u
d~ I d
where dL and dU are the vectors of lower and upper limits of the components of d . i.e. the move limits. Notice that the term f (xk)is omitted from the objective function because t o minimize f (x) is the same as minimize f (x) + K where K is a
38
constant because the constant does not depend on the design variables, and therefore it cannot be minimized. Once the problem is stated, it is necessary to obtain a method t o compute the move limits dL and du to be used in the LP problem. This is the most critical step of the SLP algorithm. A correct value for the move limits should be as large as possible, and, a t the same time, should limit the error of the approximations t o say, 1%. If the move limits chosen are too small, the algorithm will converge to the optimum slowly. On the other hand, if the move limits are too large, the algorithm may never converge. If correct move limits are chosen, sequential linear programming has proven to be a robust and efficient method for nonlinear optimization, [8]. Efficient ways t o determine move limits have been described in [52, 19, 53, 541. In [15] several of these methods are compared. In DOT, the move limits are computed using the technique in [52]. Therefore, this is the technique that will be discussed here. The approach in D O T is as follows [52, 471. At the first iteration, the move limits for the ith component are chosen as
where k is a user defined constant, in this work k = 0.05. Then, in the following iteration, if the maximum constraint violation increases, the move limits are reduced by 50% . This is done in order t o reduce the design space when the approximations yield infeasible results. However, this can result in premature convergence if the move limits are reduced too quickly. To correct for this problem, individual move limits are increased by 33% for all variables that reach its upper or lower bound in two consecutive iterations. The 33% is used based on the experience of the designers of
XL
are the upper and lower bounds for the design variables if they
2.3.1
Implementation
Step 5 Create the LP problem as described in (2.38) using information from steps 3
and 4
Step 6 Update the design point using (2.40) Step 7 Check for convergence. If
f(Xk+l)-f(Xk)
f(xk)
+ 1. Go t o STEP 2.
2.4
Sequential Quadratic Programming is considered t o be one of the most efficient methods for solving nonlinear constraint optimization problems. In order to implement this method, the main requirement is an efficient quadratic programming solver. To solve the nonlinear programming problem in (2.6), a quadratic programming subproblem is formulated using the KKT conditions of the original problem to obtain the direction that will lead the current design variables to the optimum. Then, a line search is performed in this direction in order to obtain the next design. The quadratic subproblem is then updated and the process is repeated until convergence is achieved.
41
The optimal solution of the optimization problem in (2.6) must satisfy the KKT conditions
gj(x*)5 0 for j = 1 , . . . , q
C p;vxgj(x*) = 0
j=1
' l
1 , . . . ,q
where
is the Lagrangian, V,L(x*, p*)is the gradient of the Lagrangian and {x*,p*) is the optimal design variable-multipliers pair. In a nonlinear problem and, even more so, when numerical methods are used to compute the objective function or constraints, the equations in the KKT conditions can be quite tedious t o obtain analytically. Furthermore, once obtained, it is difficult to solve the complex system of equations generated. Therefore, it is necessary t o approximate the K K T conditions using simpler equations and then solve the problem sequentially. Given a set of design variables and Lagrangian multipliers in the kth
pk),the goal is t o obtain an increment, iteration, {xk,
variables will satisfy the approximated KKT conditions a t point {xk a,, pk Sp). The approximate K K T conditions a t the kth iteration are obtained using a first order Taylor expansion of the equations in (2.41)
42
Sx E Rnxl,pk E
The approximation of the KKT conditions yields the new set of equations in (2.43). This new set of equations is equivalent to the KKT conditions of the Q P problem,
1 Minimize -S;H~S, 2
+ SFpr,
subject to: AkSx+ bk 5 0 which can be solved easily. In DOT, the Q P problem is solved using the MMFD. By solving the Q P problem in (2.44), the design variables increment S, is obtained. Notice that the new optimization problem minimizes a second order approximation of the Lagrangian of the original problem, and not just the objective function. Therefore, the design variable increment reduces the objective function and violated constraints, while at the same time obtaining the minimum Lagrangian possible. Two main problems arise from the above formulation: how t o compute the Hessian matrix and how t o check that the approximation of the KKT conditions holds. To compute the matrix Hk, second order derivatives of the objective function and constraints are necessary, and these computations are computationally expensive. Therefore, a method is necessary t o obtain an approximation of Hk that will converge t o the real Hessian matrix as the optimization problem evolves, and, that will
C H A P T E R 2. OPTIMIZATION THEORY
44
always be positive definite - in order to guarantee the existence of a solution for the optimization problem in (2.44). The method used t o obtain an approximation of the matrix Hk will be discussed later in this section. Assuming that a value for Hk exists, and that a solution of the problem in (2.44) has been obtained, it then becomes necessary to check the accuracy of the solution. If d, is large, then the approximation of the KKT conditions that led to the optimization problem in (2.44) may not be accurate. In order to test the accuracy of the approximation and to reduce the value of d, if necessary, a parameter a is used to control the dimensions of vector d,. Then, once the QP problem in (2.44) is solved, the vector of the design variables is updated using
Minimize f (xk
r.t. a
(2.46a)
where
( ~ k + l )= j
I ( ~ k + jl 1)
max(l(~k+l)jl,( ( r k ) j $
j = 1 .. . , q
+ I ( ~ k + i ) ~ lj ) = 1,. . . ,q
and (Pk+l)jare the Lagrangians from the approximated problem computed using
This problem is solved using the line search with a E [0, 1 and with an initial a of 1
45
one. Finally, once a has been found the Lagrange multipliers are also updated using
At the first iteration, the Hessian matrix of the Lagrangian, H k , is approximated by the identity matrix. In subsequent iterations, the approximation of the Hessian matrix of the Lagrangian denoted by Bk, is obtained using the BFGS formula 116, 13, 471, commonly used in quasi-Newton methods and written here for completeness without proof
Bk+1
=B k -
BkdkdTBk
d p k d k
+-rlkrl: d:rlk
There are other SQP methodologies available in the literature 1161. However, the SQP discussed here, and implemented in DOT, is one of the most popular versions of SQP. The DOT implementation has one main disadvantage with respect t o other SQP software; the Q P problem is solved using the MMFD, which is computationally inefficient compared t o the simplex method for Q P or interior-point methods. However, since the number of design variables in this thesis is quite small, this problem is minimal.
46
2.4.1
Implementation
The sequential quadratic programming method in DOT can be summarized in the following steps
Step 1 Set k = 0, x k = xo and Bk = I where I is the identity matrix Step 2 Evaluate f ( x k ) and g(xk) Step 3 Evaluate gradient of objective function and constraints Step 4 Solve the Q P problem in (2.44). Step 5 Compute the Lagrange multipliers using (2.47) and compute a by doing the
line search in (2.46)
Step 6 Update the design point and the Lagrange multipliers using (2.45) and (2.48)
respectively
Step 7 Update the Hessian matrix approximation, Bk,using (2.49) Step 8 Check for convergence. If
f(xk;;~~{(xk)
+ 1. Go t o STEP 2.
where, from an engineering perspective, x is the design parameters that can be changed in the design, f (x) is a measure of the performance of the design and gj(x) are a set of equations used t o guarantee that the design meets the necessary requirements. In aerodynamic shape optimization, the design variables, x, in the aforementioned problem are a set of parameters that represents the shape of the airfoil. The objective function, f (x), is a combination of aerodynamic characteristics. Finally, the constraints, gj (x), are aerodynamic and geometric constraints. An example of an
gj(x)
<0
where x represents an airfoil shape, q(x) and cd(x) are the lift and drag coefficient for the airfoil shape represented by x, c;l"s"ed is a minimum lift requirement and gj(x) are a set of linear geometric constraints t o constrain the shape of the airfoil. In this case, the objective function and the aerodynamic constraint, ( 3 . 2 ~ are obtained )~ numerically by solving a set of partial differential equations that model the flow around the airfoil. In particular, the Navier-Stokes equations and a transport equation t o model the turbulence are solved iteratively using a numerical method to obtain the value of c, (x) and cd(x). The evaluation of these two terms is the most time consuming part of the optimization process taking more than 95% of the computational time. To write and solve the problem in (3.2) it is necessary to: Develop a set of parameters, x, that represents the airfoil shape. Develop tools that, given a set of parameters, x, will compute the objective function and constraints. Namely, an analysis tool, and an algorithm t o transform the set of parameters into the input necessary for the analysis tool. Develop tools that, given design variables, x , objective function, f (x), and constraints, gj(x), will obtain a new shape closer t o the optimal. These tools were discussed in chapter 2.
49
Develop tools that, given a set of parameters, x , will compute the gradients of the objective function and constraints with respect to the parameters x. In this chapter, all the components listed above are discussed in detail. Section 3.1 focuses on the different methods used to represent the airfoil and, in particular, it focuses on the method finally chosen in this work. Section 3.2 describes the computational fluid dynamics solver used to compute the aerodynamic characteristics of the given shapes. CFD solvers need a discretization of the flow domain in order to obtain the characteristics of the airfoil. Such discretization is called the fluid mesh. In section 3.3, the method used to translate the set of parameters, x , that defines the airfoil into a fluid mesh is discussed. Section 3.4 describes the existing methods used to compute the gradients. The method chosen in this thesis t o obtain the gradients is contrasted with other methods. Finally, section 3.5 focuses on the implementation of aerodynamic shape optimization and the coupling of all different elements described in order to create an efficient and robust program for airfoil design.
3.1
Shape Representation
To formulate an aerodynamic shape optimization problem in the form of (3.1), a shape representation for the airfoil shape is necessary. This representation should be able to represent the airfoil with a small set of parameters, and it should also be able to represent a wide variety of shapes. The former property is necessary in order to reduce the computational time required to solve the optimization problem, and in order t o reduce the amount of time necessary to compute the gradient of objective function and constraints. The latter property is important in order to guarantee that the optimal shape is not restricted by limitations of shape representation capabilities. Additionally, the shape representation needs to be able to be converted into the
C H A P T E R 3. AERODYNAMIC OPTIMIZATION
necessary input for the analysis tools used to solve the analysis problem - in this case a CFD solver. Shape parametrization is an active area of research. In the literature, several methods have been suggested for representing an aerodynamic shape [33, 341. The main methods are Analytic Representation Partial Differential Equation Representation Discrete Representation Polynomial Representation Spline Representation CAD Representation In the analytic representation, given an original shape, a set of functions are used to deform the original shape. The parameters that determine the value of the functions are used as the design variables. Therefore, the design variables represent the deformations added to the original shape in order t o create the new shape. This method was used in [28] t o optimize the shape of several airfoils and wings. This method has the advantage of reducing the necessary number of design variables to a small set. It also gives the airfoil an smooth surface. On the other hand, it is only applicable t o simple geometries and the deformations are dependent on the shape functions used. The second method, the partial differential equation representation, generates the shape by solving a boundary-value problem of an elliptic partial differential equation.
51
This method has two main drawbacks: it is time consuming to implement and it is only applicable to simple geometries. The discrete representation method can only be used when using computational methods to solve the analysis problem. If a computational method is used, the boundary nodes of the fluid flow mesh a t the surface of the airfoil can be used as the design variables. This method is easy t o implement and can be used with any geometry. However, it requires a large number of design variables and the final shape can have high frequency oscillations. In [55, 561, this method is used with a smoothing function to prevent the high frequency oscillation of the shape. A polynomial can also be used t o represent the airfoil. In this method, the coefficients of a polynomial are used as the design variables. An example is the NACA representation for an airfoil. If the NACA representation is used, then the thickness, maximum camber and position of the maximum camber can be used as the design variables to define the airfoil. [57] describes the NACA representation. The main advantage in this method is that a small set of design variables can be used. The main disadvantage is that if a low order polynomial is used some shapes become impossible t o represent. A spline can also be used t o represent the airfoil. Spline representations use a sum of weighted polynomials t o represent the airfoil. In this case, the set of weighting parameters, called control points, are used as the design variables. There exist several types of splines: Bezier curves, B-splines and non-uniform rational B-spline (NURBS). The most complete spline representations are the NURBS which are able t o represent any shape using a small set of parameters, create a smooth shape and offer the possibility of modifying the shape locally. However, they are difficult to implement. B-splines are easier t o implement and they offer the same advantages as NURBS, except that they are unable to represent implicit conic sections; however,
52
these shapes are not common in airfoils. Finally, Bezier curves are the simplest spline t o implement. However, in order t o represent a complex geometry they require high order polynomials and they do not offer the same advantages as the other two groups. In this work, B-splines are used t o represent the shape of the airfoil. In particular, a uniform cubic B-spline is used [58]. There are several reasons for using a B-spline: it allows for a reduction in the number of design variables required because the control points of the B-spline can be used as the design variables; the perturbation of one control point has only local effects on the design shape; it results in a curve with C2 continuity, therefore it guarantees a shape that is most likely possible t o manufacture; it is easy t o implement; and, it generates a smooth airfoil without any high frequency oscillations. In the next subsection, the B-spline representation is described.
3.1.1
where X(E) and Y (ti) are single-value functions of the parameter ii. X(ii) and Y (ii) represent the Cartesian coordinates x and y of the points on the curve for any value of ii. In order t o be able t o represent complex curves, X(E) and Y(ii) are divided into several pieces, called segments. Each segment is characterized by a different polynomial representation. The different polynomials are then joined together t o create a piecewise polynomial curve. The values of ii where the segments are joined,
iii, are called knots. Therefore, t o represent a curve, a sequence of knots is created
and then, a t each segment between knots, a polynomial is used t o represent the curve. In a uniform cubic B-spline (B- stands for basis) the curve is created by a sum of
where Vi are the control points of the spline and Bi(ii) are the basis functions. The basis functions are defined as
where u =
-"-"iui+l -Ui
and ii E
(3.5) is obtained
by using a cubic polynomial to represent each segment, requiring that at the joined positions, first derivatives and second derivatives match and requiring that bi(0) +
bi+l (0)
+ biS2 (0) + bi+3 (0) = 1. Figure 3.1 shows the shape of the basis function. The
uniform knot sequence is a sequence of knots where all the knots are different and a certain distance apart. In this case, the knot sequence considered is iii+l = iii + 1. From (3.4) and (3.5), the coordinates of a point in the curve on an knot interval
iii
This equation is used t o compute any point in the curve. Then, in order to be able to
Basis Function
use equation (3.6)) four basis function segments must exist a t any location, including the initial and final curve interval. Therefore, the first curve segment must start a t
For example, figure 3.2 shows the four segments used t o create the initial segment of the spline curve as well as the control points numbering. From figure 3.2, it can be observed that the curve will start a t the second control point. However, it is sometimes desirable t o start the curve a t the initial control point. In this case, phantom vertices can be created t o generate a new initial or new final control point. Several methods can be used t o create phantom vertices [58]. In this thesis, the phantom vertices a t the beginning and a t the end are created using
Figure 3.2: Basis functions used t o create the initial segment of the curve Q ( G )
which guarantees that the curve starts and ends a t Vo and V, respectively. This is particularly useful in this case because the initial and final control points are the trailing edge of the airfoil, therefore the curve should start a t such points. Given the above discussion, the main properties of the uniform B-spline can be described as follows. Due t o (3.4) and also to the fact that the basis functions are zero everywhere but in the four segments around the control point, moving a control point only affects part of the curve. This gives local control over the B-spline curve generated. Moreover, due t o the requirements set t o create the composite polynomial in (3.5) the basis functions are C2 continuous and since the sum of C2 continuous function is also C2 continuous, any B-spline is C2 and therefore, smooth. To summarize, in this thesis, a uniform cubic B-spline with 15 control points is used t o represent the airfoil shapes. From the 15 control points, the y-coordinate of control points numbered 1-5 and 7-11 in figure 3.3 are used as design variables. The three control points aligned a t the x position, one a t the fixed point (0,O) and the
other two symmetrically distributed around (0,O) in the y direction are used to force the different airfoils t o have the same leading edge point. Then, a last design variable is introduced t o represent the distance between the two aforementioned points a t the leading edge. This is done in order t o control the radius of curvature of the leading edge. This B-spline representation can be used t o represent a great variety of existing and new airfoil shapes. Its adaptability makes it a good candidate for shape optimization, because it guarantees an almost free-form representation of the airfoil. For example, in figure 3.3 the B-spline is used t o represent the Eppler 66 airfoil [59]. It can be observed that the B-spline accurately represents the E66 airfoil.
3.2
Once an airfoil is obtained from the shape representation, the aerodynamic characteristics of this airfoil must be obtained by solving the fluid flow around the airfoil. In this case, the flow around the airfoil is assumed t o be steady, viscous and incompressible, and it is solved using a viscous Navier-Stokes CFD code. The CFD code used is the Structured PArallel Research Code (SPARC). SPARC has been developed by Magagnato 1391 a t the University of Karlsruhe, Germany, and the source code is available free of charge in exchange for further development and debugging. SPARC is implemented in Fortran90 and it is designed t o be used in distributed memory parallel architectures, such as a parallel cluster. The parallel capabilities are implemented using the message passing interface (MPI) programs. In this thesis, only small modifications have been made t o SPARC, the sole purpose being t o debug the code and t o ease the interactions between SPARC and the other programs used in the optimization process. SPARC is a very general code able t o solve a large variety of problems: steady and unsteady flows, laminar and turbulent flows, compressible and incompressible flows and, viscid and inviscid flows. Furthermore, it has a large number of turbulence models. Upon solution of the flow, SPARC returns lift, drag and pitch moment coefficients as well as the pressure and velocities of the flow field. Therefore, this code is an excellent choice for solving fluid flow problem because it is able t o output t o the optimization algorithm, the required aerodynamic characteristics and, enables the optimization code t o optimize airfoils for any flow regime. Furthermore, there is the possibility of comparing the behavior of several turbulence models. Finally, because the source code is available, the code may be modified t o include the computations of the analytic sensitivities of the design variables.
58
To obtain the flow field around the airfoil SPARC solves the compressible massweighted Reynolds Averaged Navier Stokes (RANS) equations [60, 391 8P -+dt d(m) dx d(P5) + -+ -dz- = 0 dy compressible continuity (3.9a)
;
D P - (Dt ~ >--
-p
) x momentum
y momentum
(3.9~)
z momentum
(3.9d)
where p is the density of the flow, El Z, E are the mean x, y and z velocities of the flow, ;iT is the mean pressure, and 1-11 is the laminar viscosity of the flow. To solve the above equations, the pressure is obtained by using the energy equation and the ideal gas law, [60]. The Reynolds stress terms
71. =
23
- p m f3 o r i = 1 , 2 , 3 and j = 1 , 2 , 3 2
(3.10)
are not solved and are modeled by the addition of an eddy viscosity term to the laminar viscosity. In the last equation, indexes i, j and k imply summation over all values of repeated subscript and ul, u2 and u3 are equivalent to u, v and w in equation (3.9). The eddy viscosity is obtained using the Spalart-Allmaras one equation turbulence model without the tripping term [61]. The Spalart-Allmaras
59
model in SPARC has been extensively tested at the University of Victoria to predict the lift and drag of a NACA0012 airfoil and it has yielded good results for steady and unsteady state simulations [62]. The main disadvantage of the Spalart-Allmaras model is that it is unable to properly predict laminar-to-turbulent transition because the tripping term in [61] is not implemented in SPARC. In the future, the SpalartAllmaras model in SPARC should be improved by introducing a tripping source term to force laminar-to-turbulent transition, as discussed in [61]. SPARC solves the partial differential equations in (3.9) by discretizing the equations using a finite volume formulation and central differences in space. To discretize the equations, SPARC uses a structured multiblock discretization of the fluid flow domain, commonly called fluid mesh. The multiblock mesh enables SPARC to divide the flow domain and use MPI to solve the governing equations using a distributed memory architecture. Once the equations have been discretized in space, a Runge-Kutta ordinary differential equation (ODE) solver is used to solve in time the discretized equations in space. If the flow is steady, a similar procedure is used to solve the equations in (3.9). However, the changes of the velocity and pressure in time are considered to be the residuals of the equations, and are reduced to zero at the steady state solution. Additionally to the ODE solver, SPARC uses a multigrid technique and local stepping to accelerate convergence to the steady state. Once the fluid flow around the airfoil has been solved the aerodynamic characteristics of the airfoil can be obtained. The aerodynamic characteristics obtained from SPARC are the lift, drag and pitch moment coefficients of the airfoil. These parameters are defined as
L ft i
Drag - Ua S 2p 2
1
Cd
C H A P T E R 3. AERODYNAMIC OPTIMIZATION
=
60 (3.13)
C ,
Pitch Moment 1 U 2s c 2p
where U , is a reference velocity, usually the freestream velocity of the flow, S is the wing area, p is the density of the fluid and c is the chord of the airfoil. The chord is defined as the distance between the leading and the trailing edge.
61
of the system of equilibrium equations for the springs is proportional t o the number of mesh points. This number is usually large - in our case more than 10,000 nodes. Algebraic methods employ algebraic equations t o redistribute the deformations of the airfoil over the mesh.
In this thesis, the deformation technique used is a combination of the springanalogy method and an algebraic method [42]. Since our problem is two-dimensional, and also for the sake of simplicity, the deformation methodology is discussed for a two-dimensional mesh only. The three-dimensional description of the algorithm can be found in [42]. In a two-dimensional structured multiblock mesh, each block is a quadrilateral element. To create the grid inside the block, the four block edges are divided into smaller segments with opposing edges having the same number of divisions. Then, the mesh inside the block is generated by creating lines connecting the edge nodes of opposing edges and using the points created from the intersection of these lines as the grid nodes. Figure 3.4 shows a multiblock structured grid. In the figure the thick solid lines represent block divisions while the thin lines are the lines connecting the points created by dividing the edges. Each point on the grid is characterized by a set of two indexes. In what follows, the indexes will be i and j , and are either local or global. Global indexes refer t o the indexes of the nodes that form the blocks. Local indexes refer t o the indexes contained inside a block. Given an initial two-dimensional structured multiblock mesh and a new airfoil shape, the deformation process can be broken down into the following steps: Find a set of parameters that relate the nodes of the mesh that belong t o the airfoil boundary t o the airfoil representation Parametrize all mesh nodes for each specific block
Compute deformations of the mesh points on the airfoil boundary Compute deformations of the corner blocks using the spring-analogy method Compute the deformations of edges and interior of each specific block independently using the computed corner block deformations and an algebraic model, in this case, transfinite interpolation (TFI)
Add the computed deformations t o the original mesh t o obtain the new mesh.
In this list, steps 1 and 2 are only carried out a t the beginning of the program. In step 1, the B-spline parametrization variable, E, associated with each one of the mesh points on the airfoil boundary is obtained. Since the control point positions of the B-spline defining the initial airfoil are known, and since the boundary nodes of the mesh are placed on this B-spline, the 2L value associated with each node is
63
obtained by generating points of the B-spline with different values for the ii variable until a B-spline point is found that matches the coordinates of the mesh point. This process is repeated for each mesh point. Finally, the ii values for each mesh point are recorded, so that the position of the boundary nodes of the mesh can be obtained from any new B-spline generated by the optimizer. Therefore, the ii values give the relation between the boundary mesh points and the airfoil shape, so that the fluid mesh can be deformed to adapt to any new airfoil shape possible. In step 2, the mesh points in each block are parametrized using the normalized arclengths according to the block local indexes i and j. As an example, the normalized arclength parameter of a line with varying i index and fixed j index would be obtained using
where i = 2,. . . , imax,si,j is the arclength of the grid point with indexes (i, j), imaxis the total number of grid points in the i direction and Mi is the normalized arclength of the grid point with indexes (i, j). The normalized arclength parameter in the j direction, Ni,j, is found using the same procedure. Using the design variables derived from the optimization process, a new B-spline parameter i is defined. Then, in step 3, using the B-spline parametrization and the ? associated to each grid point at the boundary, the new position of each boundary point is found. Once the grid points on the airfoil have been deformed, each one of the blocks that forms the grid is deformed in order to guarantee that the block size is not greatly reduced. This is done using the segment spring-analogy method described
64
in detail in [41]. However, here the method is only applied to the block corner nodes instead of all the nodes of the mesh. The corner points of all the blocks in the multiblock mesh are assumed to be connected t o their neighboring block corners by springs. The stiffness of the springs are inversely proportional to the original length of the connection edges. For example, the spring connecting corners with global indexes
(2,
j ) and (i
+ 1, j ) is defined as
where the indexes are global and p is a parameter that can be used to increase the stiffness of the springs. The higher the value of p, the stiffer the spring. In our case, p is set to 1. Once the stiffness of the springs have been calculated, the new position of the corner blocks is calculated by solving the static equilibrium equations of the spring system. At node (i,j ) the two-dimensional equilibrium equations are
where F i j is the vector of x and y forces on the (i,j ) node and deformations of the (i,j ) node.
The system of equations generated by the equilibrium equations of each corner block is solved iteratively. In this case, the system is solved using a predictor-corrector iterative process. The predictor step is computed using
ai,japproaches
the solution,
65
b i , approaches 6 i , since 6cj E 6:;'. Then, from equation (3.18) the corrector step
After several iterations the solution of the system is achieved. Note that by using the spring-analogy method only a t the corner of the blocks, instead of in all grid nodes, the system of equations t o solve is greatly reduced. Once the corner block deformations are obtained transfinite interpolation is used to interpolate the corner block deformations into the edges of the block that are not solid boundaries, and also into the interior of the block. The one-dimensional transfinite interpolation in an edge with free i index is
,i where i = 1 , . . . ,,,,
APimax,l the apriori computed deformations of the corner points and Mij is are
the normalized arclength of node (i,j) computed in step 2. The interpolation in the
j direction is similar.
Once the edges have been deformed, transfinite interpolation is used again to obtain the deformation of all the grid points in the interior of each block. The deformation of a node (i,j) inside a block is obtained using
i = I , . . . , i,,,, j = 1.
I , . . . ,j,,,,
Finally, once all the deformations have been computed, they are added t o the original grid and a new grid is obtained. Using this method t o deform the grid, only the movement of the corner block requires the use of information from all blocks. The rest of operations can be performed block by block, and therefore the grid deformation algorithm can be parallelized easily. Furthermore, because the spring-analogy method is only used for the corner block points, the system of equations t o be solved is relatively small. Finally, the original mesh is only perturbed, therefore it retains the structure of the initial grid. As an example, figure 3.5 shows a detail of the original and deformed airfoil mesh. It can be seen that the deformed grid retains the structure of the original grid even after a large deformation of the airfoil. The main disadvantage of this method is that some cells of the grid may sometimes overlap, i.e. negative block cells can occur. Negative cells are not allowed by the CFD solver, and will therefore cause the simulation t o stop. A case where negative cells may occur is when a block contains an edge at a solid wall. The edge a t the solid wall deforms with the wall. It can happen that the wall does
67
not deform a t the corner points of the block, but is greatly deformed in the middle of the block. Then, because only the information used t o obtain the deformations of the other edges of the block are from the corner nodes deformation, the other edges are not aware of the deformation of the solid wall and will not expand accordingly. This may result in overlapping edges and negative volume cells.
3.4
Sensitivity Analysis
Sensitivity analysis is concerned with obtaining the gradients or sensitivities of a certain output variable with respect t o an input variable. In the case of optimization, sensitivity analysis is used t o obtain the derivatives of objective function and constraints with respect t o the design variables. Sensitivity analysis for CFD is an active area of research. In the literature, several methods have been suggested t o compute the gradients of the aerodynamic characteristics with respect t o the design variables Finite-Difference Complex-Step Differentiation Automatic Differentiation Analytical Differentiation, i.e. the adjoint method In the following, each one of these methods is described in order t o show the rationale behind the decision t o use finite-differences t o compute the gradients in this thesis. Forward-difference uses a Taylor series expansion of a function around a point, xo, t o obtain an approximation of the gradient. Given the value of a multi-dimensional
Figure 3.5: Original (above) and deformed (below) mesh around an airfoil
69
function a t xo, f (xo), the value of the function in the neighborhood of xo can be expressed using its Taylor series expansion as
where 6 = xl
- xo.
Taking the first three terms of the Taylor expansion and using a
perturbation vector, Si E RnX1,with the ith component with a value 6 and all other components equal t o zero, an expression for the ith component of the gradient o f f (x) is obtained
then, rearranging the terms in 3.24, a first-order approximation of the ith component of the gradient can be obtained as
Equation (3.25) is known as the forward-difference equation t o compute the gradients. In a similar fashion t o the way the forward-difference equation has been obtained, other higher order approximations of the gradient can also be obtained. Forward difference needs n
function, with n number of independent variables. Forward difference is easy t o implement and is computationally more efficient than complex-step differentiation and automatic differentiation methods [45, 641. However, forward-difference is also the most inaccurate of all the methods described above. This is because the error is
70
proportional t o the step size. Therefore, t o reduce the error, the step size must be reduced. However, if the step size becomes too small, the two terms that are substracted on the numerator become very similar and a numerical error occurs when computing their difference. Therefore, it is necessary t o obtain a step size small enough t o reduce the error, but not so small that substractive errors occur. This is known as the step size dilemma. This problem is also encountered in higher order methods that use the Taylor series to approximate the gradients, e.g. the central-difference method [45, 641. Furthermore, for higher order methods more function evaluations are necessary t o compute the gradients. Complex-differentiation solves the step size dilemma encountered in the finitedifference methods by using a complex step t o compute the gradients. In this case, taking the first five terms of the Taylor expansion and using a perturbation vector,
Si E C n x l ,with the i t h component with a complex step value of iS and all other
components equal t o zero an expression for the function a t the point q written using a Taylor expansion as
+ Si can be
f (xo
and taking the imaginary part of equation (3.26) and rearranging, a value for the ith component of the gradient of the function f ( x )a t xo is obtained
In this case, there is no substractive term in the equation and therefore, the step size dilemma has disappeared. Furthermore, the approximation is second order instead of
+ S i ) = f (xo)+ iS =Iaxi
-x=xo
l 9 2! g 1
ax;
x=xo
--2s - 3 3 a 3 a x( :X ) ,~,, 1 1 f =
71
first order as in equation in (3.25). The number of function evaluations necessary to obtain the gradient is still n
the function. In order t o obtain the gradients using complex-step differentiation, the source code of the analysis program has to be changed so that all the real variables become complex variables. Some intrinsic functions such as max and min must also be redefined. If the designer is really familiar with the analysis code, the required changes t o the code can be accomplished in a small amount of time. It is important to notice that because all the variables are complex instead of real, the complexified code requires twice the time of the original code to solve the same problem . Automatic differentiation (AD) - also known as algorithmic differentiation or computational differentiation - is based on successive application of the chain rule t o each operation performed in the analysis computer code [46, 651. Since the structure of a computer code is basically composed of a successive set of arithmetic operations used to compute the value of a function, successive application of the chain rule to each one of the operations in the code will result in the exact (to machine precision) desired derivatives. For example, imagine the function f = xl
* sinx2 is to
be computed
using a computer code. Defining xl and x2 as the independent variables and f as the dependent variable, the value of the gradient of f with respect to the independent variables can be obtained adding the following equation in the code,
where
72
Using the same procedure in each line of the code, the gradient of all dependent variables with respect to the independent design variables can be obtained. In this case, the derivatives of intermediate variables with respect t o the independent variables propagate throughout the code until, finally, all derivatives of the dependent variables are computed. This type of automatic differentiation is known as the forward mode or tangent linear model. Using this method, the modified code uses approximately 2n times more memory and computational time as the original code where n is the number of independent variables. Notice that the computational time and memory of the modified code is independent of the number of function that the gradients need t o be obtained for, i.e. dependent variables. For example, t o compute the gradient of fl(xl) or t o compute the gradient of f,(xl) and f2(x1), automatic differentiation in forward mode will take the same time, 2 times more computational time than the original code. AD in forward mode is found t o be similar to complex differentiation, [66]. In contrast t o the forward mode of automatic differentiation, there is the reverse mode. In the reverse mode, the derivatives of the final result with respect to intermediate quantities - adjoint quantities - are propagated throughout the code. In order to do so, the flow of the program must be reversed and some variables need to be stored. Using this approach, the computational time is m, the number of dependent design variables, instead of the independent number of design variables, n. However, the memory requirements are larger than using forward mode and depend on the code. In order t o transform a code into a forward or reverse automatic differentiation code, there are several programs that, given a list of the dependent and independent variables, precompile the original code and transform it into a AD code. Some of the codes that can be used t o transform FORTRAN source codes t o AD codes are: ADIFOR, TAMC, DAFOR, GRESS, Odysee, PADRE2, ADOI, ADOL-F, IMAS, Tape-
73
nade and OPTIMASO. Some of these codes use forward mode, some reverse mode and some, such as ADIFOR, use a hybrid of the two in order t o take advantage of the reverse mode efficiency and the lower memory demands of the forward mode. AD is an active area of research and codes t o implement this technique are, a t this point, not very robust. In the CFD community, ADIFOR, TAF and Tapenade have been used in forward mode t o test their ability t o obtain sensitivities from simple two-dimensional CFD codes [64, 671 and ADIFOR has also been applied t o a three-dimensional CFD code [68, 691. However, t o the knowledge of the author, AD has not yet been used for aerodynamic shape optimization. Finally, analytical differentiation consists on deriving the analytical expressions for the sensitivities and introducing them t o the original analysis code. These methods are the most efficient and accurate, however, they are also the most difficult and time consuming t o implement because they require a complete knowledge of the original analysis code and the physics of the flow. There are basically two methods used t o compute the sensitivities analytically: direct methods and adjoint methods. In a CFD solver, the solution of the flow field is obtained when the governing equations of the flow are satisfied, that is when the residuals of the governing equations are equal t o zero. In mathematical form R ( x j , yk(xj)) = 0 for
= 1 , . . . ,n and k = 1,.. . , p
J'
where R(xj, yk(xj)) represents the residuals of the governing equations of the fluid flow, x j are the independent variables, i.e. the variables that represent the shape of the airfoil and, yk are the fluid flow variables which depend on xj. The sensitivities of a certain function, f (xj, yk(xj)), with respect t o the indepen-
where indexes j and k imply summation over all values of repeated subscript and j = l , . . . , n a n d k = 1 , . . . , p. 2.L and axj
6 2j
and
auk
$ can be
obtained by solving the system of equations in (3.33) for each independent variable yk. Then, once the vector
$ for j = 1 , . . . , n and k = 1 , . . . , p is obtained, it can be used in equation (3.31) to obtain $. The system of equations in equation (3.33)
governing equations of the flow. Therefore, obtaining the sensitivities of a function
to be solved for each yk contains the same number of equations as the system of
with respect t o n independent variables is computationally equivalent to solve n times the flow field. Therefore, the computational expense being similar to finite-differences in forward mode. However, it is necessary to obtain the vector
shape and it can be used to obtain the gradient of any function with respect to xj. Therefore, using this method, the necessary time to obtain the gradients of m function is n times the time to obtain the fluid flow solution, where n is the number of independent variables, i.e. design variables.
75
The method described above is the direct analytical method. In most cases in aerodynamics, there are more independent variables, i.e. the design variables in the optimization problem, than functions for which the gradients are necessary. To eliminate the dependence of the gradient computations on the number of independent variables, the adjoint method was created. Introduced in the CFD community by Jameson [55], the adjoint method differs from the direct method in that equations (3.31) and (3.32) are joined to obtain
: : where $ is free t o take any value because it is multiplying a zero term. $ is known
as the adjoint vector. Then, rewriting equation (3.33)
where
$ can easily be solved. In this case, t o obtain the gradient, the main concern
is t o obtain the adjoint vector. To obtain the adjoint vector, the system of equations in (3.36) needs t o be solved. The system of equations in (3.36) is independent of the independent variables and, therefore, it only needs to be solved once independently of the number of independent variables. Furthermore, the system of equations in (3.36) has the dimensions of the system formed by the governing equations of the flow field.
77
computationally expensive as complex-step differentiation. It also has higher memory requirements than the other methods, and it requires modifications of the existing analysis source code [64, 67, 68, 691. In the end, forward-differences was the method chosen to compute the gradient in this thesis. The main reasons for this choice were: faster computation of the gradients compared with complex-differentiation and forward AD, ease of parallelization and, ease of implementation. To reduce the inaccuracy of the gradients, a step size study will be performed to decide the most appropriate step size. Once the method to compute the gradients has been decided, a code is created to perturb each design variable of the airfoil with a small step. New meshes are created for each perturbed airfoil and the different aerodynamic characteristics are computed using SPARC for the new meshes. Finally, equation (3.25) is used to obtain the gradients of the aerodynamic characteristics with respect to the control points of the B-spline used as design variables. If the angle of attack or the Reynolds number are used as design variables, then the program perturbs such variables in SPARC and also computes the aerodynamic characteristics. For example, the gradient of the lift coefficient with respect to the ith design variable will be obtained as
where in this case x represents the original shape and original mesh and x o o
+ Si
represents the new shape when the ith design variable is perturbed. Since for each perturbed shape all aerodynamic characteristics are obtained, the gradient of lift, drag and pitch moment with respect to the n design variables are obtained after n + 1 analysis runs. Therefore, in this case, the computational cost is only proportional to the number of design variables.
78
It must be noted that the analysis runs needed t o compute the gradient are independent of each other and, therefore, they can be solved in parallel. In order to take advantage of this property and t o further reduce the computational time necessary t o compute the gradients, a scheduling program for the parallel cluster is used during the gradient calculations, namely Portable Batch System (PBS) [70]. Then, instead of solving the analysis runs one by one, all the analysis runs are sent t o PBS a t once and PBS allocates the necessary number of processors for each different analysis run until the parallel cluster does not have any more processors free. If all analysis runs are not able t o be executed a t the same time, they are saved in the PBS queue until more processors are free and then, the remaining analysis runs are executed in those new processors. By using PBS, the processors can be dynamically allocated and deallocated thereby taking full advantage of the cluster capabilities when computing the gradients. In this thesis, each analysis run uses 3 processors and the analysis program is executed in a 16 processors cluster. Therefore, 5 analysis runs can be executed a t the same time, reducing by 5 the amount of time necessary t o compute the gradients, even though the CPU time is not reduced. In summary, the gradients are computed following this procedure Step 1 Given an original shape and grid, set k = 0 Step 2 Submit analysis t o PBS and set k = Ic Step 3 If k
+1
2 1, add a
Step 4 Obtain the new airfoil shape Step 5 Deform the original mesh according t o the new airfoil shape Step 6 Submit analysis job t o PBS, set Ic = Ic
+1
79
Step 7 If all the geometric design variables have been perturbed continue, else go to
step 3
Step 8 Wait until all analysis submitted to PBS are done Step 9 Use
cl,
c and c, from all the different analysis and equation (3.25) to obtain d
gradients
3.5
Implementation
The different algorithms described above have been assembled to create a code for aerodynamic shape optimization of airfoils at any Reynolds number and angle of attack. Figure 3.6 shows a schematic of the implementation. The code can be simplified as follows:
Step 1 Create an airfoil using the B-spline generator of section 3.1 Step 2 Create a structured multiblock grid to solve the airfoil generated in step 1 Step 3 Compute objective function and constraint of the optimization problem using
the fluid flow solver in section 3.2
Step 5 Solve the optimization problem using DOT Step 6 If the optimization problem has converged STOP; if the optimization did not
converge yet CONTINUE
Step 7 Using the new design variables create new airfoil and mesh using sections 3.1
and 3.3 and go to step 3
80
Note that once the aerodynamic characteristics are obtained a subroutine must be created to used this information to obtain the desired objective function and constraints.
Initial Airfoil Flow Conditions
Deform Mesh
A
A l l Gradients?
Optimization
Figure 3.6: Flow chart of the aerodynamic shape optimization design tool
Chapter 4 Applications
Once the computational design tool described in the preceding chapter has been implemented in Fortrango, the design tool can then be used to aid in the design of airfoils for aircraft a t any Reynolds number. The only requirement is an initial airfoil shape and a fluid mesh that yields accurate results a t the Reynolds numbers being studied. In this chapter, the computational tool is used to solve several optimal design problems for application to the design of unmanned aerial vehicles (UAV)
[I, 51. Section 4.1 focuses on the testing and validation of a fluid mesh. This fluid
mesh will then be used for all the following study cases because the flow characteristics are similar for all the cases under consideration. Once a grid has been selected, the optimization process begin. However, because forward-differences are being used to compute the gradient, a parametric study of different step sizes is performed in section
4.2 in order to obtain the most accurate gradient possible. Furthermore, this data
could prove useful in the future to validate more advanced methods used to compute the gradients, such as automatic differentiation or the adjoint method. Finally, section
4.3 contains the first test case under study. In this case, a lift-constrained minimum
drag airfoil is obtained. This initial example is used t o validate the design tool's
CHAPTER 4. APPLICATIONS
82
ability t o obtain minimum drag airfoils, and t o study the performance of the different optimization algorithms. Finally, section 4.4 takes advantage of the full capability of the design tool t o obtain a set of optimal shapes for several different stages of flight of an airfoil morphing UAV.
4.1
Grid Study
Using the grid in [62] t o successfully predict the lift and the drag of a NACA0012 a t
Re = 3 x l o 6 as a base line, a fluid mesh was generated t o predict the lift and drag of
an airfoil a t the Reynolds numbers of interest in this thesis. In this case, the Reynolds numbers of interest are of the order of Re = 5 x lo5, smaller than the ones used in [62]. Since experimental data exists for an Eppler 64 airfoil a t Re = 2 x l o 5 [59], the grid studies are performed for the Eppler 64 a t the aforementioned Reynolds number so that numerical and experimental results can be compared. The grid obtained from this grid study will be used throughout the thesis and it is assumed t o be valid at
Re = 5 x lo5 as well as for other airfoils in the same flow regime, because the flow
characteristics are similar. The generated grid was refined 5 times in all directions and each refined grid was used t o solve the flow field. Tables 4.1 and 4.2 show the total lift, cl, total drag, cd, friction drag, cdf, and pressure drag, cd,, values for the Eppler 64 airfoil computed using the different grids a t an angle of attack of 0 and 4 degrees respectively. In the tables, grid 1 represents the coarsest grid and grid 5 represents the most refined grid. Comparing the lift and drag coefficient between the different grids gives an estimate of the grid resolution necessary t o obtain a grid independent solution. Looking a t the evolution of the lift coefficient in table 4.1, the lift coefficient is similar for grid levels 2 t o 5 with oscillations of less than 5% around the value of 0.5. The lift
CHAPTER 4. APPLICATIONS
83
Table 4.1: Lift and drag values for different Grid Cz 1 0.39400 2 0.48946 3 0.51137 4 0.50472 5 0.47964 Experiments, [59] 0.50
Table 4.2: Lift and drag values for different grid refinements a t Grid c z cd Cdf 1 0.76468 0.05826 0.00434 2 0.89256 0.03978 0.01335 3 0.92985 0.02408 0.01181 4 0.90990 0.01417 0.00558 5 div div div Experiments, [59] 0.925 0.01450
coefficient of 0.5 coincides with the experimental value for the lift coefficient and the lift coefficient at a 4 degrees angle of attack follows a similar pattern. Table 4.2 shows how grids 2, 3 and 4 have a lift coefficient around 0.91, a value close to the experimental value reported to be 0.925. The total drag coefficient evolution with respect to the grid refinement in tables
4.1 and 4.2 shows larger changes compared to the lift coefficient changes with different
grids. To study the drag, instead of focusing on the total drag, the pressure and the friction drag were studied independently, because SPARC computes the total drag using
cd = cdf
+ cdp
(4.1)
CHAPTER 4. APPLICATIONS
84
Looking at the evolution of the pressure drag, it can be observed that it decreases steadily from grid 1 to grid 5 with the largest changes occurring between the first three grids. After grid 3 the pressure drag still decreases, but by small amounts when compared with the initial changes. The friction drag evolution follows a similar pattern from grid 2 to grid 5; however, the changes between grids are more pronounced. The large change in the friction drag from grid 3 to grid 4 is produced by changes in the behavior of the boundary layer as the grid is refined, and also by changes in the characteristics of the laminar-to-turbulent transition as observed in the turbulent to laminar eddy viscosity ratio plot in figure 4.1. At the low Reynolds number under consideration, the laminar-to-turbulent transition happens around the middle of the airfoil [59]. This transition considerably affects the behavior of the boundary layer, and the lift and drag as discussed in [71, 721. Looking a t table 4.1, the large change in the friction drag value does not appear again when the grid is refined further, so it is assumed that the friction drag is also close to its converged value. For an angle of attack of 4 degrees, grid 5 is numerically unstable; therefore, results are not reported. The evolution of the total drag in tables 4.1 and 4.2 shows a strong dependence on the friction drag, which is difficult to predict. However, a t zero angle of attack, grids 4 and 5 yield similar results with less than a 20% change in total drag. Furthermore, the evolution of pressure and friction drag at a 4 degree angle of attack is similar. Therefore, it is assumed that grid 4 converged to a satisfactory result in predicting drag. Comparing the total drag with experimental data, it can be observed that, at a zero degree angle of attack, the total drag is under predicted by 24% using grid 4, while at a four degree angle of attack the total drag is under predicted by 4% using the same grid. Both these errors are considered to be small because of the difficulty of predicting friction drag. The discrepancy between experimental and numerical results
CHAPTER 4. APPLICATIONS
85
is probably due to an under resolved boundary layer and an inaccurate prediction of the laminar-to-turbulent transition. The results could be improved by introducing a tripping source term to the Spallart-Allmaras model in SPARC in order to accurately predict the correct laminar-to-turbulent transition, as discussed in [61]. In conclusion, since grid 4 yields good results for lift and drag predictions, and since a coarse grid is preferable due t o its lower computational cost, grid 4 is chosen to be the base grid for optimization. A study of the computational domain is not undertaken here because the domain size used is the same as the computational domain size used in [62] where it was already proven that the grid was domain independent. Grid 4 is shown in figure 4.2 and the detail of the grid around the airfoil and around the leading edge of the airfoil are shown in figures 4.3 and 4.4. Grid 4 has 36 blocks,
24,396 nodes, 157 nodes around the airfoil and the first node from the boundary of
the airfoil is a t a distance of 4 x which results in a y+ value of 0.5.
4.2
Once a grid is obtained for optimization, the optimization algorithm can already receive information of objective function and constraints. However, as discussed earlier, the optimization algorithm also needs information on the gradients of objective function and constraints. Such gradients are computed using forward differentiation. The value of the gradient of a function with respect t o its ith variable is obtained using forward differentiation as
CHAPTER 4. APPZICATIONS
EtmY
0.4 0.372143
(L3+U88
mwzn
a-
EDDY
0.4
0.372t43
0 -
mwzn
0.2m5rI 0260714 0232851 0605 a177143 0.149a88 a121423 0.-14 0.0657143 amm71 0.01
Figure dl: Turbulent to laminar eddy vbmiQ ratio cxmourplot dose t the Egpler o 64 airfoil at a 4 degree angle of attack for grids 3 (above) and grid 4 (below)
CHAPTER 4. APPLICATIONS
CHAPTER 4. APPLICATIONS
CHAPTER 4. APPLICATIONS
Figure 4.4: Detail of the grid around the leading edge of the Eppler 64 airfoil
CHAPTER 4. APPLICATIONS
90
where Siis the perturbation vector for the i variable and S the step size. This method to compute the gradients is subjected to the step size dilemma. To obtain the optimal step size for the gradient calculations, the lift and drag gradients for each design variable in the optimization problem are plotted versus step sizes from t o loF7 in figures 4.5 and 4.6. The figures show clearly the step size
dilemma. Up to a step size of low5or lop6, depending on the variable, the value of the gradients seem to converge t o a value for the gradient; then as the step size is reduced further, the value of the gradients start to change again. This is due to numerical errors in the subtraction and the fact that an iterative solver is used to solve the fluid flow. The converged solution of the CFD solver is only accurate to a certain value, in this case size is loy4, From figures 4.5 and 4.6 it appears that the most appropriate step or lop6 depending on the variable. In this case, a step size of
is chosen for all the variables as the step size for gradient calculations.
4.3
Drag Minimization
CHAPTER 4. APPLICATIONS
dc,/dx,
vs Step Size
dc&
M. Step Size
4 5 dcJdxdx,vs Step S m
-4.5 -5
- r : 4
-.
-6 2 3 4 5 dcddxlo vs Step Size 6 7
-5.5
Figure 4.5: Value of the drag coefficient gradient with respect t o the decimal logarithm of the step size used t o compute the gradient using forward differences
CHAPTER 4. APPLICATIONS
...TI~'ITI?il
dcL/dx, vs Step Slze dcL/dx, vs Step S ~ z e d c p , vs Step Size
28
275.
* -
55
-O
14
11 32 35
5 2
!
08 0 812 3
!
4
5 6
7
Figure 4.6: Value of the lift coefficient gradient with respect to the decimal logarithm of the step size used to compute the gradient using forward differences
CHAPTER 4. APPLICATIONS
93
coefficient minimization problem subject to a minimum lift coefficient requirement. The design problem is to obtain an airfoil with minimum drag and a minimum lift coefficient of 0.8, a t a Re = 500,000, and with a 2 degree angle of attack. Thickness constraints are imposed on the geometry of the airfoil and bounds are also imposed on the design variables. In particular, geometrical constraints are imposed to obtain a minimum thickness of 1% of the chord as described in table 4.3. The bounds of the design variables are presented in table 4.4, where the design variables are the
y coordinate of the control points of the B-spline that represents the airfoil, and
XLE
representing
the distance between leading edge points. Notice that the variables z5 and x7 have different bounds than the other variables. This is due t o the method used to deform the grid. If the same bounds are used, the mesh deformation algorithm creates a fluid mesh with negative cells, and the analysis program is unable to solve the flow around the airfoil.
XLE
Table 4.3: Geometric constraints of the design problem Constraint Value 1 X l - 211 0.01 2 2 2 - 210 0.01 3 2 3 - x9 0.01 4 2 4 - xg 0.01 5 xg - x7 0.01
To solve the design problem, an Eppler 66 airfoil is used as the initial airfoil for the optimization procedure. This airfoil was chosen because it is one of the airfoils recommended for the design of low Reynolds number aircraft [59]. Previous to the
CHAPTER 4. APPLICATIONS
94
23
x4
25
XLE
x7
x8
29
210
-0.2 0.2
-0.2 0.2
-0.2 0.2
-0.2 0.2
0.0 0.2
-0.2 0.2
-0.2 0.2
0.25 0.2-... .
:
. . . . . . I . . . . . . . . .:....................................... . ;.......
0 Control Points
Figure 4.7: B-spline representation of the Eppler 66 airfoil used at the initial airfoil for the optimization algorithm
optimization, the lift and drag coefficients for the intial airfoil were computed to be 0.864 and 1.009 x respectively. The lift and the drag were obtained using SPARC
with 3 processors on a 22 processor Linux cluster. The lift and drag coefficients were obtained after approximately 45 minutes of CPU time. During the optimization, the lift and drag coefficients are obtained to compute the objective function and aerodynamic constraint using the same grid and number of processors. However, the flow field is restarted from the last flow field solution, thereby enabling a reduction in the number of iterations prior to convergence. This results in a reduction of 15
CHAPTER 4. APPLICATIONS
minutes of CPU time. It can be observed from this discussion that most of the time during the optimization will be spent in the evaluation of the objective function and constraints. Starting with the Eppler 66 airfoil as the initial design, the design problem was solved using the three optimization algorithms described in chapter 2. The three optimization algorithms converged to a solution with similar aerodynamic characteristics as shown in table 4.5, with a discrepancy of less than 1%. The solution with the smallest drag is obtained using the modified method of feasible directions (MMFD), followed by the sequential linear programming (SLP) algorithm, and finally, the sequential quadratic programming (SQP) algorithm. All three methods obtain a similar airfoil shape as illustrated in figure 4.8 and, in table 4.7, where the value of all design variables at the optimal solution obtained with the different optimization algorithms are shown. The optimal solution obtained with all three methods satisfies all aerodynamic and geometric constraints as shown in tables 4.5 and 4.6. From table 4.5, it can be observed that the lift constraint is active, i.e. the lift coefficient is 0.8. This was expected, since it is well known in the aerodynamic community that lift and drag are opposing goals. From table 4.6, it can be observed that all geometric constraints are active or near active. Therefore, it can be concluded that in order to obtain an airfoil with minimum drag, the airfoil needs to be extremely thin. Note that, from a structural point of view, this presents a challange and could prove to be problematic. The three methods reduce the drag by almost 20% with respect to the original airfoil. This reduction in the total drag is achieved by a reduction of 7% in the friction drag and a reduction of approximately 32% in the pressure drag with respect to the original airfoil. To analyze how the optimization algorithms achieve these reductions, the pressure and friction coefficient are used. The pressure and friction coefficients
CHAPTER 4. APPLICATIONS
CHAPTER 4. APPLICATIONS
97
Table 4.5: Aerodynamic characteristics of the initial and optimal solution at Re = 500,000 and a = 2 Eppler 66 MMFD SLP SQP el 0.864278 0.799998 0.799934 0.800065 c d x lo2 1.008671 0.811443 0.812351 0.812701 c d f x lo2 0.509051 0.471875 0.474183 0.470825 c d P x lo2 0.499620 0.339568 0.338168 0.341876 98.59 98.47 98.45 LID 85.68
the optimal solution 4 5 -9.65003-02 -5.85003-02 -1.86263-09 -1.74263-02 -6.67013-06 -1.88153-02 -1.13173-04 -1.77133-02
where rw is the shear stress a t the surface of the airfoil. Pressure and friction coefficients over the initial and the final airfoil surfaces of the three optimization algorithms are plotted in figures 4.9 and 4.11. From the figures, it can be observed that the three optimal solutions have almost the same pressure and friction coefficient distributions over the airfoil surface. Figure 4.10 shows the pressure coefficient distribution in the flow field around both the initial airfoil and the airfoil obtained using the SQP method. From the figure, it can be observed how the maximum pressure at the leading edge is reduced.
CHAPTER 4. APPLICATIONS
design variables a t the optimal solution x2 23 x4 5.350003-02 9.250003-02 8.250003-02 3.339333-02 6.211683-02 5.302993-02 3.294923-02 6.427863-02 5.684183-02 3.069213-02 6.294163-02 5.430263-02 $5 XLE x7 x8 Eppler 66 4.600003-02 1.500003-02 -2.250003-02 -2.400003-02 MMFD 2.742603-02 5.302343-03 -4.526423-10 4.302993-02 0.00000 4.683523-02 SLP 2.881513-02 6.009703-03 SQP 2.771293-02 6.265303-03 -2.848683-13 4.418943-02 x9 x10 Xll Eppler 66 -3.500003-03 1.150003-02 7.450003-03 MMFD 5.211683-02 2.339343-02 3.233383-03 SLP 5.427633-02 2.295143-02 2.778023-03 5.294163-02 2.069213-02 3.774853-03 SQP
Table 4.7: Value of the x1 Eppler 66 1.725003-02 MMFD 1.323343-02 SLP 1.277803-02 SQP 1.377493-02
The reduction of the maximum pressure, together with a sharper leading edge, are the responsible for the reduction in pressure drag. Since the leading edge is sharper, the projection of the pressure in the x-direction which contributes to the pressure drag is reduced. In addition, the pressure a t the leading edge that contributes to the pressure drag is further reduced by the reduction of the maximum pressure. From figure 4.11, it can be seem that the friction drag is reduced in both upper (upper curve) and lower surfaces. The reduction in friction drag is due to: a smaller wetted surface of the airfoil, and a reduction in the pressure gradient in the x-direction. The new airfoil is thiner and therefore, has less area in contact with the fluid flow. The reduction of the pressure gradient in the x-direction observed in figure 4.9 produces a reduction of the adverse pressure which makes the laminar boundary layer more stable. A laminar boundary layer produces less friction drag. The optimization problem outlined above was solved using three different opti-
CHAPTER 4. APPLICATIONS
MMFD S LP SQP
Figure 4.9: Pressure coefficient distribution a t Re = 500,000 and a, = 2 over the surface of the Eppler 66 and optimal airfoils using MMFD, SLP and SQP
CHAPTER 4. APPLICATIONS
Figure 4.10: Contour plot of the pressure coefficient distribution at Re = 500,000 and a = 2 over the Eppler 66 airfoil (above) and the optimal SQP airtoil (below)
CHAPTER 4. APPLICATIONS
----.-.-.-..-..-..-
Figure 4.11: Friction coefficient distribution at Re = 500,000 and a, = 2 over the surface of the Eppler 66 and the optimal airfoils using MMFD, SLP and SQP
CHAPTER 4. APPLICATIONS
Figure 4.12: Contour plot of the velocity distribution at Re = 500,000 and over the Eppler 66 airfoil (above) and the optimal SQP airfoil (below)
a = !
CHAPTER 4. APPLICATIONS
103
mization algorithms in order to compare the computational efficiency of each one of these methods. The computational efficiency in this case is measured by the number of function evaluations, i.e. calls to the analysis program, that are necessary in order to achieve the optimum solution. A reduction in the number of calls to the analysis program is considered to be the best measure of efficiecy in this case because the analysis program used t o evaluate objective function and aerodynamic constraints is the most computationally expensive part of the process taking more thatn 95% of the total computational time. The SQP algorithm was shown to be the most efficient optimization algorithm due to the fact that it required the lowest number of function evaluations, as shown in table 4.8 and in the convergence plot in figure 4.13. The SQP method obtained the optimum airfoil shape using the least number of iterations, i.e. gradient evaluations, and without relying heavily on the line search - it required only 26 internal function evaluations. In this thesis, the term internal function evaluaions refers to the number of individual function evaluations performed during the optimization. This individual function evaluations are performed directly from the optimization algorithm and they can not be parallelized, therefore the optimization algorithm should reduce the number of internal function evaluations as much as possible.
Table 4.8: Number of function and gradient evaluations before optimum MMFD SLP SQP Iterations 26 17 10 Gradient evaluations 26 17 10 Individual function evaluations 231 25 26 Total function evaluations 543 229 146
The MMFD was executed for 26 iterations. It needed t o perform 26 gradient evaluations, and 231 internal or individual function evaluations during the line search.
CHAPTER 4. APPLICATIONS
104
The number of internal function evaluations considerably reduced the efficiency of the method, since these cannot be parallelized. The reason for the large number of internal function evaluations in each iteration is that the lift coefficient constraint must be satisfied a t each iteration. As described in section 2, the MMFD algorithm has to solve a Newton-Raphson problem in order to guarantee that the lift constraint is active in the next iteration. This results in a large number of internal function evaluations. The SLP algorithm converged to the solution after 17 iterations. It needed to perform 17 gradient evaluations and only 25 internal function evaluations. Therefore, in this case, the SLP method is less efficient than the SQP, but more efficient than the MMFD method. Even though the SLP is less efficient than the SQP method, it is important to note the small number of internal function evaluations required. The SLP method used 7 iterations more than the SQP method; however, the number of internal evaluations is 25, one internal function evaluation less than the SQP method. The reduction in the number of internal function evaluations is achieved by using moving limits instead of a line search. Taking into account that more efficient ways exist to compute the gradients of the objective function and constraints as discussed in section 3.4 and that function evaluations are always expensive, the SLP has to be considered as a good candidate for aerodynamic shape optimization. Through careful observation of the convergence history in figure 4.13, it can be noted that the SLP algorithm increases the objective function in the first iterations instead of decreasing it. Then, from iteration 9 to iteration 17 the algorithm starts to reduce the objective function until it reaches the optimum. The initial behavior is due to a poor selection of the move limits. Initially, the move limits chosen are too large to guarantee an accurate linear approximation of the objective function and constraints. However, as the algorithm evolves, the move limits are reduced
CHAPTER 4. APPLICATIONS
105
to the appropriate values. Therefore, even though the move limits techniques are responsible for a reduction in the number of internal function evaluations, it is also responsible for an increase in number of iterations required before the optimum is reached. Therefore, the SLP method could be improved by implementing an efficient method to obtain the initial move limits, for example the method discussed in [19]. The method in DOT used to reduce the move limits after the initial move limits are selected seems t o perform well in this problem. Once this technique is implemented, the SLP algorithm could be as efficient as the SQP algorithm. Furthermore, to reduce the number of function evaluations in the SQP algorithm, the line search could be substituted
Figure 4.13: Convergence history plot of the drag minimization problem solved using MMFD, SLP and SQP algorithms
In conclusion, in this case, the SQP method outperformed the SLP and MMFD methods in computational efficiency. Therefore, among the three existing method
CHAPTER 4. APPLICATIONS
106
the SQP method is the method recommended in this thesis. The SLP method is also considered a good candidate for shape optimization if an efficient method to compute the gradients exists. In case of using the SLP method, special care must be taken when selecting the initial move limits. Finally, the MMFD is not recommended, because even though it is capable of reaching the optimal solution, it requires a large amount of internal function evaluations which cannot be parallelized, and this makes the method highly computationally inefficient. The results obtained from this study are not conclusive7 given the small number of cases studied, however they are useful to highlights the main advantages and some improvements on the methods. To obtain more conclusive results, more cases should be studied: a case where the initial design is infeasible, cases with different objective function and constraints, etc. However, due to the computational expense of each one of the optimization methods, the SQP method took 3 days and the MMFD took 10 days using a 22 processor Linux cluster to obtain a solution, more studies were not undertaken. Finally, in order to test that the shape is a global optimum, a global optimization algorithm should be used to solve the problem, or the problem should be solved starting from different initial design.
4.4
Airfoil Morphing
To conclude the applications section of this thesis, the design tool is used to design a set of airfoils for an airfoil morphing UAV for surveillance applications. The UAV has the following characteristics: a takeoff weight of 400N, a chord length of 0.50m and a wing area of 1.4m2. This aircraft will morph its airfoil shape in order to increase its performance in each one of the different stages of flight. In general, the main requirements for a surveillance UAV are: a rapid deployment, fast cruise from the
CHAPTER 4. APPLICATIONS
107
deployment area to the surveillance area (and viceversa) and finally, low speed loiter in the surveillance area. The design program created in this thesis is used here to obtain the optimal airfoil shape at the two main stages of flight: loiter and cruise. The velocity of the UAV, the angle of attack of the airfoil, and the minimum lift coefficient a t each one of the stages of flight are shown in table 4.9.
Table 4.9: Characteristics and requirements at each stage of flight a C~ Velocity Air Density Re [mlsl [blm31 [-I ["I [-I Cruise 50.0 1.006 1,450,000 2 0.2272 Loiter 20.0 1.006 582,000 2 1.4201
For loiter and cruise flight, the airfoil shape is obtained by solving a minimum drag airfoil optimization problem subject to a minimum lift coefficient requirement. This method is used because minimizing the drag and keeping the lift equal to the weight of the aircraft will minimize the necessary thrust from the propulsive system. This will increase the range and efficiency of the airplane. To make lift equal to weight, a minimum lift requirement is used instead of an equality constraint to make lift equal to weight. This is because, in order t o obtain minimum drag, the final design will most probably be close to the lift constraint, since lift and drag are opposing goals. Additionally, the DOT package is design for inequality constraints and introducing equality constraints will reduce the computational efficiency of the optimization algorithms. To solve the two problems, the Eppler 66 airfoil is used as the initial airfoil. The solution of these two optimization problems is performed using the SQP method, since it was proven to be the most computationally efficient method in section 4.3. Tables 4.10 and 4.11 show the aerodynamic characteristics of the initial airfoil and the
CHAPTER 4. APPLICATIONS
108
Table 4.10: Aerodynamic Characteristics of the initial and optimal airfoils at cruise conditions, Re = 1,450,000 and a = 2 Eppler 66 (Cruise) Cruise el 0.89792 0.23154
Table 4.11: Aerodynamic characteristics of the initial and optimal airfoils at loiter conditions, Re = 582,000 and a = 2 Eppler 66 (Loiter) Loiter CI 0.87129 1.42011
optimal airfoils for cruise and loiter flight conditions. Table 4.13 shows the value of the design variables a t the beginning and at the optimal solution for both problems. In the first case, the design of the airfoil for cruise, the design tool obtained the optimal airfoil after 9 iterations: 9 gradient evaluations and 24 internal function evaluations, adding up to a total of 132 function evaluations. The design tool obtained an airfoil with a drag of 0.43632 x this is a reduction in drag of 57% with respect
to the initial design. The drag reduction is obtained mainly from a reduction of almost 80% in the pressure drag. The large reduction in pressure drag is obtained by reducing the pressure peak over the airfoil as can be seen in figure 4.15. The friction drag is also reduced as observed in figure 4.16, but by a smaller amount, because the shear stress at the airfoil boundary is more difficult to reduce. The shape of the airfoil is
CHAPTER 4. APPLICATIONS
109
plotted in figure 4.14. Comparing the original and final airfoil, it can be observed that the reduction in drag is obtained from: a reduction in camber, a reduction in the thickness of the airfoil and changes in the leading edge shape. By looking at the value of the geometric constraints a t the optimal solution in table 4.12, it can be observed that all the constraints are active except close to the leading edge. This proves that the optimization algorithm seeks a reduction in drag by reducing the thickness of the airfoil, except at the leading edge where the reduction of the pressure gradient is more important to guarantee that the boundary layer remains attached. In the second case under study, the design of the airfoil for loiter, the design tool obtained the optimal airfoil after 16 iterations: 16 function evaluations and 47 internal function evaluations, adding up to a total of 192 function evaluations. In this case, the number of iterations has increased from 9 in the last case to 16. This is due to starting the optimization with an infeasible initial design. At the end of the optimization, the airfoil satisfies all aerodynamic and geometric constraints as shown in tables 4.11 and 4.12, therefore proving that the design tool is able to solve the design problem starting from any design, feasible or infeasible. The optimal airfoil has the required lift coefficient of 1.42011 and a drag coefficient of 1.28366 x lop2. This represents an increase of 63% in the lift coefficient and an increase in drag of 33%. In this case, the drag is increased. This was necessary in order to guarantee the lift constraint, because lift and drag are opposing goals and the initial airfoil has a smaller lift than the minimum lift. However, the drag is increased by a relatively small amount while the lift is inceased by a substantial 63%. Looking at table 4.11, it can be observed that the increase in drag is mainly due to an increase in pressure drag. This increase in pressure drag is due to the change in geometry and an also to an increase in the pressure peak as shown in figure 4.17. On the other hand, the friction drag remains fairly constant and it is even slighly reduced respect to the
CHAPTER 4. APPLICATIONS
original airfoil, as shown in figure 4.18.
110
From the aforementioned results, several conclusions about the characteristics of the set of optimal airfoil for an airfoil morphing UAV and the mechanisms necessary to morph the airfoil for the morphing UAV can be reached. From figure 4.14 and table 4.12, it can be observed that cruise and loiter optimal airfoils share a common characteristic; they are both thin airfoils. In both cases, the thickness of the airfoil is close to the minimum thickness constrained. Only a t the leading edge, the airfoils have a larger thickness than the minimum thickness constraint. The main difference between the two airfoils is its camber. While, the cruise airfoil has an almost inexistent camber, the loiter airfoil has a maximum camber of around 10% of the chord. Therefore, the airfoil morphing UAV will have an extreamly thin airfoil - almost a plate - and two morphing mechanics. The first mechanism will be used to control the camber of the airfoil by deforming the airfoil as necessary. The second morphing mechanism will be used to control the thickness of the leading edge and it could be, for example, an inflatable system.
Table 4.12: Value of the geometric constraint a t the optimal solution Constraint 1 Eppler 66 2.50003-04 UAV Cruise -3.88833-08 UAV Loiter 0.0000 2 -3.20003-02 -1.54663-04 1.86273-09 3 -8.60003-02 -4.15253-04 1.86263-09 4 5 -9.65003-02 -5.85003-02 -3.11113-03 -9.92053-03 -1.42363-04 -3.76383-02
CHAPTER 4. APPLICATIONS
Figure 4.14: Shape of the initial design and the optimal cruise and loiter airfoils
CHAPTER 4. APPLICATIONS
Figure 4.15: Pressure coefficient over the initial and optimal UAV cruise airfoil surface at Re = 1,450,000 and a, = 2
CHAPTER 4. APPLICATIONS
----
Figure 4.16: Friction coefficient over the initial and optimal UAV cruise airfoil surface at Re = 1,450,000 and a = 2
CHAPTER 4. APPLICATIONS
Figure 4.17: Pressure coefficient over the initial and optimal UAV loiter airfoil surface a t Re = 582,000 and a! = 2
CHAPTER 4. APPLICATIONS
----
Figure 4.18: Friction coefficient over the initial and optimal UAV loiter airfoil surface at Re = 582,000 and a = 2
CHAPTER 4. APPLICATIONS
Table 4.13: Value of the x1 Eppler 66 1.725003-02 UAV Cruise 2.387093-03 UAV Loiter 2.654073-02
25
Eppler 66 -3.500003-03 1.150003-02 7.450003-03 UAV Cruise 9.647603-03 -4.825783-03 -7.612953-03 0.10499 5.298883-02 1.654073-02 UAV Loiter
118
and that the SQP algorithm is the most efficient method in reducing the number of iterations necessary t o solve aerodynamic shape optimization problems. The SLP is less efficient than SQP in reducing the number of iterations; however, it does not need to perform a line search a t each iteration thereby reducing the number of function evaluations necessary at each iteration. Finally, the modified method of feasible directions is not recommended, because it requires a large number of iterations and a large number of function evaluations a t each iteration to obtain the optimum. In the MMFD, the large number of function evaluations a t each iteration is due to the nature of the algorithm used, which requires that all active constraints in the current iteration remain active during the next iteration. Therefore, it is concluded that sequential quadratic programming algorithms are recommended for aerodynamic shape optimization. SLP algorithms could also be used, if an efficient method to obtain the gradients exist. The SLP algorithm could be improved by introducing an efficient methodology t o obtain the initial move limits, since inaccurate initial move limit were the cause of the computational inefficiency of this method. In the future, given that the sequential linear programming algorithm achieved the optimum without using a line search during the iteration, a sequential quadratic programming algorithm without line search should be implemented and its performance should be compared to the sequential quadratic programming algorithm with line search and the new SLP algorithm with a methodology to obtain accurate initial move limits. The design tool that has been developed has proven its efficiency in optimal airfoil design by obtaining large improvements in performance over initial airfoil shapes. However, the design tool is only able to optimize single element airfoil shapes, i.e. airfoils without flaps or slots. Furthermore, the computational efficiency of the design tool must be improved if more complex objects, such as wings, are to be optimized in a feasible amount of time. In the future, several improvements to the programs
119
should be undertaken to allow the developed design tool to be able to optimize: multiple element airfoils, wings and, full aircraft configurations. Some of the possible improvements t o each of the algorithms used in the developed tool will be outlined in the paragraphs that follow. A B-spline is used to represent the shape of the airfoil. The B-spline representation is used because it has the ability to represent a large variety of airfoils within a small set of parameters. However, the shape representation method must be reformulated if multiple element airfoils and three-dimensional bodies are t o be optimized. In future work, a CAD based parametrization technique should be used that will be able to link the CAD model of the wing or aircraft t o the design variables. The design tool is used for the design of UAVs which fly a t low Reynolds Numbers. At low Reynolds numbers, viscous effects contribute greatly to the performance of the airfoil, accounting for almost 50% of the drag. Therefore, a fully viscous NavierStokes solver was used in this thesis in order to solve the flow; in this case SPARC
[39]. At low Reynolds numbers, the boundary layer characteristics are affected by
the laminar-to-turbulent transition of the flow. A suitable turbulence model must be used t o account for this phenomenon. In the developed tool, a Spallart-Allmaras oneequation turbulence model is used to account for the turbulence of the flow. However, the laminar-to-turbulent transition is not properly predicted using this model. In the future, the Spallart-Allmaras model should be improved by adding a tripping term. Furthermore, the prediction of laminar-to-turbulent transition using other turbulence models should also be investigated. Further improvements of the analysis tool could include the implementation of a new fluid flow solver. The fluid flow solver currently used, SPARC, uses a structured multi-block mesh in order to solve the fluid flow. However, structured meshes are difficult to create when working with complex geometries. In the future, to solve the
121
takes into account not only aerodynamic considerations, but also those of structure, propulsion and control.
References
[I] Thomas J . Muller and James D. DeLaurier. Aerodynamics of small vehicles.
Annual Review in Fluid Mechanics, 35:89-111, 2003. [2] J . Reuther, J.J. Alonso, A. Jameson, M. Rimlinger, and D. Saunders. Constrained multipoint aerodynamic shape optimization using an adjoint formulation and parallel computers: Part i. Journal of Aicraft, 36(1):51-60, 1999. [3] J . Reuther, J.J. Alonso, A. Jameson, M. Rimlinger, and D. Saunders. Constrained multipoint aerodynamic shape optimization using an adjoint formulation and parallel computers: Part ii. Journal of Aicraft, 36(1):61-74, 1999. [4] M. Drela. Low-Reynolds number airfoil design for the MIT Daedalus prototype:
Materials Conference, Palm Springs, California, 19-22 April 2004. [6] Shawn E. Gano, Victor M. Pkrez, John E. Renaud, Stephen M. Batill, and Brain Sanders. Multilevel variable fidelity optimization of a morphing unmanned
REFERENCES
aerial vehicle. In 45th AIAA/ASME/ASCE/AHS/ASC
Dynamics and Materials Conference, Palm Springs, California, 19-22 April 2004. [7] T.H. Pulliam, M. Nemec, T. Holst, and D.W. Zingg. Comparison of evolutionary (genetic) algorithms and adjoint methods for multi-objective viscous airfoil optimizations. In 41st Aerospace Science Meeting and Exhibit, Reno, NV, 6-10 January 2003. [8] Schittowski K., Zillober C., and Zotemantel R. Numerical comparison of nonlinear programming algorithms for structural optimization. Structural Optimization, 7:l-28, 1994. [9] Thomas A. Zang and Lawrence L. Green. Multidisciplinary design and optimization techniques: Implications and opportunites for fluid dynamics research. In 30th AIAA Fluid Dynamics Conference, Norfolk, VA, June 28 - July 1 1999.
[lo] J.S. Arora. Introduction to Optimum Design. McGraw-Hill, 1989.
[ll]A. Antoniou and W.-S. Lu. Optimization: Methods, Algorithms, and Applica-
tions. Kluwer Academic, 2003. [12] P.E. Gill, W. Murray, and M.H. Wright. Practical Optimization. Academic Press, 1981. [13] G.N. Vanderplaats. Numerical Optimization Techniques for Engineering Design with Applications. McGraw-Hill, 1984. 1141 D.P. Bertseks. Constrained Optimization and Lagrange Multiplier Methods. Academic Press, 1982.
REFERENCES
124
[15] L. Lamberti and C. Pappalettere. Comparison of the numerical efficiency of different sequential linear programming based algorithms for structural optimization problems. Computers and Structures, 76(6):713-728, July 2000. [16] P.T. Boggs and J. W. Tolle. Sequential quadratic programming. Acta Numerica, 4:l-51, 1995. [17] G.G. Wang, Z. Dong, and P. Aitchison. Adaptive response surface method - a global optimization scheme for approximation-based design problems. Engineering Optimization, 33:707-733, 2001. [18] J.F. Rodriguez, J.E. Renaud, B.A. Wujek, and R.V. Tappeta. Trust region management is multidisciplinary design optimization. Journal of Computational and Applied Mathematics, 124:139-154, 2000. [19] T.-Y. Chen. Calculation of the move limits for the sequential linear programming method. International Journal for Numerical Methods in Engineering, 36:26612679, 1993. [20] F.Schoen. Stochastic techniques for global optimization: A survey on recent advances. Journal of Global Optimization, 1(3):207-228, 1991. [21] L. He and E. Polak. Multistart method with estimation scheme for global satisfying problems. Journal of Global Optimization, 3:139-156, 1993. [22] M. Dorigo, V. Maniezzo, and A. Colorni. The ant system: Optimization by colony of cooperating agents. IEEE Transactions on Systems, Man and Cybernetics, Part B, 1996. [23] R.P. Ge and Y.F. Qin. A class of filled functions for finding global minimizers of a function of several variables. Journal of Optmization Theory and Applications, 54(2):241-252, 1987.
REFERENCES
[24] E.R. Hansen. Global Optimization Using Interval Analysis. Dekker, 1992.
125
[25] D.E. Golberg. Genetic Algorithms in Search, Optimization, and Machine Learn-
+ Data
REFERENCES
[33] J.A. Samareh. A survey of shape parameterization techniques. In
CEAS/AIAA/ICASE/NASA Langley International Forum on Aeroelasticity and Structural Dynamics, pages 333-343, June 22-25 1999.
[34] J.A. Samareh. Status and future of geometry modelling and grid generation for design and optimization. AIAA Journal, 36(1):97-104, January-February 1999. 1351 M. Drela. Pros and cons of airfoil optimization. In D.A. Caughey and M.M. Hafez, editors, Frontiers of Computational Fluid Dynamics, pages 363-381. World Scientific, 1998. [36] Joseph Katz and Allen Plotkin. Low-Speed Aerodynamics: From Wing Theory
REFERENCES
127
[42] H. M. Tsai, A. S. F. Wong, J. Cai, Y. Zhu, and F. Liu. Unsteady flow calculations with a parallel multiblock moving mesh algorithm. AIAA Journal, 6(39):10211029, June 2001. [43] Marian Nemec.
REFERENCES
128
[52] H.L. Thomas, G.N. Vanderplaats, and Y-K Shyy. A study of move limit adjustment strategies in the approximation concepts approach t o structural synthesis. In Proceeding 4th AIAA/USAF/NASA/OAI Synopsium on Multidisciplinary
Analysis and Optimization, Holiday Inn, Cleveland, OH, September 21-23 1992.
[53] L. Lamberti and C. Pappalettere. Move limits definition in structural optimization with sequential linear programming. part i. 81(3):197-213, February 2003. [54] L. Lamberti and C. Pappalettere. Move limits definition in structural optimization with sequential linear programming. part ii. Computers and Structures, 81(3):214-238, February 2003. [55] Antony Jameson. Aerodynamic design via control theory. Journal of Scientific
Splines for use in Computer Graphics and Geometric Modeling. Morgan Kaufmann Publishers, Inc., Los Altos, California, 1987. [59] Richard Eppler. Airfoil Design and Data. Springer-Verlag, Berlin, 1990. 1601 H. K. Versteeg and W. Malalasekera. An Introduction to Computational Fluid
Dynamics. The Finite Element Volume Method. Longman Group Ltd., 1995.
REFERENCES
129
1611 P.R. Spalart and S.R. Allmaras. A one-equation turbulence model for aerodynamic flows. In 30th AIAA Aerospace Sciences Meeting & Exhibit, number AIAA Paper 92-0439, 1992. [62] Barton Thomas Stockdill. Turbulence modelling of unsteady separated flow over an airfoil. Master's thesis, Department of Mechanical Engineering, University of Victoria, Canada, 2003. [63] G. Pedro. Hydrodynamics and fluid-structure interactions in swimming propulsion. Master's thesis, University of Victoria, 2001. [64] W. Keyle Anderson, James C. Newman, David L. Whitfield, and Eric J. Nielsen. Sensitivity analysis for Navier-Stokes equations in unstructured meshes using complex variables. AIAA Journal, 39(1):56-63, January 2001. [65] Laura L. Sherman, Arthur C. Taylor 111, Larry L. Green, Perry A. Newman, Gene W. Hou, and Vamshi Mohan Korivi. First- and second-order aerodynamic sensitivity derivatives via automatic differentiation with incremental iterative methods. Journal of Computational Physics, 129:30-331, 1996. 1661 Joaquim R.R.A. Martins, Peter Sturdza, and Juan J. Alonso. The connection between the complex-step derivative approximation and algorithmic differentiation. In 39th Aerospace Sciences Meeting and Exhibit, Reno, NV, January 8-11 2001. [67] P. Cusdin and J.-D. Miiller. Automatic differentiation and sensitivity analysis methods for computational fluid dynamics. Technical report, School of Aeronautical Engineering. Queen's University, Belfast, May 2003. [68] C. Bischof, G. Corliss, L. Green, A. Griewank, K. Haigler, and P. Newman. Automatic differentiation of advanced C F D codes for multidisciplinary design.
REFERENCES
130
Computer Systems Engineering, 3(6):625-637, 1993. Presented at the Symposium on High-Performance Computing for Flight Vehicles, Arlington, Virginia, 7-9 December 1992. [69] Lawrence L. Green, Perrry A. Newman, and Kara J. Haigler. Sensitivity derivatives for advanced CFD algorithm and vicous modeling parameters via automatic differentiation. Journal of Computational Physics, (125):313-324, 1996. [70] Altair Grid Technologies, LLC. Portable Batch System User Guide, March 7 2003. [71] Mohamed Gad el Hak. Control of low-speed airfoil aerodynamics. AIAA Journal, 28(9):1537-1552, September 1990. [72] P.B.S. Lissaman. Low-Reynolds-number airfoils. Annual Review in Fluid Mechanics, 15:223-239, 1983. 1731 Emmanuel Laporte and Patric Le Tallec. Numerical Methods in Sensitivity Analysis and Shape Optimixation. Birkhauser, Boston, 2003.