FEATool Multiphysics
v1.17.2
Finite Element Analysis Toolbox
|
RUN_FEATOOL_BENCHMARKS Run FEATool benchmark scripts.
[ DATA, FEA ] = RUN_FEATOOL_BENCHMARKS( OPT ) Run FEATool benchmark scripts. Input is a struct OPT with the following fields
basename - benchmark case name solvers - cell array of solver name/descriptions grids - cell array of grid cell name/descriptions cases - cell array of benchmark case definitions (n_cases x 4) cases = { solver_type, grid_type, shape_functions, grid_levels; } fcn_fea - function handle for constructing fea data struct callable as fea = fcn_fea( grid_type, case, grid_level ) fcn_err - function handle for computing errors, err = fcn_err( fea ) fcn_proc - (optional) function handle to post-process data
The function can also be called with a file string to process previously saved benchmark data.
if( ischar(opt) && exist(opt)==2 ) load( opt ); l_process_data( opt, data, fea ); return end FEATOOL = 1; FENICS = 2; OPENFOAM = 3; SU2 = 4; % Required inputs. basename = opt.basename; solvers = opt.solvers; grids = opt.grids; cases = opt.cases; fcn_fea = opt.fcn_fea; fcn_err = opt.fcn_err; if( ~isfield(opt,'workdir') ) % Benchmark/output directory. opt.workdir = fullfile(pwd(),opt.basename); end rmkdir(opt.workdir); logdir = fullfile(tempdir(),opt.basename); % Logfile directory. rmkdir(logdir); logfile = [basename,'.log']; % Logfile name. logfullfile = fullfile(logdir,logfile); diary(fullfile(opt.workdir,[opt.basename,'.txt'])) fprintf( 'START: %s %s\n\nSystem Info:\n\n', opt.workdir, datestr(now()) ) cleanupObj1 = onCleanup(@()cleanup(logdir)); cleanupObj2 = onCleanup(@()diary('off')); try [~,~,sys,os,cpu,ml] = sysinfo(); fprintf( ' %s\n', [sys,' ',cpu], os, ml ); catch,end % Run benchmarks. data = {}; for i_case=1:size(cases,1) case_i = cases(i_case,:); i_solver = case_i{1}; i_grid = case_i{2}; sfun_i = case_i{3}; for j=1:length(sfun_i) ipos_ = max([1, find( sfun_i{j} == '_', 1, 'last' ) + 1]); sfun_i{j} = strrep( sfun_i{j}(ipos_:end), 'disc0', 'P0' ); sfun_i{j} = strrep( sfun_i{j}, 'disc1', 'P-1' ); end s_case = [solvers{i_solver},'-',grids{i_grid},'-',strcat(sfun_i{:})]; solver_args = {}; if( length(case_i)>=5 ) solver_args = case_i{5}; end data_i = []; for i_lev=case_i{4} fea = fcn_fea( i_grid, case_i{3}, i_lev ); fprintf( '\n%s - Level %i\n\n', s_case, i_lev ); % Parse and solve problem. fid = []; try switch( i_solver ) case {FEATOOL} fid = fopen( logfullfile, 'W+' ); fea.sol.u = solvestat( fea, 'fid', fid, 'nsolve', 1, 'tolchg', 1e-4, 'relchg', 0, 'maxnit', 50, solver_args{:} ); case {FENICS} % Use external FEniCS solver. fea = fenics( fea, 'fdir', logdir, 'fname', opt.basename, 'clean', false, 'maxnit', 50, solver_args{:} ); case {OPENFOAM} % Use external OpenFOAM CFD solver. fea.sol.u = openfoam( fea, 'casedir', logdir, 'logfname', logfile, 'clean', false, ... 'interp', 2*(~strcmp(fea.sfun{1},'sf_disc0')), ... 'upwind', 0, 'tolres', 1e-6, 'endTime', 2000, 'writePrecision', 16, solver_args{:} ); case {SU2} % Use external SU2 CFD solver. fea.sol.u = su2( fea, 'workdir', logdir, 'logfname', logfile, 'clean', false, solver_args{:} ); end [t_sol,it] = l_parse_logfile( i_solver, logfullfile, fid ); % Error checking. err = fcn_err( fea ) catch me warning(me.message) t_sol = nan; it = nan; err = nan; end nel = size(fea.grid.c,2); nvt = size(fea.grid.p,2); if( i_solver==OPENFOAM && strcmp(sfun_i{1},'P0') ) ndof = length(fea.dvar)*nel; % If OpenFOAM uses cell centered dofs. else ndof = sum(fea.eqn.ndof); end data_i = [ data_i; [ i_lev, nel, nvt, ndof, t_sol, it, err ] ]; cleanup( logfile ) end data = [ data; { s_case, data_i } ]; savefile = fullfile(opt.workdir,opt.basename); save( savefile, 'fea', 'data', 'opt' ); end fprintf( '\nEND: %s %s\n\n', opt.workdir, datestr(now()) ) % Data processing. l_process_data( opt, data, fea ); %