Application Center - Maplesoft

App Preview:

Multivariate Distributions In Maple

You can switch back to the summary page by clicking here.

Learn about Maple
Download Application


 

 

Image 

Multivariate Distributions In Maple 

with applications in Finance 

 

 

Igor Hlivka 

MUFG Securities International 

LONDON 

 

 

 

The document demonstrates the extension of Maple's comprehensive Statistical package into multivariate setting. It shows how Maple's symbolic analytics and numerical engines can be seamlessly applied in the field of multivariate statistics. The core concept of multivariate analysis - joint distributions - are discussed in the context of multivariate Normal distribution and particular aspects of "jointness" are presented through marginal and conditional densities. Extension of multinormality into related family of joint distributions is shown on the example of multivariate Student-t distribution. 

 

Application of multivariate analysis is demonstrated in the field of Finance, however many other fields and branches can be naturally explored and tested with the presented set up. 

The Multivariate Normal Distribution 

Similar to the univariate setting, the core concept of mutivariability resides on the Normal Distribution. 

For a given vector of random variables `#mover(mi(`(X[1], X[2], () .. X[n])" align="center" border="0"> we define the Multivariate Normal Distribution as N(`#mover(mi(with mean vector `#mover(mi(`(mu[1], mu[2] .. mu[n])" align="center" border="0"> and variance-covariance matrix Σ. 

 

The probability density then can be defined as:      pdf(`#mover(mi( 

where `#mover(mi(is a vector of real-valued random variables on n-length and Σ is a symmetric and positive definite variance-covariance matrix of `*`(`*`(n, `*`(x)), n) size. The function fully resembles the "familiar" univariate Normal PDF, and indeed with n = 1, the above formula reduces to the univariate density function. 

 

We build the N(`#mover(mi( in several steps: 

  • Create the relevant vectors of RVs, (X)  means (M)  and standard deviations (S)
 

  • Build the correlation (CorrMat) and variance-covariance matrix (CoVar)
 

  • Combine the components into a multinormal PDF
 

 

The Bivariate Normal Distribution 

We will first demonstrate the implementation in the bivariate setting: 

 

> restart; -1; with(Statistics); -1; with(LinearAlgebra); -1; with(plots); -1
 

> `:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 2...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 2...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 2...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 2...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 2...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 2...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 2...
 

 

 

 

 

`:=`(X, Vector[column](%id = 51525216))
`:=`(M, Vector[column](%id = 51808040))
`:=`(S, Vector[column](%id = 65383344))
`:=`(CorrMat, Matrix(%id = 64451508))
Matrix(%id = 163270788) (1.1.1)
 

> `:=`(p1, `/`(`*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(Typesetting:-delayDotProduct(Typesetting:-delayDotProduct(Transpose(`+`(X, `-`(M))), `/`(1, `*`(CoVar))), `+`(X, `-`(M))))))))), `*`(`^`(`+`(`*`(2, `*`(...
`:=`(p1, `/`(`*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(Typesetting:-delayDotProduct(Typesetting:-delayDotProduct(Transpose(`+`(X, `-`(M))), `/`(1, `*`(CoVar))), `+`(X, `-`(M))))))))), `*`(`^`(`+`(`*`(2, `*`(...
`:=`(p1, `/`(`*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(Typesetting:-delayDotProduct(Typesetting:-delayDotProduct(Transpose(`+`(X, `-`(M))), `/`(1, `*`(CoVar))), `+`(X, `-`(M))))))))), `*`(`^`(`+`(`*`(2, `*`(...
 

`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`-`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)))), `*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1])))), `*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`-`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)))), `*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1])))), `*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`-`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)))), `*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1])))), `*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`-`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)))), `*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1])))), `*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`-`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)))), `*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1])))), `*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`-`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)))), `*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1])))), `*`(2, `*`(sigma[2], `*`(x[1], `*...
(1.1.2)
 

This is the desired Bivariate Normal PDF with mean vector M and covariance matrix CoVar. 

We can obtain the standardized version of the density by setting the mean vector to 0 and variance to 1 

 

> `:=`(bistd, eval(bipdf, [mu[1] = 0, mu[2] = 0, sigma[1] = 1, sigma[2] = 1])); 1
 

`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`-`(`*`(`^`(x[1], 2))), `*`(2, `*`(x[1], `*`(rho, `*`(x[2])))), `-`(`*`(`^`(x[2], 2)))))), `*`(`+`(rho, `-`(1)), `*`(`+`(rho, 1)))))))... (1.1.3)
 

The Bivariate CDF can be obtained by integrating the PDF up to a given limit, however the outer integral has be to be computed numerically 

> `:=`(bicdf, `assuming`([int(int(bipdf, x[2] = `+`(`-`(infinity)) .. y[2]), x[1] = `+`(`-`(infinity)) .. y[1])], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); 1
`:=`(bicdf, `assuming`([int(int(bipdf, x[2] = `+`(`-`(infinity)) .. y[2]), x[1] = `+`(`-`(infinity)) .. y[1])], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); 1
 

int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[1], 2)), `-`(`*`(2, `*`(x[1], `*`(mu[1])))), `*`(`^`(mu[1], 2))))), `*`(`^`(sigma[1], 2))))))...
int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[1], 2)), `-`(`*`(2, `*`(x[1], `*`(mu[1])))), `*`(`^`(mu[1], 2))))), `*`(`^`(sigma[1], 2))))))...
(1.1.4)
 

Now we can compute various expectations: 

  • sums
 

  • power sum
 

  • products
 

 

> `:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
`:=`(Y[1], `+`(x[1], x[2])); 1; `:=`(res[1], `assuming`([int(int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity), x[1] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1...
 

 

 

 

 

 

 

 

`+`(x[1], x[2])
`+`(mu[2], mu[1])
`*`(`^`(`+`(x[1], x[2]), 2))
`+`(`*`(`^`(mu[2], 2)), `*`(2, `*`(mu[1], `*`(mu[2]))), `*`(`^`(mu[1], 2)), `*`(`^`(sigma[1], 2)), `*`(2, `*`(sigma[1], `*`(sigma[2], `*`(rho)))), `*`(`^`(sigma[2], 2)))
`*`(x[1], `*`(x[2]))
`+`(`*`(mu[1], `*`(mu[2])), `*`(sigma[1], `*`(sigma[2], `*`(rho))))
`*`(x[1], `*`(exp(x[2])))
`+`(`*`(exp(mu[2]), `*`(exp(`+`(`*`(`/`(1, 2), `*`(`^`(sigma[2], 2))))), `*`(sigma[1], `*`(sigma[2], `*`(rho))))), `*`(exp(mu[2]), `*`(exp(`+`(`*`(`/`(1, 2), `*`(`^`(sigma[2], 2))))), `*`(mu[1])))) (1.1.5)
 

Once the join PDF has been defined, we can compute Marginal and Conditional densities 

Marginal PDF:            f[X] (x)  = int(f[X, Y], y = `+`(`-`(infinity)) .. infinity) 

> `:=`(MarDist[X[1]], `assuming`([int(bipdf, x[2] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); 1; `:=`(MarDist[X[2]], `assuming`([int(bip...
`:=`(MarDist[X[1]], `assuming`([int(bipdf, x[2] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); 1; `:=`(MarDist[X[2]], `assuming`([int(bip...
 

 

`+`(`/`(`*`(`/`(1, 2), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[1], 2)), `-`(`*`(2, `*`(x[1], `*`(mu[1])))), `*`(`^`(mu[1], 2))))), `*`(`^`(sigma[1], 2))))))))), `*`...
`+`(`/`(`*`(`/`(1, 2), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[2], 2)), `-`(`*`(2, `*`(x[2], `*`(mu[2])))), `*`(`^`(mu[2], 2))))), `*`(`^`(sigma[2], 2))))))))), `*`... (1.1.6)
 

Conditional PDF of             

> `:=`(CondDist[XY], simplify(`/`(`*`(bipdf), `*`(MarDist[X[2]])), symbolic)); 1
 

`+`(`/`(`*`(`/`(1, 2), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`^`(`+`(`-`(`*`(rho, `*`(sigma[1], `*`(x[2])))), `*`(rho, `*`(sigma[1], `*`(mu[2]))), `*`(x[1], `*`(sigma[2])), `-`(`*`... (1.1.7)
 

We can define the multivariate Moment Generating Function as the expectation of the vectors product 

Multivariate MGF:                          

 

> `:=`(q, proc (i) options operator, arrow; t[i] end proc); -1; `:=`(T, Vector(N, q)); 1; `:=`(temp1, `assuming`([int(int(`*`(exp(Typesetting:-delayDotProduct(Transpose(T), X)), `*`(bipdf)), x[2] = `+`(...
`:=`(q, proc (i) options operator, arrow; t[i] end proc); -1; `:=`(T, Vector(N, q)); 1; `:=`(temp1, `assuming`([int(int(`*`(exp(Typesetting:-delayDotProduct(Transpose(T), X)), `*`(bipdf)), x[2] = `+`(...
`:=`(q, proc (i) options operator, arrow; t[i] end proc); -1; `:=`(T, Vector(N, q)); 1; `:=`(temp1, `assuming`([int(int(`*`(exp(Typesetting:-delayDotProduct(Transpose(T), X)), `*`(bipdf)), x[2] = `+`(...
`:=`(q, proc (i) options operator, arrow; t[i] end proc); -1; `:=`(T, Vector(N, q)); 1; `:=`(temp1, `assuming`([int(int(`*`(exp(Typesetting:-delayDotProduct(Transpose(T), X)), `*`(bipdf)), x[2] = `+`(...
`:=`(q, proc (i) options operator, arrow; t[i] end proc); -1; `:=`(T, Vector(N, q)); 1; `:=`(temp1, `assuming`([int(int(`*`(exp(Typesetting:-delayDotProduct(Transpose(T), X)), `*`(bipdf)), x[2] = `+`(...
 

 

Vector[column](%id = 150474764)
exp(`+`(`*`(t[2], `*`(mu[2])), `*`(`/`(1, 2), `*`(`^`(sigma[2], 2), `*`(`^`(t[2], 2)))), `*`(sigma[2], `*`(t[2], `*`(rho, `*`(sigma[1], `*`(t[1]))))), `*`(`/`(1, 2), `*`(`^`(t[1], 2), `*`(`^`(sigma[1]... (1.1.8)
 

We can now compute product moments (the first and the second) using MGF 

> `:=`(Mom[1], eval(diff(mgf, t[1], t[2]), [t[1] = 0, t[2] = 0])); 1; `:=`(Mom[2], eval(diff(mgf, t[1], t[1], t[2], t[2]), [t[1] = 0, t[2] = 0])); 1
`:=`(Mom[1], eval(diff(mgf, t[1], t[2]), [t[1] = 0, t[2] = 0])); 1; `:=`(Mom[2], eval(diff(mgf, t[1], t[1], t[2], t[2]), [t[1] = 0, t[2] = 0])); 1
 

 

`+`(`*`(mu[1], `*`(mu[2])), `*`(sigma[1], `*`(sigma[2], `*`(rho))))
`+`(`*`(`^`(sigma[1], 2), `*`(`^`(sigma[2], 2))), `*`(`^`(sigma[1], 2), `*`(`^`(mu[2], 2))), `*`(2, `*`(`^`(sigma[1], 2), `*`(`^`(sigma[2], 2), `*`(`^`(rho, 2))))), `*`(4, `*`(sigma[2], `*`(mu[1], `*`... (1.1.9)
 

One can verify that the first moment is the same as the product expectation EV[3] calculated above 

 

Graphics 

We will present some graphical representation of densities defined above: 

 

Bivariate Standard PDF will exhibit different shapes depending on the correlation coefficient 

> animate(plot3d, [bistd, x[1] = -3 .. 3, x[2] = -3 .. 3, axes = boxed, title = [
animate(plot3d, [bistd, x[1] = -3 .. 3, x[2] = -3 .. 3, axes = boxed, title = [
animate(plot3d, [bistd, x[1] = -3 .. 3, x[2] = -3 .. 3, axes = boxed, title = [
 

Plot
 

> `:=`(numres1, evalf(eval(bicdf, [sigma[1] = 1, sigma[2] = 1, mu[1] = 0, mu[2] = 0, rho = 0]))); -1; plot3d(numres1, y[1] = -2 .. 3, y[2] = -2 .. 3, axes = Boxed, title = [
`:=`(numres1, evalf(eval(bicdf, [sigma[1] = 1, sigma[2] = 1, mu[1] = 0, mu[2] = 0, rho = 0]))); -1; plot3d(numres1, y[1] = -2 .. 3, y[2] = -2 .. 3, axes = Boxed, title = [
`:=`(numres1, evalf(eval(bicdf, [sigma[1] = 1, sigma[2] = 1, mu[1] = 0, mu[2] = 0, rho = 0]))); -1; plot3d(numres1, y[1] = -2 .. 3, y[2] = -2 .. 3, axes = Boxed, title = [
 

Plot
 

This is a Conditional Expectation for x[1]=1..2 

> `:=`(MarExp, `assuming`([int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); -1; `:=`(CondExp, simplify(`/`(`*...
`:=`(MarExp, `assuming`([int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); -1; `:=`(CondExp, simplify(`/`(`*...
`:=`(MarExp, `assuming`([int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); -1; `:=`(CondExp, simplify(`/`(`*...
`:=`(MarExp, `assuming`([int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); -1; `:=`(CondExp, simplify(`/`(`*...
`:=`(MarExp, `assuming`([int(`*`(Y[1], `*`(bipdf)), x[2] = `+`(`-`(infinity)) .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(sigma[1], 0), `>`(sigma[2], 0)])); -1; `:=`(CondExp, simplify(`/`(`*...
 

Plot
 

>
 

 

The Trivariate Normal Distribution 

We can extend the Bivariate PDF for a higher dimension 

> restart; -1; with(Statistics); -1; with(LinearAlgebra); -1; with(plots); -1
 

> `:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 3...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 3...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 3...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 3...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 3...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 3...
`:=`(h, proc (i) options operator, arrow; x[i] end proc); -1; `:=`(g, proc (i) options operator, arrow; mu[i] end proc); -1; `:=`(w, proc (i) options operator, arrow; sigma[i] end proc); -1; `:=`(N, 3...
 

 

 

 

 

`:=`(X, Vector[column](%id = 64708356))
`:=`(M, Vector[column](%id = 62445416))
`:=`(S, Vector[column](%id = 64244124))
`:=`(CorrMat, Matrix(%id = 65150960))
Matrix(%id = 153478288) (1.2.1)
 

We will simplify the covariance matrix, knowing that symmetric matrix     rho[1, 2] = rho[2, 1], rho[1, 3] = rho[3, 1], rho[2, 3] = rho[3, 2] 

At the same time, we will introduce the Trivariate Standard Normal PDF 

 

Maple can handle this complex computational task quite easily... 

 

> `:=`(p2, `/`(`*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(Typesetting:-delayDotProduct(Typesetting:-delayDotProduct(Transpose(`+`(X, `-`(M))), `/`(1, `*`(Covar))), `+`(X, `-`(M))))))))), `*`(`^`(`+`(`*`(2, `*`(...
`:=`(p2, `/`(`*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(Typesetting:-delayDotProduct(Typesetting:-delayDotProduct(Transpose(`+`(X, `-`(M))), `/`(1, `*`(Covar))), `+`(X, `-`(M))))))))), `*`(`^`(`+`(`*`(2, `*`(...
`:=`(p2, `/`(`*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(Typesetting:-delayDotProduct(Typesetting:-delayDotProduct(Transpose(`+`(X, `-`(M))), `/`(1, `*`(Covar))), `+`(X, `-`(M))))))))), `*`(`^`(`+`(`*`(2, `*`(...
`:=`(p2, `/`(`*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(Typesetting:-delayDotProduct(Typesetting:-delayDotProduct(Transpose(`+`(X, `-`(M))), `/`(1, `*`(Covar))), `+`(X, `-`(M))))))))), `*`(`^`(`+`(`*`(2, `*`(...
`:=`(p2, `/`(`*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(Typesetting:-delayDotProduct(Typesetting:-delayDotProduct(Transpose(`+`(X, `-`(M))), `/`(1, `*`(Covar))), `+`(X, `-`(M))))))))), `*`(`^`(`+`(`*`(2, `*`(...
 

 

`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(sigma[3], 2), `*`(`^`(x[1], 2), `*`(`^`(rho[2, 3], 2))))), `*`(2, `*`(`^`(sigma[2], 2), `*`(`^`(sigma[3]...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[2], 2), `*`(`^`(rho[1, 3], 2))), `*`(`^`(x[3], 2), `*`(`^`(rho[1, 2], 2))), `-`(`*`(2, `*`(x[1], `*`(x[2], `*`(rho[1, 3], `*...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[2], 2), `*`(`^`(rho[1, 3], 2))), `*`(`^`(x[3], 2), `*`(`^`(rho[1, 2], 2))), `-`(`*`(2, `*`(x[1], `*`(x[2], `*`(rho[1, 3], `*...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[2], 2), `*`(`^`(rho[1, 3], 2))), `*`(`^`(x[3], 2), `*`(`^`(rho[1, 2], 2))), `-`(`*`(2, `*`(x[1], `*`(x[2], `*`(rho[1, 3], `*...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[2], 2), `*`(`^`(rho[1, 3], 2))), `*`(`^`(x[3], 2), `*`(`^`(rho[1, 2], 2))), `-`(`*`(2, `*`(x[1], `*`(x[2], `*`(rho[1, 3], `*...
`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[2], 2), `*`(`^`(rho[1, 3], 2))), `*`(`^`(x[3], 2), `*`(`^`(rho[1, 2], 2))), `-`(`*`(2, `*`(x[1], `*`(x[2], `*`(rho[1, 3], `*...
(1.2.2)
 

We can now use the Trivariate Standard density to calculate expectations: 

Foe example:       f = `+`(x[1], `*`(x[2], `*`(exp(x[3])))) 

 

> `:=`(YT[3], `+`(x[1], `*`(x[2], `*`(exp(x[3]))))); 1; `:=`(trires[1], `assuming`([int(int(int(`*`(YT[3], `*`(tristd)), x[3] = `+`(`-`(infinity)) .. infinity), x[2] = `+`(`-`(infinity)) .. infinity), x...
`:=`(YT[3], `+`(x[1], `*`(x[2], `*`(exp(x[3]))))); 1; `:=`(trires[1], `assuming`([int(int(int(`*`(YT[3], `*`(tristd)), x[3] = `+`(`-`(infinity)) .. infinity), x[2] = `+`(`-`(infinity)) .. infinity), x...
`:=`(YT[3], `+`(x[1], `*`(x[2], `*`(exp(x[3]))))); 1; `:=`(trires[1], `assuming`([int(int(int(`*`(YT[3], `*`(tristd)), x[3] = `+`(`-`(infinity)) .. infinity), x[2] = `+`(`-`(infinity)) .. infinity), x...
`:=`(YT[3], `+`(x[1], `*`(x[2], `*`(exp(x[3]))))); 1; `:=`(trires[1], `assuming`([int(int(int(`*`(YT[3], `*`(tristd)), x[3] = `+`(`-`(infinity)) .. infinity), x[2] = `+`(`-`(infinity)) .. infinity), x...
 

 

`+`(x[1], `*`(x[2], `*`(exp(x[3]))))
`+`(`-`(`*`(rho[2, 3], `*`(exp(`/`(1, 2)))))) (1.2.3)
 

The expectation in this example is a function of single correlation coefficient: 

> plot(EVT, rho[2, 3] = -1 .. 1, title = [
plot(EVT, rho[2, 3] = -1 .. 1, title = [
 

Plot_2d
 

 

Expectations in trivariate setting are generally more complex and they may exist only for certain set of parameters.  One of the restrictions will apply to covariance matrix which by definition must be positive definite.  

 

The Multivariate Student-t Distribution 

We will now show how simple transformation argument leads to an elegant solution for the multivariate Student-t density. 

We assume that `#mover(mi(`(X[1], X[2], () .. X[n])" align="center" border="0">is a vector of random variables drawn from multivariate normal distribution    N(`#mover(mi(and let other RV  Y be a Chi-Square-distributed quantity with the degree of freedom  ν:        `+`(Y~Chi, `-`(Square(nu)))independent of  `#mover(mi( 

 

Then the joint density of `#mover(mi( and Y  is:            T[k] = `/`(`*`(X[k]), `*`(sqrt(`/`(`*`(Y), `*`(nu))))) 

This relationship then determined the multivariate Student-t distribution with the vector:    `#mover(mi(`(t[1], t[2], () .. t[n])" align="center" border="0">and the correlation matrix  Σ:     t(`#mover(mi( 

 

The Bivariate Student-t Distribution 

We will demonstrate the above theory in bivariate setting. 

Since both `#mover(mi(and Y and independent, we can obtain the joint density of `<,>`(X[1], X[2], U)by simple multiplication of Bivariate Normal and Chi-Square densities 

  • We will first define the Chi-Square PDF using Maple's Statistics package:
 

  • We will recall the definition of the bivariate standard PDF computed in the previous section:
 

 

> restart; -1; with(Statistics); -1; with(LinearAlgebra); -1; with(VectorCalculus); -1; with(plots); -1
 

> `:=`(chipdf, `assuming`([PDF(ChiSquare(nu), u)], [`>`(u, 0)])); 1
 

`/`(`*`(`^`(u, `+`(`*`(`/`(1, 2), `*`(nu)), `-`(1))), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(u))))))), `*`(`^`(2, `+`(`*`(`/`(1, 2), `*`(nu)))), `*`(GAMMA(`+`(`*`(`/`(1, 2), `*`(nu))))))) (2.1.1)
 

> `:=`(bistd, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[1], 2)), `-`(`*`(2, `*`(x[1], `*`(rho, `*`(x[2]))))), `*`(`^`(x[2], 2))))), `*`(`+`(rho, `-`(1)), `*`(`+`(rho, 1))))...
 

`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[1], 2)), `-`(`*`(2, `*`(x[1], `*`(rho, `*`(x[2]))))), `*`(`^`(x[2], 2))))), `*`(`+`(rho, `-`(1)), `*`(`+`(rho, 1)))))))), `*`(`^... (2.1.2)
 

Then the joint PDF   psi(x[1], x[2], u) can be expressed as: 

> `:=`(psi, `*`(bistd, `*`(chipdf))); 1
 

`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[1], 2)), `-`(`*`(2, `*`(x[1], `*`(rho, `*`(x[2]))))), `*`(`^`(x[2], 2))))), `*`(`+`(rho, `-`(1)), `*`(`+`(rho, 1)))))), `*`(`^`(... (2.1.3)
 

We now want to transform this PDF product into a Student-t quantities:  T[k] 

  • We apply the change of variables transformation
 

  • Obtain the determinant of the Jacobian
 

  • Substitute the result into ψ
 

> `:=`(g1, `/`(`*`(x[1]), `*`(sqrt(`/`(`*`(u), `*`(nu)))))); -1; `:=`(g2, `/`(`*`(x[2]), `*`(sqrt(`/`(`*`(u), `*`(nu)))))); -1; `:=`(g3, u); -1; `:=`(h1, solve(g1 = t[1], x[1])); -1; `:=`(h2, solve(g2 =...
`:=`(g1, `/`(`*`(x[1]), `*`(sqrt(`/`(`*`(u), `*`(nu)))))); -1; `:=`(g2, `/`(`*`(x[2]), `*`(sqrt(`/`(`*`(u), `*`(nu)))))); -1; `:=`(g3, u); -1; `:=`(h1, solve(g1 = t[1], x[1])); -1; `:=`(h2, solve(g2 =...
`:=`(g1, `/`(`*`(x[1]), `*`(sqrt(`/`(`*`(u), `*`(nu)))))); -1; `:=`(g2, `/`(`*`(x[2]), `*`(sqrt(`/`(`*`(u), `*`(nu)))))); -1; `:=`(g3, u); -1; `:=`(h1, solve(g1 = t[1], x[1])); -1; `:=`(h2, solve(g2 =...
`:=`(g1, `/`(`*`(x[1]), `*`(sqrt(`/`(`*`(u), `*`(nu)))))); -1; `:=`(g2, `/`(`*`(x[2]), `*`(sqrt(`/`(`*`(u), `*`(nu)))))); -1; `:=`(g3, u); -1; `:=`(h1, solve(g1 = t[1], x[1])); -1; `:=`(h2, solve(g2 =...
 

`/`(`*`(nu), `*`(u)) (2.1.4)
 

> `:=`(biprod2, `assuming`([simplify(`/`(`*`(algsubs(x[1] = h1, algsubs(x[2] = h2, psi))), `*`(abs(Jdet))))], [`>`(u, 0), `>`(nu, 0)])); -1; `:=`(biprod3, algsubs(u = h3, biprod2)); 1
`:=`(biprod2, `assuming`([simplify(`/`(`*`(algsubs(x[1] = h1, algsubs(x[2] = h2, psi))), `*`(abs(Jdet))))], [`>`(u, 0), `>`(nu, 0)])); -1; `:=`(biprod3, algsubs(u = h3, biprod2)); 1
 

`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(t[1], 2)), `-`(`*`(2, `*`(rho, `*`(t[2], `*`(t[1]))))), `*`(`^`(t[2], 2)), `-`(`*`(nu, `*`(`^`(rho, 2)))), nu), `*`(y))), `*`(nu, ... (2.1.5)
 

This is the transformed density expressed in terms of t-parameters:   `<,>`(t[1], t[2], y) 

We will now obtain the bivariate t-density by integrating the above density over y 

 

> `assuming`([int(biprod3, y = 0 .. infinity)], [`and`(`<`(-1, rho), `<`(rho, 1)), `>`(nu, 0)]); 1
 

int(`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(t[1], 2)), `-`(`*`(2, `*`(rho, `*`(t[2], `*`(t[1]))))), `*`(`^`(t[2], 2)), `-`(`*`(nu, `*`(`^`(rho, 2)))), nu), `*`(y))), `*`(... (2.1.6)
 

The crude integration des not work due to ambiguity of the integrand in the exponential term 

Noting that the term `+`(`-`(`*`(`^`(t[1], 2))), `*`(2, `*`(rho, `*`(t[2], `*`(t[1])))), `-`(`*`(`^`(t[2], 2))), `*`(nu, `*`(`^`(rho, 2))), `-`(nu))is negative, we can integrate with this assumption 

  • Make the term substitution
 

  • Integrate
 

  • Make the reverse substitution
 

 

We can verify and examine the negativity of the exponent term visually: 

 

> `:=`(expterm, `+`(`-`(`*`(`^`(t[1], 2))), `*`(2, `*`(rho, `*`(t[2], `*`(t[1])))), `-`(`*`(`^`(t[2], 2))), `*`(nu, `*`(`^`(rho, 2))), `-`(nu))); -1; animate(plot3d, [eval(expterm, [nu = 3]), t[1] = -3 ...
`:=`(expterm, `+`(`-`(`*`(`^`(t[1], 2))), `*`(2, `*`(rho, `*`(t[2], `*`(t[1])))), `-`(`*`(`^`(t[2], 2))), `*`(nu, `*`(`^`(rho, 2))), `-`(nu))); -1; animate(plot3d, [eval(expterm, [nu = 3]), t[1] = -3 ...
`:=`(expterm, `+`(`-`(`*`(`^`(t[1], 2))), `*`(2, `*`(rho, `*`(t[2], `*`(t[1])))), `-`(`*`(`^`(t[2], 2))), `*`(nu, `*`(`^`(rho, 2))), `-`(nu))); -1; animate(plot3d, [eval(expterm, [nu = 3]), t[1] = -3 ...
`:=`(expterm, `+`(`-`(`*`(`^`(t[1], 2))), `*`(2, `*`(rho, `*`(t[2], `*`(t[1])))), `-`(`*`(`^`(t[2], 2))), `*`(nu, `*`(`^`(rho, 2))), `-`(nu))); -1; animate(plot3d, [eval(expterm, [nu = 3]), t[1] = -3 ...
 

Plot
 

As chart shows, the expterm will always stay negative, hence the integration with the negativity assumption is acceptable 

 

> `:=`(intsubs, algsubs(`+`(`-`(`*`(`^`(t[1], 2))), `*`(2, `*`(rho, `*`(t[2], `*`(t[1])))), `-`(`*`(`^`(t[2], 2))), `*`(nu, `*`(`^`(rho, 2))), `-`(nu)) = a, biprod3)); 1; `assuming`([simplify(int(expand...
`:=`(intsubs, algsubs(`+`(`-`(`*`(`^`(t[1], 2))), `*`(2, `*`(rho, `*`(t[2], `*`(t[1])))), `-`(`*`(`^`(t[2], 2))), `*`(nu, `*`(`^`(rho, 2))), `-`(nu)) = a, biprod3)); 1; `assuming`([simplify(int(expand...
`:=`(intsubs, algsubs(`+`(`-`(`*`(`^`(t[1], 2))), `*`(2, `*`(rho, `*`(t[2], `*`(t[1])))), `-`(`*`(`^`(t[2], 2))), `*`(nu, `*`(`^`(rho, 2))), `-`(nu)) = a, biprod3)); 1; `assuming`([simplify(int(expand...
 

 

`+`(`/`(`*`(`/`(1, 4), `*`(exp(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(y, `*`(a))), `*`(nu, `*`(`+`(rho, `-`(1)), `*`(`+`(rho, 1)))))))), `*`(`^`(y, `+`(`*`(`/`(1, 2), `*`(nu)))), `*`(`^`(2, `+`(`-`(`*`(`/`(1,...
`+`(`-`(`/`(`*`(`/`(1, 2), `*`(`^`(nu, `+`(`*`(`/`(1, 2), `*`(nu)), 1)), `*`(`^`(`+`(1, `-`(`*`(`^`(rho, 2)))), `/`(1, 2)), `*`(`^`(`+`(rho, 1), `+`(`*`(`/`(1, 2), `*`(nu)))), `*`(`^`(`+`(`-`(`*`(`^`(... (2.1.7)
 

This is the desired Bivariate Student-t density  phi(t[1], t[2], nu) 

We can plot it 

> plot3d(eval(phi, [rho = 0, nu = 3]), t[1] = -3 .. 3, t[2] = -3 .. 3, title = [
plot3d(eval(phi, [rho = 0, nu = 3]), t[1] = -3 .. 3, t[2] = -3 .. 3, title = [
 

Plot
 

>
 

 

Application in Finance 

We now demonstrate how multivariate analysis can be applied in problems solving arising in Financial Economics. 

Two particular cases will be reviewed here: 

  • Derivation of a hedging scheme
 

  • Valuation of spread options
 

 

Formal derivation of the hedging concept 

Hedging is a transactional process that aims to minimize the risk of the trader's activity. In short, hedging typically refers to the risk offsetting. The risk can be associated with a single transaction (the trade risk) or a number of individual transactions (portfolio risk). 

 

Following trader's activity (buying or selling of financial product), an institution ends up with the position which value can be formally described as:  `*`(A, `*`(x[1])) 

where:                         A = amount    and      x[1]            represents a risky financial product where price changes follow a Normal Distribution:      N(mu, sigma) 

To eliminate the fluctuation in the value of the position, an institution considers hedging programme, i.e. taking position in different instrument - say x[2] - in order to eliminate the risk. 

The task is to determine the quantity of hedging instrument - say amount B -  that minimizes the value fluctuation of the original transaction. 

 

We assume that the hedging instrument  x[2]  is a financial product that similar to x[1] follows a Normal Distribution.  Once the quantity `*`(B, `*`(x[2])) is added to the original transaction, the risk is not any longer univariate (two instruments now constitute a mini-portfolio), but now is governed by a bivariate normal distribution      N[2](mu[1], mu[2], sigma[1], sigma[2], rho) 

To present this case formally: 

  • We will create the portfolio of two instruments     `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))
 

  • Compute the first two moments - mean and variance
 

 

> restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
restart; -1; with(plots); -1; `:=`(port, `+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))); 1; `:=`(bipdf, `+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2)...
 

 

 

 

`+`(`*`(A, `*`(x[1])), `*`(B, `*`(x[2])))
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2))), `-`(`*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1]))))), `-`(`*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2))), `-`(`*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1]))))), `-`(`*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2))), `-`(`*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1]))))), `-`(`*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2))), `-`(`*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1]))))), `-`(`*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2))), `-`(`*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1]))))), `-`(`*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[2], 2), `*`(`^`(x[1], 2))), `-`(`*`(2, `*`(x[1], `*`(`^`(sigma[2], 2), `*`(mu[1]))))), `-`(`*`(2, `*`(sigma[2], `*`(x[1], `*...
`+`(`*`(B, `*`(mu[2])), `*`(mu[1], `*`(A)))
`+`(`*`(`^`(A, 2), `*`(`^`(sigma[1], 2))), `*`(2, `*`(A, `*`(sigma[1], `*`(B, `*`(rho, `*`(sigma[2])))))), `*`(`^`(sigma[2], 2), `*`(`^`(B, 2)))) (3.1.1)
 

The reader can see that we have computed the portfolio variance EV2by the formula:     Var = `+`(E(`*`(`^`(X, 2))), `-`(`*`(`^`(E(X), 2)))) 

 

Given our objectives, we want to minimize the portfolio's risk, i.e. variance. Although Maple's  Optimization routines can be used here, we will apply step-by-step procedures to derive this result explicitly. 

 

We will: 

  • Differentiate the portfolio variance EV2w.r.t B
 

  • Set this to zero
 

  • Solve the equation for the quantity B
 

 

> B = solve(diff(EV2, B) = 0, B); 1
 

B = `+`(`-`(`/`(`*`(A, `*`(sigma[1], `*`(rho))), `*`(sigma[2])))) (3.1.2)
 

This is the solution to our problem - we have determined the quantity B = `+`(`-`(`/`(`*`(A, `*`(sigma[1], `*`(rho))), `*`(sigma[2])))) that needs to added to the existing position A to minimize the risk.   

The B quantity will be: 

  • positive        if    (i) correlation is negative   or (ii) amount A is negative    (the so-called short position)
 

  • negative        if    (i) correlation is positive   or (ii) amount A is positive    (the so-called long position)
 

 

We still need to verify that this is the minimum (rather than maximum) 

The standard condition for minimizations problems stipulates that        

 

> `:=`(MinTest, diff(EV2, B, B)); 1
 

`+`(`*`(2, `*`(`^`(sigma[2], 2)))) (3.1.3)
 

The seconded derivative of the portfolio's variance  EV2   - MinTest   is always positive, so adding the quantity B shown above is indeed the solution to our minimization exercise.  

 

As seen from above, the efficiency of the hedging is a function of three variables:    sigma[1], sigma[2], rhovolatility of individual assets and the correlation between the two instruments.  

How sensitive is the this amount to the functional input? 

  • The quantity is primarily affected by the volatility of the hedging instrument  sigma[2]
 

  • When sigma[2] is low, the correlation rho will have more pronounced impact on the hedging scheme
 

  • For higher values of correlation effect will diminish
 

  • This is confirmed in the animation chart below:
 

> `:=`(Bquant, solve(diff(EV2, B) = 0, B)); -1; animate(plot3d, [eval(Bquant, A = 1), sigma[1] = 0.5e-1 .. .3, sigma[2] = .3 .. 0.5e-1, axes = framed, title = [
`:=`(Bquant, solve(diff(EV2, B) = 0, B)); -1; animate(plot3d, [eval(Bquant, A = 1), sigma[1] = 0.5e-1 .. .3, sigma[2] = .3 .. 0.5e-1, axes = framed, title = [
`:=`(Bquant, solve(diff(EV2, B) = 0, B)); -1; animate(plot3d, [eval(Bquant, A = 1), sigma[1] = 0.5e-1 .. .3, sigma[2] = .3 .. 0.5e-1, axes = framed, title = [
 

Plot
 

>
 

 

 

Spread Options 

Spread options naturally arise in Finance when optionality on future value is taken w.r.t  two assets. Spread in finance is usually defined as a difference between the two quantities and can be expressed in terms of difference in (i) prices, (ii) yields, (iii) rates or (iv) spreads themselves (eg. credit spreads). 

Spreads options are designed and traded to manage future expectations of assets behavior and allow monetisation of a particular view on their direction and dependency 

  • If trader expects the spread between two instruments to widen beyond a certain level (the strike),  he(she) will buy a Call Option (benefits if `>`(`*`(Future, `*`(Spread)), Strike)
 

  • If, on the other hand, trader predicts the narrowing of the spread, he(she) will buy a Put Option (benefits if `<`(`*`(Future, `*`(Spread)), Strike)
 

 

Mathematically, spread options are class of truncated expectations where the expectation is taken w.r.t joint distribution of two instruments in the defined bivariate space. 

To value the spread option, we will define: 

 

  • each instrument own stochastic process  (here we assume that the underlyings are "rates" instruments)
 

  • Instrument[1] = S
 

  • Instrument[2] = U
 

  • joint distribution
 

  • option types  Call and Put Spread Option
 

> restart; -1; `:=`(ST, `*`(S, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2))))), T), `*`(sigma[1], `*`(sqrt(T), `*`(x[1])))))))); 1; `:=`(UT, `*`(U, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2),...
restart; -1; `:=`(ST, `*`(S, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2))))), T), `*`(sigma[1], `*`(sqrt(T), `*`(x[1])))))))); 1; `:=`(UT, `*`(U, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2),...
restart; -1; `:=`(ST, `*`(S, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2))))), T), `*`(sigma[1], `*`(sqrt(T), `*`(x[1])))))))); 1; `:=`(UT, `*`(U, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2),...
restart; -1; `:=`(ST, `*`(S, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2))))), T), `*`(sigma[1], `*`(sqrt(T), `*`(x[1])))))))); 1; `:=`(UT, `*`(U, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2),...
restart; -1; `:=`(ST, `*`(S, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2))))), T), `*`(sigma[1], `*`(sqrt(T), `*`(x[1])))))))); 1; `:=`(UT, `*`(U, `*`(exp(`+`(`*`(`+`(`-`(`*`(`/`(1, 2),...
 

 

 

`*`(S, `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T)))), `*`(sigma[1], `*`(`^`(T, `/`(1, 2)), `*`(x[1])))))))
`*`(U, `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[2], 2), `*`(T)))), `*`(sigma[2], `*`(`^`(T, `/`(1, 2)), `*`(x[2])))))))
`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(x[1], 2)), `-`(`*`(2, `*`(x[1], `*`(rho, `*`(x[2]))))), `*`(`^`(x[2], 2))))), `*`(`+`(rho, `-`(1)), `*`(`+`(rho, 1)))))))), `*`(`^... (3.2.1)
 

> `:=`(lambda, `+`(ST, `-`(UT))); -1; `:=`(Pmt, proc (z) options operator, arrow; `if`(z = C, `+`(lambda, `-`(K)), `+`(K, `-`(lambda))) end proc); -1; Pmt(C); 1
 

`+`(`*`(S, `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T)))), `*`(sigma[1], `*`(`^`(T, `/`(1, 2)), `*`(x[1]))))))), `-`(`*`(U, `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[2], 2), `*`(T))... (3.2.2)
 

The formula above is the "adjusted"payoff of the Call Spread Option in the raw format. It differs from the standard notation by having the usual Max(0.....) notation removed, since we will value this option by taking the discounted expectation of the payoff function over the "eligible" positive domain. 


The trick to value an option in bivariate setting is to determine the correct limits of integration for each stochastic variable. We will achieve this in three steps:
 

  • Determine the critical threshold for which the stochastic variable takes greater or lower value  -  we compute this threshold w.r.t   x[1]
 

  • Perform the integration using this critical limit in the inner space
 

  • Keep the outer integration along the whole variable domain  for the second variable  -   x[2]
 

> `:=`(crtval, solve(lambda = K, x[1])); 1
 

`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(`^`(sigma[1], 2), `*`(T)), `*`(2, `*`(ln(`/`(`*`(`+`(`*`(U, `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[2], 2), `*`(T)))), `*`(sigma[2], `*`(`^`(T, `/`(1, 2)), `*`(... (3.2.3)
 

This is the required critical threshold 

  • For Call Option - to ensure the posiitivity of the payoff - we will integrate the probability-weighted payoff  from    Crtval .. infinity
 

  • For Put Option - to stay positive- we will do the opposite:  `+`(`-`(infinity)) .. Crtval
 

> `:=`(lowlimit, crtval); -1; `:=`(highlimit, infinity); -1; `:=`(CallOpt, `*`(DF, `*`(Int(Int(`*`(Pmt(C), `*`(bistd)), x[1] = lowlimit .. highlimit), x[2] = `+`(`-`(infinity)) .. infinity)))); 1
`:=`(lowlimit, crtval); -1; `:=`(highlimit, infinity); -1; `:=`(CallOpt, `*`(DF, `*`(Int(Int(`*`(Pmt(C), `*`(bistd)), x[1] = lowlimit .. highlimit), x[2] = `+`(`-`(infinity)) .. infinity)))); 1
`:=`(lowlimit, crtval); -1; `:=`(highlimit, infinity); -1; `:=`(CallOpt, `*`(DF, `*`(Int(Int(`*`(Pmt(C), `*`(bistd)), x[1] = lowlimit .. highlimit), x[2] = `+`(`-`(infinity)) .. infinity)))); 1
 

`*`(DF, `*`(Int(Int(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(S, `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T)))), `*`(sigma[1], `*`(`^`(T, `/`(1, 2)), `*`(x[1]))))))), `-`(`*`(U, `*`(exp(`+`(`...
`*`(DF, `*`(Int(Int(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(S, `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T)))), `*`(sigma[1], `*`(`^`(T, `/`(1, 2)), `*`(x[1]))))))), `-`(`*`(U, `*`(exp(`+`(`...
`*`(DF, `*`(Int(Int(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*`(S, `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T)))), `*`(sigma[1], `*`(`^`(T, `/`(1, 2)), `*`(x[1]))))))), `-`(`*`(U, `*`(exp(`+`(`...
(3.2.4)
 

This is the desired Call Spread Option expression - a discounted expectation w.r.t bivariate standard normal density with correlation ρ. The discounting is performed with the DF expression outside the integral. 

 

> `assuming`([value(CallOpt)], [`>`(S, 0), `>`(U, 0), `>`(T, 0), `>`(sigma[1], 0), `>`(sigma[2], 0), `and`(`<`(-1, rho), `<`(rho, 1))]); 1
 

`*`(DF, `*`(int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(x[2], 2)))), `-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T, `*`(`^`(rho, 2)))))), `-`(`*`(`/`(...
`*`(DF, `*`(int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(x[2], 2)))), `-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T, `*`(`^`(rho, 2)))))), `-`(`*`(`/`(...
`*`(DF, `*`(int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(x[2], 2)))), `-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T, `*`(`^`(rho, 2)))))), `-`(`*`(`/`(...
`*`(DF, `*`(int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(x[2], 2)))), `-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T, `*`(`^`(rho, 2)))))), `-`(`*`(`/`(...
`*`(DF, `*`(int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(x[2], 2)))), `-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T, `*`(`^`(rho, 2)))))), `-`(`*`(`/`(...
`*`(DF, `*`(int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(x[2], 2)))), `-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T, `*`(`^`(rho, 2)))))), `-`(`*`(`/`(...
`*`(DF, `*`(int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(x[2], 2)))), `-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T, `*`(`^`(rho, 2)))))), `-`(`*`(`/`(...
`*`(DF, `*`(int(`+`(`-`(`/`(`*`(`/`(1, 4), `*`(`^`(2, `/`(1, 2)), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(x[2], 2)))), `-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T, `*`(`^`(rho, 2)))))), `-`(`*`(`/`(...
(3.2.5)
 

Maple returns a semi-analytical result that, unfortunately, cannot be evaluated symbolically any further, so we need to resort to numerical routines, which Maples handles with ease. 

All we need is to assign numerical values to each parameter and numerically integrate: 

We use the particular case: 

  • Rate[1]                       S = 4.50%
 

  • Rate[2]                      U = 4.60%
 

  • Strike                         K = 0.20%
 

  • σ[1] = 18%
 

  • σ[2] = 15%
 

  • Correlation between S and U:      ρ=0.65
 

  • Option maturity   T  = 1  (year)
 

  • Discount factor       DF = 0.96
 

 

Here we are valuating a call option that pays  the unit of currency (i.e. $1 or ?1 ) if in one year from now the S - U > 0.20%    (irrespective of the fact that today U > S) 

 

> `:=`(NumCall, evalf(eval(CallOpt, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1
`:=`(NumCall, evalf(eval(CallOpt, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1
 

0.1300748182e-2 (3.2.6)
 

This is the Call Option Premium obtained numerically. 

 

Now, what is the sensitivity of the option premium w.r.t functional input? 

Although we have computed the value numerically, this does not impact Maple's productivity or efficiency: 

  • It can first perform the differentiation symbolically
 

  • Evaluate the result numerically
 

 

For example, we can compute the option's sensitivity w.r.t. each underling rate  - the deltas  for  S and U 

 

> `:=`(SDelta, diff(CallOpt, S)); 1; `:=`(SNumDelta, evalf(eval(SDelta, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1; `:=`(UDelta, diff(CallOp...
`:=`(SDelta, diff(CallOpt, S)); 1; `:=`(SNumDelta, evalf(eval(SDelta, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1; `:=`(UDelta, diff(CallOp...
`:=`(SDelta, diff(CallOpt, S)); 1; `:=`(SNumDelta, evalf(eval(SDelta, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1; `:=`(UDelta, diff(CallOp...
`:=`(SDelta, diff(CallOpt, S)); 1; `:=`(SNumDelta, evalf(eval(SDelta, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1; `:=`(UDelta, diff(CallOp...
`:=`(SDelta, diff(CallOpt, S)); 1; `:=`(SNumDelta, evalf(eval(SDelta, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1; `:=`(UDelta, diff(CallOp...
`:=`(SDelta, diff(CallOpt, S)); 1; `:=`(SNumDelta, evalf(eval(SDelta, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1; `:=`(UDelta, diff(CallOp...
`:=`(SDelta, diff(CallOpt, S)); 1; `:=`(SNumDelta, evalf(eval(SDelta, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, rho = .65, DF = .96]))); 1; `:=`(UDelta, diff(CallOp...
 

 

 

 

`*`(DF, `*`(Int(Int(`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T)))), `*`(sigma[1], `*`(`^`(T, `/`(1, 2)), `*`(x[1]))))), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*...
`*`(DF, `*`(Int(Int(`+`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[1], 2), `*`(T)))), `*`(sigma[1], `*`(`^`(T, `/`(1, 2)), `*`(x[1]))))), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+`(`*...
.3331803264
`*`(DF, `*`(Int(Int(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[2], 2), `*`(T)))), `*`(sigma[2], `*`(`^`(T, `/`(1, 2)), `*`(x[2]))))), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+...
`*`(DF, `*`(Int(Int(`+`(`-`(`/`(`*`(`/`(1, 2), `*`(exp(`+`(`-`(`*`(`/`(1, 2), `*`(`^`(sigma[2], 2), `*`(T)))), `*`(sigma[2], `*`(`^`(T, `/`(1, 2)), `*`(x[2]))))), `*`(exp(`+`(`/`(`*`(`/`(1, 2), `*`(`+...
-.2848584336 (3.2.7)
 

What do these values mean? 

  • If the value of the rate S changes by +1%, then the call option premium will increase by 0.33%
 

  • If the value of the rate U increases by 1% then the call option premium will drop by 0.28%
 

 

Maple can be equally efficient in computing any other desired comparative static - gamma (2nd derivative w.r.t rate), vega (derivative w.r.t sigma) etc. 

Reader can verify that in the spread option case, the sensitivity set increases by the factor of two - we will have two deltas, two gammas etc. 

 

At the same time, for example, we can visualize the impact of a certain parameter - such as correlation- on the call option premium computed above: 

 

> plot(evalf(eval(CallOpt, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, DF = .96])), rho = .1 .. .7, title = [
plot(evalf(eval(CallOpt, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, DF = .96])), rho = .1 .. .7, title = [
plot(evalf(eval(CallOpt, [S = 0.45e-1, U = 0.46e-1, T = 1, K = 0.2e-2, sigma[1] = .18, sigma[2] = .15, DF = .96])), rho = .1 .. .7, title = [
 

Plot_2d
 

As seen from the chart, the option premium will increase when the correlation gets lower and will gradually decrease as the correlation increases - as expected. The curvature on the graph also reveals that the relationship between the premium and the correlation is non-linear. 

 

 

Conclusion 

 

This short presentation shows the ways how Maple's univariate statistical analysis can be easily extended into multivariate platform. The centered focus resides on the Multivariate Normal Distribution that with the help of suitable transformation can be turned into other multivariate distributions.  

 

Two particular examples from Finance demonstrate the advantages of using CAS platforms in applied multivariate analysis. Maple, as the above examples highlight, is well suited and flexible to handle these tasks well. 

 

 

 

 

Legal Notice: The copyright for this application is owned by the author(s). Neither Maplesoft nor the author are responsible for any errors contained within and are not liable for any damages resulting from the use of this material. This application is intended for non-commercial, non-profit use only. Contact the author for permission if you wish to use this application in for-profit activities.