Surrogate model based design optimization Aerospace design is synonymous with the use of long running and computationally intensive simulations, which are employed in the search for optimal designs in the presence of multiple, competing objectives and constraints. The difficulty of this search is often exacerbated by numerical `noise' and inaccuracies in simulation data and the frailties of complex simulations, that is they often fail to return a result. Surrogate-based optimization methods can be employed to solve, mitigate, or circumvent problems associated with such searches. Please use the dd month yyyy format for the date for example 11 January 2008. The main title can be one or two lines long. Alex Forrester, Rolls-Royce UTC for Computational Engineering Bern, 22nd November 2010
Coming up before the break: Surrogate model based optimization – the basic idea Kriging – an intuitive perspective Alternatives to Kriging Optimization using surrogates Constraints Missing data Parallel function evaluations Problems with Kriging error based methods
Surrogate model based optimization SAMPLING PLAN OBSERVATIONS CONSTRUCT SURROGATE(S) design sensitivities available? multi-fidelity data? SEARCH INFILL CRITERION (optimization using the surrogate(s)) constraints present? noise in data? multiple design objectives? ADD NEW DESIGN(S) PRELIMINARY EXPERIMENTS Surrogate used to expedite search for global optimum Global accuracy of surrogate not a priority
Kriging (with a little help from Donald Jones)
Intuition is Important! People are reluctant to use a tool they can’t understand Recall how basic probability was motivated by various games of chance involving dice, balls, and cards? In the same way, we can also make kriging intuitive. Therefore, we will now describe The Kriging Game
Game Equipment: 16 function cards (A1, A2,…, D4) A B C D 1 2 3 4
Rules of the Kriging Game Dealer shuffles cards and draws one at random. He does not show it. Player gets to ask the value at either x=1, x=2, x=3, or x=4 Based on the answer, the Player must guess the values of the function at all of x=1, x=2, x=3, and x=4 Dealer reveals the card. Player’s score is the sum of squared differences between the guesses and actual values (lower is better) The Player and Dealer switch roles and repeat. After 100 times, the person with the lowest score wins. What’s the best strategy?
Example: Ask value at x=2 and answer is y=1 A B C D 1 2 3 4
The value at x=2 rules out all but 4 functions: C1, A2, A3, B3 At any value other than x=2, we aren’t sure what is the value of the function. But we know the possible values. What guess will minimize our squared error?
Yes, it’s the mean — But why?
The best predictor is the mean Our best predictor is the mean of the functions that match the sampled values. Using the range or standard deviations of the values, we could also give a confidence interval for our prediction.
Why could we predict with a confidence interval? We had a set of possible functions and a probability distribution over them—in this case, all equally likely Given the data on the sampled points, we could subset out those functions that match, that is, we could “condition on the sampled data” To do this for more than a finite set of functions, we need a way to describe a “probability distribution over an infinite set of possible functions” — a stochastic process Each element of this infinite set of functions would be a “random function” But how do we describe and/or generate a random function?
How about a purely random function? Here we have x values 0, 0.01, 0.02, …., 0.99, 1.00. At each of these we have generated a random number. Clearly this is not the kind of function we want.
What’s wrong with a purely random function? No continuity! Values at y(x) and y(x+d) for small d can be very different. Root cause: the values at these points are independent. To fix this, we must assume the values are correlated, and that C(d) = Correlation( y(x+d), y(x) ) 1 as d0 Where the correlation is over all possible random functions. OK. Great. I need a correlation function C(d) with C(0)=1. But how do I use such a correlation function to generate a continuous random function?
Making a random function
The correlation function
We are ready! Assuming we have estimates of the correlation parameters (more on this later), we have a way of generate a set of functions — the equivalent of the cards in the Kriging Game. Using statistical methods involving “conditional probability,” we can condition on the data to get an (infinite) set of random functions that agree with the data.
Random Functions Conditioned on Sampled Points
Random Functions Conditioned on Sampled Points
The Predictor and Confidence Intervals
What it looks like in practice: Sample the function to be predicted at a set of points i.e. run your experiments/simulations
20 Gaussian “bumps” with appropriate widths (chosen to maximize likelihood of data) centred around sample points
Multiply by weightings (again chosen to maximize likelihood of data)
Add together, with mean term, to predict function Kriging prediction True function
Alternatives to Kriging
Moving least squares ✓ Quick ✓ Nice regularization parameter ✗ No useful confidence intervals ✗ How to choose polynomial & decay function?
Support vector regression ✓ Quick predictions in large design spaces ✗ Slow training (extra quadratic programming problem) ✓ Good noise filtering Lovely maths!
Multiple surrogates Surrogate built using a “committee machine” (also called “ensembles”) ✓ Hope to choose best model from a committee or combine a number of methods ✗ Often not mathematically rigorous and difficult to get confidence intervals Blind Kriging is, perhaps a good compromise ν selected by some data analytic procedure
Blind Kriging (mean function selected using Bayesian forward selection)
RMSE ~50% better than ordinary Kriging in this example
Optimization Using Surrogates
Polynomial regression based search (as Devil’s advocate) Use divider pages to break up your presentation into logical sections and to provide a visual break for the viewer. The title can be one or two lines long.
Gaussian process prediction based optimization
Gaussian process prediction based optimization (as Devil’s advocate)
But, we have error estimates with Gaussian processes
Error estimates used to construct improvement criteria Probability of improvement Expected improvement
Probability of improvement Probability there will be any improvement, at all Can be extended to constrained and multi- objective problems
Expected improvement Useful metric that balances prediction & uncertainty Can be extended to constrained and multi- objective problems
Constrained EI
Probability of constraint satisfaction is just like the probability of improvement Constraint function Prediction of constraint function Constraint limit Probability of satisfaction
Constrained expected improvement Simply multiply by probability of constraint satisfaction:
A 2D example
Missing Data
What if design evaluations fail? No infill point augmented to the surrogate model is unchanged optimization stalls Need to add some information or perturb the model add random point? impute a value based on the prediction at the failed point, so EI goes to zero here? use a penalized imputation (prediction + error estimate)?
Aerofoil design problem 2 shape functions (f1,f2) altered Potential flow solver (VGK) has ~35% failure rate 20 point optimal Latin hypercube max{E[I(x)]} updates until within one drag count of optimum
Results
A typical penalized imputation based optimization
Four variable problem f1,f2,f3,f4 varied 82% failure rate
A typical four variable penalized imputation based optimization Legend as for two variable Red crosses indicate imputed update points. Regions of infeasible geometries are shown as dark blue. Blank regions represent flow solver failure
Parallel Function Evaluations
Simple parallelization of maximizing EI Find maximum EI Assume function value here is not so good and impute a penalised value (we use prediction + predicted error) Rebuild and re-search EI Repeat 1-3 for number of processors before evaluating infill points
Problems With EI et al.
Two-stage approaches rely on parameter estimation Choose correlation parameters by maximizing likelihood Then maximize expected improvement
What if parameters are estimated poorly? Error estimates are wrong Usually under- estimates Search may dwell in local basins of attraction
Different parameter values have a big effect on expected improvement
Tea Break!