5#ifndef STOCHTREE_ORDINAL_SAMPLER_H_
6#define STOCHTREE_ORDINAL_SAMPLER_H_
8#include <stochtree/data.h>
9#include <stochtree/ensemble.h>
10#include <stochtree/gamma_sampler.h>
11#include <stochtree/partition_tracker.h>
12#include <stochtree/tree.h>
20static double sample_truncated_exponential_low_high(
double u,
double rate,
double low,
double high) {
21 return -std::log((1-u)*std::exp(-rate*low) + u*std::exp(-rate*high))/rate;
24static double sample_truncated_exponential_low(
double u,
double rate,
double low) {
25 return -std::log((1-u)*std::exp(-rate*low))/rate;
28static double sample_truncated_exponential_high(
double u,
double rate,
double high) {
29 return -std::log1p(u*std::expm1(-high*rate))/rate;
32static double sample_exponential(
double u,
double rate) {
33 return -std::log1p(-u)/rate;
84 double alpha_gamma,
double beta_gamma,
85 double gamma_0, std::mt19937& gen);
API for loading and accessing data used to sample tree ensembles The covariates / bases / weights use...
Definition data.h:271
Definition gamma_sampler.h:10
Sampler for ordinal model hyperparameters.
Definition ordinal_sampler.h:44
void UpdateCumulativeExpSums(ForestDataset &dataset)
Update cumulative exponential sums (seg)
void UpdateLatentVariables(ForestDataset &dataset, Eigen::VectorXd &outcome, std::mt19937 &gen)
Update truncated exponential latent variables (Z)
static double SampleTruncatedExponential(std::mt19937 &gen, double rate, double low=0.0, double high=1.0)
Sample from truncated exponential distribution.
void UpdateGammaParams(ForestDataset &dataset, Eigen::VectorXd &outcome, double alpha_gamma, double beta_gamma, double gamma_0, std::mt19937 &gen)
Update gamma cutpoint parameters.
A collection of random number generation utilities.
Definition category_tracker.h:36