/*************************************************************************** * Copyright (c) 2023 Ondsel, Inc. * * * * This file is part of OndselSolver. * * * * See LICENSE file for details about copyright. * ***************************************************************************/ #include "ASMTSpatialItem.h" #include "Units.h" #include "Part.h" #include "ASMTSpatialContainer.h" using namespace MbD; void MbD::ASMTSpatialItem::setPosition3D(FColDsptr vec) { position3D = vec; } void MbD::ASMTSpatialItem::setQuarternions(double q0, double q1, double q2, double q3) { auto eulerParameters = CREATE>::With(ListD{ q1, q2, q3, q0 }); eulerParameters->calc(); rotationMatrix = eulerParameters->aA; } void MbD::ASMTSpatialItem::setRotationMatrix(FMatDsptr mat) { rotationMatrix = mat; } void MbD::ASMTSpatialItem::setVelocity3D(FColDsptr vec) { velocity3D = vec; } void MbD::ASMTSpatialItem::setOmega3D(FColDsptr vec) { omega3D = vec; } void MbD::ASMTSpatialItem::readPosition3D(std::vector& lines) { assert(lines[0].find("Position3D") != std::string::npos); lines.erase(lines.begin()); std::istringstream iss(lines[0]); position3D = std::make_shared>(); double d; while (iss >> d) { position3D->push_back(d); } lines.erase(lines.begin()); } void MbD::ASMTSpatialItem::readRotationMatrix(std::vector& lines) { assert(lines[0].find("RotationMatrix") != std::string::npos); lines.erase(lines.begin()); rotationMatrix = std::make_shared>(3, 0); for (int i = 0; i < 3; i++) { auto& row = rotationMatrix->at(i); std::istringstream iss(lines[0]); double d; while (iss >> d) { row->push_back(d); } lines.erase(lines.begin()); } } void MbD::ASMTSpatialItem::readVelocity3D(std::vector& lines) { assert(lines[0].find("Velocity3D") != std::string::npos); lines.erase(lines.begin()); std::istringstream iss(lines[0]); velocity3D = std::make_shared>(); double d; while (iss >> d) { velocity3D->push_back(d); } lines.erase(lines.begin()); } void MbD::ASMTSpatialItem::readOmega3D(std::vector& lines) { assert(lines[0].find("Omega3D") != std::string::npos); lines.erase(lines.begin()); std::istringstream iss(lines[0]); omega3D = std::make_shared>(); double d; while (iss >> d) { omega3D->push_back(d); } lines.erase(lines.begin()); } void MbD::ASMTSpatialItem::getPosition3D(double& a, double& b, double& c) { a = position3D->at(0); b = position3D->at(1); c = position3D->at(2); } void MbD::ASMTSpatialItem::getQuarternions(double& q0, double& q1, double& q2, double& q3) { auto eulerParameters = rotationMatrix->asEulerParameters(); q0 = eulerParameters->at(3); q1 = eulerParameters->at(0); q2 = eulerParameters->at(1); q3 = eulerParameters->at(2); } // Overloads to simplify syntax. void MbD::ASMTSpatialItem::setPosition3D(double a, double b, double c) { position3D = std::make_shared>(ListD{ a, b, c }); } void MbD::ASMTSpatialItem::setVelocity3D(double a, double b, double c) { velocity3D = std::make_shared>(ListD{ a, b, c }); } void MbD::ASMTSpatialItem::setOmega3D(double a, double b, double c) { omega3D = std::make_shared>(ListD{ a, b, c }); } void MbD::ASMTSpatialItem::setRotationMatrix(double v11, double v12, double v13, double v21, double v22, double v23, double v31, double v32, double v33) { rotationMatrix = std::make_shared>(ListListD{ { v11, v12, v13 }, { v21, v22, v23 }, { v31, v32, v33 } }); }