In the previous tutorial we used variables and methods to find properties and traits of the Normal distribution. Before that we looked at statistical methods and construction of the Normal distribution. In this tutorial we look at multivariate distributions, which should feel similar to univariate distributions.
Construction of a multivariate distribution is identical to a univariate distribution, except that a vector input is likely to be required for one of the parameters. In keeping with our running Normal example, we will now use the Multivariate Normal distribution.
MN <- MultivariateNormal$new(mean = c(0,0), cov = c(1,0,0,1)) MultivariateNormal$new() # This is in fact the default #> MultiNorm(mean = c(0, 0), cov = c(1, 0, 0, 1), prec = c(1, 0, 0, 1))
Notice how this is almost identical to constructing a univariate Normal distribution. We even allow multiple parameterisations
The biggest difference between univariate and multivariate distributions is in how arguments are passed to the d/p/q/r methods. This differs slightly from R stats. For example to evaluate the pdf of the multinomial distribution at (1,2) in R stats we would run
Whereas in distr6, each point is its own argument
There is a very important reason for this: vectorisation. In R stats there is no way to generate multiple points from a multivariate distribution, whereas in distr6…
In this tutorial we looked at multivariate distributions and discussed the difference between distr6 and R stats in using the d/p/q/r functions. The next tutorial concludes the ‘Basic’ set of tutorials with a look at listing in distr6 to help you navigate the package more easily.