mirror of
				https://github.com/ciphervance/supercell-wx.git
				synced 2025-10-31 08:30:04 +00:00 
			
		
		
		
	Parse Volume Coverage Pattern Data (Message Type 5)
This commit is contained in:
		
							parent
							
								
									2fc12d44db
								
							
						
					
					
						commit
						517c77cb5f
					
				
					 7 changed files with 635 additions and 52 deletions
				
			
		|  | @ -92,6 +92,9 @@ public: | |||
| 
 | ||||
|    virtual bool Parse(std::istream& is) = 0; | ||||
| 
 | ||||
|    static constexpr double ANGLE_DATA_SCALE      = 0.005493125; | ||||
|    static constexpr double AZ_EL_RATE_DATA_SCALE = 0.001373291015625; | ||||
| 
 | ||||
| private: | ||||
|    std::unique_ptr<MessageImpl> p; | ||||
| }; | ||||
|  |  | |||
|  | @ -0,0 +1,89 @@ | |||
| #pragma once | ||||
| 
 | ||||
| #include <scwx/wsr88d/rda/message.hpp> | ||||
| 
 | ||||
| #include <string> | ||||
| 
 | ||||
| namespace scwx | ||||
| { | ||||
| namespace wsr88d | ||||
| { | ||||
| namespace rda | ||||
| { | ||||
| 
 | ||||
| class VolumeCoveragePatternDataImpl; | ||||
| 
 | ||||
| class VolumeCoveragePatternData : public Message | ||||
| { | ||||
| public: | ||||
|    explicit VolumeCoveragePatternData(); | ||||
|    ~VolumeCoveragePatternData(); | ||||
| 
 | ||||
|    VolumeCoveragePatternData(const Message&) = delete; | ||||
|    VolumeCoveragePatternData& | ||||
|    operator=(const VolumeCoveragePatternData&) = delete; | ||||
| 
 | ||||
|    VolumeCoveragePatternData(VolumeCoveragePatternData&&) noexcept; | ||||
|    VolumeCoveragePatternData& operator=(VolumeCoveragePatternData&&) noexcept; | ||||
| 
 | ||||
|    uint16_t pattern_type() const; | ||||
|    uint16_t pattern_number() const; | ||||
|    uint16_t number_of_elevation_cuts() const; | ||||
|    uint8_t  version() const; | ||||
|    uint8_t  clutter_map_group_number() const; | ||||
|    float    doppler_velocity_resolution() const; | ||||
|    uint8_t  pulse_width() const; | ||||
|    uint16_t vcp_sequencing() const; | ||||
|    uint16_t number_of_elevations() const; | ||||
|    uint16_t maximum_sails_cuts() const; | ||||
|    bool     sequence_active() const; | ||||
|    bool     truncated_vcp() const; | ||||
|    uint16_t vcp_supplemental_data() const; | ||||
|    bool     sails_vcp() const; | ||||
|    uint16_t number_of_sails_cuts() const; | ||||
|    bool     mrle_vcp() const; | ||||
|    uint16_t number_of_mrle_cuts() const; | ||||
|    bool     mpda_vcp() const; | ||||
|    bool     base_tilt_vcp() const; | ||||
|    uint16_t number_of_base_tilts() const; | ||||
|    double   elevation_angle(uint16_t e) const; | ||||
|    uint8_t  channel_configuration(uint16_t e) const; | ||||
|    uint8_t  waveform_type(uint16_t e) const; | ||||
|    uint8_t  super_resolution_control(uint16_t e) const; | ||||
|    bool     half_degree_azimuth(uint16_t e) const; | ||||
|    bool     quarter_km_reflectivity(uint16_t e) const; | ||||
|    bool     doppler_to_300km(uint16_t e) const; | ||||
|    bool     dual_polarization_to_300km(uint16_t e) const; | ||||
|    uint8_t  surveillance_prf_number(uint16_t e) const; | ||||
|    uint16_t surveillance_prf_pulse_count_radial(uint16_t e) const; | ||||
|    double   azimuth_rate(uint16_t e) const; | ||||
|    float    reflectivity_threshold(uint16_t e) const; | ||||
|    float    velocity_threshold(uint16_t e) const; | ||||
|    float    spectrum_width_threshold(uint16_t e) const; | ||||
|    float    differential_reflectivity_threshold(uint16_t e) const; | ||||
|    float    differential_phase_threshold(uint16_t e) const; | ||||
|    float    correlation_coefficient_threshold(uint16_t e) const; | ||||
|    uint16_t supplemental_data(uint16_t e) const; | ||||
|    bool     sails_cut(uint16_t e) const; | ||||
|    uint16_t sails_sequence_number(uint16_t e) const; | ||||
|    bool     mrle_cut(uint16_t e) const; | ||||
|    uint16_t mrle_sequence_number(uint16_t e) const; | ||||
|    bool     mpda_cut(uint16_t e) const; | ||||
|    bool     base_tilt_cut(uint16_t e) const; | ||||
|    double   ebc_angle(uint16_t e) const; | ||||
|    double   edge_angle(uint16_t e, uint16_t s) const; | ||||
|    uint16_t doppler_prf_number(uint16_t e, uint16_t s) const; | ||||
|    uint16_t doppler_prf_pulse_count_radial(uint16_t e, uint16_t s) const; | ||||
| 
 | ||||
|    bool Parse(std::istream& is); | ||||
| 
 | ||||
|    static std::unique_ptr<VolumeCoveragePatternData> | ||||
|    Create(MessageHeader&& header, std::istream& is); | ||||
| 
 | ||||
| private: | ||||
|    std::unique_ptr<VolumeCoveragePatternDataImpl> p; | ||||
| }; | ||||
| 
 | ||||
| } // namespace rda
 | ||||
| } // namespace wsr88d
 | ||||
| } // namespace scwx
 | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Dan Paulat
						Dan Paulat