Solutions To Sheldon Ross Simulation
Solutions To Sheldon Ross Simulation
Solutions To Sheldon Ross Simulation
SOLUTIONS.
1. 1.1 The following data gives the arrival times and the service times that each
customer will require for the first 13 customers in a single server queue. On
arrival the customer either enters service if the server is free or joins the waiting
line. When the server completes work on a customer, the next one in the queue(
i.e. the one that has been waiting the longest) enters service.
Arrival Times 12 31 63 95 99 154 198 221 304 346 411
Service Times 40 32 55 48 18 50
47
18
28
54
40
455
72
537
12
end
end
2. 2.6 The continuous random variable X has probability density function given
by
f (x) = cx, 0<x<1
Find c and P [X > 1/2].
Since f is a probability density function we need to find the constant c so that
R1
R1
f (x)dx = 1 or 0 cxdx = 1 giving c = 2. Then
0
P (X >
1
)=
2
1/2
< Y)=
=
Z Z
Z
{
f (x, y)dxdy
{(x,y);x<y}
f (x, y)dx}dy
1
.
3
4. 2.15 An airplane needs at least half its engines to safely complete its mission.
If each engine independently functions with probability p, for what values of p
is a two engine plane safer than a three engine plane?
Let c be the number of engines required to safely complete the mission. Then
when there are n engines, c = 1 when n = 2 and c = 2 when n = 3. The
number of engines that operate properly is X, a binomial random variable with
parameters n and p. Therefore the probability that the mission is successful is
P2
P3
2
X
2
px (1 p)2x when n = 2
x
1
3
X
3 x
= P (X 2) =
p (1 p)3x when n = 3
x
2
= P (X 1) =
When is the two-engine plane better? When P2 > P3 or for values of p for
which
2p(1 p) + p2
1 + 2p3 p2 p
3p2 (1 p) + (1 p)3
0
(b) var(X) =
The expected value of a Poisson random variable is
E(X) =
=
x=0
xP (X = x)
x
x=0
= ex
= .
x e
x!
X
x1
(x 1)!
x=1
x(x 1)
x=0
= 2 ex
= 2 .
x ex
x!
X
x2
(x 2)!
x=2
It follows that
var(X) = E(X 2 ) 2
= E(X(X 1)) + E(X) 2
= .
8. 2.20 Let X and Y be independent Poisson random variables with parameters
1 and 2 respectively. Use question number 6 and a limit theorem for binomial
random variables to argue heuristically that X + Y has a Poisson(1 + 2 )
distribution. Then give an analytic proof of this result.
The heuristic argument is as follows. A binomial(n, p) random variable with
a small value of p and large n is approximately Poisson() with = np.
Therefore X is approximately Binomial(n1 , p) and Y Binomial(n2 , p) where
n1 = 1 /p and n2 = 2 /p and p is chosen very small. By 2.17 it follows that
the sum X +Y is approximately binomial (n1 +n2 , p) which is, since n1 +n2 is
large and p is small is approximately Poisson((n1 + n2 )p) or Poisson(1 + 2 ).
The formal argument is as follows. Suppose X has a P oisson(1 ) distribution
= k] =
k
X
P (X = i, Y = k i)
i=0
k
2
X
i1 e1 ki
2 e
i!
(k i)!
i=0
k
1 (1 +2 ) X k i ki
=
e
i 1 2
k!
i=0
(1 + 2 )k (1 +2 )
e
k!
(b) var(X) = 12 .
For an exponential random variable X, with probability density function
f (x) = ex , x > 0
Z
xex dx
E(X) =
0
= 1/.
and
E(X 2 ) =
x2 ex dx
= 2/2 .
Therefore the variance is
var(X) = E(X 2 ) (EX)2 = 2/2 1/2 = 1/2 .
10. 2.29 Persons A, B, and C are waiting at a bank having two tellers when it
opens in the morning. Persons A and B each go to a teller and C waits in line.
If the times required to serve customers are independent exponential() random
variables, what is the probability that C is the last to leave the bank? (No
computation is required)
Let us suppose that B leaves the bank after A. Then by the memoryless property
of the Exponential distribution, at the moment that A leaves the bank, C has
remaining service time which is exponentially distributed with parameter , and
so does B. These two service times have the same continuous exponential
distribution are independent. Therefore the probability that Cs service time is
the larger is 12 .
5
11. 2.30 Let X and Y be independent exponential random variables with rate
parameters and respectively. Show that
P [X < Y ] =
.
+
The joint probability density function, since X and Y are independent exponential is
f (x, y) = ex ey , x > 0, y > 0.
Therefore
P (X
< Y)=
=
Z Z
Z
{
f (x, y)dxdy
{(x,y);x<y}
ex dx}ey dy
.
+
12. 2.31 Consider a Poisson process in which events occur at a rate of 0.3 per hour.
What is the probability that not events occur between 10 AM and 2 P.M.?
Let N (t) be the number of events occurring in an interval of length t. According
the properties of a Poisson process, N (t) has a Poisson distribution with parameter given by t where is the intensity of the Poisson process. In this case
the intensity is = .3 and so N (4) has a Poisson distribution with parameter
1.2. Therefore
P [N (4) = 0] = e1.2
13. 2.32 For a Poisson process with rate , define N (s) =the number of events in
the interval [0, s]. Find
P [N (s) = k|N (t) = n]
for s < t.
For a Poisson process, recall that N (t) is the number of events in the interval
[0, t]. Therefore for s < t and 0 k n,
P [N (s) = k|N (t) = n] =
14. 2.36 If X and Y are independent exponential random variables, show that
the conditional distribution of X given X + Y = t is the uniform distribution
on (0, t).
Suppose that f (x, y) denotes the joint probability density function of X, Y and
fX and fT denote the probability density functions of X and T = X + Y
respectively. Then the conditional probability density function of X given
T = t is
fX (x)fY (t x)
fX|T (x|t) =
for 0 x t.
fT (t)
In this case both X and Y are exponentially distributed with identical probability density functions fX (x) = ex , x > 0. This is a special case of
the gamma density function and the sum of independent gamma random variables with the same scale parameter is also gamma. In other words, T has the
Gamma(2, 1/) probability density function
fT (t) = 2 tet , t > 0
Substituting
fX|T (x|t) =
=
=
fX (x)fY (t x)
fT (t)
ex e(tx)
2 tet
1
for 0 x t.
t
In other words given that the sum of two independent exponential random variables is t the conditional distribution of one of them, say X, is uniform on the
interval of possible values of X, namely [0, t].
15. 3.1
the sequence is 5, 15, 45, 135, 105, 15, 45, 135, 105, 15, 45, ....Note that
the sequence repeats after the four distinct numbers 15, 45, 135, 105 and so the
sequence has period 4.
16. 3.2 If x0 = 3 and
xn = (5xn1 + 7) mod 200
find x1 , ...x10 and the period of the generator.
Using lcg(3,5,7,200,20) we obtain the first 20 values of xn , 3 22 117 192 167 42
17 92 67 142 117 192,.... Notice that the values 3 and 22 never recur again but
117 appears again after 8 numbers. Indeed after 117 the sequence cycles through
117 192 167 42 17 92 67 142 repeatedly and the period is 8.
17. 3.3 Use simulation to approximate the integral
Z 1
exp{ex }dx
0
We can approximate this integral using Monte Carlo with the following Matlab
Code:
T=rand(1,100000);
mean(exp(exp(T)))
18. Use the runs (up) test and the normal approximation to its distribution to determine whether the following sequence is significantly different from independent
U [0, 1] variables.
.427,.321,.343,.474,.558,.746,.032,.522,.604,.745,.251,.310,
.798,.037,.081,.95,.812,.453,.644,.920,.951,.146,.155,.429,.525,.2,. 219,.675,.845,.
676
In this case n = 30 and the observed number of runs is R = 15. The expected number and standard deviation under the hypothesis that the numbers are
independent Uniform[0,1] is
r
2n 1
16n 29
E(R) =
= 19.67, SD(R) =
= 2.24
3
90
In this case, the observed value 15 is within 2SD(R) of the expected value
E(R) and so there is no significant evidence against the hypothesis of independent uniform. (note: this is a test of independence that can be applied for any
continuous random variables- it is not sensitive to the particular continuous distribution)
19. Let x1 , ..., x30 be the supposed U [0, 1] values listed in problem 18 and suppose
we plot the 15 points {(x2j1 , x2j ), j = 1, 2, ...15}. Divide the unit square is
divided into four equal subsquares, and count the number of points in each of
these four regions. Use the chi-squared test to determine whether the chi-squared
statistic is significant.
The number of point in each of the four quadrants
is 3, 4, 4, 4 respectively. The expected number under the assumption that the
points are uniform in the square is 17
4 = 3.75 for each of the four quadrants.
Therefore the Chi-square statistic is
2
This should be compared with a chi-squared distribution having 4 1 = 3 degrees of freedom and for this distribution the critical value at level 5% is 7.81.
Since the observed value is well below this critical value, there is no evidence
according to this test that the sequence does not consist of independent uniform
random variables.
8
8
16
or around 0.58905. We can approximate this integral using Monte Carlo with the
following Matlab Code:
T=rand(1,100000);
mean((1-T.^2).^1.5);
ex+x dx
Ross suggests changing variables so that the new variable ranges over the unit
interval to
y
dy
1
1
y
= 1/(x + 1)2 dx = y 2 dx
1
1
( 1)(1 + ( 1)2 )2 y 2 dy
y
y
1
( 1)(2y 2 2y + 1)1 dy
y
and the true value of this integral is 1/2. We can approximate this integral using
Monte Carlo with the following Matlab Code: the last line obtains
the standard error of the estimator
U=rand(1,100000);
T=(1/U-1)./(2*U.^2 -2*U+1)
mean(T)
se= sqrt(var(T)/100000)
23. 3.7 Use simulation to approximate the integral
Z
2
ex dx
ex dx
dy
so the integral becomes
2
1
exp{( 1)2 }y 2 dy.
y
10
First write this as E(exp(X + Y )2 ) where X and Y are independent U [0, 1].
Then in matlab:
x=(rand(1,100000)); y=(rand(1,100000));
f=exp((x+y).^2); m=mean(f)
ans=4.8924
25. 3.9 Use simulation to approximate the integral
Z Z x
e(x+y) dydx
0
Z x
e(x+y) dydx
t = 1/(x + 1),
s = y/x,
1
(x+y)
t
s
e
dydx =
exp{( 1)(1 + s)} y
y dsdt
t
0
0
0
0
t
s
Z 1Z 1
1
1
2
exp{( 1)(1 + s)}t 1 dsdt
=
t
t
0
0
This integral can be approximated using two independent uniform[0, 1], say S, T
and is equal to
E[exp{(
1
1)(1 + S)}T 2 (T 1 1)].
T
or in matlab
S=rand(1,100000); T=rand(1,100000); mean(exp(-(1./T-1).*(1+S)).*(1./T.^2).*(1./T-1))
.0832 .1406
.1406 .2416
and the covariance is the off-diagonal element 0.1406.
27. 3.11 Let U be uniform[0, 1]. Use simulation to approximate
(a) cov(U, 1 U 2 )
(b) cov(U 2 , 1 U 2 )
The easiest approximation is to use the sample covariance.
U=rand(1,100000);
V=sqrt(1-U.^2);
mean(U.*V)-mean(U)*mean(V). Gives value -0.0597.
Similarly
mean((U.^2).*V)-mean(U.^2)*mean(V) returns value -0.06578.
28. 3.12 Let U1 , U2 , ... be uniform[0, 1] random variables and define
N = min{n;
n
X
Ui > 1}.
i=1
Estimate E(N ) by generating 100, 1000, 10,000 and 100, 000 values. What is
the true value of E(N )?
For the expected value of N, note that
P (N
P (N
2) = 1
3) = P (U1 + U2 1) = 1/2
P (N
4) = P (U1 + U2 + U3 1) =
P (N
j) =
j=1
1
3!
1
(j 1)!
P (N j) can be written as
= P (N = 1)
+P (N = 2)
P (N = 2)
+P (N = 3)
+P (N = 3)
P (N = 3)
+P (N = 4)
+P (N = 4)
+P (N = 4)
P (N = 4)
+4P (N = 4)
P (N = 1)
+2P (N = 2) +3P (N = 3)
P
P
This shows that E(N ) = j=1 jP (N = j) = j=1 P (N j) = 1+1+1/2+
... = e.
12
+...
+...
+...
+...
+...
We may generate values of N using the following function. The function is not
perfect however, since it does not allow the event N > 100, an event which has
probability less than 10157 .
function N=generateN(m)
N=[];
for i=1:m
V=cumsum(rand(1,100));
N=[N 1+sum(V<1)];
end
29. 3.13 Let U1 , U2 , ... be uniform[0, 1] random variables and define
N = max{n;
n
Y
Ui > e3 }.
i=1
= max{n;
= max{n;
n
X
i=1
n
X
i=1
3i 3
e , i = 0, 1, ...
i!
end
For example the statement mean(q29(1000)) provides the average of 1000 simulated values of N and mean(3==q29(1000))
provides the value 0.2260 which estimates the probability P (N = 3)
(the true value is about 0.2240).
30. 4.1 Write a program to generate n values of a random variable X with
P [X = i] = i/3, i = 1, 2
Generate n = 100, 1, 000 and 10, 000 values of the random variable and compare the proportion of values of X equal to 1.
The vector of length N of suitable values of X can be generated using X=1+(rand(1,N)>1/3);
31. 4.2 Write a Matlab function which takes a vector of probabilities (p1 , ..., pn )
as input and outputs a single value of a random variable having this probability
(mass) function.
function X=simul(p);
X=sum(rand>[0 cumsum(p)]);
32. 4.3 Give an efficient algorithm to simulate the value of a random variable X
such that
P [X = 1] = 0.3, P [X 2] = 0.2, P [X = 3] = 0.35, P [X = 4] = 0.15
Generate U=Uniform(0,1)
If U<0.35, set x=3 and stop
if U<0.65, set x=1 and stop
if U<0.85 set x=2 and stop
else set x=4
33. 4.4 A deck of 100 cards numbered 1,2,...,100 is shuffled and then turned over one
card at a time. Say a hit occurs whenever card i is the ith card to be turned
over. Write a Matlab program to estimate the expected value and the variance of
the total number of hits. Find the true value and compare with your estimates.
Consider the probability that the i0 th card is a hit. Since all 100 cards are possible in the i0 th location, the probability of a hit on card i is 1/100. Therefore
if Ii = 1 or 0 as the i0 th card is a hit or not, then the total number of hits is
P
100
i=1 Ii . The expected value is therefore 100E(Ii ) = 1. We may generate values of N with the following two functions.
function p=permuternd(n)
% generates a random permutation of the integers 1:n
p=1:n;
for k=n:-1:2
i=ceil(k*rand); q=[p(i) p(k)];
p(k)=q(1) ;p(i)=q(2);
end
14
function f=matchesrnd(n,m)
% f is the observed number of matches of n items over m
trials.
f=[];
for i=1:m
f=[f sum(permuternd(n)==(1:n))];
end
f=matchesrnd(100,1000);
mean(f) = 0.98000000000000
var(f) = 0.94254254254255 (the true values are both =1)
34. 4.5 Consider the following recursive algorithm for generating a random permutation n of the integers {1, 2, ..., n}. Begin with a random permutation, n = 1,
namely 1. To generate a random permutation i+1 from a random permutation
i = {j1 , j2 , ..., ji }, first adjoin the value i + 1 to obtain {j1 , j2 , ..., ji , i + 1}
and then interchange the last component i + 1 with component J, randomly
selected from the i + 1 values {j1 , j2 , ..., ji , i + 1} (so that i + 1 can end up
being interchanged with itself). Show that this algorithm produces a random
permutation and write a Matlab function which implements this algorithm. Test
your algorithm by repeatedly generating permutations 10 .
Consider the following function
function v=perm(n)
v=1;
for i=2:n;
j=ceil(i*rand);
v=[v j];
end
Running this function 1000 times as with
x=[]
for i=1:1000; x=[x;perm(10)]; end
generates a matrix x of 1000 such permutations, each one occupying
a row of the matrix. One can check that the individual columns, say
column 3 has the correct frequency with mean(x(:,3)==1)
35. 4.6
for
ei/N
i=1
where N = 10, 000. Find the approximation and indicate if it is a good one.
We wish to approximate a sum of the form
N
X
i=1
15
ei/N
36. 4.7 A pair of dice are to be continually rolled until all the possible outcomes
2, 3, . . . , 12 have occurred at least once. Develop a simulation study to estimate
the expected number of dice rolls that are needed.
The following matlab function will generate the number of dice rolls needed. If
we define this function and then enter v=q36(1000) then the vector v consists the results of 1000 simulations and mean(v) produces 59.08, an estimate
of E(N ).
function v=q36(nsim)
%nsim=number of simulations. output v=vector of results of nsim simulations
v=[];
for i=1:nsim
y=sum(ceil(6*rand(2,12))); % initializes with 12 rolls
while (length(unique(y))<11)
x=sum(ceil(6*rand(1,2))); %generates sum of two rolls of the dice
y=[y x]; % augments the list of y values until unique(y)=11
end
v=[v length(y)];
end
37. 5.1 Give a method for generating a random variable having density function
f (x) =
ex
,0 < x < 1
e1
Using 10000 simulated values from this distribution, estimate its mean and variance. Use inverse transform. In this case F (x) = (ex 1)/(e 1) and
F 1 (U ) = ln(1+U (e1)). x=log(1+rand(1,10000)*(exp(1)-1)); mean(x)=0.58
R 1 ex
dx = 0.58198 and the variance
and var(x)=.0792. The true values are 0 x e1
R 1 2 ex
2
is 0 x e1 dx (0.58198) := 0.07932 3.
16
38. 5.2 Give a method for generating a random variable having density function
x2
if 2 x 3
2
f (x) =
1 x6 if 3 x 6
Using 10000 simulated values from this distribution, estimate its mean and variance.
Apply the inverse transform method. In this case
F (x) =
(x2)2
4
1
4
3)( 34
+ (x
if 2 x 3
x
12
) if 3 < x < 6
(U ) =
2 + 2 U if 0 U 1/4
6 2 3 3U if U > 1/4
39. 5.4 Give a method for generating a Weibull random variable having cumulative
distribution function
F (x) = 1 exp(x ), 0 < x <
Using 10000 simulated values from this distribution, estimate its mean and variance when = 1, = 2.
Again inverse transform. X = ( ln(1
U )/)1/ . The probability density function is
2
0
Similarly
E(X 2 ) = 2
x3 ex dx = 1
4.
40. 5.5 Give a method for generating a random variable having density function
2x
e
if x < 0
f (x) =
e2x if 0 x
Using 10000 simulated values from this distribution, estimate its mean and variance.
As in Ross, page 63-66 we obtain the cumulative
distribution function
e2x
if x < 0
F (x) = 2e22x
if x > 0
2
17
(U ) =
ln(2U)
if
2
ln(22U )
U < 1/2
if U > 1/2
where the values pi are nonnegative and sum to one? Give an algorithm to
generate a random variable X with c.d.f.
F (x) =
x + x3 + x5
,0 < x < 1
3
and by simulating 10000 values of this random variable estimate its mean and
variance.
This is a mixture and we use the composition method.
First generate a random variable I with probability function
P (I = i) = pi
Then output the value X = FI1 (U ). For this example the integer I is generated uniformly on the set {1, 2, 3} and so, for example
I=3*ceil(rand(1,10000));
X=(rand(1,10000)).^(1./I); mean(X)=0.75 var(X)=.0373
43. 5.9 Give a method to generate a random variable with cumulative distribution
function
Z
F (x) =
xy ey dy
44. 5.11 Suppose it is easy to generate random variables Xi from each of the c.d.f.s
Fi (x). Indicate how to generate a random variable X having as c.d.f.
Q
(a) ni=1 Fi (x )
Q
(b) 1- ni=1 (1 Fi (x)).
(Hint: consider the distribution of max{Xi ; i = 1, 2, ...n} and min{Xi ; i =
1, ..., n} where the Xi are independent with c.d.f. Fi (x).
Suppose
we generate independent random variables Xi with c.d.f. Fi (x) for each
i = 1, 2, ..., n. Then check that the random variable max(X1 , ..., Xn ) has
c.d.f. F1 (x)F2 (x)...Fn (x). Therefore we generate X as
X = max(F11 (U1 ), ..., Fn1 (Un ))
It is also easy to show that the minimum
X = min(F11 (U1 ), ..., Fn1 (Un ))
has the c.d.f. in part (b).
45. 5.15 Give an algorithm for generating a random variable from the probability
density function
f (x) = 30(x2 2x3 + x4 ), 0 x 1
and discuss the efficiency of your algorithm.
Use acceptance rejection.
Note that 30x2 (1 x)2 30
16 for all 0 < x < 1 and so we may use c times a
U[0,1] probability density function to dominate f (x). We expect to generate on
average 30
16 or nearly two points (i.e. 4 uniform) in order to produce one random
variable with this probability density function.
46. Write a Matlab function which uses the Box-Muller algorithm to generate n
pairs (X1 , X2 ) of independent normal(0,1) random variables. By simulating
10000 random variables from this algorithm, estimate the value of E[(X1
X2 )4 ].
The statement
u=rand(10000,2);
r=sqrt(-2*log(u(:,1)));
theta=2*pi*u(:,2);
x=r*[cos(theta) sin(theta)];
produces a 10000 by 2 matrix of independent N (0, 1) and to estimate the
expectation E[(X1 X2 )4 ] we may use mean((x(:,1)-x(:,2)).^4).
The true value is 12 so this should give a value near 12.
47. Suppose two stocks are presently both worth exactly $10 and in one month stock
1 will be worth 10 exp(X1 ) and stock 2 will be worth 10 exp(X2 ) where
(X1 , X2 ) are both normal random variables with mean 0, variance 2 = 0.05
and the correlation coefficient is = 0.2. You have exactly $10 to spend but
we are able to borrow one stock in order to invest in the other. In other words
we have the ability to own y + 1 shares of stock 1 and y shares of stock 2 for
any value of y (positive or negative).
19
Figure 1:
(a) Determine whether the expected value of the value of your portfolio 10[(y+
1) exp(X1 ) y exp(X2 )] depends on the value you chose for y.
(b) For various values of y in the interval [1, 1] determine the variance of
your portfolio 10[(y + 1) exp(X1 ) y exp(X2 )] by simulation.
(c) What value of y do you recommend if your objective is to achieve the same
mean but with the smallest possible variance?
Notice that the expected value of the portfolio after one month is
10E[(y + 1) exp(X1 ) y exp(X2 )] = 10EeX1 + y(E[exp(X1 )] E[exp(X2 )]
= 10E exp(X1 )
since exp(X1 ) and exp(X2 ) have the same distribution. Therefore the
mean does not depend on the value we choose for y. We may generate
correlated random variables X1 , X2 as follows: first generate correlated
normal(0,1) random variables and modify to have the correct mean and
standard deviation:
x=randn(10000,2);
rho=-0.2;
x(:,2)=rho*x(:,1)+sqrt(1rho^2)+x(:,2);
x=sqrt(0.5)*x;
Now consider the variance of the value of possible portfolios for a given
values of y,ranging from 5 to 5.
va=[]; for y=-1:.01:1; v=10*((y+1)*exp(x(:,1))-y*exp(x(:,2)));
va=[va var(v)];
end
we can plot this using
plot((-1:.01:1),va);
xlabel(y);
ylabel(Variance
of portfolio)
and this gives a figure like the following: which would appear to indicate that the optimal value of y is around y = .2. Therefore we
should buy 0.8 shares of stock 1 and 0.2 shares of stock 2.
20
48. 4.10 The negative binomial probability mass function with parameters (r, p)
where r is a positive integer and 0 < p < 1 is given by
j1 r
P [X = j] =
p (1 p)jr , j = r, r + 1, .....
r1
(a) Use the relationship between the negative Binomial and the geometric distribution to simulate from this distribution
(b) Verify the relationship
P [X = j + 1] =
j(1 p)
P [X = j]
j+1r
(c) Use the relationship in (b) to give a second algorithm for generating from
the negative binomial distribution
(d) A Negative binomial random variable is generated as the number of trials
it takes to generate a total of r successes where trials are independent
and the probability of success on each trial is p. Use this fact to generate a
negative binomial random variable.
(a) The sum of r independent geometric random variables has a Negative binomial distribution. Therefore since we can generate a Geometric
random variable using
ln(Ui )
1+
ln(1 p)
the generator takes the form
X =r+
r
X
i=1
ln(Ui )
.
ln(1 p)
one which uses the inverse transform method and the other based on the fact
that this distribution is of the form P [Y = i|Y A] for some random variable
21
Y and some set A. Discuss which method you expect to be more efficient for
large/small values of k.
The crude method is to repeatedly generate Poisson randnom variables until we
observe a value such that X k and then accept this value. Alternatively we
can use inverse tranform since if the Poisson cumulative distribution function is
F (x) then the cumulative distribution function in this problem takes the form
F (x)
, x = 0, 1, ..., k.
F (k)
We simply generate a uniform[0,1] random variable U and then search for an
integer X which satisfies the inequality
F (X)
F (X 1)
<U
.
F (k)
F (k)
50. 4.13 Let X be a Bin(n, p) random variable. Suppose we want to generate a
random variable Y whose probability distribution is the same as that of X given
that X k for some k n. Suppose = P [X k] has been computed.
(a) Give the inverse transform method for generating Y
(b) Give a second method for generating Y
(c) For what values of , large or small would the second method be inefficient?
Let X be a binomial random variable with parameters n and p. Suppose
that we want to generate a random variable Y whose probability mass function is the same as the conditional mass function of X given that X k,
for some k n. Let = P [X k] and suppose that the value of has
been computed. (a) Give the inverse transform method for generating Y .
(
P [X=i]
if n i k
P [X = i, X k]
P [Y = i] = P [X = i|x k] =
=
P [X k]
0
otherwise.
And this is:
P [Y = i] =
n!
i
i!(ni)! p (1
p)n1
if n i k
otherwise.
ni p
P [Y = i]
i+1 1p
22
(c)
0.11
0.09
P [X = j] =
pj = .55p1j + .45p2j
where,
p1j = .2,
The probability function is a mixture, f1 (x) is the uniform distribution on the set
{5, 7, 9, 11, 13} and f2 (x) is the uniform distribution on the set {6, 8, 10, 12, 14}.
52. 4.15 Suppose that a random variable takes on values
i
P [X = i]
1
.06
2
.06
3
.06
4
.06
5
.06
6
.15
7
.13
8
.14
9
.15
10
.13
Use the composition method to provide an algorithm for generating the random
variable X.
The probability function is a mixture
f (x) = .3f1 (x) + 0.3f2 (x) + 0.26f3 (x) + .14f4 (x)
where f1 (x)is the uniform distribution on the set {1, 2, 3, 4, 5},f2 (x) uniform on
the two points {6,9}, f3 (x) uniform on the points {7,10} and f4 (x) = 1 for
x = 8 (all of the mass is at this one point).
23
53. 4.16 Give a method for generating values of the random variable X where
1
2i2
P [X = i] = ( )i+1 + i , i = 1, 2, ...
2
3
This is the mixture of two geometric distributions. With probability 1/2 generate
from Geom(1/2) and otherwise from Geom(1/3). If U1 < 1/2 output X =
ln(U2 )
2)
1 + [ ln(U
1/2 ] and otherwise if U1 > 1/2 output X = 1 + [ 2/3 ].
54. 4.17 Let X be a random variable taking values on the set {1, 2, 3, ...} such that
for certain values 1 , 2 , ...
P [X = n|X > n 1] = n , n = 1, 2, ...
Show that
P [X
P [X
= n] = n (1 n1 )...(1 1 ) for n 2
= 1] = 1
and that
n =
pn
Pn1
i=1
pi
, n = 2, 3, ...
1
1
pn+1
Pn
pj
pn+1
j=1
Pn1
pj pn
pn+1
=
(1 1 )(1 2 ) . . . (1 n1 ) pn
pn+1
=
(1 1 )(1 2 ) . . . (1 n1 ) (1 1 )(1 2 ) . . . (1 n1 )n
pn+1
=
(1 1 )(1 2 ) . . . (1 n1 )(1 n )
j=1
So,
pn+1 = (1 1 )(1 2 ) . . . (1 n )n+1
24
Show that the value of X when the above stops has the desired mass function.
Suppose that the algorithm stops at X = m then, Um < m and Um1
m1 , i.e. Um1 < 1 m1 , Um2 < 1 m2 . So we have:
P (X = m) = P (Um < m )P (Um1 m 1) . . . P (U1 1) = pm
Suppose that X is a geometric random variable with parameters p. Determine
the values n , n 1. Explain what the above algorithm is doing in this
case and why its validity is clear.
If X is a geometric r.v. then
pn = p(1 p)n1
n1
Then we have:
n =
=
=
=
pn
Pn1
j=1 pj
n1
p(1 p)
P
1 n1
j=1 pj
p(1 p)n1
1 p[1 + (1 p) + (1 p)2 + . . . + (1 p)n2 ]
p(1 p)n1
n1
1 p 1(1p)
1(1p)
=p
55. 5.16 Consider generating a N (0, 1) random variable Z by first generating the
absolute value |Z|, having probability density function
r
2
f (x) =
exp(x2 /2), x > 0
where
f (x) =
f (x)
g (x)
2 x2 /2
and g (x) = ex , for x > 0
e
25
2 2 /2
e
The best choice of is the choice which minimizes the value of c(). Again
using calculus we can show that this corresponds to = 1.
56. 5.21 Consider a job that consists of a number of a total of k stages that must
be done in sequence. The time required to complete stage i is an exponential random variable with parameter i and then after completing stage i, the
worker goes on to stage i + 1 with probability i , otherwise the worker stops
working with probability (1 i ). Let X be the total amount of time the
worker spends on the job. Write an algorithm for generating the value of X.
Note that if P [Y = j] = 1 2 ...j1 (1 j ) then P [Y > j] = 1 2 ...j .
For independent U[0,1] random variables Ui , define a random variable Y = j
if and only if Ui < i for all i < j and Uj j . Thus Y is the smallest index
such that UY Y . Q
Alternatively we can use inverse transform to generate
y
Y with F (y) = 1 i=1 i (this is in fact the same method). Then Y is
the number of stages required. The amount of time required is the sum of Y
exponentially distributed random variables
X=
Y
X
ln(Vi )
i=1
57. 5.23 Buses arrive at a sporting event according to a Poisson process with rate
5 per hour. Each bus is equally likely to carry 20,21,...,40 fans with the numbers
in different buses being independent. Write an algorithm to simulate the arrival
of fans in the time interval 0 < t < 1. Notice that
(t) 7 for all t > 0.
Ggenerating a sequence of independent bus arrival times Ti independent exponential(5) and then at each generate the number of passengers. Record at event
times in the vector ET the total number of passengers NA that have arrived.
(a) t = 0; N A = []; ET = [];
(b) while (t < 1)
(c) t = t
ln(rand)
;
5
See Ross pages 78-79 for a method to generate the Poisson process. Generate
a Poisson process on the interval 0 < t < 5 with intensity 1. Thin using the
above thinning method to obtain the process on 0 < t < 5 which has intensity
function (t) = 5t . For 5 < t 6, again generate the Poisson process with
intensity (t) = 1 + 5(t 5) by thinning a process with constant intensity 6.
Similarly for 6 < t 7, thin a process with constant intensity 11, etc. This
is more efficient than using a constant intensity of 26 and thinning to obtain the
process over the whole interval 5 < t < 10.
59. Give two algorithms for generating observations from a distribution with probability density function
(x 1)3
, for 2 x 4.
20
f (x) =
Record the time necessary to generate the sample mean of 100,000 random variables with this distribution. Which algorithm is faster?
The simplest method is to use inverse transform, since in this case the cumulative
distribution function
F (x) =
(x 1)4
, for 2 x 4
80
is easily inverted. An alternative might be to use acceptance-rejection dominating the density with a function like c(x 1) for 2 x 4 but acceptancerejection is bound to be slower.
60. Give two different algorithms for generating observations from a distribution
with a density function of the form f (x) = cx3 ex/2 for x > 0 and appropriate constant c. Record the time necessary to generate the sample mean
of 100,000 random variables with this distribution. Which algorithm is faster?
This is a gamma(4,2) distribution and the constant is
c=
1
1
=
4
(4)2
96
so we can either use the sum of four independent exponential random variables
(each Gamma(1,2))
4
X
ln(Ui )
X = 2
i=1
3
whose maximum value 128
= 2.124 2 occurs for x = 8 Therefore the value
3 e
of c is 2.1242. The algorithm is
27
1
X 3 e 8 X cU2 , and otherwise return to step 1.
Accept X if 12
There are other functions one can use to dominate more closely the gamma
density function (see the notes for example) We might use a function of
the form
pkxp1
g(x) =
(k + xp )2
and try and find a suitable value for p, k. One suggestion .is to choose these
p
values
so that the mode of the functions f and g match, giving k = and
p = 2 1. In this case
f (x) cg(x)
with c =
efficient.
2
p()e .
61. Give a precise algorithm for generating observations from a discrete distribution with P [X = j] = (2/3)(1/3)j ; j = 0, 1, ....Record the time necessary to
generate the sample mean of 100,000 random variables with this distribution.
Compute as well the sample variance. How large would the simulation need to
be if we wanted to estimate the mean within 0.01 with a 95% confidence interval?
This is a variation of the geometric distribution. In this case, X counts the number of failures we generated before obtaining a single success if the probaiblity
of a success on each trial is 2/3. In other words, X = Y 1 where Y has
a geometric distribution with p = 2/3. Therefore we can generate, by inverse
transform,
ln(1 U )
X=[
]
ln(1 p)
where [] represents the integer part.
62. Give a precise algorithm for generating observations froma distribution which
has probability density function f (x) = x3 , 0 < x < 2 . Record the time
necessary to generate the sample mean of 100,000 random variables with this
distribution. Determine the standard error of the sample mean. How large would
the simulation need to be if we wanted to estimate the mean within 0.01 with a
95% confidence interval? This is a simple inverse transform problem. Note
that
x4
F (x) =
, 0<x< 2
4
and so the inverse transform is
X = (4U )1/4 .
R 2
R 2
The mean is E(X) = 0 xf (x)dx = 0 x4 dx = 45 2 = 1.131 4. and the
standard deviation of X is around 0.23. In order to estimate the mean within
28
n
n
29
0.01
462 = 2116
Fi (x) = x2 ,
i=1
ex 1
=
, i=2
e1
= xex1 , i = 3
for 0 < x < 1. Explain how to obtain random variables with cumulative
distribution functions
G(x) = 3i=1 Fi (x) and G(x) = 1 3i=1 (1 Fi (x)).
We need to generate three random variables Xi having c.d.f. Fi (x) for i =
1, 2, 3 and then use max(X1 , X2 , X3 ) as a random variable having c.d.f. 3i=1 Fi (x)
and min(X1 , X2 , X3 ) having c.d.f. 1 3i=1 (1 Fi (x)). The random variables
X1 , X2 can be generated by inverse transform. The random variable X3 can
be generated using acceptance-rejection We can use the the density function
g(x) = 23 (x + 1) to dominate x since the corresponding density satisfies
f3 (x) = (x + 1)ex1 (x + 1) on 0 < x < 1
Since in this case c = 3/2 we can expect reasonable efficiency (only an averge
of 1 point in 3 is rejected).
64. Evaluate the following integral by simulation. Give two different methods
Z 1
(1 x2 )3/4 dx.
0
2, 4
1X
(1 Ui2 )3/4
n i=1
1 X
[(1 Ui2 )3/4 + (1 (1 Ui )2 )3/4 ].
2n i=1
The graph of the function f (x) = 1 (1 x2 )3/4 shows that the function is
monotone on the interval [0,1] and so the method of antithetic random numbers
should provide some variance reduction.
30
1
0.8
0.6
0.4
0.2
0.2
0.4
0.6
0.8
This equals
E(2X 3/2 (4 X)1/2 )
where X = 2U has the uniform[0,2] distribution. Therefore the simulated
value is
n
2X
3/2
(2Ui )(4 2Ui )1/2
n i=1
66. Find
by simulationthe area of the region {(x, y); 1 < x < 1, y > 0,
1 2x2 < y < 1 2x4 }. The boundaries of the region are graphed in
Figure 1. Which method do you expect to be more efficient, generating random
points in the rectangle (1 < x < 1, 0 < y < 1) and counting the proportion that lie in the region between these curves or generating a random value
of x in the
interval 1< x < 1 and using a multiple of the average of the
values of 1 2x4 1 2x2 ? We begin by generating values in the rectangle and counting what proportion of these points fall in the region between the
two graphs. Define (Xi , Yi ) = (2Ui 1, Vi ) where both Ui , Vi are independent
U [0, 1]. Then the crude Monte Carlo estimator is the average of the indicator
random variables
n
n
q
q
1X
1X
b
crude =
I( 1 2Xi2 < Yi < 1 2Xi4 ) =
Ii
n i=1
n i=1
Notice however that if you were told the value of Xi , then the conditional expectation
q
q
E[Ii |Xi ] = 1 2Xi4 1 2Xi2
and since the conditional expectation E(Ii |Xi ) has the same mean as does Ii but
smaller variance, a second estimator with the same expected value as b
crude but
31
0.9
0.8
0.7
0.6
0.5
0.4
0.3
0.2
0.1
0
-1
-0.8
-0.6
-0.4
-0.2
0.2
0.4
0.6
0.8
Figure 2:
with smaller variance is
n q
q
1X
( 1 2Xi4 1 2Xi2 ).
n i=1
67. Briefly indicate an efficient algorithm for generating one random variable from
each of the following distributions and generate such a random variable using
one or more of the uniform[0,1] random numbers.
Ui :
0.794
0.603
0.412
0.874
0.268
0.990
0.059
0.112
0.395
3U 1
3 1/2
,
16 x
0<
68. Briefly indicate an efficient algorithm for generating one random variable from
each of the following distributions and generate such a random variable using
one or more of the uniform[0,1] random numbers.
Ui :
0.794
0.603
0.412
0.874
0.268
0.990
0.059
0.112
0.395
(a) A random variable X with the normal distribution, mean 1 and variance
4. Generate (Z1 , Z2 ) using Box Muller and use (X, Y ) = 1 + 2(Z1 , Z2 )
32
xp1
(c + xp )2
for sensible values of c and p. Compare the speed of the two algorithms.
We wish to generate from a Gamma distribution having mean 20 and variance
20. If I let
xp1
g(x) = constant
(c + xp )2
can we find parameters p and c so that we have approximately the same location
and shape of distribution? Note that
Z z
xp1
1
1
dx =
+
p
2
p
p (c + z ) pc
0 (c + x )
and so
g(x) = g(x) = cp
xp1
(c + xp )2
c
.
(c + z p )
p+1
p1
We now try several values of p to see if we get approximately the right shape of
the distribution. For example in the case p = 10 we obtain a probability density
function that resembles the Gamma
0.12
0.1
0.08
0.06
0.04
0.02
0
10
20
x
30
70. Haggis Elevators has a total of four elevators installed in MC. A typical elevator
breaks down once every 10 days. One repairman can repair an elevator in an
average of 4 days (from the time that the repair is ordered). Currently there
is one repairmen on call. Service times and the time between breakdowns are
exponentially distributed.
(a) Draw a state diagram including transition rates for the Markov Chain. The
state is the number of elevators operating. Breakdown rate=1/10 per operating elevator. Service rate=1/4.
Figure 3:
34
40
(b) Assuming that the system begins with all four elevators operating, use the
uniform numbers and their negative logarithms listed below to simulate the
operation of the system for the first 4 events.
Ui :
0.019 0.821 0.445 0.180 0.792 0.922 0.738 0.240
ln(Ui ) : 3.99 0.20
0.81 1.71 0.23
0.08
0.30 1.43
Define the variables below and fill in the following table:
System state=Number of elevators operating {0,1,2,3,4}
Event List=(tB , tS ) =(time of next breakdown, time of next service completion).
Clock Time
0
9.975
10.775
15.05
15.32
System State
4
3
4
3
2
Event List
(9.975,)
(12.675,10.775)
(15.05,)
(15.32,15.97)
(16.82,15.97)
(c) Run a simulation and compare the observed proportion of time each of the
5 states are occupied with the expected time when the system is operating
at steady state. (you need to solve for the equilibrium distribution)
71. A communications network transmits binary digits, 0 or 1. There is probability
q that a digit transmitted will be incorrectly received at the next stage. If X0 denotes the binary digit originally transmitted, Xn the digit after it has been retransmitted n times, simulate the process for n = 1, 2, .....10000 beginning both
with X0 = 1 and X0 = 0 and for various values of q(e.g. .q = 0.1, 0.2, ...0.5).
Record the proportion of time that the process spends in each of its two states
0 and 1.
The proportion of time that the chain is in state 0 should be
close to the equilibrium probability of state 0. This is obtained by solving the
equations 0 P = 0 giving solution (1/2,1/2) no matter what the value of q (if
0 < q < 1).
(b) Given that 0 is originally transmitted ( X0 = 0 ), what is the probability that
the first error in retransmission (i.e. Xn = 1 for the first time) occurs on the
n0 th retransmission. What is the expected time before the chain returns to its
original state. The probability of the first error occurring after n transmissions
is given by the geometric distribution (1 q)n1 q. Expected time to first change
of state = 1/q. Expected time till second change of state and it returns to the
original one = 2/q.
72. Two mechanics are employed to service 3 aircraft. All aircraft not undergoing
repair are in use and the time until breakdown of any one aircraft while in use has
an exponential distribution with expected value 1/. One mechanic is assigned
to each aircraft requiring repair, and the time until this repair is completed is
exponential with expectation 1/. Let Xt be the number of aircraft requiring
repair at time t (Note that when Xt = 3, only two aircraft are being repaired and
35
Figure 4:
one is waiting to begin repair). Draw a state diagram including transition rates
for the Markov Chain. Determine by simulation the answers to the following
questions. Try and indicate some measure of the precision of your estimate and
compare where possible with the theoretical equilibrium values.
(a) Suppose = = 1. If the company loses $1,000 per unit time that only
one aircraft is operating and $5,000 for each unit of time when no aircraft
are operating, what is the long run average cost to the company per unit
time?
(b) Suppose = = 1. What is the average length of time that an aircraft
spends waiting before beginning repair?
The state transition diagram with rates of transitions are as in the following
diagram:FIX THESOLUTION. Solving for the equilibrium distribution by
equating flow in and flow out for the various states, we obtain the equations
20
31
32
= 1
= 0 + 2 2
= 2 1 + 3 3
36
Figure 5:
73. Consider the following network of five components ( components are represented
by directed arcs in Figure 3).The network operates as long as there is flow permitted from the input (source) to the output (sink). The arrows indicate the direction
of flow possible. Find by simulation the expected lifetime of this system if the
individual components all have independent lifetimes
(a) that are exponential with mean 1.
(b) that are uniform on the interval [0,2]. Suppose the lifetimes of the components are T1 , ...T 5. Then the lifetime of the system is max(Y1 , Y2 , Y3 , Y4 )
where Y1 = min(T1 , T2 ), Y2 = min(T1 , T3 , T5 ), Y3 = min(T4 , T5 ), Y4 =
min(T4 , T3 , T5 ).
L=[];
for i=1:10000
T=2*rand(1,5); (for part b) or T = log(rand(1, 5)) (for part (a)
L=[L max([min(T([1 2])) min(T([1 3 5])) min(T([4 5])) min(T([4 3 2]))])];
end
mean(L); sqrt(var(L)/length(L)); hist(L,50)
74. The interarrival times between consecutive buses at a certain bus stop are independent Beta(1/2,1/2) random variables with probability density function
1
f (x) = p
, 0 < x < 1.
x(1 x)
starting at clock time t = 0. You arrive at the bus stop at time t = 10. Determine
by simulation the expected time that you will have to wait for the next bus. Is
37
it more than 1/2 ? Repeat when the intarrival times have the distribution of Y 2
where Y is an exponential with parameter = 10. Explain how this is possible.
Ry
dx = 2 arcsin(2y1)+
. Use inverse transform to generate
F (y) = 0 1
2
x(1x)
n
X
Ui > 1}
i=1
end
Running this function as with N=generateN(1000); mean(N); var(N);
produces an estimator of the mean around 2.71 and the variance around .7627.
Since the 95% confidence interval takes the approximate form
X 2S/ n
we have
2S/ n .001
or
n(
2S 2 4 .7627
) =
.001
(.001)2
or n 3, 050, 800.
76. Ross 7.9 Consider a sequence of random U [0, 1] numbers and let M be the first
one that is less than its predecessor:
M = min{n; U1 U2 ... Un1 > Un }
1
n! , n = 0, 1, ....
P
= n=0 P [M >
n} to show E(M ) = e.
(c) Use 1000 simulation runs and part b to estimate e with a 95% confidence
interval.
77. Ross 7.14 If n = 2 and X1 = 1, X2 = 3 determine what is the bootstrap
estimator of var(S 2 ).
The bootstrap estimator is obtained
by taking random samples of size 2 with replacement from the values {1, 3}
repeatedly and computing the value of the sample variance S 2 . There are only
three possible samples with probabilities as below
Sample
{1, 1}
{1, 3} (either order)
{3, 3}
Probability
1/4
1/2
1/4
S2
0
2
0
S2=[S2 var(bootx)];
end
disp([bootstrap estimate of var(S^2) = num2str(var(S2))])
and this gives a value around 64.7
79. Use both crude and antithetic random numbers to integrate the function
Z 1 u
e 1
du.
0 e1
What is the efficiency gain attributed to the use of antithetic random numbers?
First for a crude monte-carlo estimator:
t1=cputime U=rand(1,200000); % crude Monte Carlo
F=(exp(U)-1)/(exp(1)-1); % value of 200000 values of the
function
m=mean(F) % average value
S1=var(F)/length(F) % estimated variance of estimator
t1=[t1 cputime];
Now we use 100000 antithetic pairs for the same number of function evaluations. ************************
U=rand(1,100000);
F=.5*(exp(U)-1)/(exp(1)-1)+.5*(exp(1-U)-1)/(exp(1)-1);
mean(F)
S2=var(F)/length(F) ;
t1=[t1 cputime];
display([times mat2str(diff(t1))]);
display([efficiency= num2str(S1/S2)])
This gives means around .4180 and variances S1 = 4.1 107 and S2 =
1.32 108 for a ratio (the efficiency gain due to antithetic) of around 31.
Moreover the antithetic takes about 30% less time.
80. Under what conditions on f does the use of antithetic random numbers completely remove the variance of the Monte-Carlo estimator? i.e. When is var(f (U )+
f (1 U )) = 0? If the variance of a random variable is 0 then the random
40
(
)
=
1
F
(X
)
=
1
U.
F (2 X1 ) = ( X
1
2
82. Show
that it is better to use U than U as a control variate when estimating
E( 1 U 2 ). The necessary covariance may be estimated by simulation.
2
2
We
need to compare the variance of ( 1 U 1 U ) and the variance of
( 1 U 2 2 U ) where these coefficients are chosen optimally
cov( 1 U 2 , U 2 )
.0656
=
= .736
1 =
var(U 2 )
.0891
cov( 1 U 2 , U )
.0595
=
= .714
2 =
var(U )
.0833
1
0
eu 1
du.
e1
What do you recommend for intervals (two or three) and sample sizes? What is
the efficiency gain over crude Monte Carlo?
By experimentation, two intervals such as [0 55],[55 1] results in optimal sample sizes (for a total sample of 100000) around 47400 and 52600 respectively
and provides an efficiency gain of around 4 over crude monte carlo. Three intervals e.g. [0 .35],[.35 .75], [.75 1] with sample sizes abou 25229,48686,26083
provides an effeicncy gain of around 8 over crude monte carlo.
84. Use a combination of stratified random sampling and an antithetic random number in the form
1
[f (U/2) + f (1 U/2)]
2
41
eu 1
du.
e1
1
85. In the case f (x) = ee1
, use g(x) = x as a control variate to integrate over
[0,1]. Show that the variance is reduced by a factor of approximately 60. Is there
much additional improvement if we use a more general quadratic function of x?
1
86. In the case f (x) = ee1
, consider using g(x) = x as a control variate to integrate over [0,1]. Note that regression of f (U ) on g(U ) yields
f (U ) E(f (U )) = [g(U ) Eg(U )] + where the error term has mean 0
and is uncorrelated with g(U ) and = cov(f (U ), g(U ))/var(g(U ). Therefore, taking expectations on both sides and reorganising the terms, E(f (U )) =
f (U ) [g(U ) E(g(U ))]. The Monte-Carlo estimator
n
1X
{f (Ui ) [g(Ui ) E(g(Ui ))]}
n i=1
is an improved control variate estimator, equivalent to the one discussed above
in the case = 1. Determine how much better this estimator is than the basic
contol variate case = 1 by performing simulations. Show that the variance is
reduced by a factor of approximately 60. Is there much additional improvement
if we use a more general quadratic function of x?
In this case the optimal value of is given by cov(f (U ), g(U ))/var(g(U )) =
.0822/.0836 = . 983 25 and var(f (U ).98325U ) = .0013 resulting in an efficiency gain of around .0822/.0013=63. If we allow a general quadratic function
the efficiency gain is even greater than the 2600 observed in problem 86.
42
1
95. In the case f (x) = ee1
, use importance sampling with a probability density
function proportional to g(x) = x to integrate over [0,1]. What is the efficiency
gain over crude Monte Carlo?
43
1
97. In the case f (x) = ee1
, use g(x) = x as a control variate to integrate
over [0,1]. Find the optimal linear combination using estimators 12 [f (U/2) +
f (1 U/2)] and 14 [f (U/2) + f ( 12 U/2) + f ( 12 + U/2) + f (1 U/2)], an
importance sampling estimator and the control variate estimator above. What
is the efficiency gain over crude Monte-Carlo?
A modification of the matlab function optimal will do. OurX matrix is of the
form X = [Y 10 Y 20 Y 30 Y 40] and cov(X) gives the covariance matrix V. Then
with Z = ones(1, 4), V 1 = inv(V ), we find b = V 1 Z/(Z 0 V 1 Z) = [.366
.622 -.217 .229] and the combination
.366Y1 + .622Y2 .217Y3 + .229Y4
has efficiency gain in excess of 60,000.
98. For independent uniform
P random numbers U1 , U2,.... define the random variable
N = minimum{n; ni=1 Ui > 1}.
Estimate E(N ) by crude Monte Carlo simulation and using antithetic random
numbers. What is the efficency of the use of antithetic random numbers. Can
you suggest any other variance reduction techniques? What do you think is the
value of E(N )?
Define the functions hn (x) = P [N > n] = P [U1 + ... + Un x] when x 1.
Then check that h1 (x) = x and
Z x
hn1 (x u)du
hn (x) =
0
X
1
E(N ) =
P (N > n) =
=e
n!
n=0
n=0
44
1
x1/10 ex , x > 0.
(1.1)
Show that generating a random uniform[0,1] U and then using the estimator
1 U2
e (1 + e12U )
2
is better than generating two independent uniform U1 , U2 and using
1
(exp(U12 ) + exp(U22 )).
2
Notice that the antithetic variate estimator is
2
1 2
1 U2
(e + e(1U ) ) = eU (1 + e12U )
2
2
and so this estimator uses antithetic random numbers. Since they are applied to
the function ex which is monotone, it results in a variance reduction. var(exp(u.^2))
gives .2255 and var(.5*(exp(u.^2)+exp((1-u).^2))) gives .0279 so the efficiency gain is around .2255/.0279 or about 8.
101. Ross 8.2 Explain how to use antithetic random numbers to estimate by simulation the value of the integral
Z 1Z 1
exp((x + y)2 )dydx
0
To determine the extent of the variance reduction, this has variance around 11.4
while a crude estimator using only one function evaluation has variance around
36.2. Therefore after adjusting for the number of function evaluations the efficiency gain due to the use of antithetic random numbers is 18.1/11.4 or around
1.6. Very little improvement due to using antithetic random numbers in this
case.
102. Ross 8.3 Let Xi , i = 1, ..., 5 be independent exponential random variables
each with mean 1. Define
5
X
= P[
iXi > 21.6].
i=1
for i=1:10000
u=rand(1,5);
c= [c (sum(-(1:5).*log(u))>21.6)];
a=[a .5*((sum(-(1:5).*log(u))>21.6)+(sum(-(1:5).*log(1-u))>21.6))];
end
[mean(c) mean(a)]
[var(c) var(a)]
results in variances 0.1437 for crude and 0.0582 for antithetic which, after adjusting for the number of function evaluations, implies an
.1437
: 1.234 5 which again gives very little improvement over
efficiency of 2.0582
crude Monte Carlo.
103. Ross 8.4 Show that if X, Y have the same distribution then
var(
X +Y
) var(X)
2
Use this to show that a pair of antithetic random numbers will never have a
larger variance than using a single random number. (However it may be worse
than using two independent random numbers)
Here
46
X +Y
) =
2
1
(var(X) + var(Y ) + 2cov(X, Y ))
4
1
=
(var(X) + cov(X, Y )) var(X)
2
p
p
since cov(X, Y ) var(X) var(Y ) = var(X). The variance using two
independent random numbers is var(X)/2. Using two antithetic random numbers to generate X and Y, cov(X, Y ) 0 and so
var(
var(
X +Y
1
) = (var(X) + cov(X, Y )) var(X)/2
2
2
b
2
b
3
1 3 Z
1
(Z e + (Z)3 eZ ) = Z 3 (eZ eZ )
2
2
3 Z
= Z (e 1)
exp(X 2 /2)
= X 3 eX
where X = + Z
exp((X )2 /2)
=
est=.5*(z.^3).*(exp(z)-exp(-z));
(ans = 6.7509)
4S/ n 0.1
47
where S = 47.69 and this gives n (40S)2 and this is around 3.64
million. This is the number of antithetic pairs required so the total number
of function evaluations is twice this.
105. Ross 8.10
106. Ross 8.6 & 8.9
(a) Give a pair of exponential random variables with mean 2 which are negatively correlated. Repeat for a pair of exponential random variables with
positive correlation.
(b) Explain why it is unusual to achieve much additional variance reduction
from the use of anithetic variates if we use a control variate and then introduce an antithetic variate.
107. Ross 8.12 Show that the variance of a weighted average
var(X + (1 )W )
is minimized over when
=
var(W ) cov(X, W )
var(W ) + var(X) 2cov(X, W )
cov(X, I)
var(X)
48
=
=
E(var(bI|X)) + var(E(bI|X))
var(E(bI|X))
b2 var(g(X)/b)
var(g(X)), X is U [0, 1]
and since e2x as x , this is an integral that does not even converge
(i.e. it is infinite). No wonder we were having trouble with variance reduction. We are chasing infinity. In fact the larger your sample, the larger will the
apparent value of the monte carlo integral be. (g) In general, we might hope
to improve on the estimator eX + X 2 /2 by using a control variate that is a
quadratic function of X, say 0 + 1 X + 2 X 2 . This will have known expected
value 0 + 1 + 2 2 . The coefficients i may be estimated by a preliminary regression. However, there is no hope if the integral we are trying to approximate
is infinite.
113. Ross 8.26
114. Ross 8.27
115. Ross 8.28
116. Ross 8.32
117. Ross 8.33 A system experiences shocks with a Poisson rate of 1 per hour. The
initial damage associated with each shock is a random variable with probability
density function f (x) = xex , x > 0 and after a period of time s following
the shock the residual damage is xes . The system fails when the total damage
at a given time exceeds C. We wish to estimate the probability p that the system
fails by time t. Explain how to use importance sampling to efficiently estimate p
in the case that p is small.
118. Ross 8.35
(a) This result can be shown counting the repetitions of each name.
(b) Use that E{Y|N(x)} = P{Y = 1|N(x)}= 1/N(x).
(c) Use the equalities E{Y} = E{E{Y|N(x)}} and E{1/N(i)} = E{1/N(j)}.
(d) W is a mirror image of Y, so that the argument holds as in (b).
(e) W and Y are negatively correlated which reduces the variance of n(W +
Y)/2.
119. Suggest three different Monte Carlo methods for approximating the integral
E(Z 3 eZ ) where Z is Normal(0, 1). Find the optimal linear combination of
these estimators and determine the efficiency of this optimal linear combination
compared with a crude Monte Carlo estimator. Notice that the function eZ is
50
close to 1 when Z is close to 0 so we might use as a control variate the function g(Z) = Z 3 where E(g(Z) = 0. The control variate estimator is then an
average of values of the form
Z 3 eZ + cZ 3
where c = cov(Z 3 , Z 3 eZ )/var(Z 3 ). Since the function Z 3 eZ is monotone
we may also use antithetic random numbers and average the values of
1 3 Z
(Z e Z 3 eZ )
2
Also since it appears that large values of Z are more important than small
ones to the integral one might use importance sampling, generating X from a
N (, 1) distribution (call the corresponding density function g (x) ) and then
averaging
g0 (X)
X 3 eX
.
g (X)
We could then choose so that the variance of this estimator is, as nearly as
possible, minimized. Note that
X 3 eX
2
g0 (X)
= X 3 eX(1) e /2 .
g (X)
120. Suppose f (X) and g(Y ) are two increasing functions of X and Y respectively, where X and Y are both exponentially distributed random variables
with rate parameters 2 and 3 respectively. How would you (as efficiently as
possible) uses a simulation method to estimate
E[f (X)] E[g(Y )]
where we assume that you have a U [0, 1] random number generator with output
U1 , U2 , . . . Taking into account that Xi = (1/2) ln(Ui ) is an exponential
with rate 2 and Yi = (1/3) ln(Ui ) is an exponential with rate 3, we can use
the same random numbers to generate both expectations. This approach will
reduce the variance because
Var{f(X)-g(X)}=Var{f(X)}+Var{g(X)}-2Cov(f(X),g(X))
where the covariance will be positive.
121. Define
f (x) = x10 ex
and suppose we wish to estimate the integral
Z 1
f (x)dx
=
0
using Monte Carlo integration. Give three methods of using simulation to determine as efficiently as possible.
51
(a) Implement all three of these methods, giving the estimator of using at
most 1000 evaluations of the function f (x). Which of your estimators is
closest to the true value 0.036?
(b) Determine the optimal linear combination of these three estimators and its
efficiency compared with a crude Monte Carlo estimator.
122. Shocks to a system arrive at times according to a Poisson process with parameter
1 (per hour) . Whenever there are five or more shocks within one hour the system
fails. Explain how to simulate the probability p that the system fails within 10
hours using
(a) A crude monte Carlo simulation
(b) Importance sampling designed to reduce the variance of the estimator. For
importance sampling we wish more failures for a more efficient estimator
and this can be achieved by increasing the intensity of the Poisson process.
i.e. run the simulation with intensity of shocks > 1. Let I be the indicator of the event that the system fails. Then compute the average of the
values
f1 (N )
I
f (N )
with N = the number of shocks in the interval [0, 10] This is the only thing
that varies when we change the intensity since given the value of N the
shocks themselves are uniformly distributed on the interval [0,10]) and
f (x) =
(10)x e10
, x = 0, 1, ....
x!
exp(10( 1))
N
Alternatively we could multiply by the ratio of the joint probability density function of N and the N spacings Z1 , Z2 , ...ZN between the shocks
under the Poisson process with parameter . Note that since the Zi are
exponential() random variables, this corresonds to averaging the values
I
QN
I QN
i=1
exp(Zi )
i=1 { exp(Zi )}
= I{N
N
Y
exp(( 1)Zi )}
i=1
= I{N exp(( 1)
N
X
Zi )}
i=1
using Monte Carlo integration. Give estimators based on (i) a control variate
(ii) a stratified sample (iii) importance sampling to determine as efficiently
as possible.
(a) Determine the efficiency of each of these methods compared with crude
Monte Carlo. (i) Notice that the term x1/3 varies between and 21/2
over the range of this integral but the term ex is relatively more stable.
Therefore we might try as a contral variate the function g(x) = x1/3
R2
where 0 x1/3 dx = 32 22/3 . Now = 2E(f (2U )) So average values of
n
2X
3
b
(f (2Ui ) g(2Ui )) + 22/3
CV =
n i=1
2
having efficiency
2var(f (2Ui ))
var(f (Ui )) + var(f (1 + Ui ))
(iii) Suppose we generate X from probability density function g(x) =
cx1/3 , 0 < x < 2 where c = 21/3 31 . X has cumulative distribution
function G(x) = 22/3 x2/3 , 0 < x < 2. Then G1 (U ) = 2U 3/2 and
Z 2
Z 2
1
X
1
x
e g(x)dx =
ex x1/3 dx =
c E(e ) = c
0
53
1 X Xi
b
e
,
IM =
cn i=1
3/2
where Xi = 2Ui
having efficiency
3x2
2
+ x, 0 < x < 1.
Use composi-
126. Suppose Ui, i = 1, 2, 3, ...n are independent uniform [0, 1] random variables
variates and f (X) and g(Y ) are two increasing functions of X and Y
respectively, where X and Y are both exponentially distributed random variables with rate parameters 2 and 3 respectively. How would you (as efficiently
as possible) uses a simulation method to estimate
54
Figure 6:
(a) E[f (X)] E[g(Y )] Use common random numbers to generate X and
1
Y i.e. X = FX
(U ) and Y = FY1 (U ) or alternatively X = 12 ln(U )
1
and Y = 3 ln(U ).
(b) E[f (X)]
Since f is monotone there is a known benefit from use of
anithetic random numbers. e.g. X1 = 12 ln(U ) and X 2 = 12 ln(1 U )
(c) E[f (X)] + E[g(Y )] May generate X and Y using antithetic random
numbers. e.g. X = 12 ln(U ) and Y = 13 ln(1 U ).
For each Explain how to measure the efficiency with respect to a crude
Monte Carlo simulation.
127. Consider the following network of four components ( components are represented by directed arcs).The network operates as long as there is flow permitted
from the input (source) to the output (sink). The arrows indicate the direction
of flow possible. Suppose that the lifetimes of the component i is given by the
random variables Ti , i = 1, 2, ..., 4.
(a) Write an expression involving the random variables Ti , i = 1, 2, ..., 4. for
the lifetime of the system.
(b) Explain how to simulate the expected lifetime of the system if the components have independent lifetimes with an exponential distribution with
expected value 2. Provide one such simulation using the uniform random
numbers below
U .92 .51
.24 .43
.35
ln(U ) .08 .67 1.43 .84 1.05
(c) The first 10 simulations were placed in a vector T of length 10. We then
ran the following in MATLAB,
mean(T)
ans = 1.17
var(T)
ans =0.41
55
k
X
(Ni npi )2
i=1
npi
56
131. Ross 9.3 Approximate the pvalue for the hypothesis that the following 10 values are uniform[0,1] random numbers. [.12, .18, .06, .33, .72, .83, .36, .27, .77, .74]
Here using the Kolmogorov Smirnov test
D = max{
j1
j
U(j) , U(j)
} = 0.24
10
10
9
67
(6 2.37)2
(6 2.01)2
+ ... +
= 18.7
2.37
2.01
We con estimate the p value by repeating these steps: (1) Generate 16 values Xi from Bin(16, .6172). (2) Estimate from the sample the value of p =
P16
1
2
i=1 Xi . (3) Compute the statistic as before but using the bin(8, p)
128
probabilities (4) Determine whether this statistic is >18.7. (5) Repeat steps 1-4
m times to obtain the observed fraction of times the 2 > 18.7. This is the
approximate p value of the test if m is large.
135. Ross 9.7 For the K-S test,
D = .5717
136. Ross 9.8
57
(a)
138. Show that if Qij is a transition matrix of a Markov chain satisfying Qij = Qji
for all i, j, and if we define a new Markov chain transition matrix by
Pij
Pii
b(j)
= Qij min(
, 1), j 6= i
b(i)
X
= 1
Pij
j6=i
b(j)
139. Simulate a Markov Chain on the values {1,2,3,...,20} such that the chain only
moves to neighbouring states (e.g. from 4 to 3 or 5) and the stationary distribution of the chain is i = i/210, i = 1, 2, ...20. For simplicity we assume that
the states 1. and 20 are neighbours. Define b(i) = i for i = 1, 2, ..., 20. In this
case we can use a chain with transition probability matrix
Pij
P1,20
Pii
1
b(j)
min(
, 1), j = i 1 or i + 1, and i = 2, ..., 19
2
b(i)
1
= P20,1 =
X 2
= 1
Pij
=
j6=i
2 2 + 2
2(1 )
2 c2 +2
2(1) .
c /3+
. The shortest queue length corresponds to the constant service
Lq = 2(1)
time (in all cases the expected service time remains the same). In general, for
fixed expected service time, the smaller the variance of service time, the shorter
the queue on average.
143. Consider an M/G/1// queue with the following type of service distribution. Customers require one of two types of service in proportions p, 1 p
and the resulting service times are exponentially distributed with parameters
1 , 2 respectively. Let X be the service time of a random customer. Show that
E(X) = p/1 + (1 p)/2 and var(X) = 2p/21 + 2(1 p)/22 (E(X))2 .
Simulate this queue for values of the parameters = 1, p = .5, and (1 , 2 ) =
(1, 23 ), ( 12 , 2). Use these simulations to check the above Pollaczek-Khintchine
formula. Which values of the parameters seems to result in the shortest queue?
Explain.
59
144. Arrivals to a self-serve gasoline pump occur according to a Poisson process with
arrival rate = 1/2 per minute. There are 4 pumps and the service times (in
minutes) appear to have probability density function f (x) = 34 x2 (2 x) , 0 <
x < 2. Experience shows that only one car will wait for the next available
pump. i.e. if there are more than 5 cars in the system, the next arrival will leave
immediately. If each customer that is served produces an average profit of
$1.00 ,conduct a simulation designed to show whether another pump should be
added. Assume that the lease of an additional pump will cost the gas station
owner a total of 100 dollars per day, that the station remains open for a total of
16 hours during the day.
145. An analyst has developed a queueing model for a parking lot. The lot has space
for N cars, and during the daytime shift, cars arrive at the parking lot following
a Poisson process with rate or intensity function 10 ct cars per hour at time t
where 0 < t < 8, c some constant. The length of time that a car spends in the
lot is assumed to be exponential with mean 1 hour.
(a) Find the equilibrium distribution of the number of cars in the lot in the case
c = 0.
(b) Assuming that a lot with N spaces costs $9 per hour to maintain, (ignore
initial costs of building the lot) and the cars pay $1 per hour to park, what is the
expected net profit from operating the lot when N is very large?
(c) Simulate this system in the case c = 1 using the uniform(0,1) random numbers
0.20 0.60 0.21 0.75 0.93 0.42 0.53 0.67 0.02 0.38
0.25 0.27 0.02 0.45 0.48 0.85 0.29 0.84 0.68 0.83
until there have been at least two departures. Give a table like the following
Clock Time
System State
Future Event List
146. Suppose below that you are able to generate independent U [0, 1] random variables U1 , U2 , . . . Un ..Give a formula or algorithm for generating a single ran3
dom variable X having the probability density function f (x) = 4x2 + 32 x2 , 0 <
x < 1. In this case the c.d.f. is
F (x) =
1
1
F1 (x) + F2 (x)
2
2
where
F1 (x) = x4 , 0 < x < 1
F2 (x) = x3 , 0 < x < 1
wo we can use the composition method. Generate U1 , U2 independent U [0, 1]
and put
X
1/4
if U1 < 1/2
1/3
U2
if U1 1/2
= U2
=
60
i. T1 = 12 [logU1 + logU2 ]
ii. T2 = 12 [log(U1 ) + log(1 U1 )]
For part i, this is the average of two INDEPENDENT exponential
random variables each with parameters 1. For (ii) we have a similar average only the exponential random variables are obtained using
antithetic random numbers. Therefore both have the same mean but
the second average using antithetic random numbers has smaller variance.
150. Give a formula or algorithm for generating a single random variable with probak
bility density function f (x) = x2 +3x+1
, 0 < x < , k = 1.16168, otherwise
f (x) = 0.
In this case it is clear that
f (x)
x2
k
k
= kg(x), say
=
+ 2x + 1
(x + 1)2
Here we can easily generate from the density function g(x) = 1/(1 + x)2 by
inverse transform. G(x) = 1 1/(1 + x) and
G1 (U ) =
61
1
1.
1U
1
1U1
X 2 +2X+1
X 2 +3X+1
g(X) + g(Y )
] = E[g(X)]
2
since X and Y have the same distribution. However the first estimator does
not have the correct expected value, except in the rare case that the function g is
linear. In other words
E(g(
X +Y
) ) 6= E(g(X))
2
If we dont even have the right expected value there is no point in discussing its
variance!
152. Explain what the following MATLAB code is designed to do:
(a) mu=r*T-sigma^2*T/2;
z=norminv(rand(1,100000),mu,sigma*sqrt(T));
ST1=S0*exp(z); ST2=S0*exp(2*mu-z);
v=exp(-r*T)*0.5*(max(ST1-K,0)+max(ST2-K,0));
mean(v)
2
1 rT
[(ST 1 K)+ + (ST 2 K)+ ]
(e
2
is the discounted to present return from two call options, one antithetic to
the other. This is therefore an estimator of the current price of a call option
with exercise price K using antithetic random numbers.
62
153. Suppose we wish to estimate E(X) for X EXP (1) using an estimator of the
form b
= X+Y
where X and Y have the same EXP (1) distribution but may
2
be dependent.
(a) Show that
var(b
) var(X).
i. X, Y independent
ii. X, Y antithetic
R1
iii. X, Y use common random numbers. (Hint: 0 ln(u) ln(1 u)du =
R1
0.355 and 0 (ln(u))2 du = 2).
iv. What is the efficiency of the antithetic and common random numbers
methods compared with crude Monte Carlo.
Part (a) is a simple calculation since
1
(var(X) + var(Y ) + 2cov(X, Y ))
4
1
=
(var(X) + cov(X, Y ))
2
p
p
1
var(b
) =
=
=
1
(var(X) + var(Y ) + 2cov(X, Y ))
4
1
(var(X) + cov(X, Y ))
2
1
(var(X)) = 1/2
2
var(b
) =
63
var(b
) =
var(X)
50
Therefore the estimator is the average of the terms
b
b2 var(X)
> a) (X
EX)) = var(I(T > a))
= 0.0099 (.012)2 (50) = .0027
If we want the average lifetime within .01 we want the width of a 95%
confidence interval
2/ n 0.01
and solving this we obtain
n 16, 400
Corrections to be made:
Question 47 code is for one day but picture is for one month.
69 There is a better choice of c and p available-see Chengs algorithm.
66