1function options = SolverOptions(solverName)
2% SOLVEROPTIONS Create solver configuration options structure
4% @brief Creates a configuration structure with solver-specific
default options
5% @param solverName Optional solver name
for specific configurations (
default:
'Solver')
6% @return options Struct containing solver configuration parameters
8% SolverOptions generates a standardized options structure for configuring
9% LINE solvers. It provides default values for common parameters like
10% convergence tolerances, iteration limits, ODE solvers, and solver-specific
11% settings. The function customizes defaults based on the solver type.
13% Common options include:
14% - Convergence parameters (tol, iter_tol, iter_max)
15% - Analysis parameters (samples, seed, cutoff)
16% - Language selection (MATLAB vs Java)
17% - ODE solver configuration for fluid methods
18% - Verbosity and caching controls
19% - Solver-specific configuration overrides
21% Solver-specific customizations are available for:
22% - CTMC: State space generation and transient analysis
23% - Fluid: ODE solver selection and timespan
24% - JMT: Simulation parameters and confidence intervals
25% - MVA: Method selection and approximation settings
26% - SSA: Sampling and parallel execution options
30% opts = SolverOptions(
'MVA'); % MVA-specific defaults
31% opts.method =
'exact'; % Override method
32% opts.iter_tol = 1e-6; % Tighter tolerance
33% solver = SolverMVA(model, opts); % Use custom options
37 solverName =
'Solver'; % global options unless overridden by a solver
40%% Solver
default options
44options.config =
struct(); % solver specific options
45options.config.highvar =
'default';
46options.config.multiserver =
'default';
47options.config.np_priority =
'default';
48options.config.fork_join =
'default';
49options.config.nonmkv =
'bernstein'; % Method
for non-Markovian distribution conversion: 'none', 'bernstein'
50options.config.nonmkvorder = 20; % Order (number of phases)
for non-Markovian distribution approximation
52if ~isempty(LINEDefaultLang)
53 options.lang = LINEDefaultLang;
55 options.lang =
'matlab';
59options.iter_max = 1000;
60options.iter_tol = 1e-4; % convergence tolerance to stop iterations
61options.tol = 1e-4; % tolerance
for all other uses
63options.method =
'default';
64%options.remote =
false;
65%options.remote_endpoint =
'127.0.0.1';
68odesfun.fastOdeSolver = @ode23;
69%odesfun.fastOdeSolver = @lsoda_fast;
70odesfun.accurateOdeSolver = @ode113;
71%odesfun.accurateOdeSolver = @lsoda_accurate;
72odesfun.fastStiffOdeSolver = @ode23s;
73%odesfun.fastStiffOdeSolver = @lsoda_fast_stiff;
74odesfun.accurateStiffOdeSolver = @ode15s;
75%odesfun.accurateStiffOdeSolver = @lsoda_accurate_stiff;
76options.odesolvers = odesfun;
78% options.samples - Simulation length (solver-dependent semantics):
79% JMT: Samples per metric for confidence interval estimation (min 5000, default 10000)
80% LDES: Service completion events to simulate (default 200000)
81% SSA: RNG operations in Gillespie algorithm (~2 per event) (default 10000)
82% NC: Monte Carlo samples for normalization constant (default 100000)
83% Analytical solvers (MVA, MAM, CTMC, Fluid): Not used
85options.seed = randi([1,1e6]);
87options.confint =
false; % confidence interval:
false,
true (95%), or level (0.0-1.0)
88options.timespan = [Inf,Inf];
90options.verbose = VerboseLevel.STD;
92options.config.num_cdf_pts = 200;
94%% Solver-specific defaults
97 options.cutoff = 10; % finite per-class state-space cutoff for open/mixed models (matches native/JAR)
98 options.timespan = [Inf,Inf];
99 options.timestep = []; % timestep
for fixed time steps in transient analysis
100 options.config.hide_immediate =
true; % hide immediate transitions
if possible
101 %options.config.state_space_gen =
'reachable'; % still buggy
102 options.config.state_space_gen =
'full';
103 options.rewardIterations = 1000; % number of value iterations
for reward computation
104 options.config.qrf_params = []; % blocking config
struct (f, MR, BB, F, MM, MM1, ZZ, ZM)
105 options.config.qrf_alpha = []; % load-dependent rates M x N matrix
107 options.method = 'default';
108 options.init_sol = [];
109 options.iter_max = 100;
110 options.iter_tol = 1e-4;
112 options.verbose = VerboseLevel.SILENT;
113 options.config.da =
'courtois'; % CTMC decomposition/aggregation:
'courtois',
'kms',
'takahashi',
'multi'
114 options.config.da_iter = 10; % Number of iterations
for kms/takahashi
116 options = Solver.defaultOptions();
117 options.config.highvar =
'default';
118 options.config.hide_immediate =
false; % stiff ODE solver handles immediate rates accurately
119 options.iter_max = 200;
120 options.stiff =
true;
121 options.timespan = [0,Inf];
125 options = Solver.defaultOptions();
126 options.config.interlocking =
true;
127 options.config.multiserver =
'default';
128 % Under-relaxation options for convergence improvement
129 options.config.relax = 'fixed'; %
'auto' |
'fixed' |
'adaptive' |
'none'
130 options.config.relax_factor = 0.5; % Relaxation factor (0 < omega <= 1)
131 options.config.relax_min = 0.1; % Minimum relaxation factor for adaptive mode
132 options.config.relax_history = 5; % Error history window for adaptive mode
133 options.timespan = [Inf,Inf];
135 options.verbose = VerboseLevel.STD;
136 options.iter_max = 200; % More iterations for difficult LQN models
137 options.iter_tol = 5e-3; % Convergence tolerance (looser than default for LQN models)
139 % MOL (Method of Layers) options for hierarchical iteration
140 options.config.mol_task_inner_max = 50; % Max task inner iterations per host outer iteration
141 options.config.mol_task_inner_tol = 1e-4; % Task layer convergence tolerance (utilization delta)
142 options.config.mol_host_outer_tol = 1e-4; % Host layer convergence tolerance (utilization delta)
143 options.config.mol_min_steps = 2; % Minimum outer iterations before checking host convergence
145 options = Solver.defaultOptions();
146 options.timespan = [Inf,Inf];
148 options.verbose = false;
149 options.config.multiserver = 'default';
150 options.config.remote = false; % Enable remote execution via REST API
151 options.config.remote_url = 'http:
153 options.iter_max = 100;
154 options.timespan = [Inf,Inf];
155 % FJ-specific options (used when Fork-Join topology detected)
156 options.config.fj_accuracy = 100; % C parameter for FJ_codes (higher = more accurate)
157 options.config.fj_tmode = 'NARE'; % T matrix computation: 'NARE' or 'Sylves'
158 % num_cdf_pts uses global default of 200
160 options.iter_max = 1000;
161 options.iter_tol = 1e-6;
163 options.samples = 1e5;
164 options.timespan = [Inf,Inf];
165 options.config.highvar = 'interp';
167 options.iter_max = 1000;
168 options.iter_tol = 1e-6;
170 options.config.multiserver = 'default';
172 options.timespan = [0,Inf];
173 options.verbose = true;
174 options.config.state_space_gen = 'none';
175 % Warmup discard: drop the first floor(warmupfrac * samples) samples
176 % before computing steady-state averages. 0 = disabled (default).
177 options.config.warmupfrac = 0.0;
178 % Number of independent replications used by the 'para'/'parallel'
179 % methods. Fixed (i.e. not tied to the parallel pool size) so the
180 % parallel result
is worker-count invariant: replication r always
181 % simulates ceil(samples/nreplicas) events seeded with (seed+r-1),
182 % regardless of how many workers execute it. The serial methods
184 options.config.nreplicas = 8;
187 options.config.eventcache = true;
189 options.config.eventcache = false;
192 options.samples = 2e5;
193 options.lang = 'java';
194 % Transient detection options
195 options.config.tranfilter = 'mser5'; % 'mser5', 'fixed', or 'none'
196 options.config.mserbatch = 5; % MSER batch size (default: 5)
197 options.config.warmupfrac = 0.2; % Warmup fraction for fixed filter (0.0 to 1.0)
198 % Confidence interval options
199 options.config.cimethod = 'obm'; % overlapping batch means: 'obm', batch mean: 'bm', or 'none'
200 options.config.obmoverlap = 0.5; % OBM overlap fraction (0.0 to 1.0)
201 options.config.ciminbatch = 10; % Minimum batch size for CI
202 options.config.ciminobs = 100; % Minimum observations for CI
203 % Convergence options
204 options.config.cnvgon = false; % Enable convergence-based stopping
205 options.config.cnvgtol = 0.05; % Convergence tolerance (5% relative precision)
206 options.config.cnvgbatch = 20; % Min batches before checking convergence
207 options.config.cnvgchk = 0; % Events between checks (0 = auto)