mirror of
				https://github.com/ciphervance/supercell-wx.git
				synced 2025-10-31 04:50:06 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			221 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			221 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include <scwx/util/iterator.hpp>
 | |
| #include <scwx/wsr88d/rda/level2_message.hpp>
 | |
| 
 | |
| #include <units/angle.h>
 | |
| #include <units/length.h>
 | |
| 
 | |
| namespace scwx
 | |
| {
 | |
| namespace wsr88d
 | |
| {
 | |
| namespace rda
 | |
| {
 | |
| 
 | |
| enum class DataBlockType
 | |
| {
 | |
|    Volume,
 | |
|    Elevation,
 | |
|    Radial,
 | |
|    MomentRef,
 | |
|    MomentVel,
 | |
|    MomentSw,
 | |
|    MomentZdr,
 | |
|    MomentPhi,
 | |
|    MomentRho,
 | |
|    MomentCfp,
 | |
|    Unknown
 | |
| };
 | |
| typedef util::
 | |
|    Iterator<DataBlockType, DataBlockType::MomentRef, DataBlockType::MomentCfp>
 | |
|       MomentDataBlockTypeIterator;
 | |
| 
 | |
| class DataBlockImpl;
 | |
| class ElevationDataBlockImpl;
 | |
| class MomentDataBlockImpl;
 | |
| class RadialDataBlockImpl;
 | |
| class VolumeDataBlockImpl;
 | |
| 
 | |
| class DigitalRadarDataGeneric;
 | |
| class DigitalRadarDataGenericImpl;
 | |
| 
 | |
| typedef std::map<uint16_t, std::shared_ptr<DigitalRadarDataGeneric>>
 | |
|    ElevationScan;
 | |
| 
 | |
| class DataBlock
 | |
| {
 | |
| protected:
 | |
|    explicit DataBlock(const std::string& dataBlockType,
 | |
|                       const std::string& dataName);
 | |
|    ~DataBlock();
 | |
| 
 | |
|    DataBlock(const DataBlock&)            = delete;
 | |
|    DataBlock& operator=(const DataBlock&) = delete;
 | |
| 
 | |
|    DataBlock(DataBlock&&) noexcept;
 | |
|    DataBlock& operator=(DataBlock&&) noexcept;
 | |
| 
 | |
| private:
 | |
|    std::unique_ptr<DataBlockImpl> p;
 | |
| };
 | |
| 
 | |
| class 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:
 | |
|    std::unique_ptr<ElevationDataBlockImpl> p;
 | |
| 
 | |
|    bool Parse(std::istream& is);
 | |
| };
 | |
| 
 | |
| class MomentDataBlock : public DataBlock
 | |
| {
 | |
| 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;
 | |
| 
 | |
|    uint16_t                 number_of_data_moment_gates() const;
 | |
|    units::kilometers<float> data_moment_range() const;
 | |
|    uint16_t                 data_moment_range_raw() const;
 | |
|    units::kilometers<float> data_moment_range_sample_interval() const;
 | |
|    uint16_t                 data_moment_range_sample_interval_raw() const;
 | |
|    float                    snr_threshold() const;
 | |
|    int16_t                  snr_threshold_raw() const;
 | |
|    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:
 | |
|    std::unique_ptr<MomentDataBlockImpl> p;
 | |
| 
 | |
|    bool Parse(std::istream& is);
 | |
| };
 | |
| 
 | |
| class 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:
 | |
|    std::unique_ptr<RadialDataBlockImpl> p;
 | |
| 
 | |
|    bool Parse(std::istream& is);
 | |
| };
 | |
| 
 | |
| class 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;
 | |
|    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:
 | |
|    std::unique_ptr<VolumeDataBlockImpl> p;
 | |
| 
 | |
|    bool Parse(std::istream& is);
 | |
| };
 | |
| 
 | |
| class DigitalRadarDataGeneric : public Level2Message
 | |
| {
 | |
| public:
 | |
|    explicit DigitalRadarDataGeneric();
 | |
|    ~DigitalRadarDataGeneric();
 | |
| 
 | |
|    DigitalRadarDataGeneric(const DigitalRadarDataGeneric&)            = delete;
 | |
|    DigitalRadarDataGeneric& operator=(const DigitalRadarDataGeneric&) = delete;
 | |
| 
 | |
|    DigitalRadarDataGeneric(DigitalRadarDataGeneric&&) noexcept;
 | |
|    DigitalRadarDataGeneric& operator=(DigitalRadarDataGeneric&&) noexcept;
 | |
| 
 | |
|    std::string           radar_identifier() const;
 | |
|    uint32_t              collection_time() const;
 | |
|    uint16_t              modified_julian_date() const;
 | |
|    uint16_t              azimuth_number() const;
 | |
|    units::degrees<float> azimuth_angle() const;
 | |
|    uint8_t               compression_indicator() const;
 | |
|    uint16_t              radial_length() const;
 | |
|    uint8_t               azimuth_resolution_spacing() const;
 | |
|    uint8_t               radial_status() const;
 | |
|    uint8_t               elevation_number() const;
 | |
|    uint8_t               cut_sector_number() const;
 | |
|    units::degrees<float> elevation_angle() const;
 | |
|    uint8_t               radial_spot_blanking_status() const;
 | |
|    uint8_t               azimuth_indexing_mode() const;
 | |
|    uint16_t              data_block_count() 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<MomentDataBlock> moment_data_block(DataBlockType type) const;
 | |
| 
 | |
|    bool Parse(std::istream& is);
 | |
| 
 | |
|    static std::shared_ptr<DigitalRadarDataGeneric>
 | |
|    Create(Level2MessageHeader&& header, std::istream& is);
 | |
| 
 | |
| private:
 | |
|    std::unique_ptr<DigitalRadarDataGenericImpl> p;
 | |
| };
 | |
| 
 | |
| } // namespace rda
 | |
| } // namespace wsr88d
 | |
| } // namespace scwx
 | 
