1 #ifndef __STAN__PROB__DISTRIBUTIONS__MULTIVARIATE__CONTINUOUS__WISHART_HPP__
2 #define __STAN__PROB__DISTRIBUTIONS__MULTIVARIATE__CONTINUOUS__WISHART_HPP__
10 #include <boost/concept_check.hpp>
46 template <
bool propto,
47 typename T_y,
typename T_dof,
typename T_scale,
49 typename boost::math::tools::promote_args<T_y,T_dof,T_scale>::type
50 wishart_log(
const Eigen::Matrix<T_y,Eigen::Dynamic,Eigen::Dynamic>& W,
52 const Eigen::Matrix<T_scale,Eigen::Dynamic,Eigen::Dynamic>& S,
54 static const char*
function =
"stan::prob::wishart_log(%1%)";
58 using boost::math::tools::promote_args;
61 typename promote_args<T_y,T_dof,T_scale>::type lp(0.0);
63 "Degrees of freedom parameter", &lp, Policy()))
73 Eigen::LLT< Eigen::Matrix<T_y,Eigen::Dynamic,Eigen::Dynamic> > LLT_W = W.llt();
74 if (LLT_W.info() != Eigen::Success) {
75 lp = stan::math::policies::raise_domain_error<T_y>(
function,
76 "W is not positive definite (%1%)",
80 Eigen::LLT< Eigen::Matrix<T_scale,Eigen::Dynamic,Eigen::Dynamic> > LLT_S = S.llt();
81 if (LLT_S.info() != Eigen::Success) {
82 lp = stan::math::policies::raise_domain_error<T_scale>(
function,
83 "S is not positive definite (%1%)",
88 Eigen::Matrix<T_y,Eigen::Dynamic,Eigen::Dynamic> L_W = LLT_W.matrixL();
89 Eigen::Matrix<T_scale,Eigen::Dynamic,Eigen::Dynamic> L_S = LLT_S.matrixL();
96 lp += nu * k * NEG_LOG_TWO_OVER_TWO;
102 lp -= nu * L_S.diagonal().array().log().sum();
106 Eigen::Matrix<T_scale,Eigen::Dynamic,1> S_inv_vec = Eigen::Map<
107 const Eigen::Matrix<T_scale,Eigen::Dynamic,Eigen::Dynamic> >(
108 &L_S(0), L_S.size(), 1);
109 Eigen::Matrix<T_y,Eigen::Dynamic,1> W_vec = Eigen::Map<
110 const Eigen::Matrix<T_y,Eigen::Dynamic,Eigen::Dynamic> >(
116 lp += (nu - k - 1.0) * L_W.diagonal().array().log().sum();
120 template <
bool propto,
121 typename T_y,
typename T_dof,
typename T_scale>
123 typename boost::math::tools::promote_args<T_y,T_dof,T_scale>::type
124 wishart_log(
const Eigen::Matrix<T_y,Eigen::Dynamic,Eigen::Dynamic>& W,
126 const Eigen::Matrix<T_scale,Eigen::Dynamic,Eigen::Dynamic>& S) {
131 template <
typename T_y,
typename T_dof,
typename T_scale,
134 typename boost::math::tools::promote_args<T_y,T_dof,T_scale>::type
135 wishart_log(
const Eigen::Matrix<T_y,Eigen::Dynamic,Eigen::Dynamic>& W,
137 const Eigen::Matrix<T_scale,Eigen::Dynamic,Eigen::Dynamic>& S,
139 return wishart_log<false>(W,nu,S,Policy());
143 template <
typename T_y,
typename T_dof,
typename T_scale>
145 typename boost::math::tools::promote_args<T_y,T_dof,T_scale>::type
146 wishart_log(
const Eigen::Matrix<T_y,Eigen::Dynamic,Eigen::Dynamic>& W,
148 const Eigen::Matrix<T_scale,Eigen::Dynamic,Eigen::Dynamic>& S) {