File: wide_field_utilities.cc

package info (click to toggle)
purify 5.0.1-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 186,852 kB
  • sloc: cpp: 17,731; python: 510; xml: 182; makefile: 7; sh: 6
file content (111 lines) | stat: -rw-r--r-- 4,598 bytes parent folder | download
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#include "purify/config.h"
#include <iostream>
#include "catch2/catch_all.hpp"
#include "purify/logging.h"

#include "purify/types.h"

#include "purify/convolution.h"
#include "purify/directories.h"
#include "purify/kernels.h"
#include "purify/uvw_utilities.h"
#include "purify/wide_field_utilities.h"

using namespace purify;
using Catch::Approx;

TEST_CASE("uvw units") {
  const t_uint imsizex = 128;
  const t_uint imsizey = 128;
  const t_real oversample_ratio = 2;

  SECTION("1arcsec") {
    const utilities::vis_params uv_lambda(Vector<t_real>::Ones(5), Vector<t_real>::Ones(5),
                                          Vector<t_real>::Ones(5), Vector<t_complex>::Ones(5),
                                          Vector<t_complex>::Ones(5));
    auto const uv_radians = utilities::set_cell_size(uv_lambda, 1., 1.);
    auto const uv_pixels = utilities::uv_scale(uv_radians, std::floor(oversample_ratio * imsizex),
                                               std::floor(oversample_ratio * imsizey));
    CHECK(uv_radians.units == utilities::vis_units::radians);
    CHECK(uv_lambda.units == utilities::vis_units::lambda);
    CHECK(uv_pixels.units == utilities::vis_units::pixels);
    // const t_real scale = 60. * 60. * 180. / std::floor(oversample_ratio * imsizex) /
    // constant::pi;
    const t_real scale = widefield::pixel_to_lambda(1., imsizex, oversample_ratio);
    CAPTURE(1. / scale);
    CAPTURE(uv_pixels.u.transpose());
    CHECK(uv_lambda.u.isApprox(uv_pixels.u * scale, 1e-6));
    CHECK(
        1. ==
        Approx(widefield::equivalent_miriad_cell_size(1., imsizex, oversample_ratio)).margin(1e-4));
  }
  SECTION("arcsec") {
    const t_real cell = 3;
    const utilities::vis_params uv_lambda(Vector<t_real>::Ones(5), Vector<t_real>::Ones(5),
                                          Vector<t_real>::Ones(5), Vector<t_complex>::Ones(5),
                                          Vector<t_complex>::Ones(5));
    auto const uv_radians = utilities::set_cell_size(uv_lambda, cell, cell);
    auto const uv_pixels = utilities::uv_scale(uv_radians, std::floor(oversample_ratio * imsizex),
                                               std::floor(oversample_ratio * imsizey));
    CHECK(uv_radians.units == utilities::vis_units::radians);
    CHECK(uv_lambda.units == utilities::vis_units::lambda);
    CHECK(uv_pixels.units == utilities::vis_units::pixels);
    // const t_real scale
    //    = 60. * 60. * 180. / cell / std::floor(oversample_ratio * imsizex) / constant::pi;
    const t_real scale = widefield::pixel_to_lambda(cell, imsizex, oversample_ratio);
    CAPTURE(1. / scale);
    CAPTURE(uv_pixels.u.transpose());
    CHECK(uv_lambda.u.isApprox(uv_pixels.u * scale, 1e-6));
    CHECK(3. == Approx(widefield::equivalent_miriad_cell_size(cell, imsizex, oversample_ratio))
                    .margin(1e-4));
  }
}

TEST_CASE("test cell size conversion") {
  const t_real oversample_ratio = 2;
  const t_int imsize = 8192;
  for (t_real FoV : {0.1, 0.2, 0.3, 0.4, 0.5, 1., 5., 10., 15., 20., 25., 30., 40., 50., 60., 70.,
                     80., 90., 120.}) {
    const t_real cell = FoV / imsize * 60 * 60;
    const t_real miriad_cell =
        widefield::equivalent_miriad_cell_size(cell, imsize, oversample_ratio);
    CAPTURE(cell);
    CAPTURE(miriad_cell);
    CAPTURE(FoV);
    CAPTURE(miriad_cell * imsize / 60. / 60.);
    CAPTURE((1 - miriad_cell * imsize / 60. / 60. / FoV) * FoV);
    if (FoV < 0.5)
      CHECK(cell == Approx(miriad_cell).margin(1e-12));
    else
      CHECK(cell > miriad_cell);
  }
}

TEST_CASE("Calcuate DDE Image") {
  const t_int imsizex = 128;
  const t_int imsizey = 128;
  SECTION("w is zero") {
    const t_real w_rate = 0;
    const Image<t_complex> chirp_image =
        widefield::generate_dde([](t_real, t_real) { return 1.; }, 1, 1, imsizex, imsizey, 0);
    REQUIRE(chirp_image.cols() == imsizex);
    REQUIRE(chirp_image.rows() == imsizey);
    REQUIRE(chirp_image.isApprox(Image<t_complex>::Constant(imsizey, imsizex, 1)));
  }
}

TEST_CASE("estimate_sample_density") {
  const t_int imsizex = 1024;
  const t_int imsizey = 1024;
  const t_real cellx = 10;
  const t_real celly = 10;
  const t_real oversample_ratio = 2;
  const t_int M = 6;
  const Vector<t_real> u = Vector<t_real>::Random(M) * 1000;
  const Vector<t_real> v = Vector<t_real>::Random(M) * 1000;

  const Vector<t_complex> weights =
      widefield::sample_density_weights(u, v, cellx, celly, imsizex, imsizey, oversample_ratio, 1);
  REQUIRE(weights.size() == M);
  CHECK(weights.isApprox(Vector<t_complex>::Ones(weights.size())));
}