Rocstar  1.0
Rocstar multiphysics simulation application
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
MP/Source/v3d4_nl_arruda_boyce.f90
Go to the documentation of this file.
1 !*********************************************************************
2 !* Illinois Open Source License *
3 !* *
4 !* University of Illinois/NCSA *
5 !* Open Source License *
6 !* *
7 !* Copyright@2008, University of Illinois. All rights reserved. *
8 !* *
9 !* Developed by: *
10 !* *
11 !* Center for Simulation of Advanced Rockets *
12 !* *
13 !* University of Illinois *
14 !* *
15 !* www.csar.uiuc.edu *
16 !* *
17 !* Permission is hereby granted, free of charge, to any person *
18 !* obtaining a copy of this software and associated documentation *
19 !* files (the "Software"), to deal with the Software without *
20 !* restriction, including without limitation the rights to use, *
21 !* copy, modify, merge, publish, distribute, sublicense, and/or *
22 !* sell copies of the Software, and to permit persons to whom the *
23 !* Software is furnished to do so, subject to the following *
24 !* conditions: *
25 !* *
26 !* *
27 !* @ Redistributions of source code must retain the above copyright *
28 !* notice, this list of conditions and the following disclaimers. *
29 !* *
30 !* @ Redistributions in binary form must reproduce the above *
31 !* copyright notice, this list of conditions and the following *
32 !* disclaimers in the documentation and/or other materials *
33 !* provided with the distribution. *
34 !* *
35 !* @ Neither the names of the Center for Simulation of Advanced *
36 !* Rockets, the University of Illinois, nor the names of its *
37 !* contributors may be used to endorse or promote products derived *
38 !* from this Software without specific prior written permission. *
39 !* *
40 !* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, *
41 !* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES *
42 !* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND *
43 !* NONINFRINGEMENT. IN NO EVENT SHALL THE CONTRIBUTORS OR *
44 !* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
45 !* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, *
46 !* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE *
47 !* USE OR OTHER DEALINGS WITH THE SOFTWARE. *
48 !*********************************************************************
49 !* Please acknowledge The University of Illinois Center for *
50 !* Simulation of Advanced Rockets in works and publications *
51 !* resulting from this software or its derivatives. *
52 !*********************************************************************
53  SUBROUTINE v3d4_nl_arruda_boyce(coor,matcstet,lmcstet,R_in,d, &
54  s11,s22,s33,s12,s23,s13, &
55  numnp,nstart,nend,numcstet,numat_vol, &
56  mu,kapp)
57 
58 !________________________________________________________________________
59 !
60 ! V3D4 - Performs displacement based computations for Volumetric 3D
61 ! 4-node tetrahedra large deformation (i.e. nonlinear) elastic
62 ! elements with linear interpolation functions. (constant strain
63 ! tetrahedra). Returns the internal force vector R_in.
64 !
65 ! DATE: 04.2000 AUTHOR: SCOT BREITENFELD
66 !________________________________________________________________________
67 
68  IMPLICIT NONE
69 !---- Global variables
70  INTEGER :: numnp ! number of nodal points
71  INTEGER :: numcstet ! number of CSTet elements
72  INTEGER :: numat_vol ! number of volumetric materials
73 !-- coordinate array
74  REAL*8, DIMENSION(1:3,1:numnp) :: coor
75 !-- internal force
76  REAL*8, DIMENSION(1:3*numnp) :: r_in
77 !-- displacement vector
78  REAL*8, DIMENSION(1:3*numnp) :: d
79 !-- CSTet stress
80  REAL*8, DIMENSION(1:numcstet) :: s11, s22, s33, s12, s23, s13
81 !-- x, y and z displacements of nodes
82  REAL*8 :: u1,u2,u3,u4,v1,v2,v3,v4,w1,w2,w3,w4
83 !-- coordinate holding variable
84  REAL*8 :: x1,x2,x3,x4,y1,y2,y3,y4,z1,z2,z3,z4
85 !-- 6*volume, inverse(6*volume), and the volume
86  REAL*8 :: vx6, vx6inv, vol
87 !-- spacial derivatives
88  REAL*8 :: b1,b2,b3,b4,b5,b6,b7,b8,b9,b10,b11,b12
89 !-- partial derivatives of the displacement
90  REAL*8 :: dudx,dvdy,dwdz,dudy,dvdx,dvdz,dwdy,dudz,dwdx
91 !-- strains
92  REAL*8 :: e11,e22,e33,e12,e23,e13
93 ! -- connectivity table for CSTet
94  INTEGER, DIMENSION(1:4,1:numcstet) :: lmcstet
95 ! -- mat number for CST element
96  INTEGER, DIMENSION(1:numcstet) :: matcstet
97 ! -- node numbers
98  INTEGER :: n1,n2,n3,n4
99 ! -- dummy and counters
100  INTEGER :: i,j,nstart,nend
101  INTEGER :: k1n1,k1n2,k1n3,k1n4,k2n1,k2n2,k2n3,k2n4
102  INTEGER :: k3n1,k3n2,k3n3,k3n4
103 !-- Coordinate subtractions
104  REAL*8 :: x14, x24, x34, y14, y24, y34, z14, z24, z34
105 !-- Coordinate subtractions: These are to speed up B calculation
106  REAL*8 :: x12, x13, y12, y13, z12, z13
107  REAL*8 :: val11, val21, val31
108 ! --
109  REAL*8 :: f11, f12, f13, f21, f22, f23, f31, f32, f33
110  REAL*8, DIMENSION(1:numat_vol) :: mu, kapp
111  REAL*8, DIMENSION(1:3,1:3) :: fij, cij
112 
113  INTEGER :: kk,ll,mm
114 
115  DO i = nstart, nend
116  j = matcstet(i)
117 
118  n1 = lmcstet(1,i)
119  n2 = lmcstet(2,i)
120  n3 = lmcstet(3,i)
121  n4 = lmcstet(4,i)
122 
123  k3n1 = 3*n1
124  k3n2 = 3*n2
125  k3n3 = 3*n3
126  k3n4 = 3*n4
127 
128  k2n1 = k3n1 - 1
129  k2n2 = k3n2 - 1
130  k2n3 = k3n3 - 1
131  k2n4 = k3n4 - 1
132 
133  k1n1 = k3n1 - 2
134  k1n2 = k3n2 - 2
135  k1n3 = k3n3 - 2
136  k1n4 = k3n4 - 2
137  ! k#n# dummy variables replaces:
138  u1 = d(k1n1) ! (3*n1-2)
139  u2 = d(k1n2) ! (3*n2-2)
140  u3 = d(k1n3) ! (3*n3-2)
141  u4 = d(k1n4) ! (3*n4-2)
142  v1 = d(k2n1) ! (3*n1-1)
143  v2 = d(k2n2) ! (3*n2-1)
144  v3 = d(k2n3) ! (3*n3-1)
145  v4 = d(k2n4) ! (3*n4-1)
146  w1 = d(k3n1) ! (3*n1)
147  w2 = d(k3n2) ! (3*n2)
148  w3 = d(k3n3) ! (3*n3)
149  w4 = d(k3n4) ! (3*n4)
150 
151  x1 = coor(1,n1)
152  x2 = coor(1,n2)
153  x3 = coor(1,n3)
154  x4 = coor(1,n4)
155  y1 = coor(2,n1)
156  y2 = coor(2,n2)
157  y3 = coor(2,n3)
158  y4 = coor(2,n4)
159  z1 = coor(3,n1)
160  z2 = coor(3,n2)
161  z3 = coor(3,n3)
162  z4 = coor(3,n4)
163 
164 
165  x12 = x1 - x2 ! not used in vol. calc
166  x13 = x1 - x3 ! not used in vol. calc
167  x14 = x1 - x4
168  x24 = x2 - x4
169  x34 = x3 - x4
170  y12 = y1 - y2 ! not used in vol. calc
171  y13 = y1 - y3 ! not used in vol. calc
172  y14 = y1 - y4
173  y24 = y2 - y4
174  y34 = y3 - y4
175  z12 = z1 - z2 ! not used in vol. calc
176  z13 = z1 - z3 ! not used in vol. calc
177  z14 = z1 - z4
178  z24 = z2 - z4
179  z34 = z3 - z4
180 
181  val11 = y24*z34 - z24*y34
182  val21 = -( x24*z34 - z24*x34 )
183  val31 = x24*y34 - y24*x34
184 
185  vx6 = -( x14*val11 + y14*val21 + z14*val31 )
186 
187  vx6inv = 1.d0 / vx6
188 
189 ! See the maple worksheet 'V3D4.mws' for the derivation of [B]
190 ! NOTE: Factored for a more equivalent/compact form then maple's
191 
192  b1 = (y34*z24 - y24*z34) * vx6inv
193  b2 = (z34*x24 - z24*x34) * vx6inv
194  b3 = (x34*y24 - x24*y34) * vx6inv
195  b4 = (y13*z14 - y14*z13) * vx6inv
196  b5 = (z13*x14 - z14*x13) * vx6inv
197  b6 = (x13*y14 - x14*y13) * vx6inv
198  b7 = (y14*z12 - y12*z14) * vx6inv
199  b8 = (z14*x12 - z12*x14) * vx6inv
200  b9 = (x14*y12 - x12*y14) * vx6inv
201  b10 = (y12*z13 - y13*z12) * vx6inv
202  b11 = (z12*x13 - z13*x12) * vx6inv
203  b12 = (x12*y13 - x13*y12) * vx6inv
204 !
205 ! deformation gradients F
206 !
207  f11 = 1.d0 + ( b1*u1 + b4*u2 + b7*u3 + b10*u4 ) ! 1 + ( dudx )
208  f22 = 1.d0 + ( b2*v1 + b5*v2 + b8*v3 + b11*v4 ) ! 1 + ( dvdy )
209  f33 = 1.d0 + ( b3*w1 + b6*w2 + b9*w3 + b12*w4 ) ! 1 + ( dwdz )
210  f12 = b2*u1 + b5*u2 + b8*u3 + b11*u4 ! dudy
211  f21 = b1*v1 + b4*v2 + b7*v3 + b10*v4 ! dvdx
212  f23 = b3*v1 + b6*v2 + b9*v3 + b12*v4 ! dvdz
213  f32 = b2*w1 + b5*w2 + b8*w3 + b11*w4 ! dwdy
214  f13 = b3*u1 + b6*u2 + b9*u3 + b12*u4 ! dudz
215  f31 = b1*w1 + b4*w2 + b7*w3 + b10*w4 ! dwdx
216 !
217 ! Arruda-Boyce Nonlinear Elasticity Model
218 !
219 ! -- NOTE: ci(7,j) : shear modulus
220 
221 
222 !-- (1) Deformation Gradient Fij
223 
224  fij(1,1) = f11
225  fij(1,2) = f12
226  fij(1,3) = f13
227  fij(2,1) = f21
228  fij(2,2) = f22
229  fij(2,3) = f23
230  fij(3,1) = f31
231  fij(3,2) = f32
232  fij(3,3) = f33
233 
234 !-- (2) right Cauchy-Green deformation Tensor Cij = Fmi Fmj
235 ! T
236 ! C = F F
237 
238  DO kk=1,3
239  DO ll=1,3
240  cij(kk,ll) = 0.d0
241  DO mm=1,3
242  cij(kk,ll)=cij(kk,ll)+fij(mm,kk)*fij(mm,ll)
243  ENDDO
244  ENDDO
245  ENDDO
246 
247  CALL arruda_boyce(cij, &
248  s11(i),s22(i),s33(i),s12(i),s23(i),s13(i),i, &
249  mu(j),kapp(j))
250 
251 ! calculate the volume
252 
253  vol = vx6 / 6.d0
254 
255 ! ASSEMBLE THE INTERNAL FORCE VECTOR
256 !
257 ! local node 1
258  r_in(k1n1) = r_in(k1n1) - vol* &
259  ( s11(i)*b1*f11 + s22(i)*b2*f12 + s33(i)*b3*f13 &
260  + s12(i)*( b2*f11 + b1*f12 ) &
261  + s23(i)*( b3*f12 + b2*f13 ) &
262  + s13(i)*( b3*f11 + b1*f13 ) )
263  r_in(k2n1) = r_in(k2n1) - vol* &
264  ( s11(i)*b1*f21 + s22(i)*b2*f22 + s33(i)*b3*f23 &
265  + s12(i)*( b1*f22 + b2*f21 ) &
266  + s23(i)*( b3*f22 + b2*f23 ) &
267  + s13(i)*( b3*f21 + b1*f23 ) )
268  r_in(k3n1) = r_in(k3n1) - vol* &
269  ( s11(i)*b1*f31 + s22(i)*b2*f32 + s33(i)*b3*f33 &
270  + s12(i)*( b2*f31 + b1*f32 ) &
271  + s23(i)*( b3*f32 + b2*f33 ) &
272  + s13(i)*( b3*f31 + b1*f33 ) )
273 ! local node 2
274  r_in(k1n2) = r_in(k1n2) - vol* &
275  ( s11(i)*b4*f11 + s22(i)*b5*f12 + s33(i)*b6*f13 &
276  + s12(i)*( b5*f11 + b4*f12 ) &
277  + s23(i)*( b6*f12 + b5*f13 ) &
278  + s13(i)*( b6*f11 + b4*f13 ) )
279  r_in(k2n2) = r_in(k2n2) - vol* &
280  ( s11(i)*b4*f21 + s22(i)*b5*f22 + s33(i)*b6*f23 &
281  + s12(i)*( b4*f22 + b5*f21 ) &
282  + s23(i)*( b6*f22 + b5*f23 ) &
283  + s13(i)*( b6*f21 + b4*f23 ) )
284  r_in(k3n2) = r_in(k3n2) - vol* &
285  ( s11(i)*b4*f31 + s22(i)*b5*f32 + s33(i)*b6*f33 &
286  + s12(i)*( b5*f31 + b4*f32 ) &
287  + s23(i)*( b6*f32 + b5*f33 ) &
288  + s13(i)*( b6*f31 + b4*f33 ) )
289 ! local node 3
290  r_in(k1n3) = r_in(k1n3) - vol* &
291  ( s11(i)*b7*f11 + s22(i)*b8*f12 + s33(i)*b9*f13 &
292  + s12(i)*( b8*f11 + b7*f12 ) &
293  + s23(i)*( b9*f12 + b8*f13 ) &
294  + s13(i)*( b9*f11 + b7*f13 ) )
295  r_in(k2n3) = r_in(k2n3) - vol* &
296  ( s11(i)*b7*f21 + s22(i)*b8*f22 + s33(i)*b9*f23 &
297  + s12(i)*( b7*f22 + b8*f21 ) &
298  + s23(i)*( b9*f22 + b8*f23 ) &
299  + s13(i)*( b9*f21 + b7*f23 ) )
300  r_in(k3n3) = r_in(k3n3) - vol* &
301  ( s11(i)*b7*f31 + s22(i)*b8*f32 + s33(i)*b9*f33 &
302  + s12(i)*( b8*f31 + b7*f32 ) &
303  + s23(i)*( b9*f32 + b8*f33 ) &
304  + s13(i)*( b9*f31 + b7*f33 ) )
305 ! local node 4
306  r_in(k1n4) = r_in(k1n4) - vol* &
307  ( s11(i)*b10*f11 + s22(i)*b11*f12+s33(i)*b12*f13 &
308  + s12(i)*( b11*f11 + b10*f12 ) &
309  + s23(i)*( b12*f12 + b11*f13 ) &
310  + s13(i)*( b12*f11 + b10*f13 ) )
311  r_in(k2n4) = r_in(k2n4) - vol* &
312  ( s11(i)*b10*f21 + s22(i)*b11*f22+s33(i)*b12*f23 &
313  + s12(i)*( b10*f22 + b11*f21 ) &
314  + s23(i)*( b12*f22 + b11*f23 ) &
315  + s13(i)*( b12*f21 + b10*f23 ) )
316  r_in(k3n4) = r_in(k3n4) - vol* &
317  ( s11(i)*b10*f31 + s22(i)*b11*f32+s33(i)*b12*f33 &
318  + s12(i)*( b11*f31 + b10*f32 ) &
319  + s23(i)*( b12*f32 + b11*f33 ) &
320  + s13(i)*( b12*f31 + b10*f33 ) )
321 
322  x1 = coor(1,n1) + u1
323  x2 = coor(1,n2) + u2
324  x3 = coor(1,n3) + u3
325  x4 = coor(1,n4) + u4
326  y1 = coor(2,n1) + v1
327  y2 = coor(2,n2) + v2
328  y3 = coor(2,n3) + v3
329  y4 = coor(2,n4) + v4
330  z1 = coor(3,n1) + w1
331  z2 = coor(3,n2) + w2
332  z3 = coor(3,n3) + w3
333  z4 = coor(3,n4) + w4
334 
335  x14 = x1 - x4
336  x24 = x2 - x4
337  x34 = x3 - x4
338  y14 = y1 - y4
339  y24 = y2 - y4
340  y34 = y3 - y4
341  z14 = z1 - z4
342  z24 = z2 - z4
343  z34 = z3 - z4
344 
345  val11 = y24*z34 - z24*y34
346  val21 = -( x24*z34 - z24*x34 )
347  val31 = x24*y34 - y24*x34
348 
349  vx6 = -( x14*val11 + y14*val21 + z14*val31 )
350 
351  IF(vx6.LT.0.d0) THEN
352  print*,'ROCFRAC :: ERROR * ERROR * ERROR'
353  print*,'ROCFRAC :: DEFORMED ELEMENT VOLUME TURNED NEGATIVE'
354  stop
355  ENDIF
356 
357  ENDDO
358 
359  RETURN
360  END
361 
subroutine v3d4_nl_arruda_boyce(coor, matcstet, lmcstet, R_in, d, S11, S22, S33, S12, S23, S13, numnp, nstart, nend, numcstet, numat_vol, mu, kapp)
const NT & d
blockLoc i
Definition: read.cpp:79
virtual std::ostream & print(std::ostream &os) const
j indices j
Definition: Indexing.h:6
subroutine arruda_boyce(Cij, S11, S22, S33, S12, S23, S13, ielem, mu, kappa)