mirror of
				https://github.com/ciphervance/supercell-wx.git
				synced 2025-10-31 19:40:06 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			71 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include <scwx/wsr88d/rda/generic_radar_data.hpp>
 | |
| 
 | |
| namespace scwx
 | |
| {
 | |
| namespace wsr88d
 | |
| {
 | |
| namespace rda
 | |
| {
 | |
| 
 | |
| class DigitalRadarData : public GenericRadarData
 | |
| {
 | |
| public:
 | |
|    explicit DigitalRadarData();
 | |
|    ~DigitalRadarData();
 | |
| 
 | |
|    DigitalRadarData(const DigitalRadarData&)            = delete;
 | |
|    DigitalRadarData& operator=(const DigitalRadarData&) = delete;
 | |
| 
 | |
|    DigitalRadarData(DigitalRadarData&&) noexcept;
 | |
|    DigitalRadarData& operator=(DigitalRadarData&&) noexcept;
 | |
| 
 | |
|    std::uint32_t            collection_time() const;
 | |
|    std::uint16_t            modified_julian_date() const;
 | |
|    std::uint16_t            unambiguous_range() const;
 | |
|    std::uint16_t            azimuth_angle_raw() const;
 | |
|    units::degrees<float>    azimuth_angle() const;
 | |
|    std::uint16_t            azimuth_number() const;
 | |
|    std::uint16_t            radial_status() const;
 | |
|    std::uint16_t            elevation_angle_raw() const;
 | |
|    units::degrees<float>    elevation_angle() const;
 | |
|    std::uint16_t            elevation_number() const;
 | |
|    std::int16_t             surveillance_range_raw() const;
 | |
|    units::kilometers<float> surveillance_range() const;
 | |
|    std::int16_t             doppler_range_raw() const;
 | |
|    units::kilometers<float> doppler_range() const;
 | |
|    std::uint16_t            surveillance_range_sample_interval_raw() const;
 | |
|    units::kilometers<float> surveillance_range_sample_interval() const;
 | |
|    std::uint16_t            doppler_range_sample_interval_raw() const;
 | |
|    units::kilometers<float> doppler_range_sample_interval() const;
 | |
|    std::uint16_t            number_of_surveillance_bins() const;
 | |
|    std::uint16_t            number_of_doppler_bins() const;
 | |
|    std::uint16_t            cut_sector_number() const;
 | |
|    float                    calibration_constant() const;
 | |
|    std::uint16_t            surveillance_pointer() const;
 | |
|    std::uint16_t            velocity_pointer() const;
 | |
|    std::uint16_t            spectral_width_pointer() const;
 | |
|    std::uint16_t            doppler_velocity_resolution() const;
 | |
|    std::uint16_t            volume_coverage_pattern_number() const;
 | |
|    std::uint16_t            nyquist_velocity() const;
 | |
|    std::uint16_t            atmos() const;
 | |
|    std::uint16_t            tover() const;
 | |
|    std::uint16_t            radial_spot_blanking_status() const;
 | |
| 
 | |
|    std::shared_ptr<GenericRadarData::MomentDataBlock>
 | |
|    moment_data_block(DataBlockType type) const;
 | |
| 
 | |
|    bool Parse(std::istream& is);
 | |
| 
 | |
|    static std::shared_ptr<DigitalRadarData> Create(Level2MessageHeader&& header,
 | |
|                                                    std::istream&         is);
 | |
| 
 | |
| private:
 | |
|    class Impl;
 | |
|    std::unique_ptr<Impl> p;
 | |
| };
 | |
| 
 | |
| } // namespace rda
 | |
| } // namespace wsr88d
 | |
| } // namespace scwx
 | 
