11 #ifndef PERSISTENCE_INTERVALS_H_ 12 #define PERSISTENCE_INTERVALS_H_ 15 #include <gudhi/read_persistence_from_file.h> 29 namespace Persistence_representations {
45 Persistence_intervals(
const char* filename,
unsigned dimension = std::numeric_limits<unsigned>::max());
58 double min_ = std::numeric_limits<int>::max();
59 double max_ = -std::numeric_limits<int>::max();
60 for (
size_t i = 0; i != this->intervals.size(); ++i) {
61 if (this->intervals[i].first < min_) min_ = this->intervals[i].first;
62 if (this->intervals[i].second > max_) max_ = this->intervals[i].second;
64 return std::make_pair(min_, max_);
71 double min_ = std::numeric_limits<int>::max();
72 double max_ = -std::numeric_limits<int>::max();
73 for (
size_t i = 0; i != this->intervals.size(); ++i) {
74 if (this->intervals[i].second < min_) min_ = this->intervals[i].second;
75 if (this->intervals[i].second > max_) max_ = this->intervals[i].second;
77 return std::make_pair(min_, max_);
90 std::vector<std::pair<double, double> >
dominant_intervals(
size_t where_to_cut = 100)
const;
122 size_t number_of_bins = 10)
const;
137 std::vector<double>
k_n_n(
size_t k,
size_t where_to_cut = 10)
const;
143 for (
size_t i = 0; i != intervals.intervals.size(); ++i) {
144 out << intervals.intervals[i].first <<
" " << intervals.intervals[i].second << std::endl;
152 void plot(
const char* filename,
double min_x = std::numeric_limits<double>::max(),
153 double max_x = std::numeric_limits<double>::max(),
double min_y = std::numeric_limits<double>::max(),
154 double max_y = std::numeric_limits<double>::max())
const {
158 std::stringstream gnuplot_script;
159 gnuplot_script << filename <<
"_GnuplotScript";
161 out.open(gnuplot_script.str().c_str());
163 std::pair<double, double> min_max_values = this->
get_x_range();
164 if (min_x == max_x) {
165 out <<
"set xrange [" << min_max_values.first - 0.1 * (min_max_values.second - min_max_values.first) <<
" : " 166 << min_max_values.second + 0.1 * (min_max_values.second - min_max_values.first) <<
" ]" << std::endl;
167 out <<
"set yrange [" << min_max_values.first - 0.1 * (min_max_values.second - min_max_values.first) <<
" : " 168 << min_max_values.second + 0.1 * (min_max_values.second - min_max_values.first) <<
" ]" << std::endl;
170 out <<
"set xrange [" << min_x <<
" : " << max_x <<
" ]" << std::endl;
171 out <<
"set yrange [" << min_y <<
" : " << max_y <<
" ]" << std::endl;
173 out <<
"plot '-' using 1:2 notitle \"" << filename <<
"\", \\" << std::endl;
174 out <<
" '-' using 1:2 notitle with lp" << std::endl;
175 for (
size_t i = 0; i != this->intervals.size(); ++i) {
176 out << this->intervals[i].first <<
" " << this->intervals[i].second << std::endl;
178 out <<
"EOF" << std::endl;
179 out << min_max_values.first - 0.1 * (min_max_values.second - min_max_values.first) <<
" " 180 << min_max_values.first - 0.1 * (min_max_values.second - min_max_values.first) << std::endl;
181 out << min_max_values.second + 0.1 * (min_max_values.second - min_max_values.first) <<
" " 182 << min_max_values.second + 0.1 * (min_max_values.second - min_max_values.first) << std::endl;
186 std::cout <<
"To visualize, install gnuplot and type the command: gnuplot -persist -e \"load \'" 187 << gnuplot_script.str().c_str() <<
"\'\"" << std::endl;
193 size_t size()
const {
return this->intervals.size(); }
199 inline std::pair<double, double>
operator[](
size_t i)
const {
200 if (i >= this->intervals.size())
throw(
"Index out of range! Operator [], one_d_gaussians class\n");
201 return this->intervals[i];
224 std::vector<double>
vectorize(
int number_of_function)
const {
236 std::vector<std::pair<double, double> > output_for_visualization() {
return this->intervals; }
239 void set_up_numbers_of_functions_for_vectorization_and_projections_to_reals() {
241 this->number_of_functions_for_vectorization = this->intervals.size();
242 this->number_of_functions_for_projections_to_reals = 1;
245 std::vector<std::pair<double, double> > intervals;
246 size_t number_of_functions_for_vectorization;
247 size_t number_of_functions_for_projections_to_reals;
251 if (dimension == std::numeric_limits<unsigned>::max()) {
252 this->intervals = read_persistence_intervals_in_one_dimension_from_file(filename);
254 this->intervals = read_persistence_intervals_in_one_dimension_from_file(filename, dimension);
256 this->set_up_numbers_of_functions_for_vectorization_and_projections_to_reals();
260 : intervals(intervals_) {
261 this->set_up_numbers_of_functions_for_vectorization_and_projections_to_reals();
265 std::vector<double> result(this->intervals.size());
266 for (
size_t i = 0; i != this->intervals.size(); ++i) {
267 result[i] = this->intervals[i].second - this->intervals[i].first;
269 std::sort(result.begin(), result.end(), std::greater<double>());
271 result.resize(std::min(where_to_cut, result.size()));
275 bool compare(
const std::pair<size_t, double>& first,
const std::pair<size_t, double>& second) {
276 return first.second > second.second;
281 std::vector<std::pair<size_t, double> > position_length_vector(this->intervals.size());
282 for (
size_t i = 0; i != this->intervals.size(); ++i) {
283 position_length_vector[i] = std::make_pair(i, this->intervals[i].second - this->intervals[i].first);
286 std::sort(position_length_vector.begin(), position_length_vector.end(), compare);
288 std::vector<std::pair<double, double> > result;
289 result.reserve(std::min(where_to_cut, position_length_vector.size()));
291 for (
size_t i = 0; i != std::min(where_to_cut, position_length_vector.size()); ++i) {
292 result.push_back(this->intervals[position_length_vector[i].first]);
294 std::cerr <<
"Position : " << position_length_vector[i].first <<
" length : " << position_length_vector[i].second
304 if (dbg) std::cerr <<
"this->intervals.size() : " << this->intervals.size() << std::endl;
306 double lengthOfLongest = 0;
307 for (
size_t i = 0; i != this->intervals.size(); ++i) {
308 if ((this->intervals[i].second - this->intervals[i].first) > lengthOfLongest) {
309 lengthOfLongest = this->intervals[i].second - this->intervals[i].first;
314 std::cerr <<
"lengthOfLongest : " << lengthOfLongest << std::endl;
318 std::vector<size_t> result(number_of_bins + 1, 0);
321 for (
size_t i = 0; i != this->intervals.size(); ++i) {
323 double relative_length_of_this_interval = (this->intervals[i].second - this->intervals[i].first) / lengthOfLongest;
326 size_t position = (size_t)(relative_length_of_this_interval * number_of_bins);
331 std::cerr <<
"i : " << i << std::endl;
332 std::cerr <<
"Interval : [" << this->intervals[i].first <<
" , " << this->intervals[i].second <<
" ] \n";
333 std::cerr <<
"relative_length_of_this_interval : " << relative_length_of_this_interval << std::endl;
334 std::cerr <<
"position : " << position << std::endl;
340 for (
size_t i = 0; i != result.size(); ++i) std::cerr << result[i] << std::endl;
347 std::vector<size_t> result(histogram.size());
350 for (
size_t i = 0; i != histogram.size(); ++i) {
358 size_t number_of_bins)
const {
361 std::vector<double> result(number_of_bins);
362 std::fill(result.begin(), result.end(), 0);
364 for (
size_t i = 0; i != this->intervals.size(); ++i) {
366 std::cerr <<
"Interval : " << this->intervals[i].first <<
" , " << this->intervals[i].second << std::endl;
370 if (this->intervals[i].first < x_min) beginIt = 0;
371 if (this->intervals[i].first >= x_max) beginIt = result.size();
372 if ((this->intervals[i].first > x_min) && (this->intervals[i].first < x_max)) {
373 beginIt = number_of_bins * (this->intervals[i].first - x_min) / (x_max - x_min);
377 if (this->intervals[i].second < x_min) endIt = 0;
378 if (this->intervals[i].second >= x_max) endIt = result.size();
379 if ((this->intervals[i].second > x_min) && (this->intervals[i].second < x_max)) {
380 endIt = number_of_bins * (this->intervals[i].second - x_min) / (x_max - x_min);
383 if (beginIt > endIt) {
388 std::cerr <<
"beginIt : " << beginIt << std::endl;
389 std::cerr <<
"endIt : " << endIt << std::endl;
392 for (
size_t pos = beginIt; pos != endIt; ++pos) {
393 result[pos] += ((x_max - x_min) / static_cast<double>(number_of_bins)) *
394 (this->intervals[i].second - this->intervals[i].first);
397 std::cerr <<
"Result at this stage \n";
398 for (
size_t aa = 0; aa != result.size(); ++aa) {
399 std::cerr << result[aa] <<
" ";
401 std::cerr << std::endl;
408 size_t number_of_bins)
const {
410 std::vector<double> result(intsOfBars.size());
412 for (
size_t i = 0; i != intsOfBars.size(); ++i) {
413 sum += intsOfBars[i];
419 template <
typename T>
420 bool compare_first_element_of_pair(
const std::pair<T, bool>& f,
const std::pair<T, bool>& s) {
421 return (f.first < s.first);
425 std::vector<std::pair<double, bool> > places_where_pbs_change(2 * this->intervals.size());
427 for (
size_t i = 0; i != this->intervals.size(); ++i) {
428 places_where_pbs_change[2 * i] = std::make_pair(this->intervals[i].first,
true);
429 places_where_pbs_change[2 * i + 1] = std::make_pair(this->intervals[i].second,
false);
432 std::sort(places_where_pbs_change.begin(), places_where_pbs_change.end(), compare_first_element_of_pair<double>);
434 std::vector<std::pair<double, size_t> > pbns(places_where_pbs_change.size());
435 for (
size_t i = 0; i != places_where_pbs_change.size(); ++i) {
436 if (places_where_pbs_change[i].second ==
true) {
441 pbns[i] = std::make_pair(places_where_pbs_change[i].first, pbn);
446 inline double compute_euclidean_distance(
const std::pair<double, double>& f,
const std::pair<double, double>& s) {
447 return sqrt((f.first - s.first) * (f.first - s.first) + (f.second - s.second) * (f.second - s.second));
453 std::cerr <<
"Here are the intervals : \n";
454 for (
size_t i = 0; i != this->intervals.size(); ++i) {
455 std::cerr <<
"[ " << this->intervals[i].first <<
" , " << this->intervals[i].second <<
"] \n";
460 std::vector<double> result;
463 std::vector<std::vector<double> > distances(this->intervals.size());
464 for (
size_t i = 0; i != this->intervals.size(); ++i) {
465 std::vector<double> aa(this->intervals.size());
466 std::fill(aa.begin(), aa.end(), 0);
469 std::vector<double> distances_from_diagonal(this->intervals.size());
470 std::fill(distances_from_diagonal.begin(), distances_from_diagonal.end(), 0);
472 for (
size_t i = 0; i != this->intervals.size(); ++i) {
473 std::vector<double> distancesFromI;
474 for (
size_t j = i + 1; j != this->intervals.size(); ++j) {
475 distancesFromI.push_back(compute_euclidean_distance(this->intervals[i], this->intervals[j]));
478 double distanceToDiagonal = compute_euclidean_distance(
479 this->intervals[i], std::make_pair(0.5 * (this->intervals[i].first + this->intervals[i].second),
480 0.5 * (this->intervals[i].first + this->intervals[i].second)));
481 distances_from_diagonal[i] = distanceToDiagonal;
484 std::cerr <<
"Here are the distances form the point : [" << this->intervals[i].first <<
" , " 485 << this->intervals[i].second <<
"] in the diagram \n";
486 for (
size_t aa = 0; aa != distancesFromI.size(); ++aa) {
487 std::cerr <<
"To : " << i + aa <<
" : " << distancesFromI[aa] <<
" ";
489 std::cerr << std::endl;
494 for (
size_t j = i + 1; j != this->intervals.size(); ++j) {
495 distances[i][j] = distancesFromI[j - i - 1];
496 distances[j][i] = distancesFromI[j - i - 1];
500 std::cerr <<
"Here is the distance matrix : \n";
501 for (
size_t i = 0; i != distances.size(); ++i) {
502 for (
size_t j = 0; j != distances.size(); ++j) {
503 std::cerr << distances[i][j] <<
" ";
505 std::cerr << std::endl;
507 std::cerr << std::endl << std::endl <<
"And here are the distances to the diagonal : " << std::endl;
508 for (
size_t i = 0; i != distances_from_diagonal.size(); ++i) {
509 std::cerr << distances_from_diagonal[i] <<
" ";
511 std::cerr << std::endl << std::endl;
515 for (
size_t i = 0; i != this->intervals.size(); ++i) {
516 std::vector<double> distancesFromI = distances[i];
517 distancesFromI.push_back(distances_from_diagonal[i]);
520 std::sort(distancesFromI.begin(), distancesFromI.end(), std::greater<double>());
522 if (k > distancesFromI.size()) {
524 std::cerr <<
"There are not enough neighbors in your set. We set the result to plus infty \n";
526 result.push_back(std::numeric_limits<double>::max());
528 if (distances_from_diagonal[i] > distancesFromI[k]) {
530 std::cerr <<
"The k-th n.n. is on a diagonal. Therefore we set up a distance to diagonal \n";
532 result.push_back(distances_from_diagonal[i]);
534 result.push_back(distancesFromI[k]);
538 std::sort(result.begin(), result.end(), std::greater<double>());
539 result.resize(std::min(result.size(), where_to_cut));
547 for (
size_t i = 0; i != this->intervals.size(); ++i) {
549 (this->intervals[i].second - this->intervals[i].first) * (this->intervals[i].second - this->intervals[i].first);
558 #endif // PERSISTENCE_INTERVALS_H_ std::vector< std::pair< double, size_t > > compute_persistent_betti_numbers() const
Definition: Persistence_intervals.h:424
size_t size() const
Definition: Persistence_intervals.h:193
std::vector< double > characteristic_function_of_diagram(double x_min, double x_max, size_t number_of_bins=10) const
Definition: Persistence_intervals.h:357
std::vector< double > k_n_n(size_t k, size_t where_to_cut=10) const
Definition: Persistence_intervals.h:450
std::vector< double > vectorize(int number_of_function) const
Definition: Persistence_intervals.h:224
std::vector< std::pair< double, double > > dominant_intervals(size_t where_to_cut=100) const
Definition: Persistence_intervals.h:279
Definition: SimplicialComplexForAlpha.h:14
std::vector< double > length_of_dominant_intervals(size_t where_to_cut=100) const
Definition: Persistence_intervals.h:264
std::vector< size_t > histogram_of_lengths(size_t number_of_bins=10) const
Definition: Persistence_intervals.h:301
void plot(const char *filename, double min_x=std::numeric_limits< double >::max(), double max_x=std::numeric_limits< double >::max(), double min_y=std::numeric_limits< double >::max(), double max_y=std::numeric_limits< double >::max()) const
Definition: Persistence_intervals.h:152
std::pair< double, double > get_x_range() const
Definition: Persistence_intervals.h:57
Persistence_intervals(const char *filename, unsigned dimension=std::numeric_limits< unsigned >::max())
Definition: Persistence_intervals.h:250
Definition: Persistence_intervals.h:35
size_t number_of_vectorize_functions() const
Definition: Persistence_intervals.h:231
friend std::ostream & operator<<(std::ostream &out, const Persistence_intervals &intervals)
Definition: Persistence_intervals.h:142
std::vector< double > cumulative_characteristic_function_of_diagram(double x_min, double x_max, size_t number_of_bins=10) const
Definition: Persistence_intervals.h:407
std::pair< double, double > operator[](size_t i) const
Definition: Persistence_intervals.h:199
std::vector< size_t > cumulative_histogram_of_lengths(size_t number_of_bins=10) const
Definition: Persistence_intervals.h:345
double project_to_R(int number_of_function) const
Definition: Persistence_intervals.h:544
size_t number_of_projections_to_R() const
Definition: Persistence_intervals.h:218
std::pair< double, double > get_y_range() const
Definition: Persistence_intervals.h:70