forked from SAP-archive/fedem-mdb
-
Notifications
You must be signed in to change notification settings - Fork 0
/
FmAxialSpring.H
59 lines (40 loc) · 1.46 KB
/
FmAxialSpring.H
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
// SPDX-FileCopyrightText: 2023 SAP SE
//
// SPDX-License-Identifier: Apache-2.0
//
// This file is part of FEDEM - https://openfedem.org
////////////////////////////////////////////////////////////////////////////////
#ifndef FM_AXIAL_SPRING_H
#define FM_AXIAL_SPRING_H
#include "vpmDB/FmSpringBase.H"
#include "vpmDB/FmTriad.H"
#include "FFaLib/FFaContainers/FFaReferenceList.H"
class FmAxialSpring : public FmSpringBase
{
Fmd_DB_HEADER_INIT();
public:
FmAxialSpring();
bool connect(FmTriad* tr1, FmTriad* tr2);
using FmSpringBase::connect;
void setOwnerTriads(FmTriad* tr1, FmTriad* tr2);
void removeOwnerTriads();
FmTriad* getFirstTriad() const;
FmTriad* getSecondTriad() const;
void getTriads(std::vector<FmTriad*>& toFill) const;
static int checkAxialSprings();
virtual double getModelSpringLength() const;
virtual bool detach();
virtual int printSolverEntry(FILE* fp);
static bool readAndConnect(std::istream& is, std::ostream& os = std::cout);
virtual std::ostream& writeFMF(std::ostream& os = std::cout);
virtual bool clone(FmBase* obj, int depth);
virtual void initAfterResolve();
virtual void getEntities(std::vector<FmSensorChoice>& choicesToFill, int dof = -1);
virtual const char* getUITypeName() const { return "Axial spring"; }
protected:
virtual ~FmAxialSpring();
virtual bool cloneLocal(FmBase* obj, int depth);
FFaReferenceList<FmTriad> itsTriads;
FFaField<FFaReferenceListBase*> itsTriadsField;
};
#endif