Program Listing for File SubhingeBase.h

Program Listing for File SubhingeBase.h#

Return to documentation for file (include/Karana/SOADyn/SubhingeBase.h)

/*
*Copyright(c)2024-2025KaranaDynamicsPtyLtd.Allrightsreserved.
*
*NOTICETOUSER:
*
*Thissourcecodeand/ordocumentation(the"LicensedMaterials")is
*theconfidentialandproprietaryinformationofKaranaDynamicsInc.
*UseoftheseLicensedMaterialsisgovernedbythetermsandconditions
*ofaseparatesoftwarelicenseagreementbetweenKaranaDynamicsandthe
*Licensee("LicenseAgreement").Unlessexpresslypermittedunderthat
*agreement,anyreproduction,modification,distribution,ordisclosure
*oftheLicensedMaterials,inwholeorinpart,toanythirdparty
*withoutthepriorwrittenconsentofKaranaDynamicsisstrictlyprohibited.
*
*THELICENSEDMATERIALSAREPROVIDED"ASIS"WITHOUTWARRANTYOFANYKIND.
*KARANADYNAMICSDISCLAIMSALLWARRANTIES,EXPRESSORIMPLIED,INCLUDING
*BUTNOTLIMITEDTOWARRANTIESOFMERCHANTABILITY,NON-INFRINGEMENT,AND
*FITNESSFORAPARTICULARPURPOSE.
*
*INNOEVENTSHALLKARANADYNAMICSBELIABLEFORANYDAMAGESWHATSOEVER,
*INCLUDINGBUTNOTLIMITEDTOLOSSOFPROFITS,DATA,ORUSE,EVENIF
*ADVISEDOFTHEPOSSIBILITYOFSUCHDAMAGES,WHETHERINCONTRACT,TORT,
*OROTHERWISEARISINGOUTOFORINCONNECTIONWITHTHELICENSEDMATERIALS.
*
*U.S.GovernmentEndUsers:TheLicensedMaterialsarea"commercialitem"
*asdefinedat48C.F.R.2.101,andareprovidedtotheU.S.Government
*onlyasacommercialenditemunderthetermsofthislicense.
*
*AnyuseoftheLicensedMaterialsinindividualorcommercialsoftwaremust
*include,intheuserdocumentationandinternalsourcecodecomments,
*thisNotice,Disclaimer,andU.S.GovernmentUseProvision.
*/


#pragmaonce

#include<memory>

#include"Karana/SOADyn/CoordBase.h"

namespaceKarana::Dynamics{

namespacekc=Karana::Core;
namespacekm=Karana::Math;

classHingeBase;
classCoordData;

classSubhingeBase:publicCoordBase{

/*foraccessto_parent_hingemember*/
friendclassHingeOnode;
friendclassPhysicalHinge;

//ForaccesstoisOriented.
friendclassCompoundSubhinge;

public:
enumclassSUBHINGE_TYPE{
LOCKED,
PIN,
LINEAR,
LINEAR3,
SPHERICAL,
SPHERICAL_QUAT,
SCREW,
COMPOUND
};

virtual~SubhingeBase();

#if0
virtualstd::stringdumpString(conststd::string&prefix,
constKarana::Core::Base::dumpOptions*options)const=0;

virtualconststd::string&name()const=0;

virtualconstkc::id_t&id()const=0;
#endif

virtualconststd::string&typeString()constnoexcept=0;

virtualSubhingeBase::SUBHINGE_TYPEsubhingeType()const=0;

staticstd::stringsubhingeTypeString(SubhingeBase::SUBHINGE_TYPEshtype);

virtualvoidsetPrescribed(boolflag){_prescribed=flag;}

boolgetPrescribed()const{return_prescribed;}

constkc::ks_ptr<HingeBase>&parentHinge()const{return_parent_hinge;}

virtualkm::Matjacobian(constkf::Frame&target,booloriented=true)const=0;

#if0
virtualsize_tnQ()const=0;

virtualsize_tnU()const=0;

virtualvoidsetQ(constEigen::Ref<constkm::Vec>&val)=0;

virtualvoidsetQ(doublefill_value)=0;

virtualconstkm::Vec&getQ()const=0;

virtualvoidsetU(constEigen::Ref<constkm::Vec>&val)=0;

virtualvoidsetU(doublefill_value)=0;

virtualconstkm::Vec&getU()const=0;

virtualvoidsetT(constEigen::Ref<constkm::Vec>&val)=0;

virtualvoidsetT(doublefill_value)=0;

virtualconstkm::Vec&getT()const=0;

virtualvoidsetUdot(constEigen::Ref<constkm::Vec>&val)=0;

virtualvoidsetUdot(doublefill_value)=0;

virtualconstkm::Vec&getUdot()const=0;

virtualconstkm::Vec&getQdot()const=0;
#endif

//virtualconstkm::Mat&coordMapMatrix()const=0;

protected:
SubhingeBase(conststd::string&nm,kc::id_tid,kc::ks_ptr<HingeBase>);

//virtualstd::optional<bool>isOriented(constkf::Frame2Frame&f2f)const=0;

protected:
kc::ks_ptr<HingeBase>_parent_hinge=nullptr;

bool_prescribed=false;
};

}//namespaceKarana::Dynamics