Product: ABAQUS/Standard
User subroutine UEL provides the user with a very general option to interface with the code. The user is warned that in any use of this subroutine interface, extensive verification should be done to make sure that the results are correct.
User subroutine to define the element mass matrix, element operator matrix, and right-hand side vector.
The finite element model for each test case consists of two separate but identical meshes of a simple truss. One mesh consists of five T3D2 elements, and the other consists of five equivalent user-defined elements.
Four test cases are performed as described below.
uellinea.inp
In this problem a linear analysis is run that uses the data line input option to specify the stiffness and mass matrix of the user element. This means that the subroutine is not used, but rather the *MATRIX, TYPE=STIFFNESS and *MATRIX, TYPE=MASS suboptions of the *USER ELEMENT option are tested. One end of the truss is constrained. In the first step a load is applied at the second end of the truss. In the second step the eigenfrequencies of the truss are calculated.
uelnonli.inp
The same problem is solved as in uellinea.inp, but the user subroutine is used. The problem is still linear, but there is no assumption of linearity in the user-defined element.
uelriksx.inp
In this job the load is applied gradually, with the RIKS procedure specified on the *STATIC option.
ueldynam.inp
In this case the load is applied instantaneously as the implicit dynamics procedure is used to calculate the results for the first 10 increments.
The verification consists of comparing the results from the T3D2 models to the results obtained from the user element models, since they should be identical.
Linear analysis with data line input option.
Linear analysis with user subroutine.
User subroutine UEL used in uelnonli.inp.
Analysis with RIKS procedure.
User subroutine UEL used in uelriksx.inp.
Analysis with implicit dynamics.
User subroutine UEL used in ueldynam.inp.
The finite element model in each test case consists of two separate but identical meshes of a rectangular block. One mesh consists of two DC2D8 elements, and the other consists of two equivalent user-defined elements. The elements in each mesh have an irregular shape to ensure that the interpolation is consistent for the two element types.
Two test cases are performed as described below.
ueltran1.inp
In this problem a transient analysis is performed in which a distributed flux is specified on the left-hand side of the domain and a convection film condition on the right-hand side of the domain. The top and bottom surfaces of the block are adiabatic. The analysis is run until a steady-state condition is satisfied.
ueltran2.inp
The problem outlined in ueltran1.inp is solved again, but in this case the thermal conductivity is temperature-dependent. In addition, the unsymmetric equation solver is invoked using the *STEP, UNSYMM=YES option. For user element operator matrices to be identical to those of the DC2D8 elements, the additional unsymmetric contribution of the temperature-dependent thermal conductivity term (see Uncoupled heat transfer analysis, Section 2.11.1 of the ABAQUS Theory Manual) must be included. This is accomplished by using the UNSYMM parameter on the *USER ELEMENT option.
The verification consists of comparing the results from the DC2D8 models to the results obtained from the user element models, since they should be identical.
Transient analysis.
User subroutine UEL used in ueltran1.inp.
Transient analysis with temperature-dependent thermal conductivity.
User subroutine UEL used in ueltran2.inp.
User subroutine to test the utility subroutines for fluid kinematic data in ABAQUS/Aqua analyses.
A dummy user element is used to call the utility subroutines for fluid kinematic data. The fluid kinematic data are requested at different points. Three test cases are performed.
The verification consists of comparing the results returned by the utility subroutines with the results from the wave theory. The results from the wave theory are given in the input files as comment lines.
Gets the velocities and accelerations from the utility subroutine GetWaveVel for a Stokes' wave at a few points.
User subroutine UEL used in uelutwv1.inp.
Gets the velocities and accelerations from the utility subroutine GetWaveVel for an Airy wave at a few points.
User subroutine UEL used in uelutwv2.inp.
Gets the steady current velocities and wind velocities from the utility subroutines GetCurrVel and GetWindVel, respectively, for points below and above the still fluid surface.
User subroutine UEL used in uelutwv3.inp.