-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathrejection_sampling.hpp
53 lines (45 loc) · 1.8 KB
/
rejection_sampling.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#ifndef REJECTION_SAMPLING_HPP
#define REJECTION_SAMPLING_HPP
#include "particle.hpp"
#include "changepoint.hpp"
#include "probability_model.hpp"
#include "histogram_type.hpp"
/*allows for rejection sampling when there is only one changepoint*/
class rejection_sampling {
public:
rejection_sampling(double m_start_time = 0, double m_cp_start = 0, double m_end_time = 1, long long int m_sample_size = 10, probability_model *m_pm = NULL, double m_cp_prior = 1, double space=0, int m_seed = 0, bool m_calculate_mean = 0, bool m_calculate_sample_histogram = false, unsigned int m_num_bins = 100);
~rejection_sampling();
void write_1d_histogram_to_file(const string output_filename="1d_distribution.txt"){m_histogram->write_1d_histogram_to_file(output_filename);}
void run_simulation();
void sample_from_prior(Particle<changepoint> **);
Particle<changepoint>** get_sample() {return m_sample;}
void write_frequency_counts_to_file(const char*);
double m_acceptance_rate;
void use_smcsamplers_prior() {m_smcsamplers_prior = 1;}
private:
double m_start_time;
double m_cp_start;
double m_end_time;
long long int m_sample_size;
probability_model *m_pm;
double m_cp_prior;
int m_seed;
const gsl_rng_type *m_r_type;
gsl_rng *m_r;
double m_zero_cp_likelihood;
Particle<changepoint> **m_sample;
double draw_from_prior();
double calculate_mle(double, double);
map<unsigned int,unsigned long long int> m_dimension_frequency_count;
Histogram_Type<changepoint> *m_histogram;
bool m_calculate_sample_histogram;
int m_num_bins;
bool m_calculate_mean;
changepoint *m_end_of_int_changepoint;
double sample_mean(changepoint *);
double alternate_likelihood(changepoint *, changepoint *);
bool m_smcsamplers_prior;
bool m_spacing_prior;
double m_space;
};
#endif //REJECTION_SAMPLING_HPP