#include "nmDataSensitive.h" nmDataSensitive::VariableSampling::VariableSampling() : m_varGroup("") , m_varName("") , m_enabled(false) , m_mode(MODE_AUTOMATIC) , m_log(false) , m_number(0) { m_modelValue = nmDataAttribute("Model value", "", ""); m_minValue = nmDataAttribute("Minimum", "", ""); m_maxValue = nmDataAttribute("Maximum", "", ""); m_values.clear(); } // 序列化 VariableSampling 为 RapidJSON Value rapidjson::Value nmDataSensitive::VariableSampling::ToJsonValue( rapidjson::Document::AllocatorType& allocator) const { rapidjson::Value obj(rapidjson::kObjectType); // 字符串字段 obj.AddMember("VarGroup", rapidjson::Value(m_varGroup.toStdString().c_str(), allocator).Move(), allocator); obj.AddMember("VarName", rapidjson::Value(m_varName.toStdString().c_str(), allocator).Move(), allocator); // 简单类型 obj.AddMember("Enabled", m_enabled, allocator); obj.AddMember("Mode", static_cast(m_mode), allocator); obj.AddMember("Log", m_log, allocator); obj.AddMember("Number", m_number, allocator); // nmDataAttribute 成员 obj.AddMember("ModelValue", m_modelValue.ToJsonValue(allocator), allocator); obj.AddMember("Minimum", m_minValue.ToJsonValue(allocator), allocator); obj.AddMember("Maximum", m_maxValue.ToJsonValue(allocator), allocator); // values 数组 rapidjson::Value arr(rapidjson::kArrayType); for (int i = 0; i < m_values.size(); ++i) { arr.PushBack(m_values.at(i), allocator); } obj.AddMember("Values", arr, allocator); return obj; } // 从 RapidJSON Value 反序列化到 VariableSampling void nmDataSensitive::VariableSampling::FromJsonValue(const rapidjson::Value& jsonValue) { if (jsonValue.HasMember("VarGroup") && jsonValue["VarGroup"].IsString()) { m_varGroup = QString::fromUtf8(jsonValue["VarGroup"].GetString()); } if (jsonValue.HasMember("VarName") && jsonValue["VarName"].IsString()) { m_varName = QString::fromUtf8(jsonValue["VarName"].GetString()); } if (jsonValue.HasMember("Enabled") && jsonValue["Enabled"].IsBool()) { m_enabled = jsonValue["Enabled"].GetBool(); } if (jsonValue.HasMember("Mode") && jsonValue["Mode"].IsInt()) { int m = jsonValue["Mode"].GetInt(); m_mode = (m == MODE_MANUAL) ? MODE_MANUAL : MODE_AUTOMATIC; } if (jsonValue.HasMember("Log") && jsonValue["Log"].IsBool()) { m_log = jsonValue["Log"].GetBool(); } if (jsonValue.HasMember("Number") && jsonValue["Number"].IsInt()) { m_number = jsonValue["Number"].GetInt(); } if (jsonValue.HasMember("ModelValue") && jsonValue["ModelValue"].IsObject()) { m_modelValue.FromJsonValue(jsonValue["ModelValue"]); } if (jsonValue.HasMember("Minimum") && jsonValue["Minimum"].IsObject()) { m_minValue.FromJsonValue(jsonValue["Minimum"]); } if (jsonValue.HasMember("Maximum") && jsonValue["Maximum"].IsObject()) { m_maxValue.FromJsonValue(jsonValue["Maximum"]); } m_values.clear(); if (jsonValue.HasMember("Values") && jsonValue["Values"].IsArray()) { const rapidjson::Value& arr = jsonValue["Values"]; for (rapidjson::SizeType i = 0; i < arr.Size(); ++i) { if (arr[i].IsNumber()) { m_values.append(arr[i].GetDouble()); } } } } // varGroup QString nmDataSensitive::VariableSampling::getVarGroup() const { return m_varGroup; } void nmDataSensitive::VariableSampling::setVarGroup(const QString& group) { m_varGroup = group; } // varName QString nmDataSensitive::VariableSampling::getVarName() const { return m_varName; } void nmDataSensitive::VariableSampling::setVarName(const QString& name) { m_varName = name; } // enabled bool nmDataSensitive::VariableSampling::getEnabled() const { return m_enabled; } void nmDataSensitive::VariableSampling::setEnabled(bool e) { m_enabled = e; } // mode nmDataSensitive::VariableSampling::Mode nmDataSensitive::VariableSampling::getMode() const { return m_mode; } void nmDataSensitive::VariableSampling::setMode(Mode m) { m_mode = m; } // log bool nmDataSensitive::VariableSampling::getLog() const { return m_log; } void nmDataSensitive::VariableSampling::setLog(bool l) { m_log = l; } // number int nmDataSensitive::VariableSampling::getNumber() const { return m_number; } void nmDataSensitive::VariableSampling::setNumber(int n) { m_number = n; } // modelValue nmDataAttribute& nmDataSensitive::VariableSampling::getModelValue() { return m_modelValue; } void nmDataSensitive::VariableSampling::setModelValue(const nmDataAttribute& attr) { m_modelValue = attr; } // minValue nmDataAttribute& nmDataSensitive::VariableSampling::getMinValue() { return m_minValue; } void nmDataSensitive::VariableSampling::setMinValue(const nmDataAttribute& attr) { m_minValue = attr; } // maxValue nmDataAttribute& nmDataSensitive::VariableSampling::getMaxValue() { return m_maxValue; } void nmDataSensitive::VariableSampling::setMaxValue(const nmDataAttribute& attr) { m_maxValue = attr; } // values QVector& nmDataSensitive::VariableSampling::getValues() { return m_values; } void nmDataSensitive::VariableSampling::setValues(const QVector& vals) { m_values = vals; } nmDataSensitive::nmDataSensitive() : m_calcType(CALC_DETERMINISTIC) , m_totalModelCount(0) , m_variables() { } // 拷贝构造 nmDataSensitive::nmDataSensitive(const nmDataSensitive& other) { *this = other; } // 赋值运算符 nmDataSensitive& nmDataSensitive::operator=(const nmDataSensitive& other) { if (this != &other) { m_calcType = other.m_calcType; m_totalModelCount = other.m_totalModelCount; m_variables = other.m_variables; } return *this; } nmDataSensitive::~nmDataSensitive() { } // 序列化 nmDataSensitive 为 RapidJSON Value rapidjson::Value nmDataSensitive::ToJsonValue( rapidjson::Document::AllocatorType& allocator) const { rapidjson::Value root(rapidjson::kObjectType); // 顶部 Calculation type root.AddMember("CalculationType", static_cast(m_calcType), allocator); // 总模型数 root.AddMember("TotalModelCount", m_totalModelCount, allocator); // 变量数组 rapidjson::Value arr(rapidjson::kArrayType); for (int i = 0; i < m_variables.size(); ++i) { arr.PushBack(m_variables.at(i).ToJsonValue(allocator), allocator); } root.AddMember("Variables", arr, allocator); return root; } // 从 RapidJSON Value 反序列化数据到 nmDataSensitive void nmDataSensitive::FromJsonValue(const rapidjson::Value& jsonValue) { if (jsonValue.HasMember("CalculationType") && jsonValue["CalculationType"].IsInt()) { int t = jsonValue["CalculationType"].GetInt(); if (t == CALC_DETERMINISTIC_MULTIVARIATE) m_calcType = CALC_DETERMINISTIC_MULTIVARIATE; else m_calcType = CALC_DETERMINISTIC; } if (jsonValue.HasMember("TotalModelCount") && jsonValue["TotalModelCount"].IsInt()) { m_totalModelCount = jsonValue["TotalModelCount"].GetInt(); } m_variables.clear(); if (jsonValue.HasMember("Variables") && jsonValue["Variables"].IsArray()) { const rapidjson::Value& arr = jsonValue["Variables"]; for (rapidjson::SizeType i = 0; i < arr.Size(); ++i) { if (!arr[i].IsObject()) continue; VariableSampling vs; vs.FromJsonValue(arr[i]); m_variables.append(vs); } } } // === Calculation type === nmDataSensitive::CalculationType nmDataSensitive::getCalculationType() const { return m_calcType; } void nmDataSensitive::setCalculationType(CalculationType type) { m_calcType = type; } // === 总模型数 === int nmDataSensitive::getTotalModelCount() const { return m_totalModelCount; } void nmDataSensitive::setTotalModelCount(int count) { m_totalModelCount = count; } // === 变量列表 === QList& nmDataSensitive::getVariables() { return m_variables; } void nmDataSensitive::setVariables(const QList& vars) { m_variables = vars; } int nmDataSensitive::getVariableCount() const { return m_variables.size(); } nmDataSensitive::VariableSampling& nmDataSensitive::getVariable(int index) { return m_variables[index]; }