ObjectContactSphereSphere

[UNDER CONSTRUCTION] A simple contact connector between two spheres. The connector implements at least the same functionality as in GeneralContact and is intended for simple setups and for testing, while GeneralContact is much more efficient due to parallelization approaches and efficient contact search.

Authors: Gerstmayr Johannes, Weyrer Sebastian

Additional information for ObjectContactSphereSphere:

  • This Object has/provides the following types = Connector
  • Requested Marker type = Position + Orientation
  • Requested Node type = GenericData

The item ObjectContactSphereSphere with type = ‘ContactSphereSphere’ has the following parameters:

  • name [type = String, default = ‘’]:
    constraints’s unique name
  • markerNumbers [[m0,m1]T, type = ArrayMarkerIndex, size = 2, default = [ invalid [-1], invalid [-1] ]]:
    list of markers representing centers of spheres, used in connector
  • nodeNumber [nd, type = NodeIndex, default = invalid (-1)]:
    node number of a NodeGenericData with numberOfDataCoordinates = 4 dataCoordinates, needed for discontinuous iteration (friction and contact); data variables contain values from last PostNewton iteration: data[0] is the gap, data[1] is the norm of the tangential velocity (and thus contains information if it is stick or slip); data[2] is the impact velocity; data[3] is the plastic overlap of the Edinburgh Adhesive Elasto-Plastic Model, initialized usually with 0 and set back to 0 in case that spheres have been separated.
  • spheresRadii [[r0,r1]T, type = Vector2D, size = 2, default = [-1.,-1.]]:
    Vector containing radius of sphere 0 and radius of sphere 1 [SI:m]
  • dynamicFriction [μd, type = UReal, default = 0.]:
    dynamic friction coefficient for friction model, see StribeckFunction in exudyn.physics, Section Module: physics
  • frictionProportionalZone [vreg, type = UReal, default = 1e-3]:
    limit velocity [m/s] up to which the friction is proportional to velocity (for regularization / avoid numerical oscillations), see StribeckFunction in exudyn.physics (named regVel there!), Section Module: physics
  • contactStiffness [kc, type = UReal, default = 0.]:
    normal contact stiffness [SI:N/m] (units in case that nexp=1)
  • contactDamping [dc, type = UReal, default = 0.]:
    linear normal contact damping [SI:N/(m s)]; this damping should be used (!=0) if the restitution coefficient is < 1, as it changes its behavior.
  • contactStiffnessExponent [nexp, type = PReal, default = 1.]:
    exponent in normal contact model [SI:1]
  • constantPullOffForce [fadh, type = UReal, default = 0.]:
    constant adhesion force [SI:N]; Edinburgh Adhesive Elasto-Plastic Model
  • contactPlasticityRatio [λP, type = UReal, default = 0.]:
    ratio of contact stiffness for first loading and unloading/reloading [SI:1]; Edinburgh Adhesive Elasto-Plastic Model; λP=1kc/K2, which gives the contact stiffness for unloading/reloading K2=kc/(1λP); set to 0 in order to fully deactivate Edinburgh Adhesive Elasto-Plastic Model model
  • adhesionCoefficient [kadh, type = UReal, default = 0.]:
    coefficient for adhesion [SI:N/m] (units in case that nadh=1); Edinburgh Adhesive Elasto-Plastic Model; set to 0 to deactivate adhesion model
  • adhesionExponent [nadh, type = UReal, default = 1.]:
    exponent for adhesion coefficient [SI:1]; Edinburgh Adhesive Elasto-Plastic Model
  • restitutionCoefficient [eres, type = PReal, default = 1.]:
    coefficient of restitution [SI:1]; used in particular for impact mechanics; different models available within parameter impactModel; the coefficient must be > 0, but can become arbitrarily small to emulate plastic impact (however very small values may lead to numerical problems)
  • minimumImpactVelocity [δ˙,min, type = UReal, default = 0.]:
    minimal impact velocity for coefficient of restitution [SI:1]; this value adds a lower bound for impact velocities for calculation of viscous impact force; it can be used to apply a larger damping behavior for low impact velocities (or permanent contact)
  • impactModel [mimpact, type = UInt, default = 0]:
    number of impact model: 0) linear model (only linear damping is used); 1) Hunt-Crossley model; 2) Gonthier/EtAl-Carvalho/Martins mixed model; model 2 is much more accurate regarding the coefficient of restitution, in the full range [0,1] except for 0; NOTE: in all models, the linear contactDamping still added, if not set to zero!
  • activeConnector [type = Bool, default = True]:
    flag, which determines, if the connector is active; used to deactivate (temporarily) a connector or constraint
  • visualization [type = VObjectContactSphereSphere]:
    parameters for visualization of item

The item VObjectContactSphereSphere has the following parameters:

  • show [type = Bool, default = False]:
    set true, if item is shown in visualization and false if it is not shown; draws spheres by given radii
  • color [type = Float4, default = [0.7,0.7,0.7,1.]]:
    RGBA connector color; if R==-1, use default color

DESCRIPTION of ObjectContactSphereSphere

The following output variables are available as OutputVariableType in sensors, Get…Output() and other functions:

  • Director3:
    contains normalized vector from marker 0 to marker 1
  • Displacement:
    global displacement vector between the two spheres midpoints
  • DisplacementLocal:
    3D Vector, containing only gap (Z-component)
  • Velocity:
    global relative velocity between the two spheres midpoints
  • Force:
    global contact force vector
  • Torque:
    global torque due to friction on marker 0; to obetain torque on marker 1, multiply the torque with the factor r1+g/2r0+g/2

Definition of quantities

intermediate variables
symbol
description
marker m0 position
p0m0
global position of sphere 0 center as provided by marker m0
marker m0 orientation
A0,m0
current rotation matrix provided by marker m0
marker m1 position
p0m1
global position of sphere 1 center as provided by marker m1
marker m1 orientation
A0,m1
current rotation matrix provided by marker m1
data coordinates
x=[x0,x1,x2,x3]T
hold the current gap (0), the (norm of the) tangential velocity (1), the impact velocity (2), and the plastic deformation (3) of the adhesion model
marker m0 velocity
v0m0
current global velocity which is provided by marker m0
marker m1 velocity
v0m1
current global velocity which is provided by marker m1
marker m0 angular velocity
ω0m0
current angular velocity vector provided by marker m0
marker m1 angular velocity
ω0m1
current angular velocity vector provided by marker m1

Connector Forces

This section outlines the computation of the forces acting on the two spheres when they are in contact with each other. Two types of forces can act on the spheres due to the connector:

  • normal force computed according to the chosen impact model mimpact and with contact damping if dc0; this type of force does not create a torque acting on the spheres.

  • tangential force due to a regularized friction law to model dry friction between the spheres; this type of force creates a torque acting on the spheres and is computed independently of the chosen impact model if μd0 is set. Note that in the implemented model, rolling deformations are not considered, i.e. the friction is only a function of the relative tangential velocity between the spheres at the contact point.

../../../_images/SphereSphereContact.png

Fig. 46 Two spheres that are in contact, showing a force on marker 1 in normal direction due to overlap; forces on marker 0 act in opposite direction.

For the following, the gap g between the two spheres is computed as

g=||p0m1p0m0||(r0+r1)

and the overlap δ is the negated gap: δ=g. In the contact case, the overlap δ is positive. The normal vector n0 points from marker 0 to marker 1 and is computed with

n0=p0m1p0m0||p0m1p0m0||.

The scalar normal (gap) velocity vδ,n is computed with the velocities v0m0=p˙0m0 and v0m1=p˙0m1

vδ,n=(v0m1v0m0)n0

and the tangential (gap) velocity v0δ,t at the contact point, that is needed for the friction model, reads

(84)v0δ,t=(v0a1v0a0)vδ,nn0,vrel=||v0δ,t||.

To take the angular velocity of the spheres into account, the velocities v0a0 and v0a1 at the contact point are computed using Euler’s theorem for kinematics:

v0a0=v0m0+ω0m0×(n0(r0δ2)),v0a1=v0m1+ω0m1×(n0(r1δ2)).

The normal force acting on marker 1 is generally written as

f01,n=(fc+fd)f1,nn0,

where fc is the elastic and fd the damping part. The damping fd is always computed the same, independent of the chosen impact model:

fd=dcvδ,n.

The negative sign is because of the damping acting against the gap velocity: in the case of a positive normal (gap) velocity, the damping acts against n0 for marker 1. The elastic force fc is computed depending on the chosen impact model.

  • mimpact=0: the Adhesive Elasto-Plastic model described in is used. This model captures the key bulk behavior of cohesive powders and granular soils. For the impact model, the plastic overlap δp is needed. It is computed with

δp=λp1nexpδ.TheAdhesiveElastoPlasticmodeldistinguishesthreedifferentcases,modelingtheloadingandunloadingbehaviorofthespheres:
fc={fadh+kcδnexpif k2(δnexpδpnexp)kcδnexpfadh+k2(δnexpδpnexp)if kcδnexp>k2(δnexpδpnexp)>kadhδnadhfadhkadhδnadhif kadhδnadh>k2(δnexpδpnexp).

Note that k2 is computed with k2=kc/(1λP). The terms with the stiffness kc and k2 have a positive sign, since they act in the direction of n0 for marker 1. The constant adhesion force fadh and the stiffness kadh act against n0, which corresponds to a force sticking the spheres together.

  • mimpact=1: the restitution model proposed by Hunt and Crossley in is used to simulate the energy loss of the spheres during contact:

fc=kcδnexp+λδnexpvδ,nwith
λ=kcδ˙32(eres1).Therestitutioncoefficient :math:eres describestherationofthenormal(gap)velocitybeforeandaftertheimpactofthespheres.Inthecaseof :math:eres<1 ,theimpacthasaplasticportion,resultinginaforceactingagainst :math:n0 formarker1,whichiswhy :math:λ mustbenegativeinthatcase. :math:δ˙ istheinitialrelativevelocity,whichiseithertheminimumimpactvelocityorthenormal(negatedgap)velocity:
δ˙=max(δ˙,min;vδ,n)

Note that the Hunt-Crossley restitution is valid for a very small energy loss (eres1) .

  • mimpact=2: a generalization of the Hunt-Crossley restitution proposed by Carvalho and Martins in is used for eres>13 and a model proposed by Gonthier et al. in is used for impacts with a high plastic proportion, eres<13. Note that the two models are identical at eres=13. λ is therefore computed as follows:

λ={kcδ˙32(eres1)11eres1+9eresif eres>13kcδ˙erep21erepif eres>0.

The tangential force acting on marker 1 due to the friction model acts against the tangential velocity vδ,t, see the computation of vδ,t in Equation (84). Thus, the tangential force for marker 1 is computed as

f01,t=v0δ,t{μdf1,nvregif vrel<vregμdf1,nvrelelse.

Note that the case distinction above is made to ensure that for very small relative velocities the friction force does not become implausibly high. Taken together, the force acting on marker 1 due to the connector is computed as

f0m1=f01,n+f01,t,

the force acting on marker 0 is f0m0=f0m1. The global torque τ0m1 acting on marker 1 due to the connector is computed as

τ0m1=n0(r112δ)×f0m1,

and on marker 0 as

τ0m0=n0(r012δ)×f0m0=n0(r012δ)×f0m1.

It can be seen that the torque due to the connector is the same for both spheres, if r0=r1 applies.

Relevant Examples and TestModels with weblink:

The web version may not be complete. For details, consider also the Exudyn PDF documentation : theDoc.pdf