This repository is a collection of Matlab codes intended to demonstrate the deployment of the expected uncertainty reduction (EUR) method for kriging-based reliability analysis proposed by Li, M, et al. (2021).
Several acquisition functions have been proposed for kriging-based reliability analysis. Each of these acquisition functions can be used to identify an optimal sequence of samples to be included in the kriging model. However, no single acquisition function provides better performance over the others in all cases. Further, the best-performing acquisition function can change at different iterations over the sequential sampling process. To address this problem, we proposed a new acquisition function, namely EUR, that serves as a meta-criterion to select the best sample from a set of optimal samples, each identified from a large number of candidate samples according to the criterion of an acquisition function.
EUR does not rely on the local utility measure derived based on the kriging posterior of a performance function as most existing acquisition functions do. Instead, EUR directly quantifies the expected reduction of the uncertainty in the prediction of limit-state function by adding an optimal sample. The uncertainty reduction is quantified by sampling over the kriging posterior. In the proposed EUR-based sequential sampling process, a portfolio that consists of four acquisition functions, i.e., expected feasibility function (EFF), maximum confidence enhancement (MCE), expected risk function (ERF), and sequential exploration-exploitation with dynamic trade-off (SEEDT), is first employed to suggest four optimal samples at each iteration of sequential sampling. Each of these samples is optimal with respect to the selection criterion of the corresponding acquisition function. Then, EUR is employed as the meta-criterion to identify the best sample among those optimal samples.
The first case study has a highly nonlinear performance function, which consists of a polynomial part, a trigonometric part, and a constant. The performance function is defined as:
where the coefficient is used to adjust the nonlinearity of . The two input random variables and are considered to be independent from each other, both of which follow the normal distribution ().
The main function to implement this case study is 'main_Example1.m', while the coefficient a can be set for the performance function in 'bmfun2D.m'.
function response= bmfun2D(x)
a=7; %Set parameter a here
response=((x(1).^2+4).*(x(2)-1))/20-cos(a*x(1)/2)-1.5;
After implementing the main function, the reliability estimation results can be generated with the 'rel' function.
% %% Results
[rel_true rel_EUR ErrorEUR]=rel(modelEUR,obj_fct );
[rel_true rel_MEU ErrorMEU]=rel(modelMEU,obj_fct );
[rel_true rel_MCE ErrorMCE]=rel(modelMCE,obj_fct );
[rel_true rel_EFF ErrorEFF]=rel(modelEFF,obj_fct );
[rel_true rel_ERF ErrorERF]=rel(modelERF,obj_fct );
The second case study considers a two-degree-of-freedom primary-secondary system with uncertain damped oscillators in the presence of white noise. The performance function of this system is mathematically expressed as:
where
The reliability level of the system varies depending on the load . The statistical information of the random vaiables in this case study can be found in Table 4 of Li, M, et al. (2021).
The main function to implement this case study is 'main_Example2.m', while can be set for the performance function in the main function.
%% Design variables definition
ns = 100000; % number of candidate points
n_MCS = 1000000; % number of MCS points for reliability analysis
model.variables.ns=ns;
model.variables.n_MCS=n_MCS;
Fs=15; % Set Fs here.
After implementing the main function, the reliability estimation results can be generated with the 'rel' function.
% %% Results
[rel_true rel_EUR ErrorEUR]=rel(modelEUR,obj_fct );
[rel_true rel_MEU ErrorMEU]=rel(modelMEU,obj_fct );
[rel_true rel_MCE ErrorMCE]=rel(modelMCE,obj_fct );
[rel_true rel_EFF ErrorEFF]=rel(modelEFF,obj_fct );
[rel_true rel_ERF ErrorERF]=rel(modelERF,obj_fct );
Contributions are welcome! For bug reports or requests please submit an issue.
Feel free to contact me to discuss any issues, questions or comments.
- GitHub: mengli-2020
- Contact: Meng Li, Chao Hu
- Email: [lm881020@gmail.com], [chaohu@iastate.edu]
@misc{mengli-2020,
title={Mixture Density Networks (MDN) for distribution and uncertainty estimation},
url={https://github.com/lmhit2019/Expected-Uncertainty-Reduction-for-Kriging-based-Reliability-Analysis/},
note={Matlab codes intended to demonstrate the deployment of the expected uncertainty reduction (EUR) method for kriging-based reliability analysis.},
author={Meng Li},
year={2021}
}
The content developed by Meng Li is distributed under the following license:
Copyright 2021 Meng Li
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.