.. |BALL_JOINT| image:: ../images/en/BallJoint.png .. |HINGE_JOINT| image:: ../images/en/Hinge.png .. |PRISMATIC_JOINT| image:: ../images/en/Prismatic.png .. |CYLINDRICAL_JOINT| image:: ../images/en/Cylindrical.png .. |LOCK_JOINT| image:: ../images/en/Lock.png .. |SPRING_JOINT| image:: ../images/en/SpringJoint.png .. _joints: ====== Joints ====== Joints remove degrees of freedom between a rigid body and the world, or between two rigid bodies. Some joints also have :ref:`motor `, :ref:`spring ` and :ref:`range ` modifiers. Common to all joints is that they can be attached to *one* rigid body (and the world), or *two* rigid bodies, of which at least one must be a dynamic one (or the joint will be disabled). Available joints: .. toctree:: :maxdepth: 1 Hinge.rst Prismatic.rst Cylindrical.rst Lock Joint.rst Ball Joint.rst Spring Joint.rst .. _creating_a_joint: ---------------- Creating a Joint ---------------- A joint can be created in various ways. 1. Using the tool for the specific joint, Ctrl-clicking on a component in the one rigid body, then on an edge or an axis a component in another rigid body. This will create a joint between the two rigid bodies. 2. Using the tool for the specific joint, and clicking on an edge or an axis belonging to a component which is part of a rigid body. This will create a joint between the world and the rigid body. 3. Using the :ref:`ribbon_detect_joints`. When manually creating a joint like in 1. or 2., first select the desired joint tool on the Ribbon menu: .. |JOINTS| image:: ../images/en/Joints.png |JOINTS| ----------------------------------------- Creating a joint between two rigid bodies ----------------------------------------- .. |CREATING_A_JOINT| image:: ../images/en/CreatingAJoint.png .. |CREATING_A_JOINT2| image:: ../images/en/CreatingAJoint2.png .. |CREATING_A_JOINT3| image:: ../images/en/CreatingAJoint3.png |CREATING_A_JOINT| After the first component/rigid body has been selected with Ctrl-click, the second will be based on the solid whose edge is clicked: |CREATING_A_JOINT2| After clicking on an edge, the Joint is created at the center of the edge. *An existing joint on the same edge associated to the same components will be replaced with a warning message.* *Undo* will bring back the previous one. When multiple joints (to different bodies each) are attached to the same edge, the icons will be displaced to indicate more than one joint. The *actual* transformation of a joint is marked with a coordinate axis, visible when the joint is selected: |CREATING_A_JOINT3| ----------------------------------------------------- Creating a joint between the world and one rigid body ----------------------------------------------------- The workflow for creating a joint between the world and one rigid body is more or less the same as previously described. Just directly click on an edge or a radial line onto which you want to attach the joint. The joint will then attach the rigid body associated to the edge. ----------------------------------------------------- Moving a Joint ----------------------------------------------------- By default, a joint will follow the edge onto which it is attached. With the *Move Tool* a joint can be transformed. After a joint is moved, it will no longer move relatively to the previously attached edge/center-line. ----------------------------------------------------- Restructuring rigid bodies ----------------------------------------------------- A previously created joint might be disabled during a restructuring of your simulation. Assume for example you have a joint attached to two components, each belonging to a separate rigid body. If you now merge the two components into one single rigid body, the joint is no longer valid (a joint between one rigid body does not make sense) and will be deleted. .. _joint_status: ------------ Joint status ------------ A joint can have different status depending on the state of the joint and the rigid body/bodies it is attached to. .. |ENABLED_DYNAMIC_JOINT| image:: ../images/en/EnabledDynamicJoint.png .. |ENABLED_STATIC_JOINT| image:: ../images/en/EnabledStaticJoint.png .. |DISABLED_JOINT| image:: ../images/en/DisabledJoint.png .. |DETECTED_JOINT| image:: ../images/en/DetectedJoint.png .. |MOTORIZED_JOINT| image:: ../images/en/MotorizedJoint.png - |ENABLED_DYNAMIC_JOINT| - Purple. A joint attached between two rigid bodies with :ref:`motion control ` **Dynamics**. - |ENABLED_STATIC_JOINT| - Yellow. A joint attached to one rigid body (and the world) *or* two rigid bodies of which one has :ref:`motion control ` **Static**. - |DISABLED_JOINT| - Transparent Gray. A disabled joint *or* a joint attached to one or two rigid body which are disabled, or between two rigid bodies both with motion control **Static**. - |DETECTED_JOINT| - Gray. A potential joint detected by the :ref:`detect joints tool `. - |MOTORIZED_JOINT| - Orange. A joint with an enabled motor. .. _right_mouse_menu: .. |RIGHT_MOUSE_MENU_JOINT| image:: ../images/en/RightMouseMenuJoint.png ----------------------------------------------------- Right Mouse Menu ----------------------------------------------------- Right clicking a selected joint (in this case, a lock joint) in the graphical view will bring up a menu: |RIGHT_MOUSE_MENU_JOINT| - Use in Sequence Editor - Toggles the use of this joint in the :ref:`ribbon_sequence_editor`. - Convert to Hinge joint - Convert this joint to a :ref:`hinge_joint`. - Convert to Cylindrical joint - Convert this joint to a :ref:`cylindrical_joint` - Convert to Prismatic joint - Convert this joint to a :ref:`prismatic_joint` - Disable/Enable Joint for Simulation - Will disable the joint from the simulation. This will also automatically enable collision between the two rigid bodies. - Locate in Simulation Structure - Will highlight the Joint in the :ref:`locate_in_simulation_structure`. - Reset Violation - Not always available (see below). Reconfigure the joint so that it is non-violated when starting the simulation. (:ref:`reset_violation`). - Reverse direction - This is only available for joints attached to two bodies. This will swap the two attached rigid bodies. Effectively it will also flip the order of the joint. Reverse direction will cause the simulation recording to the initial state (t=0) and apply the operation. Analogue to changing properties. .. _reset_violation: ^^^^^^^^^^^^^^^^ Reset violation ^^^^^^^^^^^^^^^^ When a joint is first created, it will be in a non-violated state, meaning that it satisfies the joint configuration. However, during simulation a joint can be more or less violated, for example by lowering the stiffness in the properties for a given DOF a joint can become flexible. This means that you can effectively have a "charged spring" when you start the simulation. By resetting the violation you ensure that the joint is configured so that the current relative transformation between the two jointed bodies is a non-violated state. This also mean that the current *Angular* and *Linear position* will be reset to 0 for Angular and Linear motors. If this option is not available, the joint is not violated. .. _joints_with_springs: -------------------- Joints with springs -------------------- Common to all springs is that they both have a position of static equilibrium (position/rest length), elasticity and damping properties. ^^^^^^^^^^^^^^^^ Linear spring ^^^^^^^^^^^^^^^^ A linear spring can be simulated by: - using the linear :ref:`spring_joint`. - enabling the :ref:`spring modifier ` for a :ref:`prismatic_joint`, or the :ref:`linear spring ` of a :ref:`cylindrical_joint`. ^^^^^^^^^^^^^^^^ Torsional spring ^^^^^^^^^^^^^^^^ A hinge has a rotational :ref:`position/angle ` which describes its equilibrium position. This value can be in the range from -infinity to +infinity. So to define a charged torsion spring, you can enter a position value different from 0. The :ref:`Angular Spring ` on a cylindrical joint follows works analogous to the hinge. It can be enabled using the :ref:`spring` for a :ref:`hinge_joint` or the :ref:`Angular Spring ` of a :ref:`cylindrical_joint`. ^^^^^^^^^^^^^^^^ Damping ^^^^^^^^^^^^^^^^ The damping is a dimensionless property that describes how oscillations in a system decay when the spring has been disturbed from its position of equilibrium. Remember that when changing the elasticity of a spring, you might also have to change the damping to get the effect you want. See `damping ratio `_ (Wikipedia). ^^^^^^^^^^^^^^^^ Elasticity ^^^^^^^^^^^^^^^^ This corresponds to the spring constant k according to `Hooke's law `_ (Wikipedia). ^^^^^^^^^^^^^^^^^^^^ Position/rest length ^^^^^^^^^^^^^^^^^^^^ Every spring has a specified length or position at which it is in equilibrium. At this position, the spring will not apply any force to its attached rigid bodies. Pushing or stretching the bodies will move the spring out of this position, hence it will apply a force to restore its position. .. _joint_types: ------------ Joint types ------------ This section describes the usage of the different joints in detail. - |HINGE_JOINT| :ref:`hinge_joint` - |PRISMATIC_JOINT| :ref:`prismatic_joint` - |CYLINDRICAL_JOINT| :ref:`cylindrical_joint` - |LOCK_JOINT| :ref:`lock_joint` - |BALL_JOINT| :ref:`ball_joint` - |SPRING_JOINT| :ref:`spring_joint` .. _motorized_joints: -------------------- Motorized joints -------------------- The Hinge, Prismatic and Cylindrical joint can have motors. A motorized joint (with a motor enabled) will be indicated in the simulation structure with one of the following icons: - |HINGE_JOINT| :ref:`hinge_joint` - |PRISMATIC_JOINT| :ref:`prismatic_joint` - |CYLINDRICAL_JOINT| :ref:`cylindrical_joint` .. _range_joints: -------------------- Joints with range -------------------- The Hinge, Prismatic and Cylindrical joint can also have a *range* . A joint with a range will limit its motion between an upper and a lower range. The following joints can have a defined range: - |HINGE_JOINT| :ref:`hinge_joint` - |PRISMATIC_JOINT| :ref:`prismatic_joint` - |CYLINDRICAL_JOINT| :ref:`cylindrical_joint` .. _joint_internal_friction: ---------------------------- Joint with internal friction ---------------------------- The Joint Internal Friction is valid and available for **Hinge** (rotational), **Prismatic** (translational) and **Cylindrical** (rotational and translational), joints and adds an internal friction force such that: .. _joint_internal_friction_coefficient: .. math:: F_{friction} \leq \mu F_{normal} Note that for **Hinge** and rotational **Cylindrical** we've a resulting torque. For the friction condition to be dimensionally correct, the axle radius should be included in the friction coefficient, giving: .. _joint_internal_friction_radial_coefficient: .. math:: \tau_{friction} \leq \mu r F_{normal} We have stick friction mode when :math:`F_{friction} < \mu F_{normal}` and the objects are sliding when :math:`F_{friction} = \mu F_{normal}`. The internal friction is disabled by default. Activate the internal friction via the joint property Internal Friction. .. _joint_internal_friction_static_friction: ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Minimum static resistance force ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The internal friction includes a setting for minimal static friction resistance force, meaning there is a friction resistance even with the friction coefficient set to zero, i.e. we will have a friction resistence even when we have no normal forces. If you also specify a friction coefficient the friction force may exceed the static friction resistance limit, :math:`F_{friction} = max(\mu F_{normal}, F_{minimum static friction})`. .. _joint_internal_normal_force: ^^^^^^^^^^^^ Normal force ^^^^^^^^^^^^ The normal force is calculated differently depending on which type of Joint the internal friction is active on. Given the joint axis is defined to be **along/about z**, the normal force is defined to be translational force along **x** (:math:`F_{normal}^x`) and **y** (:math:`F_{normal}^y`), which gives us the normal force: .. math:: F_{normal} = \sqrt{(F_{normal}^x)^2 + (F_{normal}^y)^2} .. _joint_internal_friction-non-linear: ^^^^^^^^^^^^^^^^^^^^^^^^^ Non-Linear Force Modeling ^^^^^^^^^^^^^^^^^^^^^^^^^ The friction force depends on the normal force and in some non-trivial scenarios the normal force depends on the friction force. A simple and performance wise fast approach is to use the normal force from the previous time step to calculate the maximum friction force in the current time step. This is the default mode and will not significantly affect the performance but may affect the accuracy of the simulation. E.g., the first time step the friction forces will be zero since there's no information regarding previous normal force. For Joint solve types *Direct* and *Direct and Iterative*, Algoryx Momentum supports non-linear update of the friction forces given current normal force. This mode is similar to direct friction for contacts and will affect the performance but will also increase the accuracy of the simulation. .. _solve_type: ----------- Solve type ----------- Joints are solved together with contacts in the solver. Joints have a property *Solve Type* which determines which solver is used for the specific joint. For more information see :ref:`solvers`.