public class FrameExciter extends ModelComponentBase implements ExcitationComponent, ForceComponent, HasNumericState
Modifier and Type | Class and Description |
---|---|
static class |
FrameExciter.WrenchComponent
Deprecated.
Use
FrameExciter.WrenchDof instead. |
static class |
FrameExciter.WrenchDof
Specifies the degree-of-freedom along (or about) which the force (or
moment) of this exciter will be applied to the frame.
|
ExcitationComponent.CombinationRule
ModelComponent.NavpanelVisibility
Modifier and Type | Field and Description |
---|---|
static PropertyList |
myProps |
enforceUniqueCompositeNames, enforceUniqueNames, myNumber, NULL_OBJ, useCompactPathNames
Constructor and Description |
---|
FrameExciter() |
FrameExciter(Frame frame,
FrameExciter.WrenchComponent comp,
double maxForce)
Deprecated.
Use
FrameExciter(String,Frame,WrenchDof,double)
instead. |
FrameExciter(Frame frame,
FrameExciter.WrenchDof dof,
double maxForce) |
FrameExciter(java.lang.String name) |
FrameExciter(java.lang.String name,
Frame frame,
FrameExciter.WrenchComponent comp,
double maxForce)
Deprecated.
Use
FrameExciter(String,Frame,WrenchDof,double)
instead. |
FrameExciter(java.lang.String name,
Frame frame,
FrameExciter.WrenchDof dof,
double maxForce)
Creates a FrameExciter.
|
Modifier and Type | Method and Description |
---|---|
void |
addExcitationSource(ExcitationComponent ex,
double gain)
Adds a new excitation source to this Excitable with a specified gain.
|
static FrameExciter[] |
addFrameExciters(MechModel mech,
Frame frame,
boolean[] enabled,
double[] maxForces)
Adds frame exciters for up to 6 components of a wrench on a frame.
|
static FrameExciter[] |
addFrameExciters(MechModel mech,
Frame frame,
double maxForce) |
static FrameExciter[] |
addLinearFrameExciters(MechModel mech,
Frame frame,
double maxForce) |
void |
addPosJacobian(SparseNumberedBlockMatrix M,
double s)
Scales the components of the position Jacobian associated with this force
effector and adds it to the supplied solve matrix M.
|
void |
addSolveBlocks(SparseNumberedBlockMatrix M)
Adds any needed blocks to a solve matrix in order to accomodate the
Jacobian terms associated with this force effector.
|
void |
addVelJacobian(SparseNumberedBlockMatrix M,
double s)
Scales the components of the velocity Jacobian associated with this force
effector and adds it to the supplied solve matrix M.
|
void |
applyForces(double t)
Adds forces to the components affected by this force effector at a
particular time.
|
static java.util.ArrayList<FrameExciter> |
createForceExciters(MechModel mech,
Frame frame,
double maxForce,
boolean createNames)
Creates a set of three FrameExciters to control the translational force
on a given frame.
|
static java.util.ArrayList<FrameExciter> |
createFrameExciters(MechModel mech,
Frame frame,
double maxForce,
double maxMoment,
boolean createNames)
Creates a complete set of FrameExciters for a given frame.
|
static java.util.ArrayList<FrameExciter> |
createMomentExciters(MechModel mech,
Frame frame,
double maxMoment,
boolean createNames)
Creates a set of three FrameExciters to control the moment force on a
given frame.
|
PropertyList |
getAllPropertyInfo()
Returns a list giving static information about all properties exported by
this object.
|
ExcitationComponent.CombinationRule |
getCombinationRule()
Return the combination rule for excitations.
|
double |
getExcitation()
Returns the primary excitation for this component.
|
double |
getExcitationGain(ExcitationComponent ex)
Gets the gain for an excitation source in this component.
|
int |
getJacobianType()
Returns a code indicating the matrix type that results when the Jacobian
terms of this force effector are added to the solve matrix.
|
double |
getMaxForce() |
double |
getNetExcitation()
Returns the net excitation for this Excitable.
|
void |
getSoftReferences(java.util.List<ModelComponent> refs)
Appends all soft references for this component to a list.
|
void |
getState(DataBuffer data)
Saves state information for this component by adding data to the
supplied DataBuffer.
|
boolean |
hasState()
Queries if this component has state.
|
boolean |
removeExcitationSource(ExcitationComponent ex)
Removes an excitation source from this Excitable.
|
void |
setCombinationRule(ExcitationComponent.CombinationRule rule)
Sets the rule for combining excitations.
|
void |
setExcitation(double e)
SetsJust reiterating the primary excitation for this component.
|
boolean |
setExcitationGain(ExcitationComponent ex,
double gain)
Sets the gain for an excitation source in this component.
|
void |
setMaxForce(double maxForce) |
void |
setState(DataBuffer data)
Restores the state for this component by reading from the supplied
data buffer, starting at the current buffer offsets.
|
void |
updateReferences(boolean undo,
java.util.Deque<java.lang.Object> undoInfo)
May be called by the system if any of the soft references for
this component are removed from the the component hierarchy.
|
checkFlag, checkName, checkNameUniqueness, clearFlag, clone, connectToHierarchy, copy, createTempFlag, disconnectFromHierarchy, getChildren, getGrandParent, getHardReferences, getName, getNameRange, getNavpanelVisibility, getNavpanelVisibility, getNumber, getParent, getProperty, hasChildren, isFixed, isMarked, isScanning, isSelected, isWritable, makeValidName, makeValidName, notifyParentOfChange, postscan, printReferences, recursivelyContained, recursivelyContains, removeTempFlag, scan, setFixed, setFlag, setMarked, setName, setNavpanelVisibility, setNavpanelVisibility, setNumber, setParent, setScanning, setSelected, setWritable, write
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
connectToHierarchy, disconnectFromHierarchy, getHardReferences, getName, getNavpanelVisibility, getNumber, getParent, isFixed, isMarked, isSelected, notifyParentOfChange, scan, setFixed, setMarked, setName, setNumber, setParent, setSelected, setWritable
getProperty
getChildren, hasChildren
postscan
isWritable, write
advanceState, getAuxVarDerivative, getAuxVarState, getStateVersion, numAuxVars, requiresAdvance, setAuxVarState
public static PropertyList myProps
public FrameExciter(java.lang.String name, Frame frame, FrameExciter.WrenchDof dof, double maxForce)
name
- name of the exciter, or null
frame
- frame being activateddof
- degree of freedom being controlled (world coordinates)maxForce
- maximum force along the dofpublic FrameExciter(Frame frame, FrameExciter.WrenchComponent comp, double maxForce)
FrameExciter(String,Frame,WrenchDof,double)
instead.public FrameExciter(java.lang.String name, Frame frame, FrameExciter.WrenchComponent comp, double maxForce)
FrameExciter(String,Frame,WrenchDof,double)
instead.public FrameExciter(Frame frame, FrameExciter.WrenchDof dof, double maxForce)
public FrameExciter(java.lang.String name)
public FrameExciter()
public PropertyList getAllPropertyInfo()
HasProperties
getAllPropertyInfo
in interface HasProperties
getAllPropertyInfo
in class ModelComponentBase
public void setCombinationRule(ExcitationComponent.CombinationRule rule)
ExcitationComponent
setCombinationRule
in interface ExcitationComponent
rule
- rule for combining excitationspublic ExcitationComponent.CombinationRule getCombinationRule()
ExcitationComponent
getCombinationRule
in interface ExcitationComponent
public void setExcitation(double e)
ExcitationComponent
setExcitation
in interface ExcitationComponent
e
- excitation valuepublic double getExcitation()
ExcitationComponent
getExcitation
in interface ExcitationComponent
public void addExcitationSource(ExcitationComponent ex, double gain)
addExcitationSource
in interface ExcitationComponent
ex
- excitatation source to be addedgain
- gain for the sourcepublic boolean removeExcitationSource(ExcitationComponent ex)
removeExcitationSource
in interface ExcitationComponent
ex
- excitatation source to be removedpublic double getExcitationGain(ExcitationComponent ex)
getExcitationGain
in interface ExcitationComponent
ex
- excitatation source whose gain is to be queriedpublic boolean setExcitationGain(ExcitationComponent ex, double gain)
setExcitationGain
in interface ExcitationComponent
ex
- excitatation source whose gain is to be modifiedgain
- new gain for the sourcepublic double getNetExcitation()
getNetExcitation
in interface ExcitationComponent
public void getSoftReferences(java.util.List<ModelComponent> refs)
updateReferences()
method will
be called to update its internal reference information.getSoftReferences
in interface ModelComponent
getSoftReferences
in class ModelComponentBase
refs
- list to which soft references are appendedpublic void updateReferences(boolean undo, java.util.Deque<java.lang.Object> undoInfo)
undo
equal to false
,
this component should then examine its soft references and
use ComponentUtils.areConnected()
to determine which of them have been disconnected from the hierarchy.
Disconnected references should be removed, and sufficient information
should be appended to undoInfo
to allow this update
to be undone if this method is called later with undo
equal to true
. When undoing an update, the undo
information should be removed from the front of undoInfo
.updateReferences
in interface ModelComponent
updateReferences
in class ModelComponentBase
undo
- if true
, indicates that the most
recent reference update should be undone, using the supplied
undo information.undoInfo
- if undo
is false
, should be used
to store information allowing the reference update to be undone.
Otherwise, if undo
is true
, then this
supplied information to undo the most recent update.public double getMaxForce()
public void setMaxForce(double maxForce)
public void applyForces(double t)
ForceEffector
applyForces
in interface ForceEffector
t
- time (seconds)public void addSolveBlocks(SparseNumberedBlockMatrix M)
ForceEffector
getSolveIndex
) for all dynamic or attached components affected by this
force effector.addSolveBlocks
in interface ForceEffector
M
- solve matrix to which blocks should be addedpublic void addPosJacobian(SparseNumberedBlockMatrix M, double s)
ForceEffector
M is guaranteed to be the same matrix supplied in the most recent call to
addSolveBlocks
, and so implementations may choose
to cache the relevant matrix blocks from that call, instead of retrieving
them directly from M.
addPosJacobian
in interface ForceEffector
M
- solve matrix to which scaled position Jacobian is to be addeds
- scaling factor for position Jacobianpublic void addVelJacobian(SparseNumberedBlockMatrix M, double s)
ForceEffector
M is guaranteed to be the same matrix supplied in the most recent call to
addSolveBlocks
, and so implementations may choose
to cache the relevant matrix blocks from that call, instead of retrieving
them directly from M.
addVelJacobian
in interface ForceEffector
M
- solve matrix to which scaled velocity Jacobian is to be addeds
- scaling factor for velocity Jacobianpublic int getJacobianType()
ForceEffector
Matrix.SYMMETRIC
or Matrix.POSITIVE_DEFINITE
. The former should be set if adding the Jacobian
terms preserves symmetry, and the latter should be set if positive
definiteness if preserved. Both should be set if there is no Jacobian for
this effector (i.e., the Jacobian methods are not implemented). Matrix
types from all the force effectors are logically and-ed together to
determine the type for the entire solve matrix.getJacobianType
in interface ForceEffector
public static java.util.ArrayList<FrameExciter> createForceExciters(MechModel mech, Frame frame, double maxForce, boolean createNames)
mech
is non-null, the exciters are added to
its list of force effectors. If createName
is true
and
the frame has a name, each exciter is given a name based on the frame
name.mech
- optional MechModel to add the exciters toframe
- frame for which the exciters should be createdmaxForce
- maximum translational force along any axiscreateNames
- if true
, creates names for the exciters.public static java.util.ArrayList<FrameExciter> createMomentExciters(MechModel mech, Frame frame, double maxMoment, boolean createNames)
mech
is non-null, the exciters are added to its
list of force effectors. If createName
is true
and the
frame has a name, each exciter is given a name based on the frame name.mech
- optional MechModel to add the exciters toframe
- frame for which the exciters should be createdmaxMoment
- maximum moment force about any axiscreateNames
- if true
, creates names for the exciters.public static java.util.ArrayList<FrameExciter> createFrameExciters(MechModel mech, Frame frame, double maxForce, double maxMoment, boolean createNames)
mech
is non-null, the exciters are added to its list of force
effectors. If createName
is true
and the frame has a
name, each exciter is given a name based on the frame name.mech
- optional MechModel to add the exciters toframe
- frame for which the exciters should be createdmaxForce
- maximum translational force along any axismaxMoment
- maximum moment about any axiscreateNames
- if true
, creates names for the exciters.public static FrameExciter[] addFrameExciters(MechModel mech, Frame frame, double maxForce)
public static FrameExciter[] addFrameExciters(MechModel mech, Frame frame, boolean[] enabled, double[] maxForces)
mech
- the MechModelframe
- the frame on which the wrench is appliedenabled
- array[6] indicating which of the 6 components should be addedmaxForces
- array[6] indicating the max force for each component (value does not matter for unused components)public static FrameExciter[] addLinearFrameExciters(MechModel mech, Frame frame, double maxForce)
public void getState(DataBuffer data)
HasNumericState
getState
in interface HasNumericState
data
- buffer for storing the state values.public void setState(DataBuffer data)
HasNumericState
setState
in interface HasNumericState
data
- buffer containing the state informationpublic boolean hasState()
ModelComponent
hasState
in interface HasNumericState
hasState
in interface ModelComponent
hasState
in class ModelComponentBase
true
if this component has state