ProductsAbaqus/Standard MetalsFor metals whose material behavior includes metal creep and/or time-dependent volumetric swelling, the routine allows any “creep” and “swelling” laws (viscoplastic behavior) of the following general form to be defined: ˙ˉεcr=gcr(p,˜q,ˉεsw,ˉεcr,time,…),
˙ˉεsw=gsw(p,˜q,ˉεsw,ˉεcr,time,…),
where
The user subroutine must define the increments of inelastic strain, △ˉεcr and △ˉεsw, as functions of p and ˜q and any other variables used in the definitions of gcr and gsw (such as solution-dependent state variables introduced by you) and of the time increment, △t. If any solution-dependent state variables are included in the definitions of gcr and gsw, they must also be integrated forward in time in this routine. Abaqus computes the incremental creep strain (or the incremental viscoplastic strain) components as Δεcr=13ΔˉεswR+Δˉεcrn,
where n is the gradient of the deviatoric stress potential, defined as n=∂˜q∂σ,
and R is a matrix with the anisotropic swelling ratios in the diagonal if anisotropic swelling is defined; otherwise, R=I. Drucker-Prager materialsFor materials that yield according to the extended Drucker-Prager plasticity models using Drucker-Prager creep, the routine allows any “creep” laws (viscoplastic behavior) of the following general form to be defined: ˙ˉεcr=gcr(ˉσcr,ˉεcr,time,…),
where
The user subroutine must define the increment of inelastic strain, △ˉεcr, as a function of ˉσcr and any other variables used in the definitions of gcr (such as solution-dependent state variables introduced by you) and of the time increment, △t. If any solution-dependent state variables are included in the definitions of gcr, they must also be integrated forward in time in this routine. Abaqus computes the incremental creep strain (or the incremental viscoplastic strain) components as Δεcr=Δˉεcrfcr(q√(ϵˉσ|0tanψ)2+q2n+13tanψI),
where n=∂˜q/∂σ. The variable fcr is determined in such a way that fcr=1ˉσcrσ:∂Gcr∂σ,
and Gcr=√(ϵˉσ|0tanψ)2+q2-ptanψ
is the hyperbolic creep potential, where ψ(θ,fα) is the dilation angle measured in the p–q plane at high confining pressure, ˉσ|0=ˉσ|ˉεpl=0,˙ˉεpl=0 is the initial yield stress, and ϵ is the eccentricity. See Extended Drucker-Prager models for a discussion of ψ, ϵ, and ˉσ|0. Capped Drucker-Prager materialsFor materials that yield according to the modified Drucker-Prager/Cap plasticity model using cap creep, the routine allows any “cohesion creep” and “consolidation creep” laws (viscoplastic behavior) of the following general form to be defined: ˙ˉεcrs=gcrs(ˉσcr,ˉεcrs,time,…),
˙ˉεcrc=gcrc(ˉpcr,ˉεcrc,time,…),
where
The user subroutine must define the increments of inelastic strain, △ˉεcrs and/or △ˉεcrc, as functions of ˉσcr and/or ˉpcr and any other variables used in the definitions of gcrs and gcrc (such as solution-dependent state variables introduced by you) and of the time increment, △t. If any solution-dependent state variables are included in the definitions of gcrsand gcrc, they must also be integrated forward in time in this routine. Calculation of incremental creep strains for the cohesion mechanismAbaqus computes the incremental creep strain (or the incremental viscoplastic strain) components of the cohesion mechanism as Δεcrs=Δˉεcrsfcr(q√(0.1d(1-13tanβ)tanβ)2+q2n+13tanβI),
where n=∂˜q/∂σ,d is the material cohesion, the variable fcr is determined in such a way that fcr=1ˉσcrσ:∂Gcrs∂σ,
and Gcrs is the cohesion creep potential Gcrs=√(0.1d(1-13tanβ)tanβ)2+q2-ptanβ. Calculation of incremental creep strains for the consolidation mechanismAbaqus computes the incremental creep strain (or the incremental viscoplastic strain) components of the consolidation mechanism as Δεcrc=△ˉεcrcGcrc(R2 q n-13(p-pa) I),
where R controls the shape of the cap, and Gcrc is the consolidation creep potential Gcrc=√(p-pa)2+(Rq)2.
Cohesion material properties are determined with a uniaxial compression test in which dˉεcrs=∥dϵcr11∥, and consolidation material properties are determined with a volumetric compression test in which dˉεcrc=∥dϵcrvol∥. Most likely, gcrs is a positive function of ˉσcr, and gcrc is a positive function of ˉpcr. GasketsFor gaskets whose behavior includes creep, the routine allows any “creep” law of the following general form to be defined: ˙εcr=gcr(σ,εcr,time,…),
where εcr is the compressive creep strain, conjugate to σ, the compressive stress in the gasket. The user subroutine must define the increments of inelastic creep strain, △εcr, as functions of σ and any other variables used in the definitions of gcr (such as solution-dependent state variables introduced by you) and of the time increment, △t. If any solution-dependent state variables are included in the definitions of gcr, they must also be integrated forward in time in this routine. Abaqus will automatically multiply this creep strain by the proper thickness (see Defining the gasket behavior directly using a gasket behavior model) to obtain a creep closure. Integration schemesAbaqus provides both explicit and implicit time integration of creep and swelling behavior defined in this routine. The choice of the time integration scheme depends on the procedure type, the procedure definition, and whether a geometric linear or nonlinear analysis is requested (see Rate-dependent plasticity: creep and swelling). Implicit integration is generally more effective when the response period is long relative to typical relaxation times for the material. Simple high-temperature structural design applications usually do not need implicit integration, but more complicated problems (such as might arise in manufacturing processes), creep buckling applications, or nonstructural problems (such as geotechnical applications) often are integrated more efficiently by the implicit method provided in the program. If implicit integration is used with this subroutine, nonlinear equations must be solved at each time step and the variations of △ˉεcr, △ˉεsw, △ˉεcrs, or △ˉεcrc with respect to ˉεcr, ˉεsw, ˉεcrs, ˉεcrc, p, ˜q, ˉpcr, or ˉσcr must be defined in the subroutine. To obtain good convergence during implicit integration, it is essential to define these quantities accurately. At the start of a new increment the subroutine is called once for each integration point to calculate the estimated creep strain based on the state at the start of the increment. Subsequently, it is called twice for each iteration if explicit integration is used: once to calculate the creep strain increment at the start of the increment and once to calculate it at the end of the increment. This is needed to test the validity of the time increment with respect to the user-specified maximum allowable difference in the creep strain increment. The flag LEND indicates whether the routine is called at the start or the end of the increment. The subroutine must use the corresponding values of time, temperature, field variables, and solution-dependent state variables in the calculation of the creep strain increment. For implicit integration Abaqus uses a local iteration procedure to solve the nonlinear constitutive equations, and the subroutine is called multiple times. The exact number of calls depends on the convergence rate of the local iteration procedure and, hence, will vary from point to point. During these iterations it is possible for the values of the state variables to be far from their final values when the equations are solved. Therefore, the coding in the subroutine must adequately protect against arithmetic failures (such as floating point overflows) even when variables are passed in with physically unreasonable values. As in explicit integration, the variable LEND indicates whether the routine is called at the start or the end of the increment. Constant stress assumption when defining creep and swellingWhen the creep and swelling behavior are defined by simple formulæ, it is often possible to calculate the increments of equivalent creep and swelling strain exactly if it is assumed that the stress is constant during the increment. This approach has the advantage that it provides very good accuracy within the constant stress assumption. It also avoids the problem that arises for some creep behavior definitions: that the creep strain rate becomes infinite at zero time (or strain). Otherwise, in such a case you must protect against causing arithmetic failures at the start of the solution. Defining both plasticity and creepIf both plasticity and creep are defined for a material, Abaqus will calculate the creep strain before entering the plasticity routines. The stresses passed into the creep routine may, therefore, exceed the yield stress. Interpretation of stress and strain variablesIn finite-strain applications strain variables should be interpreted as logarithmic strains and stresses as “true” stress. User subroutine interface SUBROUTINE CREEP(DECRA,DESWA,STATEV,SERD,EC,ESW,P,QTILD,
1 TEMP,DTEMP,PREDEF,DPRED,TIME,DTIME,CMNAME,LEXIMP,LEND,
2 COORDS,NSTATV,NOEL,NPT,LAYER,KSPT,KSTEP,KINC)
C
INCLUDE 'ABA_PARAM.INC'
C
CHARACTER*80 CMNAME
C
DIMENSION DECRA(5),DESWA(5),STATEV(*),PREDEF(*),DPRED(*),
1 TIME(3),EC(2),ESW(2),COORDS(*)
user coding to define DECRA, DESWA
RETURN
END Variables to be defined
Variables that can be updated
Variables passed in for information
Example: Hyperbolic sine creep lawSuppose that we wish to model a metal using the creep behavior ˙ˉεcr=A(sinhqσ0)n,
where A, , and n are constants. User subroutine CREEP can be coded as follows: SUBROUTINE CREEP(DECRA,DESWA,STATEV,SERD,EC,ESW,P,QTILD, 1 TEMP,DTEMP,PREDEF,DPRED,TIME,DTIME,CMNAME,LEXIMP,LEND, 2 COORDS,NSTATV,NOEL,NPT,LAYER,KSPT,KSTEP,KINC) C INCLUDE 'ABA_PARAM.INC' C CHARACTER*80 CMNAME C DIMENSION DECRA(5),DESWA(5),STATEV(*),PREDEF(*),DPRED(*), 1 TIME(3),COORDS(*),EC(2),ESW(2) C C DEFINE CONSTANTS C A= SIG0= AN= C T1=EXP(QTILD/SIG0) T2=EXP(−QTILD/SIG0) DECRA(1) = A*(.5*(T1−T2))**AN*DTIME IF(LEXIMP.EQ.1) THEN DECRA(5) = AN*A*(.5*(T1−T2))**(AN−1.)*DTIME/ 1 SIG0*.5*(T1+T2) END IF C RETURN END The derivative has been defined on the assumption that the subroutine will be used with implicit integration. |