Massless contact

Massless contact is coded uniquely for explicit dynamics. The underlying contact definition uses a node-to-surface approach and fields such as islavnode and imastnode are common with the penalty contact formulation.

Within a new step some of the fields for massless contact have to be set up only once in the step. Therefore, they are calculated at the beginning of nonlingeo.c in the section in which the initial acceleration for the $ \alpha$-method is calculated (just after setting up the matrices in mafillsmmain.c).

At first the degrees of freedom needed to set up the $ [W_b]$ matrix (cf. Section 6.7.9) are collected in create_contactdofs.f. These are:

Furthermore, in the same routine the friction coefficient in each slave node is stored in field fric(1...nslavs).

Then, the matrices in between the big brackets in Equation (362) are calculated. They consist of a linear combination of the mass and damping matrix, or, since Rayleigh damping is assumed, a linear combination of the mass and stiffness matrix. Subsequently, these matrices are reduced to the internal degrees of freedom only (recall that $ [M_{ii}]$ and $ [D_{ii}]$ is used in Equation (362)) in subroutine reducematrix.f. Finally, the matrix corresponding to the left hand side is factorized. It will be repeatedly used for solving the system in each increment.

Now, the increment loop can start. The following actions are performed: