mirror of
https://github.com/ciphervance/supercell-wx.git
synced 2025-10-30 20:30:05 +00:00
General status message
This commit is contained in:
parent
dc545f19e9
commit
9b48db3d8d
5 changed files with 383 additions and 1 deletions
302
wxdata/source/scwx/wsr88d/rpg/general_status_message.cpp
Normal file
302
wxdata/source/scwx/wsr88d/rpg/general_status_message.cpp
Normal file
|
|
@ -0,0 +1,302 @@
|
|||
#include <scwx/wsr88d/rpg/general_status_message.hpp>
|
||||
#include <scwx/util/rangebuf.hpp>
|
||||
|
||||
#include <istream>
|
||||
#include <string>
|
||||
|
||||
#include <boost/log/trivial.hpp>
|
||||
|
||||
namespace scwx
|
||||
{
|
||||
namespace wsr88d
|
||||
{
|
||||
namespace rpg
|
||||
{
|
||||
|
||||
static const std::string logPrefix_ =
|
||||
"[scwx::wsr88d::rpg::general_status_message] ";
|
||||
|
||||
class GeneralStatusMessageImpl
|
||||
{
|
||||
public:
|
||||
explicit GeneralStatusMessageImpl() :
|
||||
blockDivider_ {0},
|
||||
lengthOfBlock_ {0},
|
||||
modeOfOperation_ {0},
|
||||
rdaOperabilityStatus_ {0},
|
||||
volumeCoveragePattern_ {0},
|
||||
numberOfElevationCuts_ {0},
|
||||
elevation_ {0},
|
||||
rdaStatus_ {0},
|
||||
rdaAlarms_ {0},
|
||||
dataTransmissionEnabled_ {0},
|
||||
rpgOperabilityStatus_ {0},
|
||||
rpgAlarms_ {0},
|
||||
rpgStatus_ {0},
|
||||
rpgNarrowbandStatus_ {0},
|
||||
horizontalReflectivityCalibrationCorrection_ {0},
|
||||
productAvailiability_ {0},
|
||||
superResolutionElevationCuts_ {0},
|
||||
clutterMitigationDecisionStatus_ {0},
|
||||
verticalReflectivityCalibrationCorrection_ {0},
|
||||
rdaBuildNumber_ {0},
|
||||
rdaChannelNumber_ {0},
|
||||
buildVersion_ {0},
|
||||
vcpSupplementalData_ {0},
|
||||
supplementalCutMap_ {0}
|
||||
{
|
||||
}
|
||||
~GeneralStatusMessageImpl() = default;
|
||||
|
||||
int16_t blockDivider_;
|
||||
uint16_t lengthOfBlock_;
|
||||
uint16_t modeOfOperation_;
|
||||
uint16_t rdaOperabilityStatus_;
|
||||
uint16_t volumeCoveragePattern_;
|
||||
uint16_t numberOfElevationCuts_;
|
||||
std::array<int16_t, 25> elevation_;
|
||||
uint16_t rdaStatus_;
|
||||
uint16_t rdaAlarms_;
|
||||
uint16_t dataTransmissionEnabled_;
|
||||
uint16_t rpgOperabilityStatus_;
|
||||
uint16_t rpgAlarms_;
|
||||
uint16_t rpgStatus_;
|
||||
uint16_t rpgNarrowbandStatus_;
|
||||
int16_t horizontalReflectivityCalibrationCorrection_;
|
||||
uint16_t productAvailiability_;
|
||||
uint16_t superResolutionElevationCuts_;
|
||||
uint16_t clutterMitigationDecisionStatus_;
|
||||
int16_t verticalReflectivityCalibrationCorrection_;
|
||||
uint16_t rdaBuildNumber_;
|
||||
uint16_t rdaChannelNumber_;
|
||||
uint16_t buildVersion_;
|
||||
uint16_t vcpSupplementalData_;
|
||||
uint32_t supplementalCutMap_;
|
||||
};
|
||||
|
||||
GeneralStatusMessage::GeneralStatusMessage() :
|
||||
p(std::make_unique<GeneralStatusMessageImpl>())
|
||||
{
|
||||
}
|
||||
GeneralStatusMessage::~GeneralStatusMessage() = default;
|
||||
|
||||
GeneralStatusMessage::GeneralStatusMessage(GeneralStatusMessage&&) noexcept =
|
||||
default;
|
||||
GeneralStatusMessage&
|
||||
GeneralStatusMessage::operator=(GeneralStatusMessage&&) noexcept = default;
|
||||
|
||||
int16_t GeneralStatusMessage::block_divider() const
|
||||
{
|
||||
return p->blockDivider_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::length_of_block() const
|
||||
{
|
||||
return p->lengthOfBlock_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::mode_of_operation() const
|
||||
{
|
||||
return p->modeOfOperation_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rda_operability_status() const
|
||||
{
|
||||
return p->rdaOperabilityStatus_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::volume_coverage_pattern() const
|
||||
{
|
||||
return p->volumeCoveragePattern_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::number_of_elevation_cuts() const
|
||||
{
|
||||
return p->numberOfElevationCuts_;
|
||||
}
|
||||
|
||||
float GeneralStatusMessage::elevation(uint16_t e) const
|
||||
{
|
||||
return p->elevation_[e] * 0.1f;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rda_status() const
|
||||
{
|
||||
return p->rdaStatus_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rda_alarms() const
|
||||
{
|
||||
return p->rdaAlarms_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::data_transmission_enabled() const
|
||||
{
|
||||
return p->dataTransmissionEnabled_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rpg_operability_status() const
|
||||
{
|
||||
return p->rpgOperabilityStatus_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rpg_alarms() const
|
||||
{
|
||||
return p->rpgAlarms_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rpg_status() const
|
||||
{
|
||||
return p->rpgStatus_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rpg_narrowband_status() const
|
||||
{
|
||||
return p->rpgNarrowbandStatus_;
|
||||
}
|
||||
|
||||
float GeneralStatusMessage::horizontal_reflectivity_calibration_correction()
|
||||
const
|
||||
{
|
||||
return p->horizontalReflectivityCalibrationCorrection_ * 0.25f;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::product_availiability() const
|
||||
{
|
||||
return p->productAvailiability_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::super_resolution_elevation_cuts() const
|
||||
{
|
||||
return p->superResolutionElevationCuts_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::clutter_mitigation_decision_status() const
|
||||
{
|
||||
return p->clutterMitigationDecisionStatus_;
|
||||
}
|
||||
|
||||
float GeneralStatusMessage::vertical_reflectivity_calibration_correction() const
|
||||
{
|
||||
return p->verticalReflectivityCalibrationCorrection_ * 0.25f;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rda_build_number() const
|
||||
{
|
||||
return p->rdaBuildNumber_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::rda_channel_number() const
|
||||
{
|
||||
return p->rdaChannelNumber_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::build_version() const
|
||||
{
|
||||
return p->buildVersion_;
|
||||
}
|
||||
|
||||
uint16_t GeneralStatusMessage::vcp_supplemental_data() const
|
||||
{
|
||||
return p->vcpSupplementalData_;
|
||||
}
|
||||
|
||||
uint32_t GeneralStatusMessage::supplemental_cut_map() const
|
||||
{
|
||||
return p->supplementalCutMap_;
|
||||
}
|
||||
|
||||
bool GeneralStatusMessage::Parse(std::istream& is)
|
||||
{
|
||||
bool dataValid = true;
|
||||
|
||||
const std::streampos dataStart = is.tellg();
|
||||
|
||||
is.read(reinterpret_cast<char*>(&p->blockDivider_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->lengthOfBlock_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->modeOfOperation_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->rdaOperabilityStatus_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->volumeCoveragePattern_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->numberOfElevationCuts_), 2);
|
||||
is.read(reinterpret_cast<char*>(p->elevation_.data()), 40);
|
||||
is.read(reinterpret_cast<char*>(&p->rdaStatus_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->rdaAlarms_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->dataTransmissionEnabled_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->rpgOperabilityStatus_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->rpgAlarms_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->rpgStatus_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->rpgNarrowbandStatus_), 2);
|
||||
is.read(
|
||||
reinterpret_cast<char*>(&p->horizontalReflectivityCalibrationCorrection_),
|
||||
2);
|
||||
is.read(reinterpret_cast<char*>(&p->productAvailiability_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->superResolutionElevationCuts_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->clutterMitigationDecisionStatus_), 2);
|
||||
is.read(
|
||||
reinterpret_cast<char*>(&p->verticalReflectivityCalibrationCorrection_),
|
||||
2);
|
||||
is.read(reinterpret_cast<char*>(&p->rdaBuildNumber_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->rdaChannelNumber_), 2);
|
||||
is.seekg(4, std::ios_base::cur);
|
||||
is.read(reinterpret_cast<char*>(&p->buildVersion_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->elevation_[20]), 10);
|
||||
is.read(reinterpret_cast<char*>(&p->vcpSupplementalData_), 2);
|
||||
is.read(reinterpret_cast<char*>(&p->supplementalCutMap_), 4);
|
||||
is.seekg(80, std::ios_base::cur);
|
||||
|
||||
p->blockDivider_ = ntohs(p->blockDivider_);
|
||||
p->lengthOfBlock_ = ntohs(p->lengthOfBlock_);
|
||||
p->modeOfOperation_ = ntohs(p->modeOfOperation_);
|
||||
p->rdaOperabilityStatus_ = ntohs(p->rdaOperabilityStatus_);
|
||||
p->volumeCoveragePattern_ = ntohs(p->volumeCoveragePattern_);
|
||||
p->numberOfElevationCuts_ = ntohs(p->numberOfElevationCuts_);
|
||||
p->rdaStatus_ = ntohs(p->rdaStatus_);
|
||||
p->rdaAlarms_ = ntohs(p->rdaAlarms_);
|
||||
p->dataTransmissionEnabled_ = ntohs(p->dataTransmissionEnabled_);
|
||||
p->rpgOperabilityStatus_ = ntohs(p->rpgOperabilityStatus_);
|
||||
p->rpgAlarms_ = ntohs(p->rpgAlarms_);
|
||||
p->rpgStatus_ = ntohs(p->rpgStatus_);
|
||||
p->rpgNarrowbandStatus_ = ntohs(p->rpgNarrowbandStatus_);
|
||||
p->horizontalReflectivityCalibrationCorrection_ =
|
||||
ntohs(p->horizontalReflectivityCalibrationCorrection_);
|
||||
p->productAvailiability_ = ntohs(p->productAvailiability_);
|
||||
p->superResolutionElevationCuts_ = ntohs(p->superResolutionElevationCuts_);
|
||||
p->clutterMitigationDecisionStatus_ =
|
||||
ntohs(p->clutterMitigationDecisionStatus_);
|
||||
p->verticalReflectivityCalibrationCorrection_ =
|
||||
ntohs(p->verticalReflectivityCalibrationCorrection_);
|
||||
p->rdaBuildNumber_ = ntohs(p->rdaBuildNumber_);
|
||||
p->rdaChannelNumber_ = ntohs(p->rdaChannelNumber_);
|
||||
p->buildVersion_ = ntohs(p->buildVersion_);
|
||||
p->vcpSupplementalData_ = ntohs(p->vcpSupplementalData_);
|
||||
p->supplementalCutMap_ = ntohl(p->supplementalCutMap_);
|
||||
|
||||
SwapArray(p->elevation_);
|
||||
|
||||
const std::streampos dataEnd = is.tellg();
|
||||
if (!ValidateMessage(is, dataEnd - dataStart))
|
||||
{
|
||||
dataValid = false;
|
||||
}
|
||||
|
||||
return dataValid;
|
||||
}
|
||||
|
||||
std::shared_ptr<GeneralStatusMessage>
|
||||
GeneralStatusMessage::Create(Level3MessageHeader&& header, std::istream& is)
|
||||
{
|
||||
std::shared_ptr<GeneralStatusMessage> message =
|
||||
std::make_shared<GeneralStatusMessage>();
|
||||
message->set_header(std::move(header));
|
||||
|
||||
if (!message->Parse(is))
|
||||
{
|
||||
message.reset();
|
||||
}
|
||||
|
||||
return message;
|
||||
}
|
||||
|
||||
} // namespace rpg
|
||||
} // namespace wsr88d
|
||||
} // namespace scwx
|
||||
|
|
@ -1,6 +1,7 @@
|
|||
#include <scwx/wsr88d/rpg/level3_message_factory.hpp>
|
||||
|
||||
#include <scwx/util/vectorbuf.hpp>
|
||||
#include <scwx/wsr88d/rpg/general_status_message.hpp>
|
||||
#include <scwx/wsr88d/rpg/graphic_product_message.hpp>
|
||||
#include <scwx/wsr88d/rpg/tabular_product_message.hpp>
|
||||
|
||||
|
|
@ -24,7 +25,8 @@ typedef std::function<std::shared_ptr<Level3Message>(Level3MessageHeader&&,
|
|||
CreateLevel3MessageFunction;
|
||||
|
||||
static const std::unordered_map<int16_t, CreateLevel3MessageFunction> //
|
||||
create_ {{19, GraphicProductMessage::Create},
|
||||
create_ {{2, GeneralStatusMessage::Create},
|
||||
{19, GraphicProductMessage::Create},
|
||||
{20, GraphicProductMessage::Create},
|
||||
{27, GraphicProductMessage::Create},
|
||||
{30, GraphicProductMessage::Create},
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue