Paper 37

Download as pdf or txt
Download as pdf or txt
You are on page 1of 47

INTERNATIONAL JOURNAL FOR NUMERICAL METHODS IN ENGINEERING

Int. J. Numer. Meth. Engng. 45, 399445 (1999)


AN OBJECT-ORIENTED PROGRAMMING APPROACH
TO THE LAGRANGIAN FEM ANALYSIS
OF LARGE INELASTIC DEFORMATIONS
AND METAL-FORMING PROCESSES
NICHOLAS ZABARAS

AND AKKARAM SRIKANTH


Sibley School of Mechanical and Aerospace Engineering, 188 Frank H. T. Rhodes Hall, Cornell University,
Ithaca, NY 14853-3801, U.S.A.
SUMMARY
The general deformation problem with material and geometric non-linearities is typically divided into a number
of subproblems including the kinematic, the constitutive, and the contact}friction subproblems. These problems
are introduced for algorithmic purposes; however, each of them represents distinct physical aspects of the
deformation process. For each of these subproblems, several well-established mathematical and numerical
models based on the nite element method have been proposed for their solution.
Recent developments in software engineering and in the eld of object-oriented C++ programming have
made it possible to model physical processes and mechanisms more expressively than ever before. In par-
ticular, the various subproblems and computational models in a large inelastic deformation analysis can be
implemented using appropriate hierarchies of classes that accurately represent their underlying physical, math-
ematical and}or geometric structures.
This paper addresses such issues and demonstrates that an approach to deformation processing using classes,
inheritance and virtual functions allows a very fast and robust implementation and testing of various physical
processes and computational algorithms. Here, specic ideas are provided for the development of an object-
oriented C++ programming approach to the FEM analysis of large inelastic deformations. It is shown that
the maintainability, generality, expandability, and code re-usability of such FEM codes are highly improved.
Finally, the eciency and accuracy of an object-oriented programming approach to the analysis of large
inelastic deformations are investigated using a number of benchmark metal-forming examples. Copyright
?1999 John Wiley & Sons, Ltd.
KEY WORDS: object-oriented programming; metal-forming processes; large deformations; Lagrangian analysis; plasticity
1. INTRODUCTION
Analysis of large deformation inelastic problems is extremely important in metal-forming processes
where the deformation results in a high amount of plastic ow. Lagrangian formulations have been
used extensively for the solution of such non-linear deformation problems. The major limitation
of Lagrangian large deformation formulations with a xed mesh is that the nite elements may

Correspondence to: Nicholas Zabaras, Sibley School of Mechanical and Aerospace Engineering, 188 Frank H. T. Rhodes
Hall, Cornell University, Ithaca, NY 14853-3801, U.S.A. E-mail: njz1@cornell.edu
Contract}grant sponsor: NSF; Contract}grant number: DMII-9522613
CCC 00295981/99/16039947$17.50 Received 4 November 1997
Copyright
?
1999 John Wiley & Sons, Ltd. Revised 4 August 1998
400 N. ZABARAS AND A. SRIKANTH
become severely distorted. However, Lagrangian formulations provide no diculties in dealing
with the calculation of residual stresses, with modelling of contact between deformable bodies or
with the advection of material state histories. An extensive review of Lagrangian algorithms can
be found in References 111.
This research eld has reached a rather mature level and a number of computational algorithms
has already been developed for the Lagrangian analysis of large deformation problems, namely
the constitutive, kinematic and contact subproblems. Full NewtonRapshon linearizations of the
principle of virtual work have been developed and implemented in a number of research and
commercial codes. The various implementations lead to dierent tangent stiness matrices based
on the selected stress and strain measures and the resulting linearizations corresponding to the
various constitutive models [2, 3, 5, 9, 11]. In an appropriate kinematic framework for inelastic
analysis, the deformation gradient is decomposed by means of Lees multiplicative decomposition
into plastic and elastic parts [12, 13].
Several inelastic constitutive models have been proposed including those in References 1416.
These models share a common state variable based structure and are integrated with a num-
ber of objective integration algorithms like radial return mappings or other projection methods
[3, 4, 13, 1721]. As part of the solution methodology of the incremental constitutive problem,
the consistent linearized material moduli are also computed.
Finally, a number of algorithms exist for the analysis of multidimensional contact problems. Most
of these algorithms are explicit in nature, but implicit contact algorithms have been considered
as well. In particular, the augmented Lagrangian analysis of Simo and Laursen is considered
appropriate for a fully implicit Lagrangian analysis of large deformation problems [2226]. Radial
return like mappings have been proposed for the integration of these contact models and the
contact contributions to the tangent stiness have been calculated as required in the Newton
Raphson iterations for the calculation of the non-linear kinematics.
In this work, the analysis of large hyperelasticviscoplastic deformations is considered and an
object-oriented framework is introduced for their implementation. The fundamentals of object-
oriented C++ programming for scientic computations are reviewed in Reference 27. Object-
oriented calculations have received extensive attention in computational mathematics and in partic-
ular in uid dynamics [2834]. A number of engineering applications have already been published
in this and other computational Journals [3537].
The main objective of this paper is to provide a number of specic ideas for the development of
hierarchies of classes that are appropriate for the analysis of large deformation plasticity problems
including forming processes. Such problems are amenable to an object-oriented environment in a
non-trivial manner since the underlying material, kinematic and contact mechanisms are coupled
in a highly implicit manner. To allow ourselves to concentrate on the development of deformation
processing related classes, the present computations have been adapted to the widely used dipack
library of C++ classes [38]. However, most of the discussion here is general and can be im-
plemented using other object-oriented libraries. The dipack libraries include a variety of classes
for linear algebra operations, a number of FEM-based classes for element denition, stiness de-
velopment, assembly and many other [3941]. In addition, dipack provides a secure way for
pointer declarations as well as a framework for the development of elds to represent the various
continuous variables [39]. Familiarity with the structure of the dipack libraries is useful but not
essential in understanding the present developments.
To the best of our knowledge this is the rst time that a fully object-oriented Lagrangian
non-linear deformation analysis has been implemented. Although examples presented here are for
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 401
particular numerical algorithms and material constitutive laws, the development of classes has
been performed keeping in mind the general structure of the deformation problem. The objective
is to develop a framework that allows code expandability (inclusion of other constitutive models,
algorithms, etc.) without a signicant programming eort. In addition, implementation of various
applications (e.g. of an extrusion or a forging process) is performed at an object level that does
not require the user to have a knowledge of the details of the various algorithms. The examples
presented here are also obtained with a combination of the stiness tangent and contact tangent
operators that has not been reported earlier in the literature. These calculations include the imple-
mentation of the strain projection method presented in Reference 5 to avoid element locking in
the fully plastic region.
The structure of this paper is as follows. At rst, a review of the denition of an inelastic
large deformation problem is presented. The particular constitutive structure proposed by Anand
and colleagues is adopted as a reference framework for the following presentation and numer-
ical examples [2, 3]. However, the general structure of the various parts of the large inelastic
deformation analysis is also identied in order to motivate the denition of the various class
hierarchies. Then, the basic elements of a Lagrangian FEM analysis are reviewed, namely the
analysis of the kinematic, constitutive and contact subproblems. Following the problem deni-
tion, the general structure of the Simulator class is introduced. The various class hierarchies
for the analysis of the constitutive, kinematic and contact subproblems are presented. The pa-
per concludes with the analysis of a number of benchmark test forming problems and a pre-
liminary discussion on the accuracy and cpu time requirements of the proposed object-oriented
simulations.
2. REVIEW OF THE BASIC ELEMENTS OF A NON-LINEAR
DEFORMATION ANALYSIS
2.1. Kinematic and constitutive equations
Let us consider the motion of a body occupying the conguration B
0
at time t =0 under the
action of external forces. The motion of the body is represented by a smooth mapping [(, ) such
that, at any given time t, the location x of a material point p, which at time t =0 occupied the
position X, is given by
x =[(X, t) (1)
The deformation gradient F with respect to the reference conguration B
0
is given by
F=[(X, t) =
c[(X, t)
cX
(2)
It is required that det F0 for the motion of the body to be meaningful. The total deformation
gradients at times t
n
and t
n+1
are F
n
and F
n+1
, respectively, as shown in Figure 1. In a Lagrangian
analysis, the motion of each particle is followed as the particle occupies dierent congurations in
the space at dierent times, and the deformation gradients are computed with respect to a reference
conguration B
0
. In the case of the updated Lagrangian analysis, the reference conguration is
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
402 N. ZABARAS AND A. SRIKANTH
Figure 1. Motion of the deforming body
updated at each time step. Thus, the reference conguration at time t
n+1
, will be B
n
, whereas the
current conguration becomes B
n+1
. The relative deformation gradient F
r
is dened as
F
r
=F
n+1
(F
n
)
1
(3)
In this work, the processes are quasi-static and the body is under equilibrium at all times. Let T
be the Cauchy stress and b, the body force eld dened on the current conguration B
n+1
. Then,
at a time t
n+1
, the equilibrium equations can be written as

n+1
T + b =0 x B
n+1
(4)
The subscript (n + 1) indicates that the divergence of T is dened in the current conguration
B
n+1
. The equilibrium equations can also be expressed in the reference conguration B
n
as

n
P
r
+ f
r
=0 x B
n
(5)
where the PiolaKirchho I stress P
r
and body force f
r
are obtained as,
P
r
= det F
r
TF
T
r
f
r
= det F
r
b
(6)
In order to solve the equilibrium equations, certain boundary conditions have to be specied
at all times on the boundaries of B. In addition, the constitutive relationship between the Cauchy
stress T and the deformation gradient F should be specied.
The total deformation gradient F at any time t is assumed to be decomposed as
F=F
e

F
p
(7)
where F
e
is the elastic deformation gradient and

F
p
is the plastic deformation gradient (Figure 2).
It is further assumed that the plastic deformation is isochoric, and hence,
det

F
p
=1
det F
e
0
(8)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 403
Figure 2. Multiplicative decomposition of the deformation gradient
Following Anand [15], the hyperelastic constitutive equations are written as

T=L
e
[

E
e
] (9)
where the strain measure,

E
e
, is dened with respect to the intermediate (unstressed) conguration
as

E
e
= ln U
e
(10)
The corresponding conjugate stress measure

T is the pullback of the Kirchho stress with respect
to R
e
,

T= det(U
e
)R
eT
TR
e
(11)
Here U
e
and R
e
are calculated from the polar decomposition of F
e
,
F
e
=R
e
U
e
(12)
For an isotropic material, the elastic moduli L
e
are given by
L
e
=2jI+ (
2
3
j)I I (13)
where j is the shear modulus, is the bulk modulus and I and I denote the unit second- and
fourth-order tensors, respectively.
Remark 1. Other hyperelastic models can also be considered (e.g. see Reference 5). The main
dierences between the various elasticity models are essentially in the selection of work-conjugate
stress and elastic strain measures.
The most commonly used phenomenological model for elasticplastic deformations is the clas-
sical J
2
ow theory with isotropic hardening. The ow rule for the evolution of

F
p
is here given
as follows [3]:

L
p
=

F
p
(

F
p
)
1
=
_
3
2

c
p

N
p
(

, o) (14)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
404 N. ZABARAS AND A. SRIKANTH
where

N
p
(

, o) =
_
3
2

o
(15)

=

T
tr

T
3
I (16)
and
o =
_
3
2

T

(17)
An assumption is made that an intermediate conguration can be chosen in case of isotropic
materials such that the skew symmetric part of the velocity gradient (spin) vanishes identically.
This results in

D
p
=

L
p

W
p
= 0
(18)
The evolution of the equivalent plastic strain c
p
is specied via uniaxial experiments as

c
p
=[( o, s) (19)
and the evolution of the isotropic isothermal scalar resistance s is also obtained from experiments
in the form,
s =q( o, s) =h( o, s)

c
p
r(s) (20)
where r(s) is the static recovery function.
Remark 2. Alternative forms of the ow rule can also be considered (e.g. see References 5
and 8). However, most isotropic J
2
ow rules t in a functional structure similar to that of the
model above.
Remark 3. Rate-independent elasto-plasticity models can be described as well. The main dif-
ference is in the calculation of the equivalent plastic strain rate

c
p
, which for rate-independent
models is dened implicitly using the consistency condition (i.e. from

o = s) [1, 2, 13].
2.2. The initial and the boundary value problem
The kinematic and the constitutive equations, together with the equilibrium equations and the
initial and the boundary conditions, completely describe the motion of the body. In this section, a
brief presentation is given of a numerical solution procedure to solve this boundary value problem.
The problem is divided into three subproblems: (1) the constitutive problem, (2) the contact}friction
problem and (3) the kinematic problem. In the constitutive incremental problem, one determines
the triad (T, s,

F
p
) at the end of the time step (time t
n+1
) given the body congurations B
n
and B
n+1
as well as the triad (T, s,

F
p
) at time t
n
. In the contact}friction subproblem, given the conguration
B
n+1
, the die location and shape at time t
n+1
, as well as estimates of the contact tractions (e.g.
from the previous time step or a previous NewtonRaphson iteration), one updates the regions of
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 405
contact as well as the applied contact tractions at t
n+1
. The contact subproblem is directly coupled
with the kinematic incremental problem where given the triad (T
n+1
, s
n+1
,

F
p
n+1
), the conguration
B
n
and the applied boundary conditions at t
n+1
(including the contact tractions), one calculates
(updates) the conguration B
n+1
.
2.2.1. Time integration of the constitutive model. In the following, a review is given of a
radial return algorithm that calculates (T
n+1
, s
n+1
,

F
p
n+1
), given the body congurations at time t
n
and t
n+1
, and knowing (T
n
, s
n
,

F
p
n
). The detailed algorithm is provided in References 3 and 9.
Employing the Euler backward integration to solve the dierential equations (14) and (20), leads
to the following:

F
p
n+1
= exp(t

D
p
n+1
(

n+1
, s
n+1
))

F
p
n
(21)
and
s
n+1
s
n
tq( o
n+1
, s
n+1
) =0 (22)
To solve these equations, a trial elastic deformation gradient F
e

is introduced as follows:
F
e

=F
r
F
e
n
=R
e

U
e

(23)
where F
r
is dened in equation (3). The trial stress is dened as follows:

=L
e
[

E
e

] =L
e
[ln U
e

] (24)
The equivalent stress o

is dened from the deviatoric part of the trial stress as,


o

=
_
3
2

T

(25)
and the pressure

as

=
1
3
tr(

) (26)
It can easily be shown that the tensors

T

and

T

n+1
are in the same direction, i.e [3].

N
p
n+1
=
_
3
2

(27)
So, only the scalar quantities o
n+1
,
n+1
and s
n+1
need to be evaluated. One can show the following
[3, 9]:

n+1
=

(28)
and
o
n+1
o

+ 3jt[( o
n+1
, s
n+1
) =0 (29)
Solving the non-linear, scalar, algebraic equations (29) and (22) together, one can obtain the values
of o
n+1
and s
n+1
(see the Appendix of Reference 2). From the values of o
n+1
,
n+1
and s
n+1
, one
can calculate T
n+1
and F
e
n+1
as follows [3]:
T
n+1
= exp
_

_
R
e


T
n+1
R
e

T
(30)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
406 N. ZABARAS AND A. SRIKANTH
Figure 3. Representation of the die surface and denition of the gap function
and
F
e
n+1
=R
e

_
z
i

_
p
n+1
_
z
1

z
2

z
3

_
(p
n+1
1)}3
e
i

e
i

_
(31)
where the radial return factor p
n+1
= o
n+1
} o

, and

T
n+1
=p
n+1

T

I (32)
Here, z
i

and e
i

denote the eigenvalues and eigenvectors, respectively of U


e

.
Remark 4. Note that the developments above are quite general. For isotropic plasticity, in par-
ticular, the radial return mapping always leads to two non-linear algebraic equations similar to
equations (22) and (29).
2.2.2. Boundary conditions. In the following, only the contact}frictional boundary conditions
are considered as other types of boundary conditions are explicit in nature and can be applied
directly for the solution of the non-linear kinematics.
Contact and friction is modelled here following the scheme developed by Simo and Laursen
[2225]. The presentation here is limited to plane-strain and axisymmetric problems and dies are
considered to be rigid. The die D is parametrized in two dimensions using a parameter and the
functions y() =(,
1
(), ,
2
()), 0661. A xed right-handed basis (e
1
, e
2
, e
3
) is dened, with e
2
going into the plane of the paper (as shown in Figure 3) and a convected basis (r, e
2
, ]) at each
point dened by a particular value of . The tangent vector B
1
and the unit tangent vector r are
given by
B
1
=y
,
=
c,
1
c
e
1
+
c,
2
c
e
3
, r =
B
1
B
1

(33)
The unit normal vector ] points towards the body (i.e. ] = n, where n is the outward unit
normal vector to the body) and is obtained as
] =r e
2
(34)
where denotes vector cross product. Any vector a in the direction of B
1
is represented as
a =a
1
B
1
=ar, a
1
B
1
=a (35)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 407
The die separates the space into admissible and inadmissible regions and the die is parametrized
such that the normal vector ] is pointing into the admissible region. Then, one can dene the gap
function q of any point x in space as the shortest distance of that point from the die (see Figure 3).
Thus, one can write
y x =q(x)]( y) (36)
where y D is the value of y that minimizes the norm, x y. A unique value of the parameter

is associated to each y. With this denition of the gap function, the impenetrability constraints
are as below: For all x
n
B
n
, with x
n+1
=x
n
+ u(x
n
),
q(x
n+1
) 60
t
N
= ](P
r
m)
t
N
q(x
n+1
) = 0
(37)
where t
N
is the absolute value of the contact pressure. The vector P
r
m is the current traction per
unit area in cB
n
.
It is assumed that Coulomb friction exists in the contact region with a coecient of friction j
f
.
The tangential velocity of the workpiece relative to the die is written (using equation (33)) as
v
1
=
d
dt
[ y] =y
,
(

B
1
(38)
This relative velocity v
1
makes sense only for points in contact with the die and moving along
the die. The Coulomb friction law can be written as:
t
1
= P
r
m + t
N
]
:=t
1
j
f
t
N
6 0
v
1
=
t
1
t
1

0
= 0
(39)
Following Reference 22, the penalty parameters c
N
and c
1
are introduced as well as the Lagrangian
multipliers z
N
and [
1
. The normal traction is then expressed as follows:
t
N
= z
N
+ c
N
q (40)
where is the Macauley bracket (i.e. x =1}2[x +| x|]). The frictional constraint is then written
as follows:
v
1

t
1
t
1

=
1
c
1
_

t
1

[
1
_
(41)
where, for any vector a in the direction B,

a is expressed as

a = a
1
B
1
, a
1
=
d
dt
a
1
Substituting the expression for v
1
from equation (38), equation (41) reduces to the following
scalar equation:
t
1
1
z
1
1
=c
1
_


t
1
1
t
1

_
(42)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
408 N. ZABARAS AND A. SRIKANTH
The above frictional constraint equation can be integrated over the time interval [t
n
, t
n+1
] using the
Euler backward integration scheme to obtain
t
1
1
n+1
t
1
1
n
=z
1
1
n+1
z
1
1
n
+ c
1
_

n+1

n
(
n+1

n
)
t
1
1
n+1
t
1
n+1

_
(43)
Further, the following constraint equation must be satised:

n+1
:=t
1
n+1
j
f
t
N
n+1
60 (44)
A trial value for t
1
1
n+1
is rst introduced:
t
1(trial)
1
n+1
:=t
1
1
n
+ z
1
1
n+1
z
1
1
n
+ c
1
(

n+1

n
) (45)
Then,

(trial)
n+1
:=t
(trial)
1
n+1
j
f
t
N
n+1
(46)
If
(trial)
n+1
0, equation (39) would imply that the parameter =0, and therefore, the relative
velocity of the point with respect to the die is zero. In other words, the point under consid-
eration is sticking to the die. In this case, t
1
1
n+1
=t
1(trial)
1
n+1
. If, on the other hand,
(trial)
n+1
0, the
trial value violates the constraint equation (44). Therefore, the trial value must be modied so that
the constraint equation is satised as an equality. This condition is called sliding. Thus, t
1
1
n+1
is
calculated as follows:
t
1
1
n+1
= t
1(trial)
1
n+1
if
(trial)
n+1
60
= j
f
t
N
n+1
t
1(trial)
1
n+1
t
1
(trial)
n+1

otherwise
(47)
The contribution of the contact conditions to the tangent stiness are briey undertaken in the
following section.
2.2.3. Principle of virtual work equation. Let us suppose that the conguration B
n
at time t =t
n
is known and is under equilibrium. Under the action of the external forces, the body deforms and
occupies the conguration B
n+1
at time t =t
n+1
. Equation (5) describes the equilibrium of the body
at time t
n+1
expressed in the updated reference conguration B
n
. Let be the surface (cB
n
)
which corresponds to regions of the body that may potentially come into contact with the die.
The incremental quasi-static boundary value problem at time t =t
n+1
is to nd the incremental
(with respect to the conguration B
n
) displacement eld u(x
n
, t
n+1
) u
n+1
that will satisfy equation
(5). The weak form of this equation is written as

G(u
n+1
, W) G(u
n+1
, W) + G
c
(u
n+1
, W) =0 (48)
for each test vector eld W(x
n
), which is compatible with the kinematic boundary conditions, where
G(u
n+1
, W) =
_
B
n
P
r

cW
cx
n
dJ
__
@B
n+1

tW dA +
_
B
n+1

bW dJ
_
(49)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 409
and
G
c
(u
n+1
, W) =
_

(t
N
]W + t
1
W) dA (50)
Equation (48) is a mixed form of the principle of virtual work. The internal work is expressed in
the reference conguration B
n
, whereas the external work is expressed in the current conguration
where the applied surface tractions,

t, and body forces,

b, are given. The contact work is calculated
in the reference conguration B
n
.
To solve the non-linear equation (48) for u(x
n
, t
n+1
), a NewtonRaphson iterative scheme is
employed. Let u
(k+1)
n+1
and u
(k)
n+1
be the displacement elds at the end of the (k +1)th step and the
kth step, respectively, during the NewtonRaphson iterative process. Then, the linearized form of
equation (48) is as follows:

G(u
(k)
n+1
, W) +
c

G
cu
(k)
n+1
(u
(k+1)
n+1
u
(k)
n+1
) =0 (51)

G consists of two terms, G and G


c
. In the following sections, the linearization of both terms is
provided. The term G contains the internal work and the external work done by the body forces
and surface forces not including the contact work at the die}workpiece interface:
dG =
_
B
n
dP
r

cW
cxn
dJ + d (bodyforces +applied traction) (52)
The linearizations for the follower forces and body forces have been dealt with by Hibbit [42],
and here only the linearizations of the internal work term are presented. The dierential dP
r
is
calculated as follows:
dP
r
=d(det F
r
T
n+1
F
T
r
)
Complete linearization of this term leads to the following [3]:
dP
r
= det F
r
_
tr(dF
r
F
1
r
)T
n+1
T
n+1
(dF
r
F
1
r
)
T
tr
_
1
3
C[d

E
e

]
_
T
n+1
+ exp
_

_
R
e

C[d

E
e

] (R
e

)
T
+(dR
e

(R
e

)
T
)T
n+1
T
n+1
(dR
e

(R
e

)
T
)
T
_
F
T
r
(53)
C are the consistent linearized material moduli (C=c

E
e

T) given in Reference 3 in the following


form:
C=2j

I+ (
2
3
j

)I I + 2j(c p
n+1
)

N
p
n+1


N
p
n+1
(54)
with

N
p
n+1
given from equation (27),
j

=p
n+1
j, p
n+1
=
o
n+1
o

and
c =
b
2
a
1
b
2
+ a
2
b
1
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
410 N. ZABARAS AND A. SRIKANTH
a
1
1 + 3jt
c[
c o
n+1
, a
2
3jt
c[
cs
n+1
b
1
t
cq
c o
n+1
, b
2
1 t
cq
cs
n+1
The linearization of the contact work is presented in Reference 22 and is summarized here for
completeness. The term G
c
results in
dG
c
=
_

(d(t
N
])W + dt
1
W) dA
With dierentiation of equations (40) and (47), one can show that
_

d(t
N
])W dA=
_

_
H(t
N
)c
N
(]du)(]W) +
t
N
j
1 + qj
(rdu)(rW)
_
dA (55)
and
_

dt
1
W dA=
_

t
1
1
(1 + qj)
(B
1
W) dA
+
_

t
1
1
B
1

2
(1 + qj)
2
((y
,
W)(duB
1
) + (duy
,
)(B
1
W)) dA

t
1
1
B
1

4
(1 + qj)
3
((1 2qj)(B
1
y
,
) + q(]y
,
))(B
1
W)(duB
1
) dA (56)
If the boundary is sticking (i.e. if 60), then
t
1
1
=
c
1
(1 + qj)B
1

(r du) (57)
If sliding, then
t
1
1
=
j
f
c
N
sign(t
1
1
)(]du)
B
1


j
f
t
N
sign(t
1
1
)(y
,
B
1
)
B
1

5
(1 + qj)
(B
1
du) (58)
where, in the above, H() is the heavyside function, equal to 1 when the argument is positive,
and 0 otherwise. Also, the curvature j is given by
j =
]y
,
B
1

2
(59)
A summary of the contact}friction algorithm is provided in Section 2.5.
2.3. Convergence criteria and automatic time stepping
Two dierent criteria are currently employed to monitor the convergence of the NewtonRaphson
iterations for the calculation of the incremental displacements. During each time increment, the
incremental plastic work,
W
p
=
_
t
n+1
t
n
_
B
n
o

c
p
dJ dt
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 411
is calculated. The NewtonRaphson iterations are assumed to have converged when the incremen-
tal plastic work in two successive iterations falls within a suitable tolerance (e.g. 0001 per cent).
Convergence is also monitored using the incremental displacement. Let d
i
be the computed incre-
mental displacements. Then, the displacement error R
d
is dened using the L

norm. A typical
displacement-based convergence criterion is R
d
10
5
.
An automatic time-stepping algorithm as discussed in Reference 2 is employed here so that the
incremental plastic strain in every time increment is kept close to a prescribed xed value. Let

c
p
s
be the prescribed value and

c
p
max
the maximum attained eective plastic strain increment
over the previous time step. Then the factor R is dened as follows:
R

c
p
max

c
p
s
If R125, then the solution is rejected, a new time increment which is smaller by a factor of
(085}R) is taken and the whole step is repeated. If R6125, then the solution is accepted and
the time increment for the subsequent step is determined so that the ratio R is made close to 10.
The following algorithm is used.
If 08R6125 then t
n+1
=t
n
}R
If 05R6080 then t
n+1
=125t
n
If R6050 then t
n+1
=150t
n
A value of 005, is recommended in Reference 2 for

c
p
max
, where the constitutive model of
Reference 16 was used. However, dierent values may be more appropriate for other constitutive
models.
2.4. The assumed strain method
In nearly incompressible conditions, the mesh is expected to lock [17]. To avoid locking, F
r
is dened such that a predetermined number of volumetric degrees of freedom is obtained. For
clarity of the presentation, F
r
is here denoted as simply F and its components as F
iI
. The following
decomposition of the kinematics is considered [5]:
F=F
vol
F
dev
=F
dev
F
vol
(60)
The kinematics x
hi
=[
hi
(X, t) are usually approximated as follows:
[
hi
=

a
[
ia
N
e
a
, F
h
=
n
[
h
, J
h
=det(F
h
) (61)
In the strain projection method, another measure of the discretized deformation eld is used to
model J
h
or F
vol
J
1}3
h
I. This leads to the following decomposition:

F
h
=

J
+1}3
h
F
dev
h
(62)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
412 N. ZABARAS AND A. SRIKANTH
where

J
h
is dened using the so-called bar shape functions [43]. Interpolation with the bar shape
functions is dened as follows:

J
h
(x) =

e
NINT

a
J
ha
(

a
)

N
e
a
(x) (63)
where NINT is the number of reduced integration Gauss points denoted here as

a
. The bar shape
functions are such that

N
e
a
(

b
) =o
ab
, i.e. J
ha
(

a
) is calculated at the reduced integration rule Gauss
points [43]. In this section, all bar quantities indicate calculations using interpolation with the bar
shape functions in the sense of equation (63).
In practice, an average deformation gradient is used (a-priori stabilization, see Reference 5) in
order to eliminate possible pressure modes (c between 0 and 1), i.e.
F
ave
=cF + (1 c)

J
1}3
F
dev
cF + (1 c)

F (64)
The internal work term G in the principle of virtual work (equation (49)) is now modied as
follows:
DG
ave
h
(u
h
, p
h
), p
h
=
_
B
n
P
iI
(F
ave
)D(cF
iI
+ (1 c)

F
iI
), p
h
dJ (65)
After performing the indicated linearizations, the above equation is modied as follows:
DG
ave
h
(u
h, n+1
, p
h
), p
h
=
_
B
n
P
iI
(F
ave
)(cp
hi, I
+ (1 c)(

p
h
)
ik

F
kI
) dJ (66)
where (

p
h
)
i)
is dened as follows:
(

p
h
)
i)
=p
dev
hi, )
+
1
3
div p
h
o
i)
(67)
The NewtonRapshon equations requires taking a second derivative with respect to the unknown
displacements, i.e.
D
2
G
ave
h
, p
h
, u
h
DDG
ave
h
, p
h
, u
h

from which the following equation is derived [5]:

e
_

e
o
_
cP
iI
(F
ave
)
cF
ave
)J
(cu
h), J
+ (1 c)(

u
h
)
im

F
mJ
)(cp
hi, I
+ (1 c)(

p
h
)
ik

F
kI
)
+P
iI
(F
ave
)D(cp
hi, I
+ (1 c)(

p
h
)
ik

F
kI
), u
h

_
dJ
where the rst term arises from linearizing the constitutive relations, whereas the second term is
geometrical in nature. Let =t
ii
}3, where t is the Kirchho stress. After a number of lengthy
but straightforward calculations, the linearized principle of virtual work takes the following nal
form:

e
_

e
o
D
iI)J
(cu
h), J
+ (1 c)(

u
h
)
im

F
mJ
)(cp
hi, I
+ (1 c)(

p
h
)
ik

F
kI
) dJ
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 413
+

e
_

e
o
(t
ik
cP
iI
F
kI
)
1
3
[(div u
h
div u
h
)p
hi, k
+ (div p
h
div p
h
)u
hi, k
] dJ
+

e
_

e
o
1
3
_

1
3
cF
iI
P
iI
_
(div u
h
div u
h
)(div p
h
div p
h
) dJ
+

e
_

e
o
_

1
3
cF
iI
P
iI
_
[p
k, m
u
hm, k
p
k, m
u
m, k
] dJ (68)
Using the nite element discretization p
hi
=

e

a
p
ia
N
e
a
and the bar interpolation, one can write
in terms of the vector of nodal displacements {u
e
h
} the following:
div u
e
h
=3{B
vol
}
T
{u
e
h
}, divu
e
h
=3{

B
vol
}
T
{u
e
h
} (69)
where {B
vol
} and {

B
vol
} are well dened column vectors for each element. The vector form of
the tensors u
e
h
,
n
u
e
h
(reference gradient) and

u
e
h
can now be written as follows:
u
e
h
=[B]{u
e
h
},
n
u
e
h
=[B
o
]{u
e
h
},

u
e
h
=[

B]{u
e
h
} (70)
where
[

B(x)] =[B(x)] [B
vol
(x)] + [

B
vol
(x)] (71)
where, for example, in three dimensions the 9 9 matrix [

B
vol
(x)] has its rst, fth and ninth rows
equal to the vector {

B
vol
}
T
and all other elements equal to zero. Using the above discretizations,
the matrix form of equation (68) is

e
K
e
iakb
u
e
hkb
, where i and k span over the spatial dimensions,
while a and b span over the element nodes and
K
e
iakb
=
_
_

e
o
(c[B
o
] + (1 c)[

F
right
] [

B])
T
[D] (c[B
o
] + (1 c)[

F
right
] [

B]) dJ
_
iakb
+
_
_

e
o
_
([B]
T
{[t] c[P] [F]
T
}) ({

B
vol
} {B
vol
})
T
+({

B
vol
} {B
vol
}) ([B]
T
{[t] c[P] [F]
T
})
T
+(3 c tr([P] [F]
T
))({

B
vol
} {B
vol
}) ({

B
vol
} {B
vol
})
T
_
dJ
_
iakb
+
_

e
o
_

c
3
tr([P] [F]
T
)
_
[[B

]
T
[B

] [

B

]
T
[

B

]] dJ (72)
The transformation resulting in the matrix [

F
right
] is dened in the Appendix of Reference 44.
Also, the matrices [

B

] and [B

] are derived from the matrices [



B] and [B], respectively, with
appropriate row exchanges as required by the last term of equation (68). Also note that in the
equation above, the stress t, pressure , PiolaKirchho stress P as well as the linearized moduli
D
iI)J
are calculated using F
ave
. The moduli D
iI)J
are the same as those obtained by the linearization
process of Section 2.2.3 using F. Typical values of c are 10
4
to 10
2
.
Remark 5. The performance of the strain projection method is not the same for all types of
nite elements. The issues of pressure modes and stabilization in Lagrangian analysis are not yet
fully resolved and signicant research is further needed in this area [45].
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
414 N. ZABARAS AND A. SRIKANTH
2.5. Summary of the FEM algorithm
A presentation is given here of the algorithm used to solve the principle of virtual work equa-
tions at time t
n+1
incorporating contact and frictional terms. The algorithm follows that given in
Reference 23.
1. Initialization:
Set z
(0)
N
=z
N
+ c
N
q from the last time step
z
1
1
(0)
= 0
k = 0
2. Using a NewtonRaphson iteration, solve for u
(k)
the following non-linear kinematic equations:

G(u
(k)
, W) =0 (73)
where t
N
and t
1
are evaluated from equations (40) and (47), respectively.
3. Check for constraint satisfaction. If all the boundary points do remain in the admissible region
and the boundary tractions obey the Coulomb friction law, then the iterations have converged,
i.e. IF q(u
(k)
)6TOLg AND t
1
6(1 + TOLf )j
[
z
(k)
N
+ c
N
q for all x THEN converge.
EXIT (Here TOLg and TOLf are used to denote the selected tolerances for the gap and the
frictional law).
If any of the constraints are violated, augment the Lagrangian parameters, and solve the PVW
equation once again, i.e.
ELSE augment:
z
(k+1)
N
=z
(k)
N
+ c
N
q
t
1(trial)
1
=t
1
1
n
+ z
1
1
(k)
+ c
1

(trial)
=t
(trial)
1
j
[
z
(k+1)
N
IF
(trial)
60, (sticking friction) THEN
z
1
1
(k+1)
=z
1
1
(k)
+ c
1

ELSE (sliding friction)


z
1
1
(k+1)
=
t
1(trial)
1
t
(trial)
1

j
f
z
(k+1)
N
t
1
1
n
ENDIF
k =k + 1
GOTO 2
ENDIF
Note that at the rst iteration at each time step, the (n +1)th conguration is initialized to that of
the nth conguration. The normal and tangential tractions are also updated appropriately to account
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 415
for this change in the reference conguration. Also, after each successful calculation of the incre-
mental displacements, the triad (T
n+1
, s
n+1
,

F

n+1
) is also calculated as required for the calculations
at the next time step.
Finally, it is noted that a symmetrized nested augmented Lagrangian algorithm has also been
proposed in Reference 23. Its main dierence from the above algorithm is that the return mapping
(equation (47)) is eliminated from the solution phase in the principle of virtual work (equation
(73)).
Remark 6. To accelerate the performance of the NewtonRaphson iterations, the tangent ma-
terial moduli C at the rst iteration of each time step are calculated using as

N
p
, p and c in
equation (54), the values calculated at the end of the previous time step. This approach was found
to provide a better performance than the one that calculates C using the solution of the constitu-
tive problem for the trial deformation gradient F
e

=F
e
n
(i.e. with F
r
=I, see equation (23)). Also,
some convergence problems of the Newton iterations may appear when a Gauss point comes in
contact with the die. These problems have been attributed to the soft behaviour of the material
moduli when abrupt changes occur in the direction of plastic ow. When it is needed, an articial
stiening of the material moduli in the direction

N
p
n+1
was introduced by neglecting the last term
in equation (54). Similar ideas are discussed in Reference 2.
3. THE GENERAL PICTURE OF A LAGRANGIAN CODE
An object-oriented framework for an updated Lagrangian analysis of large hyper-elastic viscoplastic
deformations is presented here. Following the brief introduction of the various subproblems given
in the earlier sections, we highlight the development of various classes and class hierarchies
associated with the subproblems. Although not all classes or all details of each class can be
presented in this paper, an attempt is made to provide sucient ideas that make the general
picture of a Lagrangian code clear. Various classes presented in dipack are utilized here for
basic linear algebra calculations as well as nite element pre- and post-processing. In addition, the
stiness}load calculations in the NewtonRapshon iterations as well as the application of essential
type of boundary conditions is performed using appropriate dipack classes. The interested reader
may consult References 3941. In this section, emphasis is given to the newly developed classes
for modeling non-linear kinematics, tangent stiness calculations, non-linear material models and
contact algorithms. The developed code is dimension independent and the selection of numerical
techniques and algorithms, material models, die surfaces, etc., is performed at run time. Even
though the developed Lagrangian simulator is general, numerical results are shown later only for
particular selections of the numerical algorithms, constitutive models, etc.
3.1. Review of dipack
A brief review is given here of a few of the key dipack classes that are used in the object
oriented large inelastic analysis simulator.
Pointers are treated in dipack using the class HandleID. The most important functionality
of this class is that it allows the automatic deletion of an object only when all pointers that are
binded to this object have been deleted. This is important for memory management when more
than one pointer is binded to a given object.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
416 N. ZABARAS AND A. SRIKANTH
The class FiniteElement provides the necessary functionality for nite element calculations
like, for example, evaluation of shape functions and their derivatives at Gauss points. The func-
tionality that allows the stiness and load calculations and the assembly of the linear system is
performed using the class FEM. The various problem-dependent calculations are performed with
the implementation in the users simulator of various virtual functions. For example, the main sti-
ness and load calculations at a particular Gauss point are performed using the pure virtual function
FEM:integrands(). The class ElmItgRules has also been implemented to allow the user to select
full, uniformly reduced integration, or selected reduced integration rules.
Continuous elds are treated in dipack using the class FieldFE. An object of this class is
binded with a particular nite element grid (object of class GridFE). The functionality of the
class FieldFE allows the calculation of the nodal values of the eld, the calculation of the eld
at any point within the domain, re-binding of the eld with another grid, etc.
The classes LinEqAdm and NonLinEqSolver provide the necessary structure for handling
various linear and non-linear algebraic equation solvers. The user via a menu is allowed to select
from a list of available methods or implement his own solvers. The basic time management is
performed using the class TimePrm.
Details on the above and many other dipack classes can be found in References 3941. It is
important to note that for the implementation of the present large deformation simulator, a number
of standard dipack classes had to be modied. Such modications were performed with the
development of derived classes that provided the additional functionality. Most of these details are
particular to the dipack structure and they will not be further discussed. In the following sections,
a presentation is given of the classes that are directly related to the large inelastic analysis. The
following developments are general and can be easily implemented using other object-oriented
libraries.
3.2. The matrix hierarchies
In this work, the deformation gradient F at a Gauss point is represented as a 3 3 F matrix in
three dimensions and as a 33 F matrix with F
13
=F
31
=F
23
=F
32
=0 in two dimensional and ax-
isymmetric problems. Such particular matrices are represented as objects of a new class MatDef
that is derived from the class Mat(real) which is a dipack class for numerical matrix compu-
tations [40]. The hierarchies of the matrix class MatDef are shown in Figure 4. In this and the
following graphs, the solid arrow lines indicate an is-a relation, whereas the dashed arrow lines
represent a has-a relation.
In addition to the functionality of the class Mat(real), the matrix class MatDef is also
equipped with matrix operations that are commonly encountered in the nite element implemen-
tation of deformation problems. In particular, when the principle of virtual work equation is lin-
earized by using the NewtonRaphson method, a linear system of algebraic equations is derived,
with respect to the incremental relative deformation gradient dF (e.g. see equation (53)). How-
ever, the form of this equation is not amenable to solving by means of well-known linear system
equation solvers. The equation obtained, though linear, involves a number of tensorial operations
with known tensors. In order to automatically resolve this equation into a simplied problem (i.e.
in the linear algebraic form [K]{du} ={f}, where {du} is the vector of the nodal incremental
displacements), the following procedure is employed. Let us consider the weak form (equation
(53)) in which all terms are known except the tensor X=dF. For simplicity of the presentation,
a plane strain or an axisymmetric problem is assumed. One of the various tensor relations in the
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 417
Figure 4. A matrix hierarchy of particular importance to deformation problems. Mat(real) is a basic dipack class with its
own hierarchies and functionality
stiness calculations in equation (53) is of the following form:
AX=B
where A is a known tensor and B is the resulting (unknown) tensor from the operation shown on
the left of the above equation. The above equation can be re-written in a discrete (matrix) form
as follows:
[A
!
]{X
c
} ={B
c
}
where the tensor X is expressed with a column vector {X
c
} as
{X
c
} =
_

_
X
11
X
12
X
21
X
22
X
33
_

_
Simple calculations show that [A
!
] is a 5 5 matrix whose components are given by
A
!
=
_

_
A
11
0 A
12
0 0
0 A
11
0 A
12
0
A
21
0 A
22
0 0
0 A
21
0 A
22
0
0 0 0 0 A
33
_

_
Here, the subscript ! is used to denote that the original tensor operation is a multiplication of
the unknown tensor X with the known tensor A from the left. The following additional tensor
operations have been transformed to equivalent matrix}vector operations:
XA[A
right
]{X
c
}
AX[A
left
]{X
c
}
sym(AX) [A
sym
]{X
c
}
skew(AX) [A
skew
]{X
c
}
trace(AX)B[A
trace
]{X
c
}, with B a given 2nd order tensor
AX
T
[A
trans
]{X
c
}
Using the above transformations, it is now straightforward to transform the linearized tensorial
form of the principle of virtual work in an algebraic system of linear equations.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
418 N. ZABARAS AND A. SRIKANTH
In addition to the above transformations, a number of basic decompositions for MatDef objects
has also been implemented. These include the classical F=RU polar decomposition as well as
the QDQ
T
decomposition for symmetric matrices (where Q is a proper rotation and D a positive
denite diagonal matrix). A summary of the basic functionality of class MatDef is given in
Box 1. The selection of appropriate virtual functions in the MatDef hierarchy is performed at
run time. Finally, it is noted that the class MatDef is also used here for representing the discrete
form of various other eld variables that are not necessarily related with the kinematics. For such
MatDef objects, only the functionality of the dipack class Mat(real) is used.
Box 1. The class MatDef used to represent matrices
class MatDef: public Mat(real)
{
private:
. .
public:
MatDef(): Mat(real) () { }
MatDef(int n): Mat(real)(n) {}
MatDef(int nrows, int ncolumns) : Mat(real) (nrows, ncolumns) {}
MatDef() {}
virtual void right(MatDef& Aright) {}
virtual void left(MatDef& Aleft) {}
virtual void trace(MatDef& Atrace, const MatDef& B) {}
virtual void symm() {}
virtual void skew() {}
virtual void transleft(MatDef& Atrans) {}
virtual void RU(MatDef& R, MatDef& U) {}
virtual void QDQt(MatDef& Q, MatDef& D) {}
. .
};
3.3. The kinematic problem
The discrete kinematic problem (each iteration in the NewtonRaphson process) consists of
the calculation of the incremental displacements assuming a known material state at time t
n+1
(as calculated from the constitutive problem). The Deformation class is dened to represent
the discrete kinematics (e.g. the deformation gradient) at a given Gauss point in the current
conguration (i.e. at a given FiniteElement fe) with respect to its position in the reference
conguration (in GridFE grid) (see Box 2).
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 419
Box 2. An object of the class Deformation represents the non-linear discrete
kinematics at an integration point
class Deformation: public HandleId
{
protected:
GridFE grid;
FiniteElement fe;
. .
public:
Deformation(GridFE grid , FiniteElement fe ): grid(grid ) ,fe(fe ) {}
Deformation() {}
virtual void resetGrid(GridFE grid ) {grid =grid ;}
virtual void resetFe (FiniteElement fe ) {fe =fe ;}
virtual void calcF(MatDef& F);
virtual void calcB(MatDef& B);
virtual real detF(MatDef& F);
virtual real calcFVol (MatDef& F);
virtual void calcFDev(MatDef& F dev);
virtual void calcBVol (MatDef& B vol);
. .
};
Figure 5. The main class introduced to describe the non-linear kinematics
A discrete matrix B is also dened to represent the relation between the velocity gradient tensor
(as a vector) and the nodal velocities (as a vector). The calculations of the deviatoric tensor
F
dev
, volumetric tensor F
vol
as well as of the B
vol
portion of B are also available through the
Deformation class. The Deformation class hierarchy is shown in Figure 5.
3.4. The constitutive class hierarchies
As discussed earlier, the (isotropic) inelastic material behavior is dened via the evolution of
the equivalent (scalar) plastic strain and the evolution of a number of state variables. Various con-
stitutive models are represented as functors (i.e. virtual functions in class hierarchies) in classes
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
420 N. ZABARAS AND A. SRIKANTH
derived from the classes PStrainEvolveUDC and StateEvolveUDC. The denition of two sep-
arate classes for the evolution of the equivalent plastic strain and of the state variables has only
been performed to simplify programming. A unied class for each constitutive model could have
been dened instead that includes all evolution equations. The current implementation, however,
allows an easy treatment of rate-independent models in which the plastic strain evolution is implic-
itly calculated via the consistency condition, whereas various hardening}relaxation models could
be prescribed. A particular constitutive model is then dened as an object of the class Constitu-
tiveBaseUDC. This object is dynamically binded with objects of the classes PStrainEvolveUDC
and StateEvolveUDC (see Box 3).
Box 3. The general class for the denition of an inelastic constitutive model
class ConstitutiveBaseUDC: public HandleId {
public:
PStrainEvolveUDC& pstrdef;
StateEvolveUDC& stadef;
ConstitutiveBaseUDC(PStrainEvolveUDC& p, StateEvolveUDC& s);
ConstitutiveBaseUDC() {}
. .
};
The functionality of the classes PStrainEvolveUDC and StateEvolveUDC is shown in Boxes
4 and 5, respectively, where for simplicity one isotropic material state variable is considered.
Box 4. This base class provides the virtual func-
tions for the denition of the equivalent plastic strain
evolution
class PStrainEvolveUDC: public HandleId {
public:
PStrainEvolveUDC() {}
PStrainEvolveUDC() {}
virtual real f (real sigma, real s) =0;
virtual real dfDsigma(real sigma, real s) =0;
virtual real dfDs(real sigma, real s) =0;
virtual real fInv(real eps, real s) =0;
virtual String name() =0;
. .
};
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 421
Box 5. This base class provides the virtual functions for the denition of the (isotropic)
state variable evolution
class StateEvolveUDC: public HandleId {
protected:
PStrainEvolveUDC& strain type;
public:
StateEvolveUDC(PStrainEvolveUDC& strain type ): strain type(strain type ) {}
StateEvolveUDC() {}
virtual real h(real sigma, real s) =0;
virtual real dhDsigma(real sigma, real s) =0;
virtual real dhDs(real sigma, real s) =0;
virtual real r (real s) =0;
virtual real drDs(real s) =0;
real g(real sigma, real s);
real dgDsigma(real sigma, real s);
real dgDs(real sigma, real s);
virtual String name() =0;
. .
};
The functions

c
p
=[( o, s) and s =q( o, s) r(s) =[( o, s)h( o, s) r(s) as well as their various
derivatives with respect to o and s are available.
The inverse function o =[
1
(

c
p
, s) is also provided. Note that most of these functions are pure
virtual and must be specied in a derived class. A graphical representation of these hierarchies is
given in Figure 6.
The base class ConstitutiveIntegrationUDC is introduced to represent the discrete constitutive
integration subproblem. An object of this class has direct access to the main Simulator data
(LargeDef& data) and thus to the values of the stresses, state variables and

F
p
at the beginning
of the time step (time t
n
). The integration of the constitutive model is performed at each Gauss
point in all nite elements. The class ConstitutiveIntegrationUDC therefore has access to an
object of the class FiniteElement which can be set to a particular Gauss point. This class also
has access to the constitutive model used (i.e. to an object of the class ConstitutiveBaseUDC).
An object of class MatDef which physically represents the deformation gradient and is used to
drive the incremental constitutive problem is also a member of ConstitutiveIntegrationUDC.
The virtual function update(BooLean post process =dpFALSE) solves the discrete constitutive
integration subproblem (i.e. calculates the stresses, state variables and

F
p
at the end of the step,
time t
n+1
). The material state, stresses and

F
p
are stored in two dierent formats. A discrete
MatDef format stores the values of these variables at every Gauss point of each element. This
format is used in all calculations. A FieldFE format of these variables is also computed and
stored. This format is essential for post-processing purposes. The BooLean argument in update
controls when the eld format of the various variables is updated. The default argument FALSE
implies that only the discrete MatDef format is updated. Such updates are performed during
the NewtonRaphson iterations. The FieldFE format is updated only after convergence has been
achieved in a given time step. The argument TRUE is used in this case.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
422 N. ZABARAS AND A. SRIKANTH
Figure 6. The main class introduced to describe the inelastic constitutive models and the algorithms for their integration
Particular integration schemes are implemented as functors (virtual function update) in classes
derived from the base class ConstitutiveIntegrationUDC. Figure 6 shows two such derived classes,
IsotropicRateDependent and IsotropicRateIndependent that are used to dene the constitutive
integration schemes for isotropic rate-independent and rate-dependent plasticity models. Currently
both of these classes have been developed using the radial return mapping as outlined earlier.
Box 7 shows the functionality of the class IsotropicRateDependent. The names of the various
functions are directly related with the various steps in the integration scheme and no further details
of this functionality will be provided.
Finally, it is mentioned here that dipack provides a convenient frame work for the use of
functors. Let us for example consider the class StateEvolveUDC and briey outline how a
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 423
pointer of this base class can be rebinded appropriately in the derived hierarchy. At rst, a param-
eter structure is dened that includes all arguments needed in the constructor of StateEvolveUDC
and in addition a String parameter that can be used to identify the state model (see Box 5):
struct prm(StateEvolveUDC) {
String state type;
PStrainEvolveUDC pstrain type;
};
Box 6. This class is used to dene the virtual function update for the numerical
integration of the discrete constitutive problem
class ConstitutiveIntegrationUDC: public HandleId {
protected:
LargeDef& data;
FiniteElement fe;
ConstitutiveBaseUDC& model;
MatDef F;
public:
ConstitutiveIntegrationUDC(LargeDef& data , FiniteElement fe ,
ConstitutiveBaseUDC& model , MatDef* F );
ConstitutiveIntegrationUDC() {}
void resetFe(FiniteElement fe) fe = fe;
void resetF(MatDef* F) {F = F;}
. .
virtual void update(BooLean post process = dpFALSE) =0;
virtual real calcPlasticWorkRate() =0;
. .
MatDef cauchy stress; // Cauchy stress
MatDef tangent moduli; // Tangent material moduli
real sigf, sf; // Equivalent stress and scalar state variable
real equiv strain; // Equivalent strain
MatDef Fe; // Elastic deformation gradient
Handle(MatDef) Fs; // Trial deformation gradient
real pres trial stress; // Mean normal pressure of the trial stress
. .
};
Here, state type is a String object that the user provides at run time to dene the specic state
evolution model. Let us assume that an object pm of prm(StateEvolveUDC) has been dened.
A pointer to the base class can now be appropriately rebinded to the specic state evolution model
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
424 N. ZABARAS AND A. SRIKANTH
Box 7. This class denes a numerical integration object for isotropic viscoplastic consti-
tutive models
class IsotropicRateDependent: public ConstitutiveIntegrationUDC {
protected:
friend class IsotropicRateIndependent;
MatDef bar cauchy stress; // Rotation neutralized Cauchy stress
real eq trial stress; // Equivalent trial stress
MatDef trial stress; // Trial stress tensor
MatDef dev trial stress; // Deviatoric part of the trial stress
real radial return; // Radial return factor
real trE; // Trace of the logarithmic strain
MatDef trialR, trialU; // From the RU decomposition of the trial def. grad.
MatDef logE; // Logarithmic strain
void init ();
void defoFields2Matrix();
void calcTrialStrain();
void calcTrE(); // Calculates the trace of the trial strain
void pressure(); // Calculates the pressure part of the trial stress
void equivStress(); // Calculates the equivalent trial stress
void calcTrialStress();
void calcDevStress(); // Calculates the deviatoric part of trial stress
void solve(); // Solves the two algebraic non-linear equs
void calcBarStress(); // Calculates the rotation neutralized Cauchy stress
void pushForward(); // Pushes forward to obtain the Cauchy stress
void updateStress(); // Updates the stress in the main simulator
void updateState(); // Updates the state variables
void updateFe(); // Updates the elastic deformation gradient
void calcEpsilon(); // Calculates the equivalent plastic strain
void calcMaterialModuli (); // Calculates the material moduli
. .
public:
IsotropicRateDependent (LargeDef& data , FiniteElement fe ,
ConstitutiveBaseUDC& model , MatDef F ):
ConstitutiveIntegrationUDC(data , fe , model , F ) {}
IsotropicRateDependent () {}
virtual void update(BooLean post process = dpFALSE);
virtual real calcPlasticWorkRate();
. .
};
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 425
as follows:
StateEvolveUDC ptr = NULL;
..
if (EQ(pm.state type, PowLaw))
ptr = new StatePowLaw(pm.pstrain type);
else if (EQ(pm.state type, SimPowLaw))
ptr = new StateSimPowLaw(pm.pstrain type);
else if (EQ(pm.state type, Perzyna))
ptr = new StatePerzyna(pm.pstrain type);
..
else if (EQ(pm.state type, Sinh))
ptr = new StateSinh(pm.pstrain type);
..
A similar re-binding process of a base class pointer is applied for all class hierarchies developed
in this work.
3.5. The contact class hierarchies
As part of the augmented Lagrangian approach to contact that has been currently implemented,
a class Die is introduced to allow for an abstract representation of a generic die surface. The
dipack class Ptv(real) provides an ecient means of dening point objects. A parametric
representation of the die surface is considered in terms of an object of the class Ptv(real) rep-
resenting the parameter in two dimensions and the parameters (, p) in three dimensions. The
parameter range used is [0, 1]. The various projection-related functions like nding the gap, cur-
vature, etc., though dimension-dependent are generic enough to be implemented in the derived
classes Die2D and Die3D. The die-shape-related functions are however specic to each die
and are implemented using functors in the hierarchy. In particular, the die surfaces must be
dened as virtual functions in a derived class e.g. the class ExtrusionApplicationDie3D (see
Figure 7). Such die-specic classes are usually introduced together with the particular Simulator
so that re-compilation of the Die class is not needed for each application. Also note that the
various projection related functions can be re-implemented in a derived class if more ecient al-
gorithms can be designed for the particular die. The basic functionality of the class Die is given
in Box 8 and a graphical representation of the various hierarchies is given in Figure 7. Note that
other types of representations of die surfaces that are possibly needed for algorithms that are not
based on the current augmented Lagrangian analysis can be introduced directly in the class Die
using either overloaded functions or additional virtual functions.
The base class for representing contact with a die is presented in Box 9. For each individual
die, a contact indicator is assigned that is used to specify the potential regions of contact, while
solving the kinematic problem. Each Contact object is dened for a given die and has direct
access to the data of the main Simulator. The most important virtual function in the class Con-
tact is the function numItgOverContactSide() which implements the contribution of contact to
the tangent stiness matrix. These contributions are strongly dependent on the particular physi-
cal contact}friction model. The actual implementation of the function numItgOverContactSide()
is provided in classes derived from Contact. For Coulomb type of frictional models, the class
Coulomb implements both the symmetric and non-symmetric stiness versions of the augmented
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
426 N. ZABARAS AND A. SRIKANTH
Figure 7. The main class introduced to describe dies in forming processes. The user-dened functions which dene the
die-shape are represented as virtual functions in the die hierarchy
Lagrangian algorithm. Dierent frictional models that take into account micromechanical mech-
anisms within the contact interface, can also be implemented using the Contact hierarchies. A
graphical representation of these hierarchies is shown in Figure 8.
Box 8. Denition of the class Die. The various die shape-related functions
are dened as virtual functions in a hierarchy derived from the class Die
class Die: public HandleId {
protected:
virtual real distance(Ptv(real)& x, Ptv(real)& param) =0;
. .
public:
virtual real shape(Ptv(real)& param, int i) =0;
virtual real dShape(Ptv(real)& param, int i, int j) =0;
virtual real d2Shape(Ptv(real)& param, int i, int j, int k) =0;
virtual real d3Shape(Ptv(real)& param, int i, int j, int k, int l) =0;
virtual real gap(Ptv(real)& x) =0;
virtual real curvature(Ptv(real)& x) =0;
virtual void x2Xi (Ptv(real)& x, Ptv(real)& param) =0;
virtual String name() =0;
. .
};
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 427
Box 9. Objects of the class Contact are here dened to represent geometric infor-
mation related to contact as well as to solve the discrete contact problem
class Contact: public HandleId
{
protected:
virtual void initMeshData() =0; // Find elements in contact, etc.
int contact indicator; // The contact boundary indicator
LargeDef& data; // Mainly for information about the grids
Die& die; // The die object against which contact occurs
. .
public:
Contact (Die& die , LargeDef& data , int contact indicator );
Contact () {}
real macauley(real x);
real heavySide(real x);
virtual void initDataStructures() =0;
virtual void init4timeStep() =0;
virtual void numItgOverContactSide(int side, int boind, ElmMatVec& elmat,
FiniteElement& fe) =0;
virtual void symmetricStiness( int side, int boind, ElmMatVec& elmat,
FiniteElement& fe) =0;
virtual void nonSymmetricStiness( int side, int boind, ElmMatVec& elmat,
FiniteElement& fe) =0;
virtual BooLean isContactOK() =0; // Checks contact constraints
virtual void augment () =0;
virtual void calcTractions() =0; // Computes boundary tractions
virtual void calcDieForce() =0; // Computes the total force on the die
virtual String name() =0;
. .
};
Figure 8. Class hierarchies introduced to describe contact with a rigid die in forming processes
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
428 N. ZABARAS AND A. SRIKANTH
Box 10. Some basic members of the main Simulator class LargeDef
class LargeDef: public FEM, public MenuUDC, public NonLinEqSolverUDC
{
protected:
. .
Handle(GridFE) grid ref, grid ini, grid cur; // Various grids
Handle(AdaptiveTimePrm) tip; // Time loop object
Handle(DegFreeFE) dof; // Mapping of nodal values unknowns
Handle(FieldsFE) u; // Field of incremental displacements
prm(NonLinEqSolver) nlsolver prm; // Parameters for non-linear solver
Handle(NonLinEqSolver) nlsolver; // Nonlinear solver
Handle(LinEqAdm) lineq; // Linear system, storage and solution
Vec(real) nonlin solution; // Nonlinear solution
Vec(real) linear solution; // Solution of linear subsystem
. .
Handle(FieldFE) equiv stress prev; // Various handles referring to the material state
. .
FieldFormat equiv strain format; // Various Field Formats
..
MatSimplest (real) equiv stress; // Material histories at Gauss points
MatSimplest (real) equiv strain;
. .
Handle(ConstitutiveBaseUDC) const base; // Handles to the constitutive, kinematic,
. . // and other subproblems
prm(ConstitutiveBaseUDC) const base prm;
. .
BooLean automatic; // Solution methodology type
BooLean axisym; // Problem type
. .
Handle(Store4Plotting) stressField; // Various handles for plotting
. .
SimResFile elas defo le; // Various les for plotting/restarting
. .
};
3.6. The main Simulator class
The main Simulator, class LargeDef , is the most essential class that allows the interaction of
all other developed classes. Some of the members of this class are shown in Box 10. Information
is included about the initial (t =0), reference (t =t
n
) and current (t =t
n+1
) grids in a GridFE
format. The main unknown eld is the incremental displacement that is represented in a FieldFE
form. Scratch vectors for both the linear (i.e. for the dierential incremental displacements) and
non-linear solutions (i.e. for the incremental displacements) are also included. The various material
histories (e.g. the Cauchy stress, the equivalent plastic strain, the state variables,

F
p
, etc.) are kept
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 429
Figure 9. The main Simulator class with some important members
in both a FieldFE format that allows the use of various plotting tools and in a MatDef form that
represents values at the Gauss points of each element. The handling of the non-linear and linear
solvers is decided at run time via the appropriate binding of the relevant pointers. Finally, smart
pointers are introduced for all subproblems discussed earlier (e.g. for the kinematic, constitutive
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
430 N. ZABARAS AND A. SRIKANTH
and contact subproblems). The binding of these initially NULL pointers is performed at run time.
At selected times, the essential elds are dumped in SimResFile les that can be used either to
restart a previously interrupted program or for plotting purposes. A specication of a FieldFormat
for each eld that is being read is then essential to dene in which form each eld is read (e.g.
from a le, function, etc.).
The most important functional aspects of the Simulator are presented in Box 11. The virtual
functions integrands and integrands4side are inherited from the class FEM and dene the
specic tangent stiness/load calculations. All contributions of an element are accounted for in
calcElmMatVec() (see Box 11) that is also inherited from the class FEM. Indicators have been
assigned to represent each type of boundary conditions. These indicators are assigned to element
nodes and sides as part of the mesh generation process and are used in the virtual function
calcElmMatVec to account for the particular contributions of an element to the tangent stiness
and load. The treatment of essential boundary conditions is described in Reference 41.
The function timeLoop contains the main time integration loop. Considering that dierent
data have to be stored/plotted at various time steps for dierent processes (e.g. in Forging, one
may be interested to calculate the die force at each time step), a number of virtual functions
(e.g. storeApplicationSpecicData) declared in the main simulator can be dened by the user in
each application (e.g. in the class Forging:LargeDef). However, it should be mentioned that the
classes derived from LargeDef have only a minor number of additional functionalities to that of
LargeDef.
The functions dene, scan and adm are used to dene and read via a menu various input
data, whereas the function driver activates the problem solution process. A summary of the key
members of the main simulator as well as of the various application classes is given in Figure 9.
4. NUMERICAL EXAMPLES
A number of numerical examples including some benchmark problems will be considered here to
validate the developed simulator as well as to report the cpu requirements of the present object
oriented implementation. All computations were performed on an IBM RS-6000 workstation at the
Cornell Theory Center.
4.1. Example 1: Axisymmetric isothermal open-die forging of 1100-Al
As an example of a large deformation metal forming problem, the upset forging of a cylindrical
1100-Al billet is considered between parallel dies. This benchmark problem was examined earlier in
References 2 and 3 using ABAQUS with the CAX4 special elements to address incompressibility.
46
The radial return mapping for the integration of the constitutive model was the same as that given
here, however, the tangent stiness, the assumed strain model and the augmented Lagrangian
algorithm for contact presented here were not implemented in the calculations of References 2
or 3.
The constitutive model for 1100-Al is presented in References 15 and 16 at 673 K. Under these
isothermal conditions, the ow function [ is given as follows:
[( o, s) =A
_
sinh
_

o
s
__
1}m
(74)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 431
Box 11. The basic functionality of class LargeDef
class LargeDef: public FEM, public MenuUDC, public NonLinEqSolverUDC
{
protected:
. .
virtual void timeLoop(); // Main time integration loop
void solveAtThisTimeLevel (); // Solves the deformation probl. in a single time step
void MakeAndSolveLinearSystem(int iter); // Solves a single Newton iteration
. .
void setIC(); // Sets initial conditions for the problem
void llEssBC(); // Treats essential boundary conditions
virtual real ebcDisplacement () = 0; // Denes process specic essen. bound. cond.
. .
void calcElmMatVec(int e, ElmMatVec& elmat, FiniteElement& fe);
void integrands(ElmMatVec& elmat, FiniteElement& fe);
void integrands4side(int side, int boind, ElmMatVec& elmat,
FiniteElement& fe);
. .
void calculateReduce(FiniteElement& fe, MatDef& F, MatDef& EF);
. .
public:
LargeDef ();
LargeDef ();
virtual void dene(MenuSystem& menu, int level =MAIN);
virtual void scan(MenuSystem& menu);
virtual void adm(MenuSystem& menu);
virtual void driver ();
. .
};
and the hardening function q is given by
q ( o, s) =h ( o, s) [( o, s) (75)
where the function h is dened as follows:
h ( o, s) =h
0

1
s
s

a
(76)
with
s

= s
_

c
p
A
_
n
(77)
The specic values of the material parameters are given in Table I.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
432 N. ZABARAS AND A. SRIKANTH
Table I. Material parameters for Al 1100-O at 673 K
Material parameter Value
A 475 10
7
s
1
70
m 023348
s
0
297 MPa
h
0
11156 MPa
a 13
s 1892 MPa
n 007049
j 202 GPa
660 GPa
Table II. Simulation parameters for the open die
forging of a cylindrical 1100-Al billet (Example 1)
Parameter Value
Energy error norm 10e 06
Displacement L

error norm 1.0e 06


Normal penalty for contact 10e +07
Tolerance for gap 10e 04
Tangent penalty for contact 10e +04
Tolerance for friction condition 10e 04
In this forging example, the initial cylindrical billet is 2 mm in diameter and 3 mm high. The
forging die is modeled as a rigid surface and to simulate sticking friction between the die and the
workpiece, a coecient of friction of 0.8 is applied. The deformation is highly non-homogeneous
with variable rates of straining at material points and time-varying}unsteady contact. The symmetry
of the problem allowed modeling one fourth of the geometry. A nominal strain rate of 001 was
applied during the forging process. A rather coarse uniform grid of 10 10 four-noded quadrilateral
nite elements was used to discretize the domain. A stabilizing parameter of c =10
4
was used
in the simulation. The initial billet was subject to a height reduction of 60 per cent in 90 s using
a xed time step t =10 s.
The primary nested augmented Lagrangian algorithm was used to enforce the contact conditions.
The main parameters used in the simulation are given in Table II. The deformed mesh after
60 per cent height reduction (90 time steps) is shown in Figure 10. Figures 11 and 12 show
the contours of the equivalent plastic strain and of the internal state variable at the end of the
upsetting process. The force necessary to forge the workpiece versus the stroke is shown with the
continuous line in Figure 13. The above results match very well with the ABAQUS calculations
reported in References 2 and 3. The computing statistics of this calculation is shown in Table III.
Table IV shows the convergence characteristics that was obtained in a typical time step.
The above forging simulation was also performed with the automatic time stepping scheme by
specifying the maximum allowable plastic strain increment in a time-step as 0.04. The correspond-
ing force versus stroke curve is also shown in Figure 13 with discrete points and is indistinguishable
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 433
Figure 10. Initial and nal deformed mesh after 60 per cent height reduction in axisymmetric open die forging (Example 1)
Figure 11. Contours of the equivalent plastic strain in the nal forged product (Example 1)
Figure 12. Contours of the internal state variable (in MPa) in the nal forged product (Example 1)
from the xed time step results. These calculations required 72 time increments. As expected, the
time step is automatically reduced in the time domain intervals where fold-over occurs.
4.2. Example 2: Axisymmetric isothermal closed die forging of an 1100-Al workpiece
We consider the closed die forging of a 1100-Al cylindrical workpiece with the same constitu-
tive model as in Example 1. This problem demonstrates the eectiveness of the implicit contact
algorithm in simulating the lling of a die cavity. The workpiece is a circular cylinder whose vol-
ume is chosen so that at the end of the forging process the material will ll exactly the die cavity
without the formation of ash. The initial radius of the cylinder is 631 mm and the initial height
is 100 mm. A friction coecient of 01 is assumed at the die-workpiece interface. A nominal
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
434 N. ZABARAS AND A. SRIKANTH
Figure 13. Upsetting force versus die stroke (Example 1)
Table III. Computing statistics for the open die forging of a
cylindrical billet (Example 1)
Parameter Value
Total cpu time 00 : 18 : 26
Augmentations per increment 1
Newton Raphson iterations per increment 53
Formation of the linear system of equations 143 s
Time to solve the linear system 05 secs
Table IV. Convergence characteristics in a typical time step for
the open die forging of a cylindrical billet (Example 1)
Iteration Displacement Energy
number error norm error norm
1 12412e 02 10000e + 00
2 67984e 04 99597e 01
3 18958e 04 16090e 02
4 28726e 06 28930e 03
5 10821e 09 34252e 05
strain rate of 001 was applied during the forging process. 13 10 four-noded quadrilateral nite
elements were used to discretize the domain (Figure 14). A stabilizing parameter of c =10
4
was
used. The automatic time stepping technique described in Section 2.3, with an allowable maximum
plastic strain increment of 001, was used in the simulation. A total of 311 time increments was
needed to maintain this strain control.
The main parameters used in the simulation are given in Table V. The deformed mesh at the
nal stage is shown together with the initial mesh in Figure 14. Figures 15 and 16 show the
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 435
Figure 14. Initial mesh and nal mesh for the axisymmetric closed die forging of a cylindrical billet (Example 2)
Table V. Parameters for the closed die forging of
the cylindrical 1100-Al billet (Example 2)
Parameter Value
Energy error norm 10e 04
Displacement L

error norm 10e 04


Normal penalty 10e + 06
Tolerance for gap 10e 04
Tangent penalty 10e + 03
Tolerance for friction condition 10e 04
Figure 15. Contours of the equivalent plastic strain in the nal forged product (Example 2)
contours of the equivalent plastic strain and of the internal state variable, respectively, at the end
of the closed die forging process. The force necessary to forge the workpiece versus the stroke is
shown in Figure 17. The computing statistics are summarized in Table VI.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
436 N. ZABARAS AND A. SRIKANTH
Figure 16. Contours of the internal state variable s (in MPa) in the nal forged product (Example 2)
Figure 17. Upsetting force versus stroke (Example 2)
4.3. Example 3: Axisymmetric extrusion of a cylindrical billet of a rate-independent material
Another benchmark test problem is considered here that is related with the axisymmetric extru-
sion of a workpiece through a rigid conical die.
23
A rate-independent material is considered with
linear hardening. The material properties and the simulation parameters are shown in Table VII
In this axisymmetric problem, the aluminum billet is of radius 508 cm and the initial length is
254 cm. The workpiece is pushed (using a displacement control method) to a total distance of
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 437
Table VI. Computing statistics for the upset closed die forging
of a cylindrical billet (Example 2)
Parameter Value
Total cpu time 01 : 35 : 16
Augmentations per increment 1
NewtonRaphson iterations per increment 45
Time to assemble stiness matrix every iteration 24 s
Time to solve every iteration 05 s
Table VII. Material and simulation parameters for the
conical extrusion process (Example 3)
Parameter Value
6384 GPa
j 2612 GPa
Initial yield stress 31 MPa
Linear hardening rate 2612 MPa
Time step 5 s
Total time 1800 s
Friction coecient 01
Displacement L

error norm 10e 05


Energy error norm 10e 05
Normal penalty 10e + 07
Tangent penalty for contact 10e + 04
18 cm into a conical die with semi-angle of 5

. The discretization of the billet was performed


using a uniform 4 20 grid of four-noded quadrilateral elements. Due to the nature of the contact
conditions, the stiened material moduli suggested in Remark 6 are used here at all time incre-
ments. Using such inconsistent material moduli and a constant time step of 5 s resulted in a total
cpu time of about 10 min.
The eect of friction is clearly seen in the deformed meshes which depict the shearing near the
die walls (Figure 18). These results are in excellent agreement with results given in Reference 23.
The contours of the equivalent plastic strain and of the state variable are shown in Figure 19. The
extrusion force versus displacement is shown in Figure 20. The extrusion force results as well as
the deformed conguration reported in Reference 23 are in excellent agreement with the results
given here. The computing statistics of this calculation performed using 36 time increments is
reported in Table VIII.
Finally, it was observed that the average number of contact augmentations required per time
increment (here 16) was signicantly smaller for simulations with smaller time step (e.g. 1
augmentation for a time step of 20 s).
4.4. Example 4: Plane strain frictionless closed die forging of an 1100-Al workpiece
A plane strain forging problem, where a cylindrical aluminum billet is converted from a circular
cross section to a crucible shape, presented in Reference 2 is analysed here. The initial billet
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
438 N. ZABARAS AND A. SRIKANTH
Figure 18. Initial and various intermediate congurations (at workpiece displacements of 30, 60, 120, 150 and 180 cm,
respectively) for the axi-symmetric conical extrusion (Example 3)
was sized so that the die would be lled completely and in addition some amount of ash would
result. This problem presents several interesting features such as a high degree of non-homogeneous
deformation, variable regions of contact between the billet and the die, time-varying deformation
rates at material points and a rapid rise of the total die force as the die becomes lled.
The dieworkpiece interface is considered frictionless and the material constitutive model is the
same as that of Example 1. The symmetry of the workpiece is used to model only one quarter
of the workpiece. 448 four-noded quadrilateral elements are used to discretize the geometry. The
initial geometry and nite element mesh are shown in Figure 21. A total of 280 time increments
were used to simulate the process. The various simulation parameters are summarized in Table IX.
Figure 22 shows the nite element mesh at various stages of deformation. The material ows
predominantly horizontally until approximately 45 mm of stroke. Figures 23 and 24 show the
contours of the equivalent plastic strain and the internal state variable (in MPa), respectively. The
die force versus the stroke is shown in Figure 25. It is noted that there is a sudden increase in
the required forging force as the workpiece is squeezed to ll the die.
The results above are in very good agreement with the results in Reference 2 where ABAQUS
was used for the simulations [46]. The computing statistics are summarized in Table X. For the
given discretization, a total cpu time of about 6 hrs was required for the complete simulation. A
cpu time of 190 h was reported in the simulation of Reference 2, where a coarser mesh than the
one used here was considered.
5. CONCLUSIONS
An object-oriented simulator based on dipack was developed for the analysis of large inelastic
deformations and metal forming processes. Several benchmark test problems were examined to
demonstrate the accuracy of the developed algorithms.
The present implementation provides a powerful and ecient tool for the analysis of large
inelastic deformations and metal-forming processes. Some of the key elements of the developed
simulator are the following:
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 439
Figure 19. Contours of equivalent plastic strain and isotropic deformation resistance (in MPa) for the extruded material
(Example 3)
Table VIII. Computing statistics for the conical extrusion problem
(Example 3)
Parameter Value
Total cpu time 00 : 10 : 15
Augmentations per increment 155
NewtonRaphson iterations per augmentation 65
Formation of the linear system of equations 14 s
Time to solve the linear system 05 s
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
440 N. ZABARAS AND A. SRIKANTH
Figure 20. Extrusion force versus displacement curve for the conical extrusion problem (Example 3)
Figure 21. Initial geometry and nite element mesh for the plane strain frictionless closed die forging problem (Example 4)
Table IX. Simulation parameters for the plane strain closed
die forging process (Example 4)
Parameter Value
Time step 02 s
Total time 560 s
Displacement L

error norm 10e 04


Energy error norm 10e 04
Normal penalty 10e + 06
1. The same code can be used for two- or three-dimensional problems.
2. The class hierarchies developed allow the implementation of additional constitutive mod-
els, integration algorithms, die surfaces, contact algorithms, etc., without any changes to the
program structure. The key idea is that new algorithms or materials have to be simply pro-
grammed as functors in the already existing class hierarchies.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 441
Figure 22. The nite element mesh at various stages of deformation: after 1, 2, 3, 4, 5 mm of stroke and at the nal forged
product, respectively (Example 4)
Figure 23. Contours of the eective plastic strain c
p
in the nal forged product (Example 4)
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
442 N. ZABARAS AND A. SRIKANTH
Figure 24. Contours of the internal state variable s (in MPa) in the nal forged product (Example 4)
Figure 25. Die force versus die stroke for the plane strain closed die forging process (Example 4)
3. Various forming process simulators can be derived from the developed LargeDef simulator
with only a minor programming eort, for example by simply implementing (as a functor)
a particular process dependent post-processing functionality. The most commonly needed pre-
and post-processing operations have already been introduced as pure virtual functions in the
main simulator.
4. The use of smart pointers (Handles) for memory management and elds to represent the
various continuous variables (FieldFE objects) allows a straightforward coupling of the
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 443
Table X. Computing statistics for the plane strain closed
die forging process (Example 4)
Parameter Value
Total cpu time 05 : 46 : 38
Augmentations per increment 1
NewtonRaphson iterations per increment 4
Formation of the linear system of equations 107 s
Time to solve the linear system 05 s
present simulator with other object-oriented simulators, e.g. a thermal or a uid ow simulator
(see References 3234 for examples of how such coupling can be implemented). Similarly,
the consideration of deformable dies can easily be implemented by representing the die itself
as an object of the class LargeDef.
Various time statistics were presented for the examples examined in order to allow the interested
reader to compare the eciency of the present dipack implementation with other non-object ori-
ented simulators of large inelastic analysis. In comparison to our earlier simulator [44], the present
object-oriented approach was found to be only slightly more expensive. A precise comparison was
not possible since the present simulator includes many features that are not available in Refer-
ence 44 (for e.g. the additional stiness terms required for the implementation of the assumed
strain method). We believe that the extra cost required for object-oriented implementations is only
a small penalty that someone has to pay for receiving the rewards of a robust code that can
run without modications in most computer platforms and that allows generality, expandability,
maintainability and FEM code re-usability [30].
ACKNOWLEDGEMENTS
This work was funded by NSF grant DMII-9522613 to Cornell University. The computing was
supported by the Cornell Theory Center, which receives major funding by the NSF and IBM cor-
poration, with additional support from the New York State. The academic license for using the
various libraries of dipack is acknowledged. Finally, the help of Mr. Yangang Bao in program-
ming various parts of the present Simulator is appreciated.
REFERENCES
1. Simo JC, Taylor RL. Consistent operators for rate-independent elastoplasticity. Computer Methods in Applied
Mechanics and Engineering 1985;48:101118.
2. Lush AM, Weber G, Anand L. An implicit time-integration procedure for a set of internal variable constitutive equations
for isotropic elasto-viscoplasticity. International Journal of Plasticity 1989;5:521549.
3. Weber G, Anand L. Finite deformation constitutive equations and a time integration procedure for isotropic, hyperelastic-
viscoplastic solids. Computer Methods in Applied Mechancis and Engineering 1990;79:173202.
4. Eterovi c AL, Bathe K-J. A hyperelastic-based large strain elasto-plastic constitutive formulation with combined isotropic-
kinematic hardening using logarithmic stress and strain measures. International Journal for Numerical Methods in
Engineering 1990;30:10901114.
5. Moran B, Ortiz M, Shih CF. Formulation of implicit nite element methods for multiplicative nite deformation
plasticity. International Journal for Numerical Methods in Engineering 1990;29:483514.
6. Zabaras N, Arif AFM. A family of integration algorithms for constitutive equations in nite deformation elasto-
viscoplasticity. International Journal for Numerical Methods in Engineering 1992;33:5984.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
444 N. ZABARAS AND A. SRIKANTH
7. Arif AFM, Zabaras N, On the performance of two tangent operators for nite element analysis of large deformation
inelastic problems. International Journal for Numerical Methods in Engineering 1992;35:369389.
8. Cuitino A, Ortiz M. A material-independent method for extending stress update algorithms from small-strain plasticity
to nite plasticity with multiplicative kinematics. Engineering Computations 1992;9:437451.
9. Badrinarayanan S, Zabaras N. A two-dimensional FEM code for the analysis of large deformations of hyperelastic-
viscoplastic solids. Technical Report MM-93-05, Materials Processing Program, Sibley School of Mechanical and
Aerospace Engineering, Cornell University, Ithaca, NY 14853, 1993.
10. Owen DRJ, Peri c D. Recent developments in the application of nite element methods to nonlinear problems. Finite
Element Analytical Design 1994;18:115.
11. Owen DRJ, Peri c D, de Souza Neto EA, Jianguo Yu, Dutko M. Advanced computational strategies for 3-D large scale
metal forming simulations. In: Shen S-F, Dawson P, Editors. Proceedings of Simulation of Materials Processing:
Theory, Methods and Applications, Numiform 95; Balkema: Rotterdam, 1995:722.
12. Lee EH, Liu DT. Finite-strain elastic-plastic theory with application to plane-wave analysis. Journal of Applied Physics
1967;38:1927.
13. Simo JC, Hughes TJR. Elastoplasticity and Viscoplasticity: Computational Aspects; Springer: Berlin, 1998.
14. Miller AK. Editor. Unied Constitutive Equations for Creep and Plasticity; Elsevier Applied Science: New York,
1987.
15. Anand L, Constitutive equations for hot-working of metals. International Journal of Plasticity 1985;1:213231.
16. Brown SB, Kim KH, Anand L. An internal variable constitutive model for hot working of metals. International Journal
of Plasticity 1989;5:95130.
17. Nagtegaal JC. On the implementation of inelastic constitutive equations with special reference to large deformation
problems. Computer Methods in Applied Mechanics in Engineering 1982;33:469484.
18. Ortiz M, Pinsky PM, Taylor RL. Operator split methods for the numerical solution of the elastoplastic dynamic problem.
Computer Methods in Applied Mechanics and Engineering 1983;39:137157.
19. Simo JC, Pister KS. Remarks on rate constitutive equations for nite deformation problems: computational implications.
Computer Methods in Applied Mechanics and Engineering 1984;46:201215.
20. Simo JC, Ortiz M. A unied approach to nite deformation elastoplastic analysis based on the use of hyperelastic
constitutive equations. Computer Methods in Applied Mechanics and Engineering 1985;49:221245.
21. Ortiz M, Simo JC. An analysis of a new class of integration algorithms for elastoplastic constitutive relations.
International Journal for Numerical Methods in Engineering 1986;23:353366.
22. Laursen TA, Simo JC. On the formulation and numerical treatment of nite deformation frictional contact problems.
In: Wriggers P, Wager W. Editors. Nonlinear Computational Mechanics State of the Art; Springer: Berlin, 1991;
716736.
23. Simo JC, Laursen TA. An augmented Lagrangian treatment of contact problems involving friction. Computers and
Structures 1992;42(1):97116.
24. Laursen TA, Simo JC. Algorithmic symmetrization of Coulomb frictional problems using augmented Lagrangians.
Computer Methods in Applied Mechanics and Engineering 1993;108:133146.
25. Laursen TA, Simo JC. A continuum-based nite element formulation for the implicit solution of multibody,
large deformation frictional contact problems. International Journal for Numerical Methods in Engineering 1993;
36:34513485.
26. Wriggers P, Vu Van T, Stein E. Finite element formulation of large deformation impact-contact problems with friction.
Computers and Structures 1990;37:319331.
27. Barton JJ, Nackman LR. Scientic and Engineering C++; Addison-Wesley: New York, 1994.
28. Arge E, Bruaset AM, Langtangen H-P. (Editors), Modern Software Tools for Scientic Computing; Birkhauser:
Boston, 1997.
29. Daehlen M, Tveito A. (Editors), Numerical Methods and Software Tools in Industrial Mathematics; Birkhauser:
Boston, 1997.
30. Zabaras N. Computational mechanics using an object oriented environment. In: Shephard MS. Editor. Proceedings of
the Fourth U.S. Congress On Computational Mechanics. San Francisco, CA, 68 August, 1997, p. 207.
31. Sampath R, Zabaras N.A dipack implementation of the Brooks} Hughes Streamline-upwind}PetrovGalerkin FEM
formulation for the incompressible NavierStokes equations. Research Report MM-97-01, Sibley School of Mechanical
and Aerospace Engineering, Cornell University, 21 March 1997 (URL: http:}}www.mae.cornell.edu}research}zabaras).
32. Sampath R, Zabaras N. Finite element simulation of buoyancy driven ows using an object oriented approach. Research
Report MM-97-02, Sibley School of Mechanical and Aerospace Engineering, Cornell University, 22 May 1997 (URL:
http:}}www.mae.cornell.edu}research}zabaras).
33. Sampath R, Zabaras N. FEM simulation of double diusive convection using an object oriented approach. Research
Report MM-97-03, Sibley School of Mechanical and Aerospace Engineering, Cornell University, 22 June 1997 (URL:
http:}}www.mae.cornell.edu}research}zabaras).
34. Sampath R, Zabaras N. An object oriented implementation of a front tracking nite element method for directional
solidication processes. International Journal for Numerical Methods in Engineering, in press.
35. Mackie RI. Object oriented programming of the nite element method. International Journal for Numerical Methods
in Engineering 1992;35:425436.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)
LAGRANGIAN FEM ANALYSIS 445
36. Zimmermann T, Dubois-P elerin Y, Bomme P. Object-oriented nite element programming: I. Governing principles.
Computer Methods in Applied Mechanics and Engineering 1992;98:291303.
37. Zeglinski GW, Han RPS. Object oriented matrix classes for use in a nite element code using C++. International
Journal for Numerical Methods in Engineering 1994;37:39213937.
38. Dipack World Wide Web document: Dipack v1.4 Report Series, SINTEF and University of Oslo, 1996 (URL:
http:}}www.nobjects.com}dipack).
39. Dipack Basic Tools, Dipack Reference Manual, Vol. I, World Wide Web document, SINTEF and University of
Oslo, 1996 (URL: http:}}www.nobjects.com}dipack).
40. Dipack Linear Algebra Tools, Dipack Reference Manual, Vol. II, World Wide Web document, SINTEF and
University of Oslo, 1996 (URL: http:}}www.nobjects.com}dipack).
41. Dipack DpKernel - DpUtil, Dipack Reference Manual, Vol. III, World Wide Web document, SINTEF and University
of Oslo, 1996 (URL: http:}}www.nobjects.com}dipack).
42. Hibbit HD. Some follower forces and load stiness. International Journal for Numerical Methods in Engineering
1979;14:937941.
43. Hughes TJR. The Finite Element Method: Linear, Static and Dynamic Finite Element Analysis; Prentice-Hall:
Englewood Clis, 1987.
44. Badrinarayanan S, Zabaras N. A sensitivity analysis for the optimal design of metal-forming processes. Computer
Methods in Applied Mechanics and Engineering 1996;129:319348.
45. Wriggers P, Korelc J. On enhanced strain methods for small and nite deformations of solids. Computational Mechanics
1996;18:413428.
46. ABAQUS, Reference Manuals, Hibbitt, Karlsson and Sorensen Inc., 100 Medway Street, Providence, RI 02906- 4402,
U.S.A.
Copyright ? 1999 John Wiley & Sons, Ltd. Int. J. Numer. Meth. Engng. 45, 399445 (1999)

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy