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