mirror of
				https://github.com/ciphervance/supercell-wx.git
				synced 2025-10-31 04:50:06 +00:00 
			
		
		
		
	Store elevation scans as a shared pointer to avoid needless copying
This commit is contained in:
		
							parent
							
								
									efeb87baaa
								
							
						
					
					
						commit
						ab616b0c62
					
				
					 6 changed files with 30 additions and 21 deletions
				
			
		|  | @ -37,10 +37,8 @@ public: | |||
|    std::chrono::system_clock::time_point start_time() const; | ||||
|    std::chrono::system_clock::time_point end_time() const; | ||||
| 
 | ||||
|    std::map<uint16_t, | ||||
|             std::map<uint16_t, std::shared_ptr<rda::DigitalRadarData>>> | ||||
|                                                          radar_data() const; | ||||
|    std::shared_ptr<const rda::VolumeCoveragePatternData> vcp_data() const; | ||||
|    std::map<uint16_t, std::shared_ptr<rda::ElevationScan>> radar_data() const; | ||||
|    std::shared_ptr<const rda::VolumeCoveragePatternData>   vcp_data() const; | ||||
| 
 | ||||
|    bool LoadFile(const std::string& filename); | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,5 +1,6 @@ | |||
| #pragma once | ||||
| 
 | ||||
| #include <scwx/util/iterator.hpp> | ||||
| #include <scwx/wsr88d/rda/message.hpp> | ||||
| 
 | ||||
| namespace scwx | ||||
|  | @ -23,6 +24,9 @@ enum class DataBlockType | |||
|    MomentCfp, | ||||
|    Unknown | ||||
| }; | ||||
| typedef util:: | ||||
|    Iterator<DataBlockType, DataBlockType::MomentRef, DataBlockType::MomentCfp> | ||||
|       MomentDataBlockTypeIterator; | ||||
| 
 | ||||
| class DataBlockImpl; | ||||
| class ElevationDataBlockImpl; | ||||
|  | @ -30,8 +34,11 @@ class MomentDataBlockImpl; | |||
| class RadialDataBlockImpl; | ||||
| class VolumeDataBlockImpl; | ||||
| 
 | ||||
| class DigitalRadarData; | ||||
| class DigitalRadarDataImpl; | ||||
| 
 | ||||
| typedef std::map<uint16_t, std::shared_ptr<DigitalRadarData>> ElevationScan; | ||||
| 
 | ||||
| class DataBlock | ||||
| { | ||||
| protected: | ||||
|  |  | |||
|  | @ -47,10 +47,8 @@ public: | |||
| 
 | ||||
|    size_t numRecords_; | ||||
| 
 | ||||
|    std::shared_ptr<rda::VolumeCoveragePatternData> vcpData_; | ||||
|    std::map<uint16_t, | ||||
|             std::map<uint16_t, std::shared_ptr<rda::DigitalRadarData>>> | ||||
|       radarData_; | ||||
|    std::shared_ptr<rda::VolumeCoveragePatternData>         vcpData_; | ||||
|    std::map<uint16_t, std::shared_ptr<rda::ElevationScan>> radarData_; | ||||
| 
 | ||||
|    std::list<std::stringstream> rawRecords_; | ||||
| }; | ||||
|  | @ -82,7 +80,7 @@ std::chrono::system_clock::time_point Ar2vFile::end_time() const | |||
|    if (p->radarData_.size() > 0) | ||||
|    { | ||||
|       std::shared_ptr<rda::DigitalRadarData> lastRadial = | ||||
|          p->radarData_.crbegin()->second.crbegin()->second; | ||||
|          p->radarData_.crbegin()->second->crbegin()->second; | ||||
| 
 | ||||
|       endTime = util::TimePoint(lastRadial->modified_julian_date(), | ||||
|                                 lastRadial->collection_time()); | ||||
|  | @ -91,7 +89,7 @@ std::chrono::system_clock::time_point Ar2vFile::end_time() const | |||
|    return endTime; | ||||
| } | ||||
| 
 | ||||
| std::map<uint16_t, std::map<uint16_t, std::shared_ptr<rda::DigitalRadarData>>> | ||||
| std::map<uint16_t, std::shared_ptr<rda::ElevationScan>> | ||||
| Ar2vFile::radar_data() const | ||||
| { | ||||
|    return p->radarData_; | ||||
|  | @ -289,7 +287,12 @@ void Ar2vFileImpl::ProcessRadarData( | |||
|    uint16_t azimuthIndex   = message->azimuth_number() - 1; | ||||
|    uint16_t elevationIndex = message->elevation_number() - 1; | ||||
| 
 | ||||
|    radarData_[elevationIndex][azimuthIndex] = message; | ||||
|    if (radarData_[elevationIndex] == nullptr) | ||||
|    { | ||||
|       radarData_[elevationIndex] = std::make_shared<rda::ElevationScan>(); | ||||
|    } | ||||
| 
 | ||||
|    (*radarData_[elevationIndex])[azimuthIndex] = message; | ||||
| } | ||||
| 
 | ||||
| } // namespace wsr88d
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Dan Paulat
						Dan Paulat