Simbody
3.4
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
ForceSubsystemGuts.h
Go to the documentation of this file.
1
#ifndef SimTK_SIMBODY_FORCE_SUBSYSTEM_GUTS_H
2
#define SimTK_SIMBODY_FORCE_SUBSYSTEM_GUTS_H
3
4
/* -------------------------------------------------------------------------- *
5
* Simbody(tm) *
6
* -------------------------------------------------------------------------- *
7
* This is part of the SimTK biosimulation toolkit originating from *
8
* Simbios, the NIH National Center for Physics-Based Simulation of *
9
* Biological Structures at Stanford, funded under the NIH Roadmap for *
10
* Medical Research, grant U54 GM072970. See https://simtk.org/home/simbody. *
11
* *
12
* Portions copyright (c) 2005-12 Stanford University and the Authors. *
13
* Authors: Michael Sherman *
14
* Contributors: *
15
* *
16
* Licensed under the Apache License, Version 2.0 (the "License"); you may *
17
* not use this file except in compliance with the License. You may obtain a *
18
* copy of the License at http://www.apache.org/licenses/LICENSE-2.0. *
19
* *
20
* Unless required by applicable law or agreed to in writing, software *
21
* distributed under the License is distributed on an "AS IS" BASIS, *
22
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
23
* See the License for the specific language governing permissions and *
24
* limitations under the License. *
25
* -------------------------------------------------------------------------- */
26
31
#include "
SimTKcommon.h
"
32
33
#include "
simbody/internal/common.h
"
34
#include "
simbody/internal/MultibodySystem.h
"
35
36
namespace
SimTK {
37
39
class
ForceSubsystem::Guts
:
public
Subsystem::Guts
{
40
public
:
41
Guts
(
const
String
& name,
const
String
& version)
42
:
Subsystem
::
Guts
(name,version)
43
{
44
}
45
46
// Make sure the virtual destructor in Subsystem::Guts remains
47
// virtual in this intermediate class.
48
virtual
~Guts
() { }
49
50
// All the other Subsystem::Guts virtuals remain unresolved.
51
52
// Return the MultibodySystem which owns this ForceSubsystem.
53
const
MultibodySystem
&
getMultibodySystem
()
const
{
54
return
MultibodySystem::downcast(
getSystem
());
55
}
56
59
virtual
Real
calcPotentialEnergy
(
const
State
& state)
const
= 0;
60
61
SimTK_DOWNCAST
(
ForceSubsystem::Guts
,
Subsystem::Guts
);
62
};
63
64
// typedef ForceSubsystem::Guts ForceSubsystemRep;
65
66
}
// namespace SimTK
67
68
#endif // SimTK_SIMBODY_FORCE_SUBSYSTEM_GUTS_H
Simbody
include
simbody
internal
ForceSubsystemGuts.h
Generated on Tue Dec 2 2014 13:13:23 for Simbody by
1.8.1.2