Skip to content

v4.0.0 (26 January 2021)

Compare
Choose a tag to compare
@serban-nicusor-toptal serban-nicusor-toptal released this 26 Jan 13:45
· 4856 commits to develop since this release

New functions:

  • Add symmetrize_from_lower_tri(matrix m) function to stan::math.(#2209)
  • Added the Moore-Penrose generalized inverse, available with the generalized_inverse function.(#2225)
  • Implement svd_U and svd_V, add gradients to singular_values.(#2286)
  • Added linspaced_int_array.(#2312)

Miscellaneous improvements and bugfixes:

  • Speedup reduce_sum parallelism.(#2162)
  • Make gradients for negative binomial and 2F1 function more robust for boundary values.(#2175)
  • Fixed problem with integrate_1d tolerances(#2183)
  • Fixed a bug in check_matching_dims that prevented checking vectors of Eigen matrices of vars.(#2220)
  • Updated log-likelihood calculation for ordered_probit_lpmf for increased numerical stability(#2229)
  • Updated TBB makefiles to support building on M1 Macs.(#2208)
  • Updated mdivide_left to avoid doing QR decomposition in reverse passes. (#2230)
  • Upgraded to Eigen 3.3.9.(#2238)
  • Upgraded Sundials to 5.6.1.(#2242, #2283)
  • Use immediately invoked lambdas in size and range error checks to improve code caching. (#2255)
  • Added a python script that can generate and run benchmarks for most of function signatures in math.(#2260)
  • scalar_type_t now decays references for var_value<T> types(#2264)
  • Added adjoint_of() function that accesses .adj() of vars, but analogous to value_of() also works on prim types (returning a dummy object).(#2270)
  • Wishart and inverse wishart functions now check that symmetric positive definite inputs are actually symmetric positive definite.(#2281)
  • Fix potential segfault when mixing reduce_sum() and print().(#2319)
  • Fixed a bug in dirichlet_lpdf and multi_normal_cholesky_lpdf, where function overloads that do broadcasting produced wrong derivatives. (#2331)

Expressions:

#2093, #2131, #2133, #2136, #2138, #2139, #2150, #2151, #2186, #2190, #2205

  • Generalized all remaining prim functions.
  • Prim functions now return expressions where applicable.
  • Removed the requirement for linear indexing from prim function
  • Improved expressions testing: No longer relying on an separate file of functions that do not support expressions

OpenCL:

#2117, #2155, #2176, #2177, #2180, #2181, #2215, #2173, #2174, #2184, #2185, #2191, #2216, #2217, #2217, #2219, #2221, #2222, #2226, #2231, #2236, #2236, #2250, #2253, #2258, #2259, #2263, #2267, #2270, #2272, #2273, #2274, #2275, #2294, #2295, #2296, #2311, #2316

  • Added OpenCL reverse mode support for lpdf/lpmf functions: bernoulli_lpmf, bernoulli_logit_lpmf, beta_lpdf, beta_proportion_lpdf, binomial_lpmf, cauchy_lpdf, chi_square_lpdf, double_exponential_lpdf, exp_mod_normal_lpdf, exponential_lpdf, frechet_lpdf, gamma_lpdf, gumbel_lpdf, inv_chi_square_lpdf, inv_gamma_lpdf, logistic_lpdf, lognormal_lpdf, neg_binomial_lpmf, neg_binomial_2_lpmf, neg_binomial_2_log_lpmf, normal_lpdf, pareto_lpdf, pareto_type_2_lpdf, poisson_lpmf, poisson_log_lpmf, rayleigh_lpdf, scaled_inv_chi_square_lpdf, skew_normal_lpdf, std_normal_lpdf, student_t_lpdf, uniform_lpdf and weibull_lpdf.
  • Added OpenCL reverse mode support for acos, acosh, add, add_diag, asin, asinh, atan, atanh, beta, block, cbrt, ceil, cholesky_decompose, col, cols, columns_dot_product, columns_dot_self, cos, cosh, crossprod, diag_matrix, diagonal, diag_post_multiply, diag_pre_multiply, digamma, dims, distance, dot_product, dot_self, elt_divide, elt_multiply, erf, erfc, exp, exp2, expm1, fabs, floor, head, hypot, inv, inv_cloglog, inv_logit, inv_Phi, inv_sqrt, inv_square, lbeta, ldexp, lgamma, lmultiply, log, log10, log1m, log1m_exp, log1m_inv_logit, log1p, log1p_exp, log2, log_diff_exp, log_inv_logit, log_inv_logit_diff, logit, mdivide_left_tri_low, mdivide_right_tri_low, mean, multiply, multiply_log, num_elements, Phi, Phi_approx, pow, round, row, rows, rows_dot_product, rows_dot_self, segment, sin, sinh, size, sqrt, square, squared_distance, sub_col, sub_row, subtract, sum, tail, tan, tanh, tcrossprod, tgamma, transpose and trunc.
  • Reduced amount of copying when using OpenCL. CPUs and integrated GPUs can use host memory in place. Transferring data to discrete GPUs can avoid one copy to pinned memory on host side if the new pinned_matrix class is used. Depending on the OPenCL implementation, optimization for CPUs and Discrete GPUs may also require use of this class. (#2219)
  • Improved kernel generator: simplified writing of broadcasting tests, fixed a bug when using same operations on different sets of unique matrices, fixed check_cl, extended support for integer arguments, added support for kernel expressions returning a scalar, added compound assignment operators, made transpose kernel generator operation assignable.
  • Bugfixed arena_matrix_cl so it can be assigned a matrix_cl.(#2270)

Varmat:

  • Added varmat implementations of cholesky_decompose, columns_dot_self, determinant, dot_self, inverse, log_determinant, matrix_power, multiply_lower_tri_self_transpose, and tcrossprod, add, operator+, operator-, quad_form, trace_quad_form, transpose (member function), variance, sd, log_softmax, log_sum_exp, divide, trace_gen_quad_form, dot_product, columns_dot_product, rows_dot_product, squared_distance, mdivide_left_spd, mdivide_left_tri, mdivide_left, log_determinant_spd, mdivide_left_ldlt, mdivide_right_ldlt, log_determinant_ldlt, trace_gen_inv_quad_form_ldlt, trace_inv_quad_form_ldlt (#2105, #2106, #2115, #2163, #2164, #2168, #2169, #2171, #2172, #2196, #2199, #2212, #2213, #2230, #2232, #2266, #2280, #2305)
  • Adds var_value<Matrix> overloads for array and column vector converters.(#2278)
  • Make multivariate distributions work with varmat(#2284)
  • Adds sequence views for var<matrix> to make some of the distributions var matrix compatible(#2292)
  • to_var_value and from_var_value now work with std::vector types(#2299)
  • Add more methods for taking blocks of var matrices.(#2188)
  • Updating matrix constrains to work with varmart(#2254)
  • Adds arc trig functions for var<matrix> along several other unary operators (#2256)