Stan  2.5.0
probability, sampling & optimization
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
modified_bessel_first_kind.hpp
Go to the documentation of this file.
1 #ifndef STAN__AGRAD__REV__FUNCTIONS__MODIFIED_BESSEL_FIRST_KIND_HPP
2 #define STAN__AGRAD__REV__FUNCTIONS__MODIFIED_BESSEL_FIRST_KIND_HPP
3 
4 #include <stan/agrad/rev/var.hpp>
7 
8 namespace stan {
9  namespace agrad {
10 
11  namespace {
12 
13  class modified_bessel_first_kind_dv_vari : public op_dv_vari {
14  public:
15  modified_bessel_first_kind_dv_vari(int a, vari* bvi) :
16  op_dv_vari(stan::math::modified_bessel_first_kind(a, bvi->val_), a, bvi) {
17  }
18  void chain() {
19  bvi_->adj_ += adj_ * (-ad_ * stan::math::modified_bessel_first_kind(ad_, bvi_->val_) / bvi_->val_ + stan::math::modified_bessel_first_kind(ad_ - 1, bvi_->val_));
20  }
21  };
22  }
23 
24  inline var modified_bessel_first_kind(const int& v,
25  const var& a) {
26  return var(new modified_bessel_first_kind_dv_vari(v, a.vi_));
27  }
28 
29  }
30 }
31 #endif
fvar< T > modified_bessel_first_kind(int v, const fvar< T > &z)
vari * vi_
Pointer to the implementation of this variable.
Definition: var.hpp:40
Independent (input) and dependent (output) variables for gradients.
Definition: var.hpp:27
T2 modified_bessel_first_kind(const int v, const T2 z)

     [ Stan Home Page ] © 2011–2014, Stan Development Team.