File: timestepbufferreader.h

package info (click to toggle)
wsclean 3.7-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 10,968 kB
  • sloc: cpp: 85,742; python: 3,526; sh: 245; makefile: 21
file content (64 lines) | stat: -rw-r--r-- 1,732 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
#ifndef MSPROVIDERS_MSREADERS_TIMESTEPBUFFERREADER_H
#define MSPROVIDERS_MSREADERS_TIMESTEPBUFFERREADER_H

#include "msreader.h"
#include "../timestepbuffer.h"

namespace wsclean {

class TimestepBufferReader final : public MSReader {
 public:
  TimestepBufferReader(TimestepBuffer* timestep_buffer);

  virtual ~TimestepBufferReader(){};

  size_t RowId() const final override {
    return buffer_[buffer_position_].row_id;
  }

  bool CurrentRowAvailable() final override;

  void NextInputRow() final override;

  void ReadMeta(MSProvider::MetaData& metadata) final override;

  void ReadData(std::complex<float>* buffer) final override;

  void ReadModel(std::complex<float>* buffer) final override;

  void ReadWeights(float* buffer) final override;

  void WriteImagingWeights(const float* buffer) final override;

  /**
   * Returns an Array containing the uvws for baselines (antenna1, antenna2)
   * that have antenna1=0, sorted by antenna2.
   * @param uvws should have the correct size on input (nantenna * 3)
   */
  void GetUVWsForTimestep(aocommon::UVector<double>& uvws) {
    for (size_t i = 0; i != buffer_.size(); ++i) {
      if (buffer_[i].metadata.antenna1 == 0) {
        size_t index = buffer_[i].metadata.antenna2 * 3;
        if (index >= buffer_.size()) buffer_.resize(index + 3);
        uvws[index + 0] = buffer_[i].metadata.u_in_m;
        uvws[index + 1] = buffer_[i].metadata.v_in_m;
        uvws[index + 2] = buffer_[i].metadata.w_in_m;
      }
    }
    uvws[0] = 0.0;
    uvws[1] = 0.0;
    uvws[2] = 0.0;
  }

 private:
  void readTimeblock();

  std::unique_ptr<MSReader> ms_reader_;

  size_t buffer_position_;
  std::vector<TimestepBuffer::RowData> buffer_;
};

}  // namespace wsclean

#endif