4 % @brief Generate load-dependent rates
for functional server model f(n)=n+c.
10 % @brief Generate load-dependent rates
for functional server model f(n)=n+c.
11 % @fn pfqn_fnc(alpha, c)
12 % @param alpha Rate parameters (Mx N matrix).
13 % @param c Constant offset parameter (
default: auto-determined).
14 % @return mu Load-dependent service rates.
15 % @return c Determined offset constant.
18function [mu,c] = pfqn_fnc(alpha,c)
19% generate rates for functional server f(n)=n+c
23 mu = pfqn_fnc(alpha,c);
24 if ~all(isfinite(mu)) % first retry with -1/2
26 mu = pfqn_fnc(alpha,c);
30 while ~all(isfinite(mu)) % randomize c
if need be but unlikely
34 mu = pfqn_fnc(alpha,c);
41N = length(alpha(1,:));
44 mu(ist,1) = alpha(ist,1)/(1+c(ist));
45 alphanum = sparse(zeros(N,N));
46 alphaden = sparse(zeros(N,N));
48 alphanum(n,1) = alpha(ist,n);
49 alphaden(n,1) = alpha(ist,n-1);
51 alphanum(n,k) = alphanum(n,k-1) * alpha(ist,n-k+1);
52 alphaden(n,k) = alphaden(n,k-1) * alpha(ist,n-k);
59 muden = muden * mu(ist,k);
60 rho = rho+(alphanum(n,k)-alphaden(n,k)) / muden;
62 mu(ist,n) = alphanum(n,n-1)*alpha(ist,1)/muden;
63 mu(ist,n) = mu(ist,n)/(1-rho);
67mu(abs(mu)>1e15) = Inf;
69 if any(isinf(mu(ist,:)))
70 s = min(find(isinf(mu(ist,:))));