#include #include #include "utils.h" void init_ct(Rice::Module& m) { Rice::define_class_under(m, "CT") .define_singleton_method( "_new", *[](size_t tw, size_t k, tomoto::Float alpha, tomoto::Float eta, int seed) { if (seed < 0) { seed = std::random_device{}(); } return tomoto::ICTModel::create((tomoto::TermWeight)tw, k, alpha, eta, seed); }) .define_method( "_correlations", *[](tomoto::ICTModel& self, tomoto::Tid topic_id) { return self.getCorrelationTopic(topic_id); }) .define_method( "num_beta_sample", *[](tomoto::ICTModel& self) { return self.getNumBetaSample(); }) .define_method( "num_beta_sample=", *[](tomoto::ICTModel& self, size_t value) { self.setNumBetaSample(value); return value; }) .define_method( "num_tmn_sample", *[](tomoto::ICTModel& self) { return self.getNumTMNSample(); }) .define_method( "num_tmn_sample=", *[](tomoto::ICTModel& self, size_t value) { self.setNumTMNSample(value); return value; }) .define_method( "_prior_cov", *[](tomoto::ICTModel& self) { return self.getPriorCov(); }) .define_method( "prior_mean", *[](tomoto::ICTModel& self) { return self.getPriorMean(); }); }