mirror of
https://github.com/ciphervance/supercell-wx.git
synced 2025-10-30 22:50:05 +00:00
203 lines
6.1 KiB
C++
203 lines
6.1 KiB
C++
#pragma once
|
|
|
|
#include <scwx/wsr88d/rda/generic_radar_data.hpp>
|
|
|
|
namespace scwx
|
|
{
|
|
namespace wsr88d
|
|
{
|
|
namespace rda
|
|
{
|
|
|
|
class DigitalRadarDataGeneric : public GenericRadarData
|
|
{
|
|
public:
|
|
class DataBlock;
|
|
class ElevationDataBlock;
|
|
class MomentDataBlock;
|
|
class RadialDataBlock;
|
|
class VolumeDataBlock;
|
|
|
|
explicit DigitalRadarDataGeneric();
|
|
~DigitalRadarDataGeneric();
|
|
|
|
DigitalRadarDataGeneric(const DigitalRadarDataGeneric&) = delete;
|
|
DigitalRadarDataGeneric& operator=(const DigitalRadarDataGeneric&) = delete;
|
|
|
|
DigitalRadarDataGeneric(DigitalRadarDataGeneric&&) noexcept;
|
|
DigitalRadarDataGeneric& operator=(DigitalRadarDataGeneric&&) noexcept;
|
|
|
|
std::string radar_identifier() const;
|
|
std::uint32_t collection_time() const;
|
|
std::uint16_t modified_julian_date() const;
|
|
std::uint16_t azimuth_number() const;
|
|
units::degrees<float> azimuth_angle() const;
|
|
std::uint8_t compression_indicator() const;
|
|
std::uint16_t radial_length() const;
|
|
std::uint8_t azimuth_resolution_spacing() const;
|
|
std::uint8_t radial_status() const;
|
|
std::uint16_t elevation_number() const;
|
|
std::uint8_t cut_sector_number() const;
|
|
units::degrees<float> elevation_angle() const;
|
|
std::uint8_t radial_spot_blanking_status() const;
|
|
std::uint8_t azimuth_indexing_mode() const;
|
|
std::uint16_t data_block_count() const;
|
|
std::uint16_t volume_coverage_pattern_number() const;
|
|
|
|
std::shared_ptr<ElevationDataBlock> elevation_data_block() const;
|
|
std::shared_ptr<RadialDataBlock> radial_data_block() const;
|
|
std::shared_ptr<VolumeDataBlock> volume_data_block() const;
|
|
std::shared_ptr<GenericRadarData::MomentDataBlock>
|
|
moment_data_block(DataBlockType type) const;
|
|
|
|
bool Parse(std::istream& is);
|
|
|
|
static std::shared_ptr<DigitalRadarDataGeneric>
|
|
Create(Level2MessageHeader&& header, std::istream& is);
|
|
|
|
private:
|
|
class Impl;
|
|
std::unique_ptr<Impl> p;
|
|
};
|
|
|
|
class DigitalRadarDataGeneric::DataBlock
|
|
{
|
|
protected:
|
|
explicit DataBlock(const std::string& dataBlockType,
|
|
const std::string& dataName);
|
|
virtual ~DataBlock();
|
|
|
|
DataBlock(const DataBlock&) = delete;
|
|
DataBlock& operator=(const DataBlock&) = delete;
|
|
|
|
DataBlock(DataBlock&&) noexcept;
|
|
DataBlock& operator=(DataBlock&&) noexcept;
|
|
|
|
private:
|
|
class Impl;
|
|
std::unique_ptr<Impl> p;
|
|
};
|
|
|
|
class DigitalRadarDataGeneric::ElevationDataBlock : public DataBlock
|
|
{
|
|
public:
|
|
explicit ElevationDataBlock(const std::string& dataBlockType,
|
|
const std::string& dataName);
|
|
~ElevationDataBlock();
|
|
|
|
ElevationDataBlock(const ElevationDataBlock&) = delete;
|
|
ElevationDataBlock& operator=(const ElevationDataBlock&) = delete;
|
|
|
|
ElevationDataBlock(ElevationDataBlock&&) noexcept;
|
|
ElevationDataBlock& operator=(ElevationDataBlock&&) noexcept;
|
|
|
|
static std::shared_ptr<ElevationDataBlock>
|
|
Create(const std::string& dataBlockType,
|
|
const std::string& dataName,
|
|
std::istream& is);
|
|
|
|
private:
|
|
class Impl;
|
|
std::unique_ptr<Impl> p;
|
|
|
|
bool Parse(std::istream& is);
|
|
};
|
|
|
|
class DigitalRadarDataGeneric::MomentDataBlock :
|
|
public DataBlock,
|
|
public GenericRadarData::MomentDataBlock
|
|
{
|
|
public:
|
|
explicit MomentDataBlock(const std::string& dataBlockType,
|
|
const std::string& dataName);
|
|
~MomentDataBlock();
|
|
|
|
MomentDataBlock(const MomentDataBlock&) = delete;
|
|
MomentDataBlock& operator=(const MomentDataBlock&) = delete;
|
|
|
|
MomentDataBlock(MomentDataBlock&&) noexcept;
|
|
MomentDataBlock& operator=(MomentDataBlock&&) noexcept;
|
|
|
|
std::uint16_t number_of_data_moment_gates() const;
|
|
units::kilometers<float> data_moment_range() const;
|
|
std::int16_t data_moment_range_raw() const;
|
|
units::kilometers<float> data_moment_range_sample_interval() const;
|
|
std::uint16_t data_moment_range_sample_interval_raw() const;
|
|
float snr_threshold() const;
|
|
std::int16_t snr_threshold_raw() const;
|
|
std::uint8_t data_word_size() const;
|
|
float scale() const;
|
|
float offset() const;
|
|
const void* data_moments() const;
|
|
|
|
static std::shared_ptr<MomentDataBlock>
|
|
Create(const std::string& dataBlockType,
|
|
const std::string& dataName,
|
|
std::istream& is);
|
|
|
|
private:
|
|
class Impl;
|
|
std::unique_ptr<Impl> p;
|
|
|
|
bool Parse(std::istream& is);
|
|
};
|
|
|
|
class DigitalRadarDataGeneric::RadialDataBlock : public DataBlock
|
|
{
|
|
public:
|
|
explicit RadialDataBlock(const std::string& dataBlockType,
|
|
const std::string& dataName);
|
|
~RadialDataBlock();
|
|
|
|
RadialDataBlock(const RadialDataBlock&) = delete;
|
|
RadialDataBlock& operator=(const RadialDataBlock&) = delete;
|
|
|
|
RadialDataBlock(RadialDataBlock&&) noexcept;
|
|
RadialDataBlock& operator=(RadialDataBlock&&) noexcept;
|
|
|
|
float unambiguous_range() const;
|
|
|
|
static std::shared_ptr<RadialDataBlock>
|
|
Create(const std::string& dataBlockType,
|
|
const std::string& dataName,
|
|
std::istream& is);
|
|
|
|
private:
|
|
class Impl;
|
|
std::unique_ptr<Impl> p;
|
|
|
|
bool Parse(std::istream& is);
|
|
};
|
|
|
|
class DigitalRadarDataGeneric::VolumeDataBlock : public DataBlock
|
|
{
|
|
public:
|
|
explicit VolumeDataBlock(const std::string& dataBlockType,
|
|
const std::string& dataName);
|
|
~VolumeDataBlock();
|
|
|
|
VolumeDataBlock(const VolumeDataBlock&) = delete;
|
|
VolumeDataBlock& operator=(const VolumeDataBlock&) = delete;
|
|
|
|
VolumeDataBlock(VolumeDataBlock&&) noexcept;
|
|
VolumeDataBlock& operator=(VolumeDataBlock&&) noexcept;
|
|
|
|
float latitude() const;
|
|
float longitude() const;
|
|
std::uint16_t volume_coverage_pattern_number() const;
|
|
|
|
static std::shared_ptr<VolumeDataBlock>
|
|
Create(const std::string& dataBlockType,
|
|
const std::string& dataName,
|
|
std::istream& is);
|
|
|
|
private:
|
|
class Impl;
|
|
std::unique_ptr<Impl> p;
|
|
|
|
bool Parse(std::istream& is);
|
|
};
|
|
|
|
} // namespace rda
|
|
} // namespace wsr88d
|
|
} // namespace scwx
|