1 #ifndef STAN_MATH_PRIM_SCAL_ERR_CHECK_BOUNDED_HPP 2 #define STAN_MATH_PRIM_SCAL_ERR_CHECK_BOUNDED_HPP 23 template <
typename T_y,
typename T_low,
typename T_high,
bool y_is_vec>
25 static void check(
const char*
function,
const char*
name,
const T_y&
y,
26 const T_low& low,
const T_high& high) {
32 if (!(low_vec[
n] <= y && y <= high_vec[
n])) {
33 std::stringstream
msg;
34 msg <<
", but must be in the interval ";
35 msg <<
"[" << low_vec[
n] <<
", " << high_vec[
n] <<
"]";
43 template <
typename T_y,
typename T_low,
typename T_high>
44 struct bounded<T_y, T_low, T_high, true> {
45 static void check(
const char*
function,
const char*
name,
const T_y&
y,
46 const T_low& low,
const T_high& high) {
53 if (!(low_vec[
n] <=
get(y,
n) &&
get(y,
n) <= high_vec[
n])) {
54 std::stringstream
msg;
55 msg <<
", but must be in the interval ";
56 msg <<
"[" << low_vec[
n] <<
", " << high_vec[
n] <<
"]";
82 template <
typename T_y,
typename T_low,
typename T_high>
84 const T_low& low,
const T_high& high) {
86 function, name, y, low, high);
void check_bounded(const char *function, const char *name, const T_y &y, const T_low &low, const T_high &high)
size_t length(const std::vector< T > &x)
void domain_error_vec(const char *function, const char *name, const T &y, size_t i, const char *msg1, const char *msg2)
static void check(const char *function, const char *name, const T_y &y, const T_low &low, const T_high &high)
T get(const std::vector< T > &x, size_t n)
size_t max_size(const T1 &x1, const T2 &x2)
void domain_error(const char *function, const char *name, const T &y, const char *msg1, const char *msg2)
static void check(const char *function, const char *name, const T_y &y, const T_low &low, const T_high &high)