1#ifndef STAN_MATH_REV_PROB_STD_NORMAL_LOG_QF_HPP
2#define STAN_MATH_REV_PROB_STD_NORMAL_LOG_QF_HPP
20template <
typename T, require_stan_scalar_or_eigen_t<T>* =
nullptr>
24 if constexpr (
is_eigen<
decltype(arena_rtn)>::value) {
25 auto deriv =
exp(log_p.val() - arena_rtn.unaryExpr([](
auto x) {
26 return std_normal_lpdf(x);
31 log_p.adj() += vi.adj() * deriv;
elt_multiply_< as_operation_cl_t< T_a >, as_operation_cl_t< T_b > > elt_multiply(T_a &&a, T_b &&b)
return_type_t< T_y_cl > std_normal_lpdf(const T_y_cl &y)
The log of the normal density for the specified scalar(s) given a location of 0 and a scale of 1.
var_value< plain_type_t< T > > make_callback_var(T &&value, F &&functor)
Creates a new var initialized with a callback_vari with a given value and reverse-pass callback funct...
arena_t< T > to_arena(const T &a)
Converts given argument into a type that either has any dynamic allocation on AD stack or schedules i...
fvar< T > std_normal_log_qf(const fvar< T > &p)
fvar< T > exp(const fvar< T > &x)
The lgamma implementation in stan-math is based on either the reentrant safe lgamma_r implementation ...
Check if type derives from EigenBase