refactor: extract core domain dof modules

This commit is contained in:
NINI
2026-05-05 01:10:30 +09:00
parent 59dcc77a24
commit fd93bc35b0
20 changed files with 915 additions and 648 deletions
+67
View File
@@ -0,0 +1,67 @@
#pragma once
#include "fesa/Core/Domain.hpp"
#include "fesa/Util/Diagnostics.hpp"
#include <cstddef>
#include <string>
#include <vector>
namespace fesa {
struct AnalysisModel {
StepDefinition step;
std::vector<GlobalId> active_element_ids;
std::vector<std::size_t> active_boundary_condition_indices;
std::vector<std::size_t> active_load_indices;
std::vector<std::size_t> active_shell_section_indices;
std::vector<std::string> active_material_keys;
std::vector<Diagnostic> diagnostics;
bool ok() const {
return !hasError(diagnostics);
}
};
inline AnalysisModel buildLinearStaticAnalysisModel(const Domain& domain, LocalIndex step_index = 0) {
AnalysisModel model;
if (domain.steps.empty()) {
model.step = {"Step-1", "linear_static"};
} else {
if (step_index < 0 || step_index >= static_cast<LocalIndex>(domain.steps.size())) {
model.diagnostics.push_back(makeDiagnostic(Severity::Error, "FESA-ANALYSIS-STEP-INDEX",
"Requested analysis step index is out of range", "analysis model"));
model.step = domain.steps.front();
} else {
model.step = domain.steps[static_cast<std::size_t>(step_index)];
}
}
if (domain.steps.size() > 1) {
model.diagnostics.push_back(makeDiagnostic(Severity::Error, "FESA-ANALYSIS-MULTIPLE-STEPS",
"Phase 1 execution supports one active linear static step", "analysis model"));
}
if (model.step.analysis_type != "linear_static") {
model.diagnostics.push_back(makeDiagnostic(Severity::Error, "FESA-ANALYSIS-UNSUPPORTED-STEP",
"Only linear static steps are supported in Phase 1", "analysis model"));
}
for (const auto& [element_id, element] : domain.elements) {
(void)element;
model.active_element_ids.push_back(element_id);
}
for (std::size_t i = 0; i < domain.boundary_conditions.size(); ++i) {
model.active_boundary_condition_indices.push_back(i);
}
for (std::size_t i = 0; i < domain.loads.size(); ++i) {
model.active_load_indices.push_back(i);
}
for (std::size_t i = 0; i < domain.shell_sections.size(); ++i) {
model.active_shell_section_indices.push_back(i);
}
for (const auto& [material_key, material] : domain.materials) {
(void)material;
model.active_material_keys.push_back(material_key);
}
return model;
}
} // namespace fesa