296 lines
7.2 KiB
C++
296 lines
7.2 KiB
C++
/**
|
|
* Jungfraujoch
|
|
* API to control Jungfraujoch developed by the Paul Scherrer Institute (Switzerland). Jungfraujoch is a data acquisition and analysis system for pixel array detectors, primarly PSI JUNGFRAU. Jungfraujoch uses FPGA boards to acquire data at high data rates.
|
|
*
|
|
* The version of the OpenAPI document: 1.0.0-rc.58
|
|
* Contact: filip.leonarski@psi.ch
|
|
*
|
|
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
* https://openapi-generator.tech
|
|
* Do not edit the class manually.
|
|
*/
|
|
|
|
|
|
#include "Rotation_axis.h"
|
|
#include "Helpers.h"
|
|
|
|
#include <sstream>
|
|
|
|
namespace org::openapitools::server::model
|
|
{
|
|
|
|
Rotation_axis::Rotation_axis()
|
|
{
|
|
m_Name = "omega";
|
|
m_NameIsSet = false;
|
|
m_Step = 0.0f;
|
|
m_Start = 0.0f;
|
|
m_StartIsSet = false;
|
|
m_Helical_step_umIsSet = false;
|
|
m_Screening_wedge_deg = 0.0f;
|
|
m_Screening_wedge_degIsSet = false;
|
|
|
|
}
|
|
|
|
void Rotation_axis::validate() const
|
|
{
|
|
std::stringstream msg;
|
|
if (!validate(msg))
|
|
{
|
|
throw org::openapitools::server::helpers::ValidationException(msg.str());
|
|
}
|
|
}
|
|
|
|
bool Rotation_axis::validate(std::stringstream& msg) const
|
|
{
|
|
return validate(msg, "");
|
|
}
|
|
|
|
bool Rotation_axis::validate(std::stringstream& msg, const std::string& pathPrefix) const
|
|
{
|
|
bool success = true;
|
|
const std::string _pathPrefix = pathPrefix.empty() ? "Rotation_axis" : pathPrefix;
|
|
|
|
|
|
if (nameIsSet())
|
|
{
|
|
const std::string& value = m_Name;
|
|
const std::string currentValuePath = _pathPrefix + ".name";
|
|
|
|
|
|
if (value.length() < 1)
|
|
{
|
|
success = false;
|
|
msg << currentValuePath << ": must be at least 1 characters long;";
|
|
}
|
|
|
|
}
|
|
|
|
|
|
/* Vector */ {
|
|
const std::vector<float>& value = m_Vector;
|
|
const std::string currentValuePath = _pathPrefix + ".vector";
|
|
|
|
|
|
if (value.size() < 3)
|
|
{
|
|
success = false;
|
|
msg << currentValuePath << ": must have at least 3 elements;";
|
|
}
|
|
if (value.size() > 3)
|
|
{
|
|
success = false;
|
|
msg << currentValuePath << ": must have at most 3 elements;";
|
|
}
|
|
{ // Recursive validation of array elements
|
|
const std::string oldValuePath = currentValuePath;
|
|
int i = 0;
|
|
for (const float& value : value)
|
|
{
|
|
const std::string currentValuePath = oldValuePath + "[" + std::to_string(i) + "]";
|
|
|
|
|
|
|
|
i++;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
if (helicalStepUmIsSet())
|
|
{
|
|
const std::vector<float>& value = m_Helical_step_um;
|
|
const std::string currentValuePath = _pathPrefix + ".helicalStepUm";
|
|
|
|
|
|
if (value.size() < 3)
|
|
{
|
|
success = false;
|
|
msg << currentValuePath << ": must have at least 3 elements;";
|
|
}
|
|
if (value.size() > 3)
|
|
{
|
|
success = false;
|
|
msg << currentValuePath << ": must have at most 3 elements;";
|
|
}
|
|
{ // Recursive validation of array elements
|
|
const std::string oldValuePath = currentValuePath;
|
|
int i = 0;
|
|
for (const float& value : value)
|
|
{
|
|
const std::string currentValuePath = oldValuePath + "[" + std::to_string(i) + "]";
|
|
|
|
|
|
|
|
i++;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
return success;
|
|
}
|
|
|
|
bool Rotation_axis::operator==(const Rotation_axis& rhs) const
|
|
{
|
|
return
|
|
|
|
|
|
|
|
((!nameIsSet() && !rhs.nameIsSet()) || (nameIsSet() && rhs.nameIsSet() && getName() == rhs.getName())) &&
|
|
|
|
(getStep() == rhs.getStep())
|
|
&&
|
|
|
|
|
|
((!startIsSet() && !rhs.startIsSet()) || (startIsSet() && rhs.startIsSet() && getStart() == rhs.getStart())) &&
|
|
|
|
(getVector() == rhs.getVector())
|
|
&&
|
|
|
|
|
|
((!helicalStepUmIsSet() && !rhs.helicalStepUmIsSet()) || (helicalStepUmIsSet() && rhs.helicalStepUmIsSet() && getHelicalStepUm() == rhs.getHelicalStepUm())) &&
|
|
|
|
|
|
((!screeningWedgeDegIsSet() && !rhs.screeningWedgeDegIsSet()) || (screeningWedgeDegIsSet() && rhs.screeningWedgeDegIsSet() && getScreeningWedgeDeg() == rhs.getScreeningWedgeDeg()))
|
|
|
|
;
|
|
}
|
|
|
|
bool Rotation_axis::operator!=(const Rotation_axis& rhs) const
|
|
{
|
|
return !(*this == rhs);
|
|
}
|
|
|
|
void to_json(nlohmann::json& j, const Rotation_axis& o)
|
|
{
|
|
j = nlohmann::json::object();
|
|
if(o.nameIsSet())
|
|
j["name"] = o.m_Name;
|
|
j["step"] = o.m_Step;
|
|
if(o.startIsSet())
|
|
j["start"] = o.m_Start;
|
|
j["vector"] = o.m_Vector;
|
|
if(o.helicalStepUmIsSet() || !o.m_Helical_step_um.empty())
|
|
j["helical_step_um"] = o.m_Helical_step_um;
|
|
if(o.screeningWedgeDegIsSet())
|
|
j["screening_wedge_deg"] = o.m_Screening_wedge_deg;
|
|
|
|
}
|
|
|
|
void from_json(const nlohmann::json& j, Rotation_axis& o)
|
|
{
|
|
if(j.find("name") != j.end())
|
|
{
|
|
j.at("name").get_to(o.m_Name);
|
|
o.m_NameIsSet = true;
|
|
}
|
|
j.at("step").get_to(o.m_Step);
|
|
if(j.find("start") != j.end())
|
|
{
|
|
j.at("start").get_to(o.m_Start);
|
|
o.m_StartIsSet = true;
|
|
}
|
|
j.at("vector").get_to(o.m_Vector);
|
|
if(j.find("helical_step_um") != j.end())
|
|
{
|
|
j.at("helical_step_um").get_to(o.m_Helical_step_um);
|
|
o.m_Helical_step_umIsSet = true;
|
|
}
|
|
if(j.find("screening_wedge_deg") != j.end())
|
|
{
|
|
j.at("screening_wedge_deg").get_to(o.m_Screening_wedge_deg);
|
|
o.m_Screening_wedge_degIsSet = true;
|
|
}
|
|
|
|
}
|
|
|
|
std::string Rotation_axis::getName() const
|
|
{
|
|
return m_Name;
|
|
}
|
|
void Rotation_axis::setName(std::string const& value)
|
|
{
|
|
m_Name = value;
|
|
m_NameIsSet = true;
|
|
}
|
|
bool Rotation_axis::nameIsSet() const
|
|
{
|
|
return m_NameIsSet;
|
|
}
|
|
void Rotation_axis::unsetName()
|
|
{
|
|
m_NameIsSet = false;
|
|
}
|
|
float Rotation_axis::getStep() const
|
|
{
|
|
return m_Step;
|
|
}
|
|
void Rotation_axis::setStep(float const value)
|
|
{
|
|
m_Step = value;
|
|
}
|
|
float Rotation_axis::getStart() const
|
|
{
|
|
return m_Start;
|
|
}
|
|
void Rotation_axis::setStart(float const value)
|
|
{
|
|
m_Start = value;
|
|
m_StartIsSet = true;
|
|
}
|
|
bool Rotation_axis::startIsSet() const
|
|
{
|
|
return m_StartIsSet;
|
|
}
|
|
void Rotation_axis::unsetStart()
|
|
{
|
|
m_StartIsSet = false;
|
|
}
|
|
std::vector<float> Rotation_axis::getVector() const
|
|
{
|
|
return m_Vector;
|
|
}
|
|
void Rotation_axis::setVector(std::vector<float> const value)
|
|
{
|
|
m_Vector = value;
|
|
}
|
|
std::vector<float> Rotation_axis::getHelicalStepUm() const
|
|
{
|
|
return m_Helical_step_um;
|
|
}
|
|
void Rotation_axis::setHelicalStepUm(std::vector<float> const value)
|
|
{
|
|
m_Helical_step_um = value;
|
|
m_Helical_step_umIsSet = true;
|
|
}
|
|
bool Rotation_axis::helicalStepUmIsSet() const
|
|
{
|
|
return m_Helical_step_umIsSet;
|
|
}
|
|
void Rotation_axis::unsetHelical_step_um()
|
|
{
|
|
m_Helical_step_umIsSet = false;
|
|
}
|
|
float Rotation_axis::getScreeningWedgeDeg() const
|
|
{
|
|
return m_Screening_wedge_deg;
|
|
}
|
|
void Rotation_axis::setScreeningWedgeDeg(float const value)
|
|
{
|
|
m_Screening_wedge_deg = value;
|
|
m_Screening_wedge_degIsSet = true;
|
|
}
|
|
bool Rotation_axis::screeningWedgeDegIsSet() const
|
|
{
|
|
return m_Screening_wedge_degIsSet;
|
|
}
|
|
void Rotation_axis::unsetScreening_wedge_deg()
|
|
{
|
|
m_Screening_wedge_degIsSet = false;
|
|
}
|
|
|
|
|
|
} // namespace org::openapitools::server::model
|
|
|