Container of dimension/time-major order floating point data. More...

#include <DataSeries.h>

Inheritance diagram for dsp::DataSeries:
dsp::Observation OwnStream Reference::Able Reference::HeapTracked dsp::TimeSeries dsp::PhaseSeries dsp::WeightedTimeSeries

Public Member Functions

 DataSeries ()
 Null constructor.
 
 DataSeries (const DataSeries &ds)
 Copy constructor.
 
void initi ()
 Called by constructor to initialise variables.
 
virtual DataSeriesclone () const =0
 Cloner (calls new)
 
virtual DataSeriesnull_clone () const =0
 Returns a null-instantiation (calls new)
 
virtual DataSeriesswap_data (DataSeries &ds)
 Swaps the two DataSeries's. Returns '*this'.
 
virtual ~DataSeries ()
 Destructor.
 
virtual DataSeriesoperator= (const DataSeries &copy)
 Set this equal to copy.
 
void copy (const Observation *ds)
 Same as operator= but takes a pointer.
 
virtual void copy (const DataSeries *ds)
 Same as operator= but takes a pointer.
 
void set_ndat (uint64_t)
 Enforces that ndat*ndim must be an integer number of bytes.
 
void set_ndim (unsigned)
 Enforces that ndat*ndim must be an integer number of bytes.
 
void set_npol (unsigned)
 Set the number of polarizations. More...
 
void set_nchan (unsigned)
 Set the number of channels. More...
 
uint64_t get_ndat_allocated ()
 return the number of samples the current buffer can hold
 
bool reshape_required ()
 Return true if reshape of data series required.
 
virtual void resize (uint64_t nsamples)
 Allocate the space required to store nsamples time samples. More...
 
virtual void resize (uint64_t nsamples, unsigned char *&old_buffer)
 
void reshape ()
 Reshape the buffer to match the current attributes.
 
void reshape (unsigned npol, unsigned ndim)
 Reshape the buffer to match the specified attributes.
 
virtual void zero ()
 Set all values to zero.
 
virtual unsigned char * get_udatptr (unsigned ichan=0, unsigned ipol=0)
 Return pointer to the specified block of time samples. More...
 
virtual const unsigned char * get_udatptr (unsigned ichan=0, unsigned ipol=0) const
 Return pointer to the specified block of time samples. More...
 
virtual uint64_t get_subsize ()
 Stride (in bytes) between the same time sample in different chan/pol.
 
virtual void internal_match (const DataSeries *)
 Match the internal memory layout of another DataSeries.
 
virtual void copy_configuration (const Observation *copy)
 
unsigned char * internal_get_buffer ()
 Return the internal memory base address.
 
const unsigned char * internal_get_buffer () const
 
uint64_t internal_get_size () const
 Return the internal memory size.
 
uint64_t internal_get_subsize () const
 Return the internal memory sub-division size.
 
virtual void set_memory (Memory *)
 Set the memory manager.
 
const Memoryget_memory () const
 
- Public Member Functions inherited from dsp::Observation
 Observation ()
 Null constructor.
 
 Observation (const Observation &)
 Copy constructor.
 
 Observation (const Observation *)
 Copy from pointer constructor.
 
const Observationoperator= (const Observation &)
 Assignment operator.
 
virtual ~Observation ()
 Virtual destructor (see Effective C++ Item 14)
 
virtual void set_basis (Signal::Basis _basis)
 Set the type of receiver feeds.
 
Signal::Basis get_basis () const
 Return the type of receiver feeds.
 
virtual void set_state (Signal::State _state)
 Set the state of the signal.
 
Signal::State get_state () const
 Return the state of the signal.
 
virtual void set_type (Signal::Source _type)
 Set the source type.
 
Signal::Source get_type () const
 Return the source type.
 
unsigned get_ndim () const
 Return the dimension of each datum.
 
unsigned get_nchan () const
 Return the number of channels into which the band is divided.
 
unsigned get_npol () const
 Return the number of polarizations.
 
virtual void set_nbit (unsigned _nbit)
 Set the number of bits per value.
 
unsigned get_nbit () const
 Return the number of bits per value.
 
uint64_t bits_per_sample () const
 Return the number of bits in a single time sample (over all channels, pols, and dimensions)
 
uint64_t get_ndat () const
 Return the number of time samples in container.
 
virtual void set_telescope (const std::string &name)
 Set the telescope name.
 
std::string get_telescope () const
 Return the telescope name.
 
virtual void set_receiver (const std::string &name)
 Set the receiver name.
 
std::string get_receiver () const
 Return the receiver name.
 
virtual void set_source (const std::string &name)
 Set the source name.
 
std::string get_source () const
 Return the source name.
 
virtual void set_coordinates (sky_coord _coordinates)
 Set the coordinates of the source.
 
sky_coord get_coordinates () const
 Return the coordinates of the source.
 
virtual void set_centre_frequency (double cf)
 Set the centre frequency of the band-limited signal in MHz.
 
double get_centre_frequency () const
 Return the centre frequency of the band-limited signal in MHz.
 
double get_centre_frequency (unsigned ichan) const
 Returns the centre frequency of the specified channel in MHz.
 
double get_base_frequency () const
 Returns the centre frequency of the reference channel in MHz.
 
unsigned get_unswapped_ichan (unsigned ichan) const
 Returns the unswapped channel index of the specified channel.
 
virtual void set_bandwidth (double _bandwidth)
 Set the bandwidth of signal in MHz (-ve = lsb; +ve = usb)
 
double get_bandwidth () const
 Return the bandwidth of signal in MHz (-ve = lsb; +ve = usb)
 
virtual void set_start_time (MJD _start_time)
 Set the start time of the leading edge of the first time sample.
 
MJD get_start_time () const
 Return the start time of the leading edge of the first time sample.
 
virtual void set_rate (double _rate)
 Set the sampling rate (time samples per second in Hz)
 
double get_rate () const
 Return the sampling rate (time samples per second in Hz)
 
virtual void set_scale (double _scale)
 Set the amount by which data has been scaled.
 
double get_scale () const
 Return the amount by which data has been scaled.
 
virtual void set_swap (bool _swap)
 Set true if frequency channels are out of order (band swappped)
 
bool get_swap () const
 Return true if frequency channels are out of order (band swappped)
 
virtual void set_nsub_swap (unsigned _nsub)
 Set the number of sub-bands that must be band swapped.
 
unsigned get_nsub_swap () const
 Return the number of sub-bands that must be band swapped.
 
virtual void set_dual_sideband (int _dual)
 Set to 1 if the spectrum in each channel has dual-sideband frequency order. More...
 
int get_dual_sideband () const
 Return the dual-sideband. More...
 
virtual void set_dc_centred (bool _centred)
 Set true if centre channel is centred on centre frequency. More...
 
bool get_dc_centred () const
 
virtual void set_identifier (const std::string &_id)
 Set the observation identifier.
 
std::string get_identifier () const
 Return the observation identifier.
 
virtual void set_machine (const std::string &_m)
 Set the instrument used to record signal.
 
std::string get_machine () const
 Return the instrument used to record signal.
 
virtual void set_format (const std::string &_f)
 Set the format used to record signal.
 
std::string get_format () const
 Return the format used to record signal.
 
virtual void set_dispersion_measure (double dm)
 Set the pulsar dispersion mesure.
 
double get_dispersion_measure () const
 Returns the pulsar dispersion measure.
 
virtual void set_rotation_measure (double rm)
 Set the pulsar rotation mesure.
 
double get_rotation_measure () const
 Returns the pulsar rotation measure.
 
virtual void set_mode (const std::string &_mode)
 Set the observation mode.
 
std::string get_mode () const
 Return the observation mode.
 
virtual void set_calfreq (double _calfreq)
 Set the calibrator frequency.
 
double get_calfreq () const
 get the calibrator frequency
 
virtual void set_oversampling_factor (const Rational &_osf)
 Set the oversampling factor.
 
const Rationalget_oversampling_factor () const
 Get the oversampling factor.
 
virtual void set_deripple (const std::vector< dsp::FIRFilter > &_deripple)
 
const std::vector< dsp::FIRFilter > & get_deripple () const
 
unsigned get_deripple_stages () const
 
virtual void set_pfb_dc_chan (const bool _pfb_dc_chan)
 set/get the DC PFB channel flag (for inverse filterbank)
 
bool get_pfb_dc_chan () const
 
virtual void set_pfb_nchan (unsigned nchan)
 set/get the number of channels output by the PFB per input channel
 
unsigned get_pfb_nchan () const
 
virtual void change_state (Signal::State new_state)
 Change the state and correct other attributes accordingly.
 
bool state_is_valid (std::string &reason) const
 Return true if the state of the Observation is valid. More...
 
bool get_detected () const
 Returns true if state is Detected, Coherence, or Stokes.
 
void change_start_time (int64_t _ndat)
 Change the start time by the number of time samples specified.
 
virtual MJD get_end_time () const
 Return the end time of the trailing edge of the last time sample.
 
uint64_t get_idat (const MJD &mjd)
 Return the nearest time sample corresponding to the specified MJD.
 
void rescale (double factor)
 Multiply scale by factor.
 
virtual uint64_t get_nbytes (uint64_t nsamples) const
 Return the size in bytes of nsamples time samples.
 
uint64_t get_nbytes () const
 Return the size in bytes of ndat time samples.
 
uint64_t verbose_nbytes (uint64_t nsamples) const
 
float get_nbyte () const
 Return the size in bytes of one time sample.
 
virtual uint64_t get_nsamples (uint64_t nbytes) const
 Return the number of samples in nbytes bytes.
 
void copy_dimensions (const Observation *)
 Copy the dimensions of another observation.
 
bool combinable (const Observation &obs) const
 Returns true if the signal may be integrated.
 
std::string get_reason ()
 Returns the reason if combinable returns false.
 
bool contiguous (const Observation &next) const
 Return true if the first sample of next follows the last sample of this.
 
void init ()
 Set all attributes to null default.
 
void set_nbyte_nsample_policy (NbyteNsamplePolicy *)
 Set the policy that defines the bijection between number of bytes and number of samples.
 
const NbyteNsamplePolicy * get_nbyte_nsample_policy () const
 Get the policy that defines the bijection between number of bytes and number of samples.
 
virtual TextInterface::Parserget_interface ()
 Return a text interface that can be used to access this instance.
 
- Public Member Functions inherited from OwnStream
 OwnStream (const OwnStream &)
 
const OwnStreamoperator= (const OwnStream &)
 
virtual void set_cout (std::ostream &) const
 
virtual void set_cerr (std::ostream &) const
 
- Public Member Functions inherited from Reference::Able
 Able (const Able &)
 
Ableoperator= (const Able &)
 
unsigned get_reference_count () const
 
- Public Member Functions inherited from Reference::HeapTracked
 HeapTracked (const HeapTracked &)
 
HeapTrackedoperator= (const HeapTracked &)
 
bool __is_on_heap () const
 

Static Public Attributes

static int instantiation_count = 0
 Counts number of DataSeries's in existence.
 
static int64_t memory_used = 0
 Stores the cumulative amount of memory used.
 
- Static Public Attributes inherited from dsp::Observation
static bool verbose = false
 Verbosity flag.
 

Protected Member Functions

virtual unsigned char * get_data ()
 Returns a uchar pointer to the first piece of data.
 
virtual const unsigned char * get_data () const
 Returns a uchar pointer to the first piece of data.
 
- Protected Member Functions inherited from Reference::Able
Handle__reference (bool active) const
 
void __dereference (bool auto_delete=true) const
 

Protected Attributes

unsigned char * buffer = nullptr
 The data buffer.
 
uint64_t size = 0
 The size of the data buffer (in bytes)
 
uint64_t subsize = 0
 The number of BYTES in a data sub-division.
 
bool shape_changed = false
 Flag for whether the shape of the data series has changed.
 
Reference::To< Memorymemory
 The memory manager.
 
- Protected Attributes inherited from dsp::Observation
std::string telescope
 Telescope name.
 
std::string receiver
 Receiver name.
 
std::string source
 Source name. If a pulsar, should be J2000.
 
double centre_frequency = 0.0
 Centre frequency of band-limited signal in MHz.
 
double bandwidth = 0.0
 Bandwidth of signal in MHz (-ve = lsb; +ve = usb)
 
Signal::Source type
 Type of signal source (Pulsar, CAL, etc.)
 
Signal::State state
 State of the signal (Full Stokes, Total Intensity, etc.)
 
Signal::Basis basis
 Type of receiver feeds (Linear or Circular)
 
double rate = 0.0
 Time samples per second in Hz.
 
MJD start_time
 Start time of the leading edge of the first time sample.
 
std::string identifier
 Observation identifier.
 
std::string mode
 Observation mode.
 
std::string machine
 Instrument used to record signal.
 
std::string format
 Data format used to record signal.
 
sky_coord coordinates
 Coordinates of the source.
 
double dispersion_measure = 0.0
 The dispersion measure to be archived.
 
double rotation_measure = 0.0
 The rotation measure to be archived.
 
bool require_equal_sources = true
 Require equal sources in combinable.
 
bool require_equal_rates = true
 Require equal rates in combinable.
 
double scale = 1.0
 Amount by which data has been scaled.
 
bool swap = false
 Flag set when frequency channels are out of order (band swappped)
 
unsigned nsub_swap = 0
 The number of sub-bands that must be band swapped.
 
bool dc_centred = false
 Flag set when centre channel is centred on centre frequency.
 
Rational oversampling_factor
 oversampling factor
 
std::vector< FIRFilter > deripple
 information about deripple correction
 
bool pfb_dc_chan = true
 Do we have the DC, or zeroth PFB channel?
 
unsigned pfb_nchan = 0
 Number of channels output by PFB for a single input time series. More...
 

Additional Inherited Members

- Static Public Member Functions inherited from Reference::Able
static size_t get_instance_count ()
 
- Static Public Member Functions inherited from Reference::HeapTracked
static void * operator new (size_t size, void *ptr=0)
 
static void operator delete (void *location, void *ptr)
 
static void operator delete (void *location)
 
static size_t get_heap_queue_size ()
 

Detailed Description

Container of dimension/time-major order floating point data.

Member Function Documentation

◆ get_udatptr() [1/2]

unsigned char * dsp::DataSeries::get_udatptr ( unsigned  ichan = 0,
unsigned  ipol = 0 
)
virtual

Return pointer to the specified block of time samples.

Return pointer to the specified data block.

Referenced by operator=().

◆ get_udatptr() [2/2]

const unsigned char * dsp::DataSeries::get_udatptr ( unsigned  ichan = 0,
unsigned  ipol = 0 
) const
virtual

Return pointer to the specified block of time samples.

Return pointer to the specified data block.

◆ resize()

void dsp::DataSeries::resize ( uint64_t  nsamples)
virtual

Allocate the space required to store nsamples time samples.

Note that the space used in each chan/pol group must be an integer number of bytes.

Precondition
The dimensions of each time sample (nchan, npol, ndim) should have been set prior to calling this method.
Postcondition
If:
  • nsamples == 0, the data buffer is completely de-allocated
  • nsamples < previous resize(nsamples), the data buffer and its data is not modified. Only the interpretation of the size of each data block is changed.
  • nsamples > previous resize(nsamples), the data buffer may be deleted and the current data fill be lost.

Reimplemented in dsp::TimeSeries, and dsp::WeightedTimeSeries.

Referenced by dsp::TimeSeries::resize().

◆ set_nchan()

void dsp::DataSeries::set_nchan ( unsigned  _nchan)
virtual

Set the number of channels.

checks for change in nchan

Reimplemented from dsp::Observation.

References dsp::Observation::set_nchan().

Referenced by dsp::CyclicFold::prepare_output(), and dsp::FZoom::transformation().

◆ set_npol()

void dsp::DataSeries::set_npol ( unsigned  _npol)
virtual

Set the number of polarizations.

checks for change in npol

Reimplemented from dsp::Observation.

References dsp::Observation::set_npol().

Referenced by dsp::CyclicFold::prepare_output().


The documentation for this class was generated from the following files:

Generated using doxygen 1.8.17