dislocation velocity output for each dislocation type (edge+,edge-,screw+,screw-)
for fcc constitutive_nonlocal_kinetics is called only once and the result is used for each dislocation type, for all other lattice structures we have one call for each dislocation type
This commit is contained in:
parent
e5407894b5
commit
5a658d1b82
|
@ -205,8 +205,10 @@ constitution nonlocal
|
||||||
(output) rho_dot_flux
|
(output) rho_dot_flux
|
||||||
(output) rho_dot_flux_edge
|
(output) rho_dot_flux_edge
|
||||||
(output) rho_dot_flux_screw
|
(output) rho_dot_flux_screw
|
||||||
(output) velocity_edge
|
(output) velocity_edge_pos
|
||||||
(output) velocity_screw
|
(output) velocity_edge_neg
|
||||||
|
(output) velocity_screw_pos
|
||||||
|
(output) velocity_screw_neg
|
||||||
(output) fluxDensity_edge_pos_x
|
(output) fluxDensity_edge_pos_x
|
||||||
(output) fluxDensity_edge_pos_y
|
(output) fluxDensity_edge_pos_y
|
||||||
(output) fluxDensity_edge_pos_z
|
(output) fluxDensity_edge_pos_z
|
||||||
|
|
|
@ -618,8 +618,10 @@ do i = 1,maxNinstance
|
||||||
'rho_dot_flux', &
|
'rho_dot_flux', &
|
||||||
'rho_dot_flux_edge', &
|
'rho_dot_flux_edge', &
|
||||||
'rho_dot_flux_screw', &
|
'rho_dot_flux_screw', &
|
||||||
'velocity_edge', &
|
'velocity_edge_pos', &
|
||||||
'velocity_screw', &
|
'velocity_edge_neg', &
|
||||||
|
'velocity_screw_pos', &
|
||||||
|
'velocity_screw_neg', &
|
||||||
'fluxdensity_edge_pos_x', &
|
'fluxdensity_edge_pos_x', &
|
||||||
'fluxdensity_edge_pos_y', &
|
'fluxdensity_edge_pos_y', &
|
||||||
'fluxdensity_edge_pos_z', &
|
'fluxdensity_edge_pos_z', &
|
||||||
|
@ -1438,11 +1440,20 @@ enddo
|
||||||
|
|
||||||
!*** get dislocation velocity and its tangent and store the velocity in the state array
|
!*** get dislocation velocity and its tangent and store the velocity in the state array
|
||||||
|
|
||||||
|
if (myStructure == 1_pInt) then ! for fcc all velcities are equal
|
||||||
|
call constitutive_nonlocal_kinetics(v(1:ns,1), tau, 1, Temperature, state, g, ip, el, dv_dtau(1:ns,1))
|
||||||
|
do t = 1,4
|
||||||
|
v(1:ns,t) = v(1:ns,1)
|
||||||
|
dv_dtau(1:ns,t) = dv_dtau(1:ns,1)
|
||||||
|
state%p((12+t)*ns+1:(13+t)*ns) = v(1:ns,1)
|
||||||
|
enddo
|
||||||
|
else ! for all other lattice structures the velcities may vary with character and sign
|
||||||
do t = 1,4
|
do t = 1,4
|
||||||
c = (t-1)/2+1
|
c = (t-1)/2+1
|
||||||
call constitutive_nonlocal_kinetics(v(1:ns,t), tau, c, Temperature, state, g, ip, el, dv_dtau(1:ns,t))
|
call constitutive_nonlocal_kinetics(v(1:ns,t), tau, c, Temperature, state, g, ip, el, dv_dtau(1:ns,t))
|
||||||
state%p((12+t)*ns+1:(13+t)*ns) = v(1:ns,t)
|
state%p((12+t)*ns+1:(13+t)*ns) = v(1:ns,t)
|
||||||
enddo
|
enddo
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
!*** Bauschinger effect
|
!*** Bauschinger effect
|
||||||
|
@ -1654,10 +1665,8 @@ forall (s = 1:ns, c = 1:2) &
|
||||||
rhoForest = state(g,ip,el)%p(10*ns+1:11*ns)
|
rhoForest = state(g,ip,el)%p(10*ns+1:11*ns)
|
||||||
tauThreshold = state(g,ip,el)%p(11*ns+1:12*ns)
|
tauThreshold = state(g,ip,el)%p(11*ns+1:12*ns)
|
||||||
tauBack = state(g,ip,el)%p(12*ns+1:13*ns)
|
tauBack = state(g,ip,el)%p(12*ns+1:13*ns)
|
||||||
v(1:ns,1) = state(g,ip,el)%p(13*ns+1:14*ns)
|
forall (t = 1:4) &
|
||||||
v(1:ns,2) = state(g,ip,el)%p(13*ns+1:14*ns)
|
v(1:ns,t) = state(g,ip,el)%p((12+t)*ns+1:(13+t)*ns)
|
||||||
v(1:ns,3) = state(g,ip,el)%p(14*ns+1:15*ns)
|
|
||||||
v(1:ns,4) = state(g,ip,el)%p(14*ns+1:15*ns)
|
|
||||||
|
|
||||||
|
|
||||||
!*** sanity check for timestep
|
!*** sanity check for timestep
|
||||||
|
@ -1813,14 +1822,9 @@ if (.not. phase_localConstitution(material_phase(g,ip,el))) then
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if (considerEnteringFlux) then
|
if (considerEnteringFlux) then
|
||||||
neighboring_fluxdensity(1:ns,1) = state(g,neighboring_ip,neighboring_el)%p(1:ns) &
|
forall (t = 1:4) &
|
||||||
* state(g,neighboring_ip,neighboring_el)%p(13*ns+1:14*ns)
|
neighboring_fluxdensity(1:ns,t) = state(g,neighboring_ip,neighboring_el)%p((t-1)*ns+1:t*ns) &
|
||||||
neighboring_fluxdensity(1:ns,2) = state(g,neighboring_ip,neighboring_el)%p(ns+1:2*ns) &
|
* state(g,neighboring_ip,neighboring_el)%p((12+t)*ns+1:(13+t)*ns)
|
||||||
* state(g,neighboring_ip,neighboring_el)%p(13*ns+1:14*ns)
|
|
||||||
neighboring_fluxdensity(1:ns,3) = state(g,neighboring_ip,neighboring_el)%p(2*ns+1:3*ns) &
|
|
||||||
* state(g,neighboring_ip,neighboring_el)%p(14*ns+1:15*ns)
|
|
||||||
neighboring_fluxdensity(1:ns,4) = state(g,neighboring_ip,neighboring_el)%p(3*ns+1:4*ns) &
|
|
||||||
* state(g,neighboring_ip,neighboring_el)%p(14*ns+1:15*ns)
|
|
||||||
normal_neighbor2me_defConf = math_det3x3(Favg) &
|
normal_neighbor2me_defConf = math_det3x3(Favg) &
|
||||||
* math_mul33x3(math_inv3x3(transpose(Favg)), mesh_ipAreaNormal(1:3,neighboring_n,neighboring_ip,neighboring_el)) ! calculate the normal of the interface in (average) deformed configuration (now pointing from my neighbor to me!!!)
|
* math_mul33x3(math_inv3x3(transpose(Favg)), mesh_ipAreaNormal(1:3,neighboring_n,neighboring_ip,neighboring_el)) ! calculate the normal of the interface in (average) deformed configuration (now pointing from my neighbor to me!!!)
|
||||||
normal_neighbor2me = math_mul33x3(transpose(neighboring_Fe), normal_neighbor2me_defConf) / math_det3x3(neighboring_Fe) ! interface normal in the lattice configuration of my neighbor
|
normal_neighbor2me = math_mul33x3(transpose(neighboring_Fe), normal_neighbor2me_defConf) / math_det3x3(neighboring_Fe) ! interface normal in the lattice configuration of my neighbor
|
||||||
|
@ -2631,7 +2635,7 @@ tauThreshold = state(g,ip,el)%p(11*ns+1:12*ns)
|
||||||
tauBack = state(g,ip,el)%p(12*ns+1:13*ns)
|
tauBack = state(g,ip,el)%p(12*ns+1:13*ns)
|
||||||
forall (t = 1:8) rhoDotSgl(1:ns,t) = dotState%p((t-1)*ns+1:t*ns)
|
forall (t = 1:8) rhoDotSgl(1:ns,t) = dotState%p((t-1)*ns+1:t*ns)
|
||||||
forall (c = 1:2) rhoDotDip(1:ns,c) = dotState%p((7+c)*ns+1:(8+c)*ns)
|
forall (c = 1:2) rhoDotDip(1:ns,c) = dotState%p((7+c)*ns+1:(8+c)*ns)
|
||||||
forall (t = 1:4) v(1:ns,t) = state(g,ip,el)%p((13+(t-1)/2)*ns+1:(14+(t-1)/2)*ns)
|
forall (t = 1:4) v(1:ns,t) = state(g,ip,el)%p((12+t)*ns+1:(13+t)*ns)
|
||||||
|
|
||||||
|
|
||||||
!* Calculate shear rate
|
!* Calculate shear rate
|
||||||
|
@ -2917,14 +2921,22 @@ do o = 1,phase_Noutput(material_phase(g,ip,el))
|
||||||
+ sum(abs(constitutive_nonlocal_rhoDotFlux(1:ns,7:8,g,ip,el)),2)
|
+ sum(abs(constitutive_nonlocal_rhoDotFlux(1:ns,7:8,g,ip,el)),2)
|
||||||
cs = cs + ns
|
cs = cs + ns
|
||||||
|
|
||||||
case ('velocity_edge')
|
case ('velocity_edge_pos')
|
||||||
constitutive_nonlocal_postResults(cs+1:cs+ns) = v(1:ns,1)
|
constitutive_nonlocal_postResults(cs+1:cs+ns) = v(1:ns,1)
|
||||||
cs = cs + ns
|
cs = cs + ns
|
||||||
|
|
||||||
case ('velocity_screw')
|
case ('velocity_edge_neg')
|
||||||
|
constitutive_nonlocal_postResults(cs+1:cs+ns) = v(1:ns,2)
|
||||||
|
cs = cs + ns
|
||||||
|
|
||||||
|
case ('velocity_screw_pos')
|
||||||
constitutive_nonlocal_postResults(cs+1:cs+ns) = v(1:ns,3)
|
constitutive_nonlocal_postResults(cs+1:cs+ns) = v(1:ns,3)
|
||||||
cs = cs + ns
|
cs = cs + ns
|
||||||
|
|
||||||
|
case ('velocity_screw_neg')
|
||||||
|
constitutive_nonlocal_postResults(cs+1:cs+ns) = v(1:ns,4)
|
||||||
|
cs = cs + ns
|
||||||
|
|
||||||
case ('fluxdensity_edge_pos_x')
|
case ('fluxdensity_edge_pos_x')
|
||||||
constitutive_nonlocal_postResults(cs+1:cs+ns) = rhoSgl(1:ns,1) * v(1:ns,1) * m_currentconf(1,1:ns,1)
|
constitutive_nonlocal_postResults(cs+1:cs+ns) = rhoSgl(1:ns,1) * v(1:ns,1) * m_currentconf(1,1:ns,1)
|
||||||
cs = cs + ns
|
cs = cs + ns
|
||||||
|
|
Loading…
Reference in New Issue