mirror of
				https://github.com/ciphervance/supercell-wx.git
				synced 2025-10-31 17:50:04 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			217 lines
		
	
	
	
		
			5.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			217 lines
		
	
	
	
		
			5.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include <scwx/util/iterator.hpp>
 | |
| #include <scwx/wsr88d/rda/level2_message.hpp>
 | |
| 
 | |
| 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 DigitalRadarData;
 | |
| class DigitalRadarDataImpl;
 | |
| 
 | |
| typedef std::map<uint16_t, std::shared_ptr<DigitalRadarData>> 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;
 | |
|    float       data_moment_range() const;
 | |
|    uint16_t    data_moment_range_raw() const;
 | |
|    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 DigitalRadarData : public Level2Message
 | |
| {
 | |
| public:
 | |
|    explicit DigitalRadarData();
 | |
|    ~DigitalRadarData();
 | |
| 
 | |
|    DigitalRadarData(const DigitalRadarData&) = delete;
 | |
|    DigitalRadarData& operator=(const DigitalRadarData&) = delete;
 | |
| 
 | |
|    DigitalRadarData(DigitalRadarData&&) noexcept;
 | |
|    DigitalRadarData& operator=(DigitalRadarData&&) noexcept;
 | |
| 
 | |
|    std::string radar_identifier() const;
 | |
|    uint32_t    collection_time() const;
 | |
|    uint16_t    modified_julian_date() const;
 | |
|    uint16_t    azimuth_number() const;
 | |
|    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;
 | |
|    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<DigitalRadarData> Create(Level2MessageHeader&& header,
 | |
|                                                    std::istream&         is);
 | |
| 
 | |
| private:
 | |
|    std::unique_ptr<DigitalRadarDataImpl> p;
 | |
| };
 | |
| 
 | |
| } // namespace rda
 | |
| } // namespace wsr88d
 | |
| } // namespace scwx
 | 
