18 return log_diff_exp(log_cdf_D, log_cdf_L);
39 real log_normalizer, real L) {
41 return log_diff_exp(log_cdf, log_cdf_L) - log_normalizer;
43 return log_cdf - log_normalizer;
70 data real L, data real D,
71 data
int dist_id, array[] real params, data real pwindow,
72 data
int primary_id, array[] real primary_params
84 result[1] = negative_infinity();
87 L | dist_id, params, pwindow,
89 positive_infinity(), primary_id, primary_params
98 D | dist_id, params, pwindow,
100 positive_infinity(), primary_id, primary_params
124 data real pwindow, data real L, data real D,
126 array[] real primary_params) {
140 d | dist_id, params, pwindow, L, D, primary_id, primary_params
149 real lower_bound = d - pwindow;
150 int n_params = num_elements(params);
151 int n_primary_params = num_elements(primary_params);
152 array[n_params + n_primary_params] real theta = append_array(params, primary_params);
153 array[4]
int ids = {dist_id, primary_id, n_params, n_primary_params};
155 vector[1] y0 = rep_vector(0.0, 1);
156 result = ode_rk45(
primarycensored_ode, y0, lower_bound, {d}, theta, {d, pwindow}, ids)[1, 1];
159 if (!is_inf(D) || !is_inf(L)) {
160 real log_result = log(result);
162 L, D, dist_id, params, pwindow, primary_id, primary_params
164 real log_cdf_L = bounds[1];
165 real log_cdf_D = bounds[2];
169 log_result, log_cdf_L, log_normalizer, L
171 result = exp(log_result);
210 data real pwindow, data real L, data real D,
212 array[] real primary_params) {
216 return negative_infinity();
228 d | dist_id, params, pwindow,
230 positive_infinity(), primary_id, primary_params
235 d | dist_id, params, pwindow,
237 positive_infinity(), primary_id, primary_params
242 if (!is_inf(D) || !is_inf(L)) {
244 L, D, dist_id, params, pwindow, primary_id, primary_params
246 real log_cdf_L = bounds[1];
247 real log_cdf_D = bounds[2];
290 data real pwindow, data real d_upper,
291 data real L, data real D, data
int primary_id,
292 array[] real primary_params) {
294 reject(
"Upper truncation point is greater than D. It is ", d_upper,
295 " and D is ", D,
". Resolve this by increasing D to be greater or equal to d + swindow or decreasing swindow.");
298 reject(
"Upper truncation point is less than or equal to d. It is ", d_upper,
299 " and d is ", d,
". Resolve this by increasing d to be less than d_upper.");
302 return negative_infinity();
305 d_upper | dist_id, params, pwindow,
307 positive_infinity(), primary_id, primary_params
310 d | dist_id, params, pwindow,
312 positive_infinity(), primary_id, primary_params
316 if (!is_inf(D) || !is_inf(L)) {
323 log_cdf_L = negative_infinity();
326 log_cdf_L = log_cdf_lower;
330 L | dist_id, params, pwindow,
332 positive_infinity(), primary_id, primary_params
338 log_cdf_D = log_cdf_upper;
339 }
else if (is_inf(D)) {
343 D | dist_id, params, pwindow,
345 positive_infinity(), primary_id, primary_params
350 return log_diff_exp(log_cdf_upper, log_cdf_lower) - log_normalizer;
352 return log_diff_exp(log_cdf_upper, log_cdf_lower);
389 data real pwindow, data real d_upper,
390 data real L, data real D, data
int primary_id,
391 array[] real primary_params) {
394 d | dist_id, params, pwindow, d_upper, L, D, primary_id, primary_params
441 data
int max_delay, data real L, data real D, data
int dist_id,
442 array[] real params, data real pwindow,
443 data
int primary_id, array[] real primary_params
446 int upper_interval = max_delay + 1;
447 vector[upper_interval] log_pmfs;
448 vector[upper_interval] log_cdfs;
452 if (D < upper_interval) {
453 reject(
"D must be at least max_delay + 1");
462 int start_idx = (!is_inf(L) && L > 0) ? max(1, to_int(floor(L))) : 1;
463 for (d in start_idx:upper_interval) {
465 d | dist_id, params, pwindow,
467 positive_infinity(), primary_id, primary_params
475 log_cdf_L = negative_infinity();
476 }
else if (L >= 1 && L <= upper_interval && floor(L) == L) {
478 log_cdf_L = log_cdfs[to_int(L)];
482 L | dist_id, params, pwindow,
484 positive_infinity(), primary_id, primary_params
490 if (D > upper_interval) {
495 D | dist_id, params, pwindow,
497 positive_infinity(), primary_id, primary_params
501 log_cdf_D = log_cdfs[upper_interval];
507 for (d in 1:upper_interval) {
510 log_pmfs[d] = negative_infinity();
511 }
else if (d - 1 < L) {
513 log_pmfs[d] = log_diff_exp(log_cdfs[d], log_cdf_L) - log_normalizer;
517 log_pmfs[d] = log_cdfs[d] - log_normalizer;
522 0.0 | dist_id, params, pwindow,
523 negative_infinity(), positive_infinity(),
524 primary_id, primary_params
526 log_pmfs[d] = log_diff_exp(log_cdfs[d], log_cdf_0) - log_normalizer;
529 log_pmfs[d] = log_diff_exp(log_cdfs[d], log_cdfs[d-1]) - log_normalizer;
575 data
int max_delay, data real L, data real D, data
int dist_id,
576 array[] real params, data real pwindow,
578 array[] real primary_params
582 max_delay, L, D, dist_id, params, pwindow, primary_id, primary_params
int check_for_analytical(int dist_id, int primary_id)
int dist_has_positive_support(data int dist_id)
vector primarycensored_ode(real t, vector y, array[] real theta, array[] real x_r, array[] int x_i)
real primarycensored_cdf(data real d, data int dist_id, array[] real params, data real pwindow, data real L, data real D, data int primary_id, array[] real primary_params)
real primarycensored_pmf(data int d, data int dist_id, array[] real params, data real pwindow, data real d_upper, data real L, data real D, data int primary_id, array[] real primary_params)
real primarycensored_lpmf(data int d, data int dist_id, array[] real params, data real pwindow, data real d_upper, data real L, data real D, data int primary_id, array[] real primary_params)
real primarycensored_lcdf(data real d, data int dist_id, array[] real params, data real pwindow, data real L, data real D, data int primary_id, array[] real primary_params)
vector primarycensored_sone_lpmf_vectorized(data int max_delay, data real L, data real D, data int dist_id, array[] real params, data real pwindow, data int primary_id, array[] real primary_params)
vector primarycensored_sone_pmf_vectorized(data int max_delay, data real L, data real D, data int dist_id, array[] real params, data real pwindow, data int primary_id, array[] real primary_params)
real primarycensored_analytical_lcdf(data real d, int dist_id, array[] real params, data real pwindow, data real L, data real D, int primary_id, array[] real primary_params)
real primarycensored_analytical_cdf(data real d, int dist_id, array[] real params, data real pwindow, data real L, data real D, int primary_id, array[] real primary_params)
real primarycensored_apply_truncation(real log_cdf, real log_cdf_L, real log_normalizer, real L)
real primarycensored_log_normalizer(real log_cdf_D, real log_cdf_L, real L)
vector primarycensored_truncation_bounds(data real L, data real D, data int dist_id, array[] real params, data real pwindow, data int primary_id, array[] real primary_params)