File: time_gridding_degridding.cc

package info (click to toggle)
purify 2.0.0-5
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 58,688 kB
  • sloc: cpp: 8,410; python: 375; makefile: 7
file content (89 lines) | stat: -rw-r--r-- 3,664 bytes parent folder | download | duplicates (3)
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#include "purify/config.h"
#include <string>
#include "purify/MeasurementOperator.h"
#include "purify/directories.h"
#include "purify/logging.h"
#include "purify/pfitsio.h"
#include "purify/utilities.h"

#include <ctime>

using namespace purify;
using namespace purify::notinstalled;

int main(int nargs, char const **args) {
  purify::logging::initialize();
  purify::logging::set_level(purify::default_logging_level());
  if(nargs != 6) {
    PURIFY_CRITICAL(" Wrong number of arguments!");
    return 1;
  }

  std::string const kernel = args[1];
  t_real const over_sample = std::stod(static_cast<std::string>(args[2]));
  t_int const J = static_cast<t_int>(std::stod(static_cast<std::string>(args[3])));
  t_int const sample = static_cast<t_int>(std::stod(args[4]));
  t_int const number_of_tests = static_cast<t_int>(std::stod(args[5]));

  std::string const results
      = output_filename("Grid_Degrid_timing_" + kernel + "_" + std::to_string(sample) + ".txt");

  // Gridding example
  t_int const width = 256;
  t_int const height = 256;
  t_int const number_of_vis = 2 * std::floor(width * height * sample / 10.);
  t_real const sigma_m = constant::pi / 3;

  Vector<t_real> grid_times = Vector<t_real>::Zero(number_of_tests);
  Vector<t_real> degrid_times = Vector<t_real>::Zero(number_of_tests);

  Image<t_complex> im = Matrix<t_complex>::Random(width, height);
  Vector<t_complex> vis = Vector<t_complex>::Random(number_of_vis);
  t_real inner_loop = 10000;
  t_complex const I(0, 1);
  for(t_int i = 0; i < number_of_tests; ++i) {
    auto uv_data = utilities::random_sample_density(number_of_vis, 0, sigma_m);
    uv_data.units = "radians";
    MeasurementOperator op(uv_data, J, J, kernel, width, height, 20,
                           over_sample); // Generating gridding matrix

    uv_data.vis
        = Vector<t_complex>::Random(number_of_vis) + I * Vector<t_complex>::Random(number_of_vis);
    std::clock_t c_start = std::clock();
    for(t_int j = 0; j < inner_loop; ++j) {
      op.grid(uv_data.vis);
    }
    std::clock_t c_end = std::clock();
    grid_times(i) = static_cast<t_real>((c_end - c_start) / CLOCKS_PER_SEC) / inner_loop;
    PURIFY_MEDIUM_LOG("inner: {:f20.12}", (c_end - c_start) / CLOCKS_PER_SEC / inner_loop);
  }

  for(t_int i = 0; i < number_of_tests; ++i) {
    auto uv_data = utilities::random_sample_density(number_of_vis, 0, sigma_m);
    uv_data.units = "radians";
    MeasurementOperator op(uv_data, J, J, kernel, width, height,
                           over_sample); // Generating gridding matrix
    Image<t_complex> im
        = Matrix<t_complex>::Random(width, height) + I * Matrix<t_complex>::Random(width, height);
    std::clock_t c_start = std::clock();
    for(t_int j = 0; j < inner_loop; ++j) {
      op.degrid(im);
    }
    std::clock_t c_end = std::clock();
    degrid_times(i) = static_cast<t_real>((c_end - c_start) / CLOCKS_PER_SEC) / inner_loop;
    PURIFY_MEDIUM_LOG("inner: {:f20.12}", (c_end - c_start) / CLOCKS_PER_SEC / inner_loop);
  }
  t_real const mean_grid_time = grid_times.array().mean();
  t_real const rms_grid_time = utilities::standard_deviation(grid_times);

  t_real const mean_degrid_time = degrid_times.array().mean();
  t_real const rms_degrid_time = utilities::standard_deviation(degrid_times);
  // writing snr and time to a file
  std::ofstream out(results);
  out.precision(20);
  out << mean_grid_time << " " << rms_grid_time << " " << mean_degrid_time << " " << rms_degrid_time
      << "\n";
  out.close();
  PURIFY_HIGH_LOG("result: {:f20.12} {:f20.12} {:f20.12} {:f20.12}", mean_grid_time, rms_grid_time,
                  mean_degrid_time, rms_degrid_time);
}