Loading [MathJax]/extensions/TeX/AMSsymbols.js
Automatic Differentiation
 
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Loading...
Searching...
No Matches
std_normal_log_qf.hpp
Go to the documentation of this file.
1#ifndef STAN_MATH_REV_PROB_STD_NORMAL_LOG_QF_HPP
2#define STAN_MATH_REV_PROB_STD_NORMAL_LOG_QF_HPP
3
9#include <cmath>
10
11namespace stan {
12namespace math {
20template <typename T, require_stan_scalar_or_eigen_t<T>* = nullptr>
21inline auto std_normal_log_qf(const var_value<T>& log_p) {
22 auto arena_rtn = to_arena(std_normal_log_qf(log_p.val()));
23 return make_callback_var(arena_rtn, [log_p, arena_rtn](auto& vi) mutable {
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);
27 }));
28 log_p.adj() += elt_multiply(vi.adj(), deriv);
29 } else {
30 auto deriv = exp(log_p.val() - std_normal_lpdf(arena_rtn));
31 log_p.adj() += vi.adj() * deriv;
32 }
33 });
34}
35
36} // namespace math
37} // namespace stan
38#endif
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...
Definition to_arena.hpp:25
fvar< T > std_normal_log_qf(const fvar< T > &p)
fvar< T > exp(const fvar< T > &x)
Definition exp.hpp:15
The lgamma implementation in stan-math is based on either the reentrant safe lgamma_r implementation ...
Check if type derives from EigenBase
Definition is_eigen.hpp:21