Stan  2.5.0
probability, sampling & optimization
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
atan2.hpp
Go to the documentation of this file.
1 #ifndef STAN__AGRAD__FWD__FUNCTIONS__ATAN2_HPP
2 #define STAN__AGRAD__FWD__FUNCTIONS__ATAN2_HPP
3 
5 #include <stan/meta/traits.hpp>
7 #include <math.h>
8 
9 namespace stan {
10 
11  namespace agrad {
12 
13  template <typename T>
14  inline
15  fvar<T>
16  atan2(const fvar<T>& x1, const fvar<T>& x2) {
18  using stan::math::square;
19  return fvar<T>(atan2(x1.val_, x2.val_),
20  (x1.d_ * x2.val_ - x1.val_ * x2.d_) /
21  (square(x2.val_) + square(x1.val_)));
22  }
23 
24  template <typename T>
25  inline
26  fvar<T>
27  atan2(const double x1, const fvar<T>& x2) {
29  using stan::math::square;
30  return fvar<T>(atan2(x1, x2.val_),
31  (-x1 * x2.d_) / (square(x1) + square(x2.val_)));
32  }
33 
34  template <typename T>
35  inline
36  fvar<T>
37  atan2(const fvar<T>& x1, const double x2) {
39  using stan::math::square;
40  return fvar<T>(atan2(x1.val_, x2),
41  (x1.d_ * x2) / (square(x2) + square(x1.val_)));
42  }
43  }
44 }
45 #endif
T square(const T x)
Return the square of the specified argument.
Definition: square.hpp:22
fvar< T > square(const fvar< T > &x)
Definition: square.hpp:15
var atan2(const double a, const var &b)
Return the principal value of the arc tangent, in radians, of the first scalar divided by the second ...
Definition: atan2.hpp:121
fvar< T > atan2(const fvar< T > &x1, const fvar< T > &x2)
Definition: atan2.hpp:16

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