1#ifndef STAN_MATH_PRIM_ERR_CHECK_SIZE_MATCH_HPP
2#define STAN_MATH_PRIM_ERR_CHECK_SIZE_MATCH_HPP
23template <
typename T_size1,
typename T_size2>
25 T_size1 i,
const char* name_j, T_size2 j) {
26 if (i !=
static_cast<T_size1
>(j)) {
28 std::ostringstream msg;
29 msg <<
") and " << name_j <<
" (" << j <<
") must match in size";
30 std::string msg_str(msg.str());
49template <
typename T_size1,
typename T_size2>
51 const char* name_i, T_size1 i,
const char* expr_j,
52 const char* name_j, T_size2 j) {
53 if (i !=
static_cast<T_size1
>(j)) {
55 std::ostringstream updated_name;
56 updated_name << expr_i << name_i;
57 std::string updated_name_str(updated_name.str());
58 std::ostringstream msg;
59 msg <<
") and " << expr_j << name_j <<
" (" << j
60 <<
") must match in size";
61 std::string msg_str(msg.str());
void invalid_argument(const char *function, const char *name, const T &y, const char *msg1, const char *msg2)
Throw an invalid_argument exception with a consistently formatted message.
void check_size_match(const char *function, const char *name_i, T_size1 i, const char *name_j, T_size2 j)
Check if the provided sizes match.
The lgamma implementation in stan-math is based on either the reentrant safe lgamma_r implementation ...