|
8 | 8 | namespace stan { |
9 | 9 | namespace math { |
10 | 10 |
|
11 | | -inline var bessel_second_kind(int v, const var& a) { |
12 | | - double ret_val = bessel_second_kind(v, a.val()); |
13 | | - auto precomp_bessel |
14 | | - = v * ret_val / a.val() - bessel_second_kind(v + 1, a.val()); |
15 | | - return make_callback_var(ret_val, [precomp_bessel, a](auto& vi) mutable { |
16 | | - a.adj() += vi.adj() * precomp_bessel; |
17 | | - }); |
18 | | -} |
19 | | - |
20 | | -/** |
21 | | - * Overload with `var_value<Matrix>` for `int`, `std::vector<int>`, and |
22 | | - * `std::vector<std::vector<int>>` |
23 | | - */ |
24 | | -template <typename T1, typename T2, require_st_integral<T1>* = nullptr, |
25 | | - require_eigen_t<T2>* = nullptr> |
26 | | -inline auto bessel_second_kind(const T1& v, const var_value<T2>& a) { |
27 | | - auto ret_val = bessel_second_kind(v, a.val()).array().eval(); |
28 | | - auto v_map = as_array_or_scalar(v); |
29 | | - auto precomp_bessel |
30 | | - = to_arena(v_map * ret_val / a.val().array() |
31 | | - - bessel_second_kind(v_map + 1, a.val().array())); |
32 | | - return make_callback_var( |
33 | | - ret_val.matrix(), [precomp_bessel, a](const auto& vi) mutable { |
34 | | - a.adj().array() += vi.adj().array() * precomp_bessel; |
35 | | - }); |
| 11 | +template <typename T1, typename T2, require_st_integral<T1>* = nullptr, require_var_t<T2>* = nullptr> |
| 12 | +inline auto bessel_second_kind(T1&& v, T2&& a) { |
| 13 | + if constexpr (is_stan_scalar_v<T2>) { |
| 14 | + double ret_val = bessel_second_kind(v, a.val()); |
| 15 | + auto precomp_bessel |
| 16 | + = v * ret_val / a.val() - bessel_second_kind(v + 1, a.val()); |
| 17 | + return make_callback_var(ret_val, [precomp_bessel, a](auto& vi) mutable { |
| 18 | + a.adj() += vi.adj() * precomp_bessel; |
| 19 | + }); |
| 20 | + } else { |
| 21 | + auto ret_val = bessel_second_kind(v, a.val()).array().eval(); |
| 22 | + auto v_map = as_array_or_scalar(v); |
| 23 | + auto precomp_bessel |
| 24 | + = to_arena(v_map * ret_val / a.val().array() |
| 25 | + - bessel_second_kind(v_map + 1, a.val().array())); |
| 26 | + return make_callback_var( |
| 27 | + ret_val.matrix(), [precomp_bessel, a](const auto& vi) mutable { |
| 28 | + a.adj().array() += vi.adj().array() * precomp_bessel; |
| 29 | + }); |
| 30 | + } |
36 | 31 | } |
37 | 32 |
|
38 | 33 | } // namespace math |
|
0 commit comments